/* ====================================================================
   ROTOBRUSH PURVI NEW MACHINE - MASTER STYLESHEET
   Client palette: Dark Navy #1B2A4A | Biosweep Green #7AC143 |
   White | Metallic Silver #C5CBD3 | Limited Red #DC2626
   ==================================================================== */

:root {
	--navy:        #1B2A4A;
	--navy-2:      #22325A;
	--navy-3:      #2A3B5C;
	--navy-4:      #34456B;
	--green:       #7AC143;
	--green-dark:  #6BAA34;
	--green-darker:#5A9E2F;
	--red:         #DC2626;
	--silver:      #C5CBD3;
	--silver-lt:   #E2E5EA;
	--white:       #FFFFFF;
	--off-white:   #F8F9FB;
	--light:       #F1F3F6;
	--ink:         #1B2A4A;
	--slate:       #5A6577;
	--slate-lt:    #8A93A3;
	--border:      #D9DFE5;
	--radius:      10px;
	--shadow:      0 4px 20px rgba(27,42,74,0.08);
	--shadow-lg:   0 12px 40px rgba(27,42,74,0.14);
	--container:   1200px;
}

/* ---- RESET / BASE ---- */
* { box-sizing: border-box; }
html, body {
	margin: 0; padding: 0;
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
	color: var(--ink);
	background: var(--white);
	-webkit-font-smoothing: antialiased;
	font-size: 17px;          /* base bumped from default 16 */
	line-height: 1.7;
}
body.rpnm-no-scroll { overflow: hidden; }
img { max-width: 100%; height: auto; display: block; }
a { color: var(--green-dark); text-decoration: none; transition: color .2s; }
a:hover { color: var(--green-darker); }
h1, h2, h3, h4, h5 { margin: 0 0 .5em; line-height: 1.22; color: var(--navy); font-weight: 800; letter-spacing: -.01em; }
h1 { font-size: 2.6rem; }
h2 { font-size: 2rem; }
h3 { font-size: 1.5rem; }
h4 { font-size: 1.2rem; }
h5 { font-size: 1rem; }
p { margin: 0 0 1em; font-size: 1.02rem; }

.rpnm-container { max-width: var(--container); margin: 0 auto; padding: 0 24px; }

/* ---- SHARED: eyebrow, buttons, sections ---- */
.rpnm-eyebrow {
	display: inline-block;
	font-size: 12.5px; font-weight: 800; letter-spacing: 2px;
	color: var(--green-dark); text-transform: uppercase; margin-bottom: 10px;
}
.rpnm-eyebrow-light { color: var(--green); }
.rpnm-green { color: var(--green); }

.rpnm-btn {
	display: inline-flex; align-items: center; gap: 8px; justify-content: center;
	padding: 13px 26px; border-radius: 6px; font-size: 14.5px; font-weight: 700;
	letter-spacing: .3px; border: 2px solid transparent; cursor: pointer;
	transition: all .2s; text-align: center; line-height: 1;
}
/* Block parent-theme pink (#c36) hover on every button state */
.rpnm-btn:hover, .rpnm-btn:focus, .rpnm-btn:active,
.rpnm-btn-mini:hover, .rpnm-btn-mini:focus, .rpnm-btn-mini:active {
	outline: none;
}
.rpnm-btn-green       { background: var(--green); color: var(--navy); border-color: var(--green); }
.rpnm-btn-green:hover, .rpnm-btn-green:focus, .rpnm-btn-green:active { background: var(--green-darker) !important; border-color: var(--green-darker) !important; color: #fff !important; }
.rpnm-btn-navy        { background: var(--navy); color: #fff; border-color: var(--navy); }
.rpnm-btn-navy:hover, .rpnm-btn-navy:focus, .rpnm-btn-navy:active  { background: var(--navy-3) !important; border-color: var(--navy-3) !important; color: #fff !important; }
.rpnm-btn-outline       { background: transparent; color: var(--navy); border-color: var(--border); }
.rpnm-btn-outline:hover, .rpnm-btn-outline:focus, .rpnm-btn-outline:active { background: var(--light) !important; border-color: var(--green) !important; color: var(--green-dark) !important; }
.rpnm-btn-outline-light       { background: transparent; color: #fff; border-color: rgba(255,255,255,.5); }
.rpnm-btn-outline-light:hover, .rpnm-btn-outline-light:focus, .rpnm-btn-outline-light:active { background: #fff !important; color: var(--navy) !important; border-color: #fff !important; }
.rpnm-btn-outline-white       { background: transparent; color: #fff; border-color: rgba(255,255,255,.6); }
.rpnm-btn-outline-white:hover, .rpnm-btn-outline-white:focus, .rpnm-btn-outline-white:active { background: rgba(255,255,255,.15) !important; color: #fff !important; border-color: rgba(255,255,255,.9) !important; }
.rpnm-btn-wa        { background: #25D366; color: #fff; border-color: #25D366; }
.rpnm-btn-wa:hover, .rpnm-btn-wa:focus, .rpnm-btn-wa:active  { background: #1da851 !important; border-color: #1da851 !important; color: #fff !important; }
.rpnm-btn-white-wa  { background: #fff; color: #128C7E; border-color: #fff; }
.rpnm-btn-white-wa:hover, .rpnm-btn-white-wa:focus, .rpnm-btn-white-wa:active { background: var(--off-white) !important; color: #128C7E !important; border-color: var(--off-white) !important; }
.rpnm-btn-red       { background: var(--red); color: #fff; border-color: var(--red); }
.rpnm-btn-red:hover, .rpnm-btn-red:focus, .rpnm-btn-red:active { background: #b91c1c !important; border-color: #b91c1c !important; color: #fff !important; }
.rpnm-btn-mini {
	display: inline-block; padding: 8px 14px; border-radius: 5px;
	font-size: 12.5px; font-weight: 800; letter-spacing: .5px;
	background: #fff; color: var(--navy); border: 1px solid var(--border); cursor: pointer;
}
.rpnm-btn-mini:hover, .rpnm-btn-mini:focus, .rpnm-btn-mini:active { background: var(--light) !important; border-color: var(--green) !important; color: var(--green-dark) !important; }
.rpnm-btn-mini-green { background: var(--green); color: var(--navy); border-color: var(--green); }
.rpnm-btn-mini-green:hover, .rpnm-btn-mini-green:focus, .rpnm-btn-mini-green:active { background: var(--green-darker) !important; border-color: var(--green-darker) !important; color: #fff !important; }

.rpnm-section { padding: 60px 0; }
.rpnm-section-tight { padding: 30px 0; }
.rpnm-section-light { background: var(--light); }
.rpnm-section-navy { background: var(--navy); }
.rpnm-section-navy-deep {
	    background: linear-gradient(135deg, #1b2a4ad6 0%, var(--navy-2) 100%);
}
.rpnm-section-navy h2, .rpnm-section-navy p,
.rpnm-section-navy-deep h2, .rpnm-section-navy-deep p { color: #fff; }
.rpnm-h2-light { color: #fff !important; }

.rpnm-section-head { margin-bottom: 36px; }
.rpnm-section-head h2 { font-size: 32px; }
.rpnm-section-head-center { text-align: center; }
.rpnm-section-head-center .rpnm-section-sub { max-width: 580px; margin: 6px auto 0; }
.rpnm-section-head-row {
	display: flex; justify-content: space-between; align-items: flex-end; gap: 20px;
}
.rpnm-section-sub { color: var(--slate); font-size: 15.5px; }
.rpnm-sub-light { color: var(--silver) !important; }

/* ====================================================================
   TOP BAR + HEADER
   ==================================================================== */
.rpnm-topbar {
	background: var(--navy); color: var(--silver);
	font-size: 12.5px; padding: 7px 0; border-bottom: 1px solid rgba(255,255,255,.06);
}
.rpnm-topbar-inner { display: flex; justify-content: space-between; align-items: center; }
.rpnm-topbar a { color: var(--silver); }
.rpnm-topbar a:hover { color: var(--green); }
.rpnm-topbar-right { display: flex; gap: 18px; align-items: center; }

.rpnm-header {
	position: sticky; top: 0; z-index: 200;
	background: var(--navy); padding: 12px 0;
	transition: box-shadow .2s, padding .2s;
}
.rpnm-header-scrolled { box-shadow: 0 4px 20px rgba(0,0,0,.25); padding: 8px 0; }
.rpnm-header-inner { display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.rpnm-header-spacer { display: none; }

/* Dual logo */
/* ===== HEADER DUAL LOGO — 2 separate clickable images ===== */
.rpnm-logo, .rpnm-logo-dual {
	display: flex; align-items: center; gap: 14px;
}
.rpnm-logo-link {
	display: inline-flex; align-items: center;
	transition: opacity .2s;
}
.rpnm-logo-link:hover { opacity: .85; }
.rpnm-logo-img {
	display: block; width: auto; height: 42px;
	max-width: 160px; object-fit: contain;
}
.rpnm-logo-img-bs { height: 42px; }
.rpnm-logo-img-rb { height: 38px; }
.rpnm-logo-divider { width: 1px; height: 32px; background: rgba(255,255,255,.25); }

/* Nav */

.rpnm-nav { display: flex; align-items: center; }
.rpnm-nav-close { display: none; }
.rpnm-nav-backdrop { display: none; }
.rpnm-menu {
	display: flex; align-items: center; gap: 20px;
	list-style: none; margin: 0; padding: 0;
}
.rpnm-menu-item { position: relative; }
.rpnm-menu-item > a {
	color: #E5E7EB; font-size: 13.5px; font-weight: 500;
	padding: 8px 0; display: inline-flex; align-items: center; gap: 4px;
	white-space: nowrap;
}
.rpnm-menu-item > a:hover, .rpnm-current > a { color: var(--green); }
.rpnm-caret { font-size: 8px; opacity: .7; }

/* Mega menu + dropdown styles below */

.rpnm-header-cta {
	background: var(--green); color: var(--navy);
	padding: 10px 18px; border-radius: 6px;
	font-size: 13.5px; font-weight: 800; white-space: nowrap;
}
.rpnm-header-cta:hover { background: var(--green-darker); color: #fff; }

.rpnm-burger {
	display: none; flex-direction: column; gap: 5px;
	background: none; border: none; cursor: pointer; padding: 6px;
}
.rpnm-burger span {
	width: 24px; height: 2px; background: #fff; border-radius: 2px; transition: all .25s;
}
.rpnm-burger-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.rpnm-burger-open span:nth-child(2) { opacity: 0; }
.rpnm-burger-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ====================================================================
   HOMEPAGE HERO
   ==================================================================== */
.rpnm-home-hero { position: relative; overflow: hidden; background: var(--navy); }
.rpnm-home-hero-bg {
	position: absolute; inset: 0; background-size: cover; background-position: center right;
	opacity: .55;
}
.rpnm-home-hero-overlay {
	position: absolute; inset: 0;
	background: linear-gradient(110deg, rgb(27 42 74 / 42%) 0%, rgba(27, 42, 74, .85) 45%, rgba(27, 42, 74, .45) 100%);
}
.rpnm-home-hero-grid {
	position: relative; display: grid; grid-template-columns: 1.1fr .9fr;
	gap: 40px; align-items: center; padding: 70px 24px;
}
.rpnm-home-hero-text h1 {
	color: #fff; font-size: 46px; line-height: 1.08; margin-bottom: 18px; letter-spacing: -1px;
}
.rpnm-home-hero-text > p { color: var(--silver); font-size: 16px; max-width: 440px; }
.rpnm-home-hero-badges {
	display: flex; flex-direction: column; gap: 8px; margin: 22px 0;
}
.rpnm-home-hero-badges span { color: #E5E7EB; font-size: 14.5px; font-weight: 600; }
.rpnm-home-hero-cta { display: flex; gap: 12px; flex-wrap: wrap; }
.rpnm-home-hero-img {
	aspect-ratio: 4/3; border-radius: 14px; background-size: cover; background-position: center;
	position: relative; box-shadow: var(--shadow-lg);
}
.rpnm-video-badge {
	position: absolute; top: 16px; right: 16px;
	background: rgba(27,42,74,.85); color: #fff;
	padding: 7px 14px; border-radius: 100px; font-size: 12.5px; font-weight: 700;
	display: inline-flex; align-items: center; gap: 7px;border: unset;
}
.rpnm-play {
	width: 22px; height: 22px; border-radius: 50%;
	background: var(--green); color: var(--navy);
	display: inline-flex; align-items: center; justify-content: center; font-size: 10.5px;
}

/* Trust strip */
.rpnm-trust-strip { background: var(--navy-2); padding: 22px 0; }
.rpnm-trust-strip-light { background: var(--light); border-radius: var(--radius); }
.rpnm-trust-grid {
	display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; text-align: center;
}
.rpnm-trust-grid > div { display: flex; flex-direction: column; }
.rpnm-trust-grid strong { color: var(--green); font-size: 24px; font-weight: 900; }
.rpnm-trust-grid span { color: var(--silver); font-size: 12.5px; }
.rpnm-trust-strip-light strong { color: var(--green-dark); }
.rpnm-trust-strip-light span { color: var(--slate); }

/* ====================================================================
   PRODUCT GRID / CARDS
   ==================================================================== */
.rpnm-product-grid {
	display: grid; grid-template-columns: repeat(4,1fr); gap: 20px;
}
.rpnm-product-grid-3 { grid-template-columns: repeat(3,1fr); gap: 24px; }
.rpnm-product-card {
	background: #fff; border: 1px solid var(--border); border-radius: 12px;
	padding: 18px; position: relative; display: block; transition: all .2s;
}
.rpnm-product-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-3px); border-color: var(--silver); }
.rpnm-product-badge {
	position: absolute; top: 14px; left: 14px; z-index: 2;
	background: var(--green); color: var(--navy);
	font-size: 10.5px; font-weight: 800; letter-spacing: .5px;
	padding: 4px 9px; border-radius: 4px;
}
.rpnm-product-card-img {
	height: 160px; background-size: contain; background-repeat: no-repeat;
	background-position: center; margin-bottom: 16px; border-radius: 8px;
	background-color: var(--light);
}
.rpnm-product-card h4 { font-size: 15.5px; margin-bottom: 6px; }
.rpnm-product-card p { font-size: 13.5px; color: var(--slate); margin-bottom: 10px; }
.rpnm-product-link { color: var(--green-dark); font-size: 12.5px; font-weight: 800; letter-spacing: .5px; }

/* Large product card (category / all products) */
.rpnm-product-card-lg {
	background: #fff; border: 1px solid var(--border); border-radius: 14px;
	overflow: hidden; position: relative; transition: all .2s;
}
.rpnm-product-card-lg:hover { box-shadow: var(--shadow-lg); transform: translateY(-3px); }
.rpnm-product-card-lg-img {
	display: block; height: 200px; background: var(--light);
	background-size: contain; background-repeat: no-repeat; background-position: center;
}
.rpnm-product-card-lg-body { padding: 20px; }
.rpnm-product-card-lg-body h4 { font-size: 17px; margin-bottom: 8px; }
.rpnm-product-card-lg-body h4 a { color: var(--navy); }
.rpnm-product-card-lg-body p { font-size: 14.5px; color: var(--slate); margin-bottom: 14px; }
.rpnm-product-card-lg-actions { display: flex; gap: 8px; }

/* ====================================================================
   VIDEO SECTION
   ==================================================================== */
.rpnm-video-section {
	display: grid; grid-template-columns: 1fr 1.2fr; gap: 36px; align-items: center;
}
.rpnm-video-section-text h2 { font-size: 30px; }
.rpnm-video-frame {
	position: relative; aspect-ratio: 16/9; border-radius: 12px; overflow: hidden;
	box-shadow: var(--shadow-lg); background: #000;
}
.rpnm-video-frame iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.rpnm-video-frame-wide { max-width: 900px; margin: 0 auto; }

/* ====================================================================
   INDUSTRIES GRID
   ==================================================================== */
.rpnm-industries-grid {
	display: grid; grid-template-columns: repeat(6,1fr); gap: 12px;
}
.rpnm-industry-tile {
	position: relative; aspect-ratio: 3/4; border-radius: 10px; overflow: hidden;
}
.rpnm-industry-bg { position: absolute; inset: 0; background-size: cover; background-position: center; }
.rpnm-industry-grad {
	position: absolute; inset: 0;
	background: linear-gradient(180deg, transparent 40%, rgba(27,42,74,.92) 100%);
}
.rpnm-industry-label {
	position: absolute; bottom: 12px; left: 12px; right: 12px;
	color: #fff; font-size: 13.5px; font-weight: 700; z-index: 2;
}

/* ====================================================================
   COMPARISON TABLE
   ==================================================================== */
.rpnm-compare-wrap {
	background: #fff; border: 1px solid var(--border);
	border-radius: 14px; padding: 22px; box-shadow: var(--shadow);
}
.rpnm-compare-scroll { overflow-x: auto; }
.rpnm-compare-table { width: 100%; border-collapse: collapse; font-size: 14.5px; min-width: 680px; }
.rpnm-compare-table thead tr { background: var(--navy); }
.rpnm-compare-table th {
	padding: 20px 12px 14px; color: #fff; font-weight: 800; text-align: center;
	font-size: 13.5px; position: relative;
}
.rpnm-compare-spec { text-align: left !important; color: var(--silver) !important; font-size: 11.5px !important; letter-spacing: 1px; }
.rpnm-compare-flagship { background: var(--navy-3); }
.rpnm-compare-tag {
	position: absolute; top: 4px; left: 50%; transform: translateX(-50%);
	background: var(--green); color: var(--navy); font-size: 8px; font-weight: 800;
	padding: 2px 8px; border-radius: 3px; letter-spacing: 1px;
}
.rpnm-compare-table td {
	padding: 12px; text-align: center; color: var(--navy);
	border-bottom: 1px solid var(--light);
}
.rpnm-compare-table td:first-child { text-align: left; font-weight: 700; color: var(--slate); }
.rpnm-row-alt { background: var(--off-white); }
.rpnm-cell-hi { color: var(--green-dark) !important; font-weight: 800; }
.rpnm-cell-yes { color: var(--green-dark) !important; font-weight: 800; }
.rpnm-cell-no { color: var(--silver) !important; }
.rpnm-compare-cta-row td { padding-top: 16px; border-bottom: none; }
.rpnm-compare-foot {
	text-align: center; margin-top: 18px; padding-top: 18px; border-top: 1px solid var(--light);
}

/* ====================================================================
   GCC FLAGS + CERTIFICATIONS
   ==================================================================== */
.rpnm-gcc-grid {
	display: grid; grid-template-columns: repeat(6,1fr); gap: 14px; margin-bottom: 22px;
}
.rpnm-gcc-card {
	background: #fff; border: 1px solid var(--border);
	border-radius: 12px; padding: 20px 12px; text-align: center;
	box-shadow: 0 2px 10px rgba(27,42,74,.06);
}
.rpnm-gcc-flag {
	width: 64px; height: 44px; margin: 0 auto 12px;
	border-radius: 6px; overflow: hidden;
	box-shadow: 0 2px 8px rgba(27,42,74,.18);
}
.rpnm-gcc-flag svg { width: 100%; height: 100%; display: block; }
.rpnm-gcc-name { color: var(--navy); font-size: 14px; font-weight: 800; }
.rpnm-gcc-city { color: var(--silver); font-size: 10.5px; margin-top: 3px; }
.rpnm-certs {
	background: #fff; border: 1px solid var(--border);
	border-radius: 12px; padding: 18px 24px;
	display: flex; align-items: center; gap: 20px; flex-wrap: wrap;
	box-shadow: 0 2px 10px rgba(27,42,74,.06);
}
.rpnm-certs-label { color: var(--green); font-size: 12.5px; font-weight: 800; letter-spacing: 1px; }
.rpnm-certs-list { display: flex; gap: 24px; flex: 1; justify-content: space-around; flex-wrap: wrap; }
.rpnm-cert { text-align: center; }
.rpnm-cert strong { color: var(--navy); font-size: 15px; display: block; }
.rpnm-cert span { color: var(--slate); font-size: 11px; letter-spacing: .5px; }

/* ====================================================================
   FINAL CTA
   ==================================================================== */
.rpnm-final-cta {
	background: linear-gradient(135deg, #7AC143 0%, #5A9E2F 100%);
	padding: 48px 0;
}
.rpnm-final-cta-inner {
	display: flex; justify-content: space-between; align-items: center; gap: 24px;
}
.rpnm-final-cta h3 { color: var(--navy); font-size: 26px; margin-bottom: 4px; }
.rpnm-final-cta p { color: #fff; font-size: 15.5px; margin: 0; }
.rpnm-final-cta-btns { display: flex; gap: 12px; flex-shrink: 0; }

/* ====================================================================
   PAGE HERO (reusable)
   ==================================================================== */
.rpnm-page-hero { position: relative; overflow: hidden; background: var(--navy); }
.rpnm-page-hero-bg {
	position: absolute; inset: 0; background-size: cover; background-position: center;
	opacity: .5;
}
.rpnm-page-hero-overlay {
	position: absolute; inset: 0;
	background: linear-gradient(180deg, rgb(27 42 74 / 13%) 0%, rgb(27 42 74 / 34%) 100%);
}
.rpnm-page-hero-content {
	position: relative; padding: 70px 24px; text-align: center;
}
.rpnm-page-hero-tall .rpnm-page-hero-content { padding: 90px 24px; }
.rpnm-page-hero-content h1 { color: #fff; font-size: 40px; margin-bottom: 12px; }
.rpnm-page-hero-content > p { color: var(--silver); font-size: 16px; max-width: 600px; margin: 0 auto; }
.rpnm-breadcrumb { font-size: 12.5px; color: var(--silver); margin-bottom: 14px; }
.rpnm-breadcrumb a { color: var(--silver); }
.rpnm-breadcrumb a:hover { color: var(--green); }
.rpnm-breadcrumb .sep { margin: 0 7px; opacity: .5; }
.rpnm-crumb-current { color: var(--green); }
.rpnm-hero-accent-line {
	display: inline-block; width: 80px; height: 2px; margin-top: 20px;
	background: linear-gradient(90deg, transparent, var(--silver), transparent);
}
.rpnm-contact-hero-actions {
	display: flex; gap: 12px; justify-content: center; margin-top: 22px; flex-wrap: wrap;
}

/* ====================================================================
   PRODUCT DETAIL PAGE
   ==================================================================== */
.rpnm-product-hero {
	position: relative; overflow: hidden; background: var(--navy); min-height: 360px;
	display: flex; align-items: center;
}
.rpnm-product-hero-bg {
	position: absolute; inset: 0; background-size: cover; background-position: center;
	opacity: .4; filter: grayscale(.35);
}
.rpnm-product-hero-overlay {
	position: absolute; inset: 0;
	/* background: linear-gradient(180deg, rgba(27,42,74,.78) 0%, rgba(27,42,74,.93) 100%); */
}
.rpnm-product-hero-pricing {
	position: absolute; top: 22px; right: 24px; z-index: 5;
	background: var(--green); color: var(--navy);
	padding: 10px 18px; border-radius: 6px; border: none;
	font-size: 13.5px; font-weight: 800; cursor: pointer;
}
.rpnm-product-hero-pricing:hover { background: var(--green-darker); color: #fff; }
.rpnm-product-hero-crumb {
	position: absolute; top: 26px; left: 24px; z-index: 5;
	font-size: 12.5px; color: var(--silver);
}
.rpnm-product-hero-crumb a { color: var(--silver); }
.rpnm-product-hero-crumb a:hover { color: var(--green); }
.rpnm-product-hero-crumb span { margin: 0 6px; opacity: .5; }
.rpnm-product-hero-text {
	position: relative; z-index: 3; text-align: center;
	width: 100%; padding: 80px 24px 50px;
}
.rpnm-product-hero-text h1 { color: #fff; font-size: 48px; margin-bottom: 14px; letter-spacing: -1px; }
.rpnm-hero-italic { color: var(--green); font-style: italic; }
.rpnm-product-hero-text p { color: var(--silver); font-size: 15.5px; max-width: 600px; margin: 0 auto; }

.rpnm-product-showcase {
	display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: start;
}
.rpnm-product-gallery-main {
	aspect-ratio: 4/3; background: #fff; border-radius: 12px;
	background-size: contain; background-repeat: no-repeat; background-position: center;
	margin-bottom: 12px;
}
.rpnm-product-gallery-thumbs { display: grid; grid-template-columns: repeat(4,1fr); gap: 8px; }
.rpnm-thumb {
	aspect-ratio: 1; background: #fff; border: 2px solid var(--border); border-radius: 8px;
	background-size: contain; background-repeat: no-repeat; background-position: center;
	cursor: pointer; display: flex; align-items: center; justify-content: center;
	font-size: 11.5px; color: var(--slate-lt); transition: border-color .2s;
}
.rpnm-thumb-active, .rpnm-thumb:hover { border-color: var(--green); }
.rpnm-product-info-badge {
	display: inline-block; background: var(--green); color: var(--navy);
	font-size: 11.5px; font-weight: 800; letter-spacing: .5px;
	padding: 4px 10px; border-radius: 4px; margin-bottom: 12px;
}
.rpnm-product-info h2 { color: #333; font-size: 32px; }
.rpnm-product-intro { color: var(--silver); font-size: 15.5px; margin: 14px 0 20px; }
.rpnm-product-spec-tiles {
	display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 22px;
}
.rpnm-spec-tile {
	background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.12);
	border-radius: 8px; padding: 12px 14px;
}
.rpnm-spec-tile-label { display: block; color: var(--silver); font-size: 11.5px; letter-spacing: .5px; margin-bottom: 3px; }
.rpnm-spec-tile-value { display: block; color: #fff; font-size: 14.5px; font-weight: 700; }
.rpnm-product-cta-row { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 14px; }
.rpnm-product-cta-trust { display: flex; gap: 16px; flex-wrap: wrap; }
.rpnm-product-cta-trust span { color: var(--silver); font-size: 12.5px; }

/* Features grid */
.rpnm-features-grid {
	display: grid; grid-template-columns: repeat(3,1fr); gap: 20px;
}
.rpnm-features-grid-4 { grid-template-columns: repeat(4,1fr); }
.rpnm-feature-card {
	background: #fff; border: 1px solid var(--border); border-radius: 14px; padding: 28px 24px;
	box-shadow: 0 2px 12px rgba(27,42,74,.05);
}
.rpnm-feature-icon {
	width: 52px; height: 52px; border-radius: 14px;
	background: linear-gradient(135deg, #7AC143 0%, #6BAA34 100%);
	color: #fff; display: flex; align-items: center; justify-content: center;
	font-size: 22px; margin-bottom: 16px;
	box-shadow: 0 4px 12px rgba(122,193,67,.3);
}
.rpnm-feature-card h4 { font-size: 18px; margin-bottom: 8px; }
.rpnm-feature-card p { font-size: 14.5px; color: var(--slate); margin: 0; line-height: 1.65; }

/* Specs table */
.rpnm-specs-table {
	background: #fff; border: 1px solid var(--border); border-radius: 12px; overflow: hidden;
}
.rpnm-specs-row {
	display: flex; justify-content: space-between; padding: 14px 20px;
	border-bottom: 1px solid var(--light);
}
.rpnm-specs-row:last-child { border-bottom: none; }
.rpnm-specs-row:nth-child(even) { background: var(--off-white); }
.rpnm-specs-label { color: var(--slate); font-size: 14.5px; font-weight: 600; }
.rpnm-specs-value { color: var(--navy); font-size: 14.5px; font-weight: 700; }

/* ====================================================================
   CONTACT PAGE
   ==================================================================== */
.rpnm-contact-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 32px; align-items: start; }
.rpnm-contact-form-wrap {
	background: #fff; border: 1px solid var(--border); border-radius: 14px; padding: 28px;
}
.rpnm-contact-form-sub { color: var(--slate); font-size: 14.5px; }
.rpnm-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.rpnm-form-group { margin-bottom: 14px; }
.rpnm-form-group label {
	display: block; font-size: 12.5px; font-weight: 700; color: var(--navy);
	margin-bottom: 6px; letter-spacing: .3px;
}
.rpnm-form-group label span { color: var(--red); }
.rpnm-form-group input, .rpnm-form-group select, .rpnm-form-group textarea {
	width: 100%; padding: 11px 13px; border: 1px solid var(--border);
	border-radius: 7px; font-size: 14.5px; font-family: inherit; color: var(--navy);
	background: var(--off-white); transition: border-color .2s;
}
.rpnm-form-group input:focus, .rpnm-form-group select:focus, .rpnm-form-group textarea:focus {
	outline: none; border-color: var(--green); background: #fff;
}
.rpnm-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.rpnm-chip {
	display: inline-flex; align-items: center; gap: 5px;
	padding: 7px 12px; border: 1px solid var(--border); border-radius: 100px;
	font-size: 12.5px; font-weight: 600; color: var(--slate); cursor: pointer;
	background: #fff; transition: all .2s;
}
.rpnm-chip input { accent-color: var(--green); }
.rpnm-chip:has(input:checked) { background: var(--green); color: var(--navy); border-color: var(--green); }
.rpnm-consent {
	display: flex; gap: 8px; align-items: flex-start;
	font-size: 12.5px; color: var(--slate); margin: 14px 0;
}
.rpnm-consent input { accent-color: var(--green); margin-top: 2px; }
.rpnm-contact-form-actions { display: flex; gap: 10px; }
.rpnm-form-message { margin-top: 12px; font-size: 14.5px; font-weight: 600; }
.rpnm-form-success { color: var(--green-darker); }
.rpnm-form-error { color: var(--red); }

.rpnm-contact-info { display: flex; flex-direction: column; gap: 14px; }
.rpnm-contact-card {
	background: #fff; border: 1px solid var(--border); border-radius: 12px; padding: 20px;
}
.rpnm-contact-card-navy { background: var(--navy); border-color: var(--navy); }
.rpnm-contact-card-navy h3, .rpnm-contact-card-navy p { color: #fff; }
.rpnm-contact-card-green { background: var(--green); border-color: var(--green); }
.rpnm-contact-card-green h3, .rpnm-contact-card-green strong { color: var(--navy); }
.rpnm-contact-card-head { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.rpnm-contact-card-head h3 { font-size: 16px; margin: 0; }
.rpnm-contact-ic { font-size: 18px; }
.rpnm-contact-line { margin-bottom: 8px; }
.rpnm-contact-line strong { display: block; color: var(--navy); font-size: 15.5px; }
.rpnm-contact-card-navy .rpnm-contact-line strong { color: #fff; }
.rpnm-contact-line span { font-size: 12.5px; color: var(--slate); }
.rpnm-contact-card-navy .rpnm-contact-line span { color: var(--silver); }
.rpnm-contact-link { color: var(--green); font-size: 13.5px; font-weight: 700; }
.rpnm-contact-card-navy .rpnm-contact-link { color: var(--green); }

.rpnm-map-wrap { border-radius: 12px; overflow: hidden; border: 1px solid var(--border); }
.rpnm-map-wrap iframe { display: block; }

/* WhatsApp banner */
.rpnm-wa-banner {
	background: linear-gradient(135deg, #25D366 0%, #128C7E 100%);
	border-radius: 16px; padding: 30px;
	display: grid; grid-template-columns: 1.5fr 1fr; gap: 28px; align-items: center;
}
.rpnm-wa-online {
	display: inline-block; background: rgba(255,255,255,.18); color: #fff;
	font-size: 11.5px; font-weight: 800; letter-spacing: .5px;
	padding: 5px 12px; border-radius: 100px; margin-bottom: 12px;
}
.rpnm-wa-banner h2 { color: #fff; font-size: 26px; margin-bottom: 10px; }
.rpnm-wa-banner h2 em { font-style: italic; }
.rpnm-wa-banner > .rpnm-wa-banner-text > p { color: rgba(255,255,255,.92); font-size: 14.5px; }
.rpnm-wa-banner-btns { display: flex; gap: 10px; flex-wrap: wrap; margin: 16px 0; }
.rpnm-wa-trust { display: flex; gap: 16px; flex-wrap: wrap; }
.rpnm-wa-trust span { color: rgba(255,255,255,.9); font-size: 12.5px; }
.rpnm-wa-banner-qr { text-align: center; }
.rpnm-wa-qr-label { display: block; color: rgba(255,255,255,.9); font-size: 12.5px; font-weight: 700; margin-bottom: 10px; }
.rpnm-wa-qr-box { background: #fff; border-radius: 12px; padding: 14px; display: inline-block; }
.rpnm-wa-qr-sub { display: block; color: rgba(255,255,255,.8); font-size: 11.5px; margin-top: 8px; }

/* ====================================================================
   BLOG
   ==================================================================== */
.rpnm-blog-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 26px; }
.rpnm-blog-card {
	background: #fff; border: 1px solid var(--border); border-radius: 12px;
	overflow: hidden; transition: all .2s;
}
.rpnm-blog-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-3px); }
.rpnm-blog-card-img { display: block; height: 200px; background-size: cover; background-position: center; }
.rpnm-blog-card-body { padding: 20px; }
.rpnm-blog-card-meta { display: flex; gap: 10px; align-items: center; margin-bottom: 10px; }
.rpnm-blog-cat {
	background: var(--green); color: var(--navy);
	font-size: 10.5px; font-weight: 800; letter-spacing: .5px;
	padding: 3px 8px; border-radius: 4px;
}
.rpnm-blog-date { font-size: 12.5px; color: var(--slate-lt); }
.rpnm-blog-card h3 { font-size: 17px; margin-bottom: 8px; }
.rpnm-blog-card h3 a { color: var(--navy); }
.rpnm-blog-card h3 a:hover { color: var(--green-dark); }
.rpnm-blog-card p { font-size: 14.5px; color: var(--slate); margin-bottom: 12px; }
.rpnm-blog-card-link { color: var(--green-dark); font-size: 13.5px; font-weight: 800; }

.rpnm-blog-hero .rpnm-page-hero-content { padding: 80px 24px; }
.rpnm-blog-hero-meta {
	display: flex; gap: 10px; justify-content: center; align-items: center;
	color: var(--silver); font-size: 13.5px; margin-top: 10px;
}

.rpnm-blog-layout { display: grid; grid-template-columns: 1fr 320px; gap: 36px; align-items: start; }
.rpnm-blog-featured-img { margin: 0 0 24px; border-radius: 12px; overflow: hidden; }
.rpnm-blog-content { font-size: 16px; color: #2d3748; line-height: 1.8; }
.rpnm-blog-content h2 { font-size: 24px; margin: 32px 0 12px; }
.rpnm-blog-content h3 { font-size: 19px; margin: 26px 0 10px; }
.rpnm-blog-content img { border-radius: 10px; margin: 18px 0; }
.rpnm-blog-content ul, .rpnm-blog-content ol { padding-left: 22px; }
.rpnm-blog-content blockquote {
	border-left: 3px solid var(--green); padding-left: 18px; margin: 20px 0;
	color: var(--slate); font-style: italic;
}
.rpnm-blog-share {
	display: flex; align-items: center; gap: 10px; margin-top: 30px;
	padding-top: 20px; border-top: 1px solid var(--border);
}
.rpnm-blog-share span { font-size: 12.5px; font-weight: 800; color: var(--slate); letter-spacing: .5px; }
.rpnm-blog-share a {
	width: 34px; height: 34px; border-radius: 8px;
	display: flex; align-items: center; justify-content: center;
	font-size: 15.5px; font-weight: 700;
}
.rpnm-share-x { background: var(--navy); color: #fff; }
.rpnm-share-in { background: #0A66C2; color: #fff; }
.rpnm-share-wa { background: #25D366; color: #fff; }
.rpnm-share-mail { background: var(--light); color: var(--navy); }

.rpnm-blog-sidebar { display: flex; flex-direction: column; gap: 18px; }
.rpnm-sidebar-card {
	background: #fff; border: 1px solid var(--border); border-radius: 12px; padding: 20px;
}
.rpnm-sidebar-card h4 { font-size: 15.5px; margin-bottom: 14px; }
.rpnm-sidebar-author { text-align: center; }
.rpnm-sidebar-avatar {
	width: 56px; height: 56px; border-radius: 50%; margin: 0 auto 10px;
	background: var(--green); color: var(--navy);
	display: flex; align-items: center; justify-content: center;
	font-size: 18px; font-weight: 900;
}
.rpnm-sidebar-author strong { display: block; color: var(--navy); font-size: 16px; }
.rpnm-sidebar-role { display: block; color: var(--green-dark); font-size: 12.5px; font-weight: 700; margin-bottom: 8px; }
.rpnm-sidebar-author p { font-size: 13.5px; color: var(--slate); margin: 0; }
.rpnm-sidebar-post { display: flex; gap: 10px; margin-bottom: 12px; align-items: center; }
.rpnm-sidebar-post-img {
	width: 54px; height: 54px; border-radius: 8px; flex-shrink: 0;
	background-size: cover; background-position: center;
}
.rpnm-sidebar-post-text strong { display: block; color: var(--navy); font-size: 13.5px; line-height: 1.3; }
.rpnm-sidebar-post-text span { font-size: 11.5px; color: var(--slate-lt); }
.rpnm-sidebar-cta { background: var(--navy); border-color: var(--navy); text-align: center; }
.rpnm-sidebar-cta h4, .rpnm-sidebar-cta p { color: #fff; }
.rpnm-sidebar-cta p { font-size: 13.5px; color: var(--silver); margin-bottom: 12px; }
.rpnm-sidebar-empty { font-size: 13.5px; color: var(--slate-lt); }

.rpnm-pagination { margin-top: 36px; text-align: center; }
.rpnm-pagination .page-numbers {
	display: inline-block; padding: 8px 14px; margin: 0 3px;
	border: 1px solid var(--border); border-radius: 6px;
	color: var(--navy); font-size: 14.5px; font-weight: 700;
}
.rpnm-pagination .page-numbers.current { background: var(--green); color: var(--navy); border-color: var(--green); }
.rpnm-pagination .page-numbers:hover { border-color: var(--green); }
.rpnm-no-posts { text-align: center; padding: 60px 0; }

/* ====================================================================
   VIDEOS PAGE
   ==================================================================== */
.rpnm-video-featured { position: relative; }
.rpnm-video-featured-badge {
	display: inline-block; background: var(--navy); color: #fff;
	font-size: 12.5px; font-weight: 800; padding: 5px 12px; border-radius: 5px; margin-bottom: 12px;
}
.rpnm-video-featured h3 { font-size: 20px; margin-top: 16px; }
.rpnm-video-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.rpnm-video-card {
	background: #fff; border: 1px solid var(--border); border-radius: 12px;
	overflow: hidden; padding-bottom: 16px;
}
.rpnm-video-card .rpnm-video-frame { border-radius: 0; box-shadow: none; }
.rpnm-video-card-body { padding: 14px 16px 4px; }
.rpnm-video-card-tag {
	display: inline-block; margin-bottom: 8px;
	background: var(--light); color: var(--green-dark);
	font-size: 10.5px; font-weight: 800; padding: 4px 10px; border-radius: 4px; letter-spacing: .5px;
}
.rpnm-video-card h4 { font-size: 15.5px; margin: 0 0 6px; line-height: 1.4; }
.rpnm-video-card-views { color: var(--slate); font-size: 12.5px; }
.rpnm-yt-cta {
	background: linear-gradient(135deg, var(--navy) 0%, var(--navy-3) 100%);
	border-radius: 14px; padding: 28px;
	display: flex; justify-content: space-between; align-items: center; gap: 20px;
}
.rpnm-yt-cta h3 { color: #fff; font-size: 20px; margin-bottom: 4px; }
.rpnm-yt-cta p { color: var(--silver); font-size: 14.5px; margin: 0; }

/* ====================================================================
   TESTIMONIALS + FAQ
   ==================================================================== */
.rpnm-testimonial-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.rpnm-testimonial-card {
	background: #fff; border: 1px solid var(--border); border-radius: 12px; padding: 24px;
}
.rpnm-testimonial-dark { background: var(--navy); border-color: var(--navy); }
.rpnm-testimonial-dark .rpnm-testimonial-text { color: #E5E7EB; }
.rpnm-testimonial-dark .rpnm-testimonial-author strong { color: #fff; }
.rpnm-testimonial-stars { color: #F5A623; font-size: 16px; margin-bottom: 12px; letter-spacing: 2px; }
.rpnm-testimonial-text { font-size: 14.5px; color: var(--slate); line-height: 1.7; margin-bottom: 18px; }
.rpnm-testimonial-author { display: flex; gap: 12px; align-items: center; }
.rpnm-testimonial-avatar {
	width: 48px; height: 48px; border-radius: 50%; flex-shrink: 0;
	background: linear-gradient(135deg, #1B2A4A 0%, #34456B 100%);
	color: #fff !important; display: flex !important; align-items: center; justify-content: center;
	font-weight: 800; font-size: 15px; letter-spacing: .5px;
	box-shadow: 0 3px 10px rgba(27,42,74,.2);
}
.rpnm-testimonial-dark .rpnm-testimonial-avatar {
	background: linear-gradient(135deg, #7AC143 0%, #5A9E2F 100%);
	color: var(--navy);
}
.rpnm-testimonial-author strong { display: block; color: var(--navy); font-size: 14.5px; }
.rpnm-testimonial-author span { display: block; color: var(--slate); font-size: 12.5px; }
.rpnm-testimonial-meta { color: var(--green-dark) !important; font-weight: 700; font-size: 11.5px !important; margin-top: 2px; }

.rpnm-faq { max-width: 760px; margin: 0 auto; }
.rpnm-faq-item {
	background: #fff; border: 1px solid var(--border); border-radius: 8px;
	margin-bottom: 10px; overflow: hidden;
}
.rpnm-faq-q {
	width: 100%; display: flex; justify-content: space-between; align-items: center;
	gap: 14px; padding: 16px 20px; background: #fff; border: none; cursor: pointer;
	font-size: 15.5px; font-weight: 700; color: var(--navy); text-align: left;
	transition: background .15s, color .15s;
}
.rpnm-faq-q:hover,
.rpnm-faq-q:focus,
.rpnm-faq-q:active {
	background: var(--light) !important;
	color: var(--green-dark) !important;
	outline: none;
}
.rpnm-faq-item.is-open .rpnm-faq-q,
.rpnm-faq-open .rpnm-faq-q {
	background: var(--navy) !important;
	color: #fff !important;
}
.rpnm-faq-item.is-open .rpnm-faq-q:hover,
.rpnm-faq-open .rpnm-faq-q:hover {
	background: var(--navy-3) !important;
	color: #fff !important;
}
.rpnm-faq-item.is-open .rpnm-faq-icon,
.rpnm-faq-open .rpnm-faq-icon { color: var(--green) !important; }
.rpnm-faq-icon { font-size: 22px; color: var(--green-dark); flex-shrink: 0; transition: transform .25s; }
.rpnm-faq-a {
	max-height: 0; overflow: hidden; transition: max-height .3s, padding .3s;
	padding: 0 20px;
}
.rpnm-faq-open .rpnm-faq-a,
.rpnm-faq-item.is-open .rpnm-faq-a { max-height: 400px; padding: 20px 18px; }
.rpnm-faq-item.is-open .rpnm-faq-icon { transform: rotate(45deg); }
.rpnm-faq-a p { font-size: 14.5px; color: var(--slate); margin: 0; line-height: 1.7; }

/* ====================================================================
   PRICING POPUP
   ==================================================================== */
.rpnm-popup-overlay {
	position: fixed; inset: 0; z-index: 9999;
	background: rgba(27,42,74,.78); backdrop-filter: blur(4px);
	display: none; align-items: flex-start; justify-content: center;
	padding: 40px 20px; overflow-y: auto;
}
.rpnm-popup-active { display: flex; }
.rpnm-popup {
	background: #fff; border-radius: 18px; max-width: 580px; width: 100%;
	padding: 0; position: relative; box-shadow: 0 30px 80px rgba(0,0,0,.4);
	overflow: hidden;
	animation: rpnmPopIn .35s cubic-bezier(.16,1,.3,1);
}
@keyframes rpnmPopIn {
	from { opacity: 0; transform: translateY(30px) scale(.96); }
	to   { opacity: 1; transform: translateY(0) scale(1); }
}
/* Green accent bar at top of popup */
.rpnm-popup::before {
	content: ''; display: block; height: 5px;
	background: linear-gradient(90deg, #7AC143 0%, #5A9E2F 100%);
}
.rpnm-popup-close {
	position: absolute; top: 18px; right: 18px;
	width: 42px; height: 42px; border-radius: 50%;
	background: var(--light); border: 1px solid var(--border); cursor: pointer;
	font-size: 22px; color: var(--slate); line-height: 1;
	display: flex; align-items: center; justify-content: center;
	transition: all .2s; z-index: 5;
	padding: 0; margin: 0;
}
.rpnm-popup-close:hover {
	background: var(--navy); border-color: var(--navy); color: var(--navy);
	transform: rotate(90deg);
}
.rpnm-popup-head {
	padding: 30px 32px 0;
}
.rpnm-popup-head h3 { font-size: 28px; margin-bottom: 8px; }
.rpnm-popup-head p { font-size: 14.5px; color: var(--slate); margin: 0 0 4px; line-height: 1.6; }
.rpnm-popup-form { padding: 18px 32px 30px; }
.rpnm-popup-submit {
	width: 100%; background: var(--green); color: var(--navy);
	border: none; padding: 15px; border-radius: 9px;
	font-size: 15.5px; font-weight: 800; cursor: pointer; margin-top: 8px;
	box-shadow: 0 4px 14px rgba(122,193,67,.35); transition: all .2s;
}
.rpnm-popup-submit:hover { background: var(--green-darker); color: #000 !important; transform: translateY(-2px); }
.rpnm-popup-submit:disabled { opacity: .6; cursor: not-allowed; transform: none; }
.rpnm-popup-trust {
	display: flex; gap: 8px; justify-content: center; flex-wrap: wrap;
	margin-top: 14px; font-size: 12.5px; color: var(--slate);
}

/* ====================================================================
   STICKY WHATSAPP
   ==================================================================== */
.rpnm-sticky-wa {
	position: fixed; right: 20px; bottom: 20px; z-index: 9000;
	background: #25D366; color: #fff;
	padding: 12px 18px; border-radius: 100px;
	display: inline-flex; align-items: center; gap: 8px;
	font-size: 14.5px; font-weight: 700;
	box-shadow: 0 6px 22px rgba(37,211,102,.45);
	transition: transform .2s;
}
.rpnm-sticky-wa:hover { transform: scale(1.05); color: #fff; }
.rpnm-sticky-wa-icon { display: inline-flex; }
.rpnm-sticky-wa-icon .rpnm-wa-svg { width: 22px; height: 22px; }

/* ====================================================================
   FOOTER
   ==================================================================== */
.rpnm-footer { background: linear-gradient(180deg, #22325A 0%, #1B2A4A 100%); padding: 50px 0 0; }
.rpnm-footer-grid {
	display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr 1.4fr; gap: 30px;
	padding-bottom: 36px; border-bottom: 1px solid rgba(255,255,255,.08);
}
.rpnm-footer-logo { display: flex; align-items: center; gap: 14px; margin-bottom: 14px; flex-wrap: wrap; }
.rpnm-footer-logo-link { display: inline-flex; align-items: center; transition: opacity .2s; }
.rpnm-footer-logo-link:hover { opacity: .8; }
.rpnm-footer-logo-img-bs { display: block; width: auto; height: 38px; max-width: 150px; object-fit: contain; }
.rpnm-footer-logo-img-rb { display: block; width: auto; height: 34px; max-width: 150px; object-fit: contain; }
.rpnm-footer-text { color: var(--silver); font-size: 13.5px; line-height: 1.7; }
.rpnm-footer-socials { display: flex; gap: 8px; margin-top: 14px; }
.rpnm-footer-socials a {
	width: 32px; height: 32px; border-radius: 7px;
	background: rgba(255,255,255,.08); color: #fff;
	display: flex; align-items: center; justify-content: center;
	font-size: 14.5px; font-weight: 700;
}
.rpnm-footer-socials a:hover { background: var(--green); color: var(--navy); }
.rpnm-footer-col h5, .rpnm-footer-contact h5 {
	color: #fff; font-size: 14.5px; margin-bottom: 14px; letter-spacing: .5px;
}
.rpnm-footer-col ul { list-style: none; margin: 0; padding: 0; }
.rpnm-footer-col li { margin-bottom: 8px; }
.rpnm-footer-col a { color: var(--silver); font-size: 13.5px; }
.rpnm-footer-col a:hover { color: var(--green); }
.rpnm-footer-contact-row {
	display: flex; gap: 8px; align-items: flex-start;
	margin-bottom: 10px; color: var(--silver); font-size: 13.5px;
}
.rpnm-footer-contact-row .ic { flex-shrink: 0; }
.rpnm-footer-contact-row a { color: var(--silver); }
.rpnm-footer-contact-row a:hover { color: var(--green); }
.rpnm-footer-wa-btn {
	display: inline-flex; align-items: center; gap: 6px; margin-top: 8px;
	background: #25D366; color: #fff; padding: 9px 16px;
	border-radius: 6px; font-size: 13.5px; font-weight: 700;
}
.rpnm-footer-wa-btn:hover { background: #1da851; color: #fff; }
.rpnm-footer-bottom {
	display: flex; justify-content: space-between; align-items: center;
	padding: 18px 0; color: var(--slate-lt); font-size: 12.5px; flex-wrap: wrap; gap: 10px;
}
.rpnm-footer-bottom a { color: var(--slate-lt); }
.rpnm-footer-bottom a:hover { color: var(--green); }

.rpnm-content-area { max-width: 820px; margin: 0 auto; font-size: 16px; line-height: 1.8; color: #2d3748; }
.rpnm-content-area h2 { font-size: 24px; margin: 30px 0 12px; }
.rpnm-content-area h3 { font-size: 19px; margin: 24px 0 10px; }
.rpnm-about-intro p { margin-bottom: 16px; }

/* ====================================================================
   RESPONSIVE - TABLET (<= 1024px)
   ==================================================================== */
@media (max-width: 1024px) {
.rpnm-topbar-left { display: none; }
	.rpnm-burger { display: flex; }
	.rpnm-header-cta { display: none; }

	/* Backdrop behind sliding menu */
	.rpnm-nav-backdrop {
		display: none;
		position: fixed; inset: 0;
		background: rgba(0,0,0,.55);
		z-index: 185;
		opacity: 0; transition: opacity .3s;
	}
	.rpnm-nav-backdrop.is-active {
		display: block; opacity: 1;
	}
	body.rpnm-no-scroll { overflow: hidden; }

	.rpnm-nav {
		position: fixed; top: 0; right: -100%; width: 85%; max-width: 340px; height: 100vh;
		background: var(--navy-2); padding: 70px 22px 30px; transition: right .35s ease;
		z-index: 195; overflow-y: auto;
		box-shadow: -10px 0 40px rgba(0,0,0,.5);
		justify-content: unset;
        align-items: flex-start;
	}
	.rpnm-nav-open { right: 0; }

	/* Close (X) button inside mobile nav */
	.rpnm-nav-close {
		display: flex; position: absolute; top: 16px; right: 16px;
		width: 50px; height: 50px; border-radius: 50%;
		background: rgba(255,255,255,.08) !important; border: none;
		color: #fff !important; align-items: center; justify-content: center;
		cursor: pointer; transition: background .15s, transform .2s;
	}
	.rpnm-nav-close:hover { background: var(--green); color: var(--navy); transform: rotate(90deg); }

	.rpnm-menu { flex-direction: column; align-items: stretch; gap: 4px; }
	.rpnm-menu-item > a { padding: 13px 4px; font-size: 15px; border-bottom: 1px solid rgba(255,255,255,.08); }

	/* Mobile: dropdown + mega become simple stacked lists */
	.rpnm-dropdown, .rpnm-mega {
		position: static; opacity: 1; visibility: visible; transform: none;
		box-shadow: none; background: rgba(255,255,255,.04); margin: 4px 0;
		width: 100%; padding: 6px; border-radius: 8px;
		max-height: 0; overflow: hidden; padding-top: 0; padding-bottom: 0;
		transition: max-height .35s ease, padding .25s;
	}
	.rpnm-mega-open .rpnm-dropdown,
	.rpnm-mega-open .rpnm-mega {
		max-height: 1400px; padding: 8px 6px;
	}
	.rpnm-dropdown a { color: var(--silver); }
	.rpnm-dropdown a:hover { color: var(--green); background: rgba(255,255,255,.06); }
	.rpnm-mega-cols { grid-template-columns: 1fr; gap: 12px; }
	.rpnm-mega-col-head strong, .rpnm-mega-col-head span { color: #fff; }
	.rpnm-mega-col-head { border-bottom-color: rgba(255,255,255,.1); }
	.rpnm-mega-col-ic { background: rgba(255,255,255,.08); }
	.rpnm-mega-item:hover { background: rgba(255,255,255,.06); }
	.rpnm-mega-text strong { color: #fff; }
	.rpnm-mega-foot { flex-direction: column; border-top-color: rgba(255,255,255,.1); }
	.rpnm-mega-foot-btns { flex-direction: row; width: 100%; }
		.rpnm-caret { float: right; transition: transform .25s; }
	.rpnm-mega-open .rpnm-caret { transform: rotate(180deg); }

	/* Mobile logo sizing */
	.rpnm-logo-img-bs { height: 36px; }
	.rpnm-logo-img-rb { height: 32px; }
	.rpnm-logo-divider { height: 26px; }

	.rpnm-home-hero-grid { grid-template-columns: 1fr; gap: 30px; padding: 50px 24px; }
	.rpnm-home-hero-text h1 { font-size: 36px; }
	.rpnm-product-grid { grid-template-columns: repeat(3,1fr); }
	.rpnm-product-grid-3 { grid-template-columns: repeat(2,1fr); }
	.rpnm-video-section { grid-template-columns: 1fr; }
	.rpnm-industries-grid { grid-template-columns: repeat(3,1fr); }
	.rpnm-gcc-grid { grid-template-columns: repeat(3,1fr); }
	.rpnm-features-grid { grid-template-columns: repeat(2,1fr); }
	.rpnm-features-grid-4 { grid-template-columns: repeat(2,1fr); }
	.rpnm-product-showcase { grid-template-columns: 1fr; }
	.rpnm-contact-grid { grid-template-columns: 1fr; }
	.rpnm-blog-grid { grid-template-columns: repeat(2,1fr); }
	.rpnm-blog-layout { grid-template-columns: 1fr; }
	.rpnm-video-grid { grid-template-columns: repeat(2,1fr); }
	.rpnm-testimonial-grid { grid-template-columns: 1fr; }
	.rpnm-wa-banner { grid-template-columns: 1fr; }
	.rpnm-footer-grid { grid-template-columns: repeat(2,1fr); }
	.rpnm-certs-list { gap: 14px; }
}

/* ====================================================================
   RESPONSIVE - MOBILE (<= 768px)
   ==================================================================== */
@media (max-width: 768px) {
	.rpnm-section { padding: 40px 0; }
	.rpnm-container { padding: 0 18px; }
	.rpnm-topbar-right { gap: 10px; font-size: 11.5px; }
	.rpnm-topbar-hours { display: none; }
	.rpnm-logo-text-rb { display: none; }
	.rpnm-section-head-row { flex-direction: column; align-items: flex-start; }
	.rpnm-section-head h2 { font-size: 23px; }

	.rpnm-home-hero-text h1 { font-size: 30px; }
	.rpnm-home-hero-cta { flex-direction: column; }
	.rpnm-home-hero-cta .rpnm-btn { width: 100%; }
	.rpnm-trust-grid { grid-template-columns: repeat(2,1fr); gap: 16px; }
	.rpnm-product-grid { grid-template-columns: repeat(2,1fr); }
	.rpnm-product-grid-3 { grid-template-columns: 1fr; }
	.rpnm-industries-grid { grid-template-columns: repeat(2,1fr); }
	.rpnm-gcc-grid { grid-template-columns: repeat(2,1fr); }
	.rpnm-features-grid { grid-template-columns: 1fr; }
	.rpnm-features-grid-4 { grid-template-columns: 1fr; }
	.rpnm-form-row { grid-template-columns: 1fr; }
	.rpnm-blog-grid { grid-template-columns: 1fr; }
	.rpnm-video-grid { grid-template-columns: 1fr; }
	.rpnm-footer-grid { grid-template-columns: 1fr; gap: 24px; }
	.rpnm-final-cta-inner { flex-direction: column; text-align: center; }
	.rpnm-final-cta-btns { width: 100%; flex-direction: column; }
	.rpnm-final-cta-btns .rpnm-btn { width: 100%; }
	.rpnm-footer-bottom { flex-direction: column; text-align: center; }

	.rpnm-page-hero-content h1 { font-size: 30px; }
	.rpnm-product-hero-text h1 { font-size: 32px; }
	.rpnm-product-hero-pricing { position: static; margin: 0 auto 16px; display: block; }
	.rpnm-product-hero-crumb { display: none; }
	.rpnm-product-hero-text { padding: 50px 18px 40px; }
	.rpnm-product-spec-tiles { grid-template-columns: 1fr; }
	.rpnm-product-cta-row { flex-direction: column; }
	.rpnm-product-cta-row .rpnm-btn { width: 100%; }
	.rpnm-contact-form-actions { flex-direction: column; }
	.rpnm-contact-form-actions .rpnm-btn { width: 100%; }
	.rpnm-wa-banner-btns { flex-direction: column; }
	.rpnm-wa-banner-btns .rpnm-btn { width: 100%; }
	.rpnm-yt-cta { flex-direction: column; text-align: center; }
	/* ===== POPUP MOBILE FULLSCREEN FIX ===== */
	.rpnm-popup-overlay { padding: 0; align-items: flex-start; }
	.rpnm-popup {
		border-radius: 0;
		min-height: 100vh; max-width: 100%;
	}
	.rpnm-popup-head { padding: 24px 20px 0; }
	.rpnm-popup-head h3 { font-size: 22px; }
	.rpnm-popup-head p { font-size: 13.5px; }
	.rpnm-popup-form { padding: 14px 20px 24px; }
	.rpnm-popup-close { top: 12px; right: 12px; width: 38px; height: 38px; }
	.rpnm-popup .rpnm-form-row { grid-template-columns: 1fr; gap: 0; }
	.rpnm-popup-submit { padding: 14px; font-size: 14.5px; }
	.rpnm-sticky-wa-text { display: none; }
	.rpnm-sticky-wa { padding: 14px; }
	.rpnm-sticky-wa-icon { font-size: 20px; }
	.rpnm-contact-hero-actions { flex-direction: column; }
	.rpnm-contact-hero-actions .rpnm-btn { width: 100%; }
}

/* ====================================================================
   RESPONSIVE - SMALL MOBILE (<= 480px)
   ==================================================================== */
@media (max-width: 480px) {
	.rpnm-product-grid { grid-template-columns: 1fr; }
	.rpnm-industries-grid { grid-template-columns: 1fr; }
	.rpnm-gcc-grid { grid-template-columns: 1fr; }
	.rpnm-trust-grid { grid-template-columns: 1fr; }
	.rpnm-home-hero-text h1 { font-size: 26px; }
	.rpnm-page-hero-content h1 { font-size: 25px; }
	.rpnm-product-hero-text h1 { font-size: 27px; }
}

/* ====================================================================
   WHATSAPP SVG ICON
   ==================================================================== */
.rpnm-wa-svg {
	display: inline-block;
	vertical-align: middle;
	flex-shrink: 0;
}
.rpnm-btn .rpnm-wa-svg { margin-right: 2px; }
.rpnm-sticky-wa-icon .rpnm-wa-svg { width: 22px; height: 22px; }
.rpnm-footer-contact-row .rpnm-wa-svg,
.rpnm-footer-wa-btn .rpnm-wa-svg { width: 16px; height: 16px; }


/* ====================================================================
   HOMEPAGE EXTRAS  (split section, check-list, 3-col features)
   ==================================================================== */
.rpnm-features-grid-3 { grid-template-columns: repeat(3,1fr); }

.rpnm-split {
	display: grid; grid-template-columns: 1fr 1fr;
	gap: 48px; align-items: center;
}
.rpnm-split-media {
	background: #fff; border-radius: 16px; padding: 20px;
	box-shadow: var(--shadow-lg); border: 1px solid var(--border);
}
.rpnm-split-media img {
	width: 100%; border-radius: 10px;
	box-shadow: none;
}
.rpnm-split-text h2 { font-size: 30px; margin-bottom: 14px; }
.rpnm-check-list {
	list-style: none; margin: 18px 0 24px; padding: 0;
	display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
}
.rpnm-check-list li {
	position: relative; padding-left: 28px;
	font-size: 15px; color: var(--slate); font-weight: 600;
}
.rpnm-check-list li::before {
	content: '✓'; position: absolute; left: 0; top: 0;
	width: 20px; height: 20px; border-radius: 50%;
	background: var(--green); color: var(--navy);
	display: flex; align-items: center; justify-content: center;
	font-size: 12px; font-weight: 800;
}

@media (max-width: 1024px) {
	.rpnm-features-grid-3 { grid-template-columns: repeat(2,1fr); }
	.rpnm-split { grid-template-columns: 1fr; gap: 28px; }
}
@media (max-width: 768px) {
	.rpnm-features-grid-3 { grid-template-columns: 1fr; }
	.rpnm-check-list { grid-template-columns: 1fr; }
}

/* ====================================================================
   OUR STORY — TIMELINE
   ==================================================================== */
.rpnm-timeline { position: relative; max-width: 900px; margin: 0 auto; padding: 20px 0; }
.rpnm-timeline::before {
	content: ''; position: absolute; left: 50%; top: 0; bottom: 0;
	width: 3px; background: var(--silver); transform: translateX(-50%);
}
.rpnm-timeline-item { position: relative; width: 50%; padding: 0 40px 36px; }
.rpnm-timeline-left { left: 0; text-align: right; }
.rpnm-timeline-right { left: 50%; text-align: left; }
.rpnm-timeline-dot {
	position: absolute; top: 6px; width: 18px; height: 18px;
	border-radius: 50%; background: var(--green);
	border: 4px solid #fff; box-shadow: 0 0 0 2px var(--green);
	z-index: 2;
}
.rpnm-timeline-left .rpnm-timeline-dot { right: -9px; }
.rpnm-timeline-right .rpnm-timeline-dot { left: -9px; }
.rpnm-timeline-card {
	background: #fff; border: 1px solid var(--border); border-radius: 14px;
	padding: 22px 24px; box-shadow: var(--shadow);
}
.rpnm-timeline-year {
	display: inline-block; background: var(--green); color: var(--navy);
	font-size: 13px; font-weight: 800; padding: 4px 12px; border-radius: 5px;
	margin-bottom: 10px; letter-spacing: .5px;
}
.rpnm-timeline-year-now { background: var(--navy); color: #fff; }
.rpnm-timeline-card h3 { font-size: 19px; margin-bottom: 6px; }
.rpnm-timeline-card p { font-size: 14.5px; color: var(--slate); margin: 0; line-height: 1.65; }

/* ====================================================================
   BEST AIR DUCT — PROCESS STEPS
   ==================================================================== */
.rpnm-process-grid {
	display: grid; grid-template-columns: repeat(3,1fr); gap: 24px;
}
.rpnm-process-step {
	background: #fff; border: 1px solid var(--border); border-radius: 14px;
	padding: 30px 24px; position: relative; box-shadow: 0 2px 12px rgba(27,42,74,.05);
}
.rpnm-process-num {
	display: inline-block; font-size: 38px; font-weight: 900;
	color: var(--green); opacity: .35; line-height: 1; margin-bottom: 12px;
}
.rpnm-process-step h4 { font-size: 18px; margin-bottom: 8px; }
.rpnm-process-step p { font-size: 14.5px; color: var(--slate); margin: 0; line-height: 1.65; }

/* ====================================================================
   PRODUCTS PAGE — CATEGORY CARDS
   ==================================================================== */
.rpnm-cat-cards {
	display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-bottom: 44px;
}
.rpnm-cat-card {
	position: relative; border-radius: 16px; overflow: hidden;
	min-height: 240px; display: flex; align-items: flex-end;
	background: var(--navy);
}
.rpnm-cat-card-bg {
	position: absolute; inset: 0; background-size: cover; background-position: center;
	opacity: .35;
}
.rpnm-cat-card-body {
	position: relative; z-index: 2; padding: 28px; color: #fff;
}
.rpnm-cat-card-body h3 { color: #fff; font-size: 24px; margin-bottom: 8px; }
.rpnm-cat-card-body p { color: var(--silver); font-size: 14px; margin-bottom: 14px; }
.rpnm-cat-card-tags { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 16px; }
.rpnm-cat-card-tag {
	background: rgba(255,255,255,.12); color: #fff;
	font-size: 11px; font-weight: 600; padding: 4px 10px; border-radius: 100px;
}

@media (max-width: 1024px) {
	.rpnm-process-grid { grid-template-columns: 1fr; }
	.rpnm-cat-cards { grid-template-columns: 1fr; }
	.rpnm-timeline::before { left: 20px; }
	.rpnm-timeline-item { width: 100%; left: 0 !important; padding: 0 0 30px 52px; text-align: left !important; }
	.rpnm-timeline-left .rpnm-timeline-dot,
	.rpnm-timeline-right .rpnm-timeline-dot { left: 11px; right: auto; }
}


/* ====================================================================
   SIMPLE DROPDOWN  (About Us menu)
   ==================================================================== */
.rpnm-has-dropdown { position: relative; }
.rpnm-dropdown {
	position: absolute; top: 100%; left: 0;
	min-width: 220px; background: #fff;
	border-radius: 10px; box-shadow: var(--shadow-lg);
	list-style: none; margin: 8px 0 0; padding: 8px;
	opacity: 0; visibility: hidden; transform: translateY(8px);
	transition: all .2s; z-index: 220;
}
.rpnm-has-dropdown:hover > .rpnm-dropdown {
	opacity: 1; visibility: visible; transform: translateY(0);
}
.rpnm-dropdown li { list-style: none; }
.rpnm-dropdown a {
	display: block; padding: 9px 12px; border-radius: 6px;
	color: var(--navy); font-size: 13.5px; font-weight: 500;
	transition: background .15s, color .15s, padding-left .2s;
}
.rpnm-dropdown a:hover { background: var(--light); color: var(--green-dark); padding-left: 16px; }

/* ====================================================================
   IMAGE MEGA MENU  (Our Products)
   ==================================================================== */
.rpnm-has-mega { position: relative; }
.rpnm-mega {
	position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(8px);
	width: 720px; background: #fff;
	border-radius: 14px; box-shadow: var(--shadow-lg);
	padding: 22px; opacity: 0; visibility: hidden;
	transition: all .25s; z-index: 230;
}
.rpnm-has-mega:hover > .rpnm-mega {
	opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0);
}
.rpnm-mega-cols {
	display: grid; grid-template-columns: 1fr 1fr; gap: 24px;
}
.rpnm-mega-col-head {
	display: flex; align-items: center; gap: 10px;
	padding-bottom: 10px; margin-bottom: 8px;
	border-bottom: 2px solid var(--light);
	transition: border-color .15s;
}
a.rpnm-mega-col-head:hover { border-bottom-color: var(--green); }
a.rpnm-mega-col-head:hover strong { color: var(--green-dark); }
.rpnm-mega-col-ic {
	width: 40px; height: 40px; border-radius: 9px;
	background: var(--light); flex-shrink: 0;
	background-size: cover; background-position: center;
	border: 1px solid var(--border);
}
.rpnm-mega-col-head strong { display: block; color: var(--navy); font-size: 14px; }
.rpnm-mega-col-head span { display: block; color: var(--slate); font-size: 11px; }
.rpnm-mega-item {
	display: flex; align-items: center; gap: 12px;
	padding: 8px; border-radius: 8px; transition: background .15s;
}
.rpnm-mega-item:hover { background: var(--light); }
.rpnm-mega-thumb {
	width: 48px; height: 48px; border-radius: 8px; flex-shrink: 0;
	background: var(--light); background-size: contain;
	background-repeat: no-repeat; background-position: center;
}
.rpnm-mega-text strong {
	display: block; color: var(--navy); font-size: 13px; line-height: 1.3;
}
.rpnm-mega-text span {
	display: block; color: var(--green-dark); font-size: 9.5px;
	font-weight: 800; letter-spacing: .5px; margin-top: 2px;
}
.rpnm-mega-viewall {
	display: inline-block; margin-top: 8px; padding-left: 8px;
	color: var(--green-dark); font-size: 12px; font-weight: 800;
}
.rpnm-mega-viewall:hover { color: var(--green-darker); }
.rpnm-mega-foot {
	display: flex; align-items: center; gap: 16px;
	margin-top: 18px; padding-top: 16px; border-top: 2px solid var(--light);
}
.rpnm-mega-featured {
	display: flex; align-items: center; gap: 12px; flex: 1;
	background: linear-gradient(135deg, var(--navy) 0%, var(--navy-3) 100%);
	border-radius: 10px; padding: 12px;
}
.rpnm-mega-featured-img {
	width: 56px; height: 56px; border-radius: 8px; flex-shrink: 0;
	background: #fff; background-size: contain;
	background-repeat: no-repeat; background-position: center;
}
.rpnm-mega-featured-badge {
	display: block; color: var(--green); font-size: 9px;
	font-weight: 800; letter-spacing: .5px; margin-bottom: 3px;
}
.rpnm-mega-featured-text strong { display: block; color: #fff; font-size: 13px; }
.rpnm-mega-featured-text > span:last-child {
	display: block; color: var(--silver); font-size: 10.5px; margin-top: 2px;
}
.rpnm-mega-foot-btns { display: flex; flex-direction: column; gap: 8px; }
.rpnm-btn-sm { padding: 8px 16px; font-size: 11.5px; }

/* ====================================================================
   CATEGORY PAGE — split hero with image + stats
   ==================================================================== */
.rpnm-cat-hero {
	background: linear-gradient(135deg, #1B2A4A 0%, #22325A 100%);
	padding: 48px 0 56px;
	position: relative; overflow: hidden;
}
.rpnm-cat-hero-bgimg {
	position: absolute; inset: 0;
	background-size: cover; background-position: center right;
	opacity: .4;
}
.rpnm-cat-hero-overlay {
	position: absolute; inset: 0;
	/* background: linear-gradient(110deg, rgba(27,42,74,.96) 0%, rgba(27,42,74,.82) 45%, rgba(27,42,74,.4) 100%); */
}
.rpnm-cat-hero-grid {
	align-items: center;
	position: relative; z-index: 2;
}
.rpnm-cat-hero-text h1 { color: #fff; font-size: 2.5rem; margin: 8px 0 14px; }
.rpnm-cat-hero-text > p { color: var(--silver); font-size: 1.02rem; margin-bottom: 22px; }
.rpnm-cat-hero-stats {
	display: flex; gap: 28px; margin-bottom: 24px;
	padding: 18px 0; border-top: 1px solid rgba(255,255,255,.12);
	border-bottom: 1px solid rgba(255,255,255,.12);
}
.rpnm-cat-hero-stats strong {
	display: block; color: var(--green); font-size: 26px; font-weight: 900; line-height: 1;
}
.rpnm-cat-hero-stats span { color: var(--silver); font-size: 12.5px; }
.rpnm-cat-hero-media {
	background: #fff; border-radius: 16px; padding: 24px;
	box-shadow: var(--shadow-lg);
}
.rpnm-cat-hero-media img { width: 100%; border-radius: 8px; }

/* ====================================================================
   HELP BANNER  (Our Products page)
   ==================================================================== */
.rpnm-help-banner {
	background: linear-gradient(135deg, #1B2A4A 0%, #2A3B5C 100%);
	border-radius: 18px; padding: 38px 40px;
	display: flex; align-items: center; justify-content: space-between;
	gap: 32px; flex-wrap: wrap;
}
.rpnm-help-banner-text { flex: 1; min-width: 280px; }
.rpnm-help-banner-text h3 { color: #fff; font-size: 24px; margin: 6px 0 8px; }
.rpnm-help-banner-text p { color: var(--silver); font-size: 14.5px; margin: 0; }
.rpnm-help-banner-btns { display: flex; gap: 12px; flex-wrap: wrap; }

/* 4-column product grid (Our Products page) */
.rpnm-product-grid-4 { grid-template-columns: repeat(4,1fr); }

@media (max-width: 1024px) {
	.rpnm-cat-hero-grid { grid-template-columns: 1fr; gap: 28px; }
	.rpnm-cat-hero-text h1 { font-size: 2rem; }
	.rpnm-product-grid-4 { grid-template-columns: repeat(2,1fr); }
	.rpnm-help-banner { padding: 28px 24px; }
}
@media (max-width: 600px) {
	.rpnm-product-grid-4 { grid-template-columns: 1fr; }
	.rpnm-cat-hero-stats { gap: 18px; }
}

/* ====================================================================
   PRODUCT DETAIL PAGE v2  (matches rebuilt template-product.php)
   ==================================================================== */
.rpnm-product-hero-content {
	position: relative; z-index: 3; padding: 70px 0 50px;
}
.rpnm-product-hero-badge {
	display: inline-block; background: var(--green); color: var(--navy);
	font-size: 12px; font-weight: 800; letter-spacing: .5px;
	padding: 5px 14px; border-radius: 5px; margin-bottom: 14px;
}
.rpnm-product-hero-content h1 {
	color: #fff; font-size: 2.8rem; margin-bottom: 12px; letter-spacing: -.02em;
}
.rpnm-product-hero-content > p {
	color: var(--silver); font-size: 1.05rem; max-width: 620px; margin: 0;
}

/* Main: gallery + info */
.rpnm-product-main {
	display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start;
}
.rpnm-product-gallery-main {
	aspect-ratio: 4/3; background: var(--light); border-radius: 14px;
	background-size: contain; background-repeat: no-repeat; background-position: center;
	margin-bottom: 12px; border: 1px solid var(--border);
}
.rpnm-product-gallery-thumbs {
	display: grid; grid-template-columns: repeat(4,1fr); gap: 10px;
}
.rpnm-gallery-thumb {
	aspect-ratio: 1; background: var(--light);
	border: 2px solid var(--border); border-radius: 9px;
	background-size: contain; background-repeat: no-repeat; background-position: center;
	cursor: pointer; transition: border-color .2s, transform .15s; padding: 0;
}
.rpnm-gallery-thumb:hover { transform: translateY(-2px); }
.rpnm-gallery-thumb.is-active { border-color: var(--green); }

.rpnm-product-info > .rpnm-eyebrow { display: block; margin-bottom: 8px; }
.rpnm-product-info h2 { font-size: 2rem; margin-bottom: 14px; }
.rpnm-product-intro { color: var(--slate); font-size: 1rem; margin-bottom: 22px; line-height: 1.7; }

.rpnm-product-keyspecs {
	display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 24px;
}
.rpnm-keyspec-tile {
	background: var(--light); border: 1px solid var(--border);
	border-radius: 10px; padding: 14px 16px;
}
.rpnm-keyspec-label {
	display: block; color: var(--slate); font-size: 11px;
	letter-spacing: .8px; font-weight: 700; margin-bottom: 4px;
}
.rpnm-keyspec-value { display: block; color: var(--navy); font-size: 17px; font-weight: 800; }

.rpnm-product-cta-row { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 14px; }
.rpnm-product-trust-row { display: flex; gap: 18px; flex-wrap: wrap; }
.rpnm-product-trust-row span { color: var(--slate); font-size: 13px; font-weight: 600; }

/* Full specs table */
.rpnm-specs-table-wrap { max-width: 760px; margin: 0 auto; }
.rpnm-specs-table {
	width: 100%; border-collapse: collapse;
	background: #fff; border: 1px solid var(--border);
	border-radius: 12px; overflow: hidden;
}
.rpnm-specs-table th, .rpnm-specs-table td {
	padding: 15px 22px; text-align: left; font-size: 14.5px;
	border-bottom: 1px solid var(--light);
}
.rpnm-specs-table th {
	color: var(--slate); font-weight: 600; width: 45%;
	background: var(--off-white);
}
.rpnm-specs-table td { color: var(--navy); font-weight: 700; }
.rpnm-specs-table tr:last-child th,
.rpnm-specs-table tr:last-child td { border-bottom: none; }

@media (max-width: 1024px) {
	.rpnm-product-main { grid-template-columns: 1fr; gap: 32px; }
	.rpnm-product-hero-content h1 { font-size: 2.1rem; }
}
@media (max-width: 600px) {
	.rpnm-product-keyspecs { grid-template-columns: 1fr; }
}

/* ====================================================================
   BLOG — category chips, featured post, article layout (PDF p16-17)
   ==================================================================== */
.rpnm-blog-chips {
	display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 32px;
}
.rpnm-blog-chip {
	padding: 8px 18px; border-radius: 100px;
	background: var(--light); border: 1px solid var(--border);
	color: var(--slate); font-size: 13px; font-weight: 700;
	transition: all .15s;
}
.rpnm-blog-chip:hover { border-color: var(--green); color: var(--green-dark); }
.rpnm-blog-chip.is-active {
	background: var(--green); border-color: var(--green); color: var(--navy);
}

/* Featured post */
.rpnm-blog-featured {
	display: grid; grid-template-columns: 1.1fr 1fr; gap: 0;
	background: #fff; border: 1px solid var(--border); border-radius: 16px;
	overflow: hidden; margin-bottom: 40px; box-shadow: var(--shadow);
}
.rpnm-blog-featured-img {
	position: relative; min-height: 320px;
	background-size: cover; background-position: center;
}
.rpnm-blog-featured-tag {
	position: absolute; top: 16px; left: 16px;
	background: var(--navy); color: #fff;
	font-size: 11px; font-weight: 800; letter-spacing: .5px;
	padding: 5px 12px; border-radius: 5px;
}
.rpnm-blog-featured-body {
	padding: 34px; display: flex; flex-direction: column; justify-content: center;
}
.rpnm-blog-featured-body h2 { font-size: 1.7rem; margin: 10px 0 12px; }
.rpnm-blog-featured-body h2 a { color: var(--navy); }
.rpnm-blog-featured-body h2 a:hover { color: var(--green-dark); }
.rpnm-blog-featured-body > p { color: var(--slate); font-size: 15px; margin-bottom: 20px; }
.rpnm-blog-featured-foot {
	display: flex; align-items: center; justify-content: space-between;
	gap: 16px; flex-wrap: wrap;
}
.rpnm-blog-author { display: flex; align-items: center; gap: 10px; }
.rpnm-blog-author-avatar {
	width: 40px; height: 40px; border-radius: 50%; flex-shrink: 0;
	background: linear-gradient(135deg, #1B2A4A 0%, #34456B 100%);
	color: #fff; display: flex; align-items: center; justify-content: center;
	font-weight: 800; font-size: 13px;
}
.rpnm-blog-author strong { display: block; color: var(--navy); font-size: 13.5px; }
.rpnm-blog-author > span > span { display: block; color: var(--slate); font-size: 11.5px; }

/* Article detail layout */
.rpnm-blog-layout {
	display: grid; grid-template-columns: 1fr 320px; gap: 44px; align-items: start;
}
.rpnm-blog-article .rpnm-blog-featured-img {
	min-height: auto; border-radius: 14px; overflow: hidden; margin-bottom: 26px;
}
.rpnm-blog-article .rpnm-blog-featured-img img { width: 100%; display: block; }
.rpnm-blog-content { color: var(--ink); font-size: 1.05rem; line-height: 1.8; }
.rpnm-blog-content h2 { font-size: 1.6rem; margin: 32px 0 12px; }
.rpnm-blog-content h3 { font-size: 1.3rem; margin: 26px 0 10px; }
.rpnm-blog-content p { margin-bottom: 18px; }
.rpnm-blog-content img { border-radius: 10px; margin: 20px 0; }
.rpnm-blog-content blockquote {
	border-left: 4px solid var(--green); background: var(--light);
	padding: 18px 24px; margin: 24px 0; border-radius: 0 10px 10px 0;
	font-style: italic; color: var(--navy);
}
.rpnm-blog-content ul, .rpnm-blog-content ol { margin: 0 0 18px 22px; }
.rpnm-blog-content li { margin-bottom: 8px; }

.rpnm-blog-share {
	display: flex; align-items: center; gap: 10px;
	margin-top: 32px; padding-top: 22px; border-top: 1px solid var(--border);
}
.rpnm-blog-share span { font-size: 12px; font-weight: 800; color: var(--slate); letter-spacing: .5px; }
.rpnm-blog-share a {
	width: 38px; height: 38px; border-radius: 9px;
	display: flex; align-items: center; justify-content: center;
	background: var(--light); color: var(--navy);
	font-size: 14px; font-weight: 700; transition: all .15s;
}
.rpnm-blog-share a:hover { background: var(--green); color: var(--navy); transform: translateY(-2px); }
.rpnm-share-wa:hover { background: #25D366; color: #fff; }

/* Sidebar */
.rpnm-blog-sidebar { display: flex; flex-direction: column; gap: 20px; }
.rpnm-sidebar-card {
	background: #fff; border: 1px solid var(--border);
	border-radius: 14px; padding: 22px;
}
.rpnm-sidebar-card h4 { font-size: 15px; margin-bottom: 14px; }
.rpnm-sidebar-author { text-align: center; }
.rpnm-sidebar-avatar {
	width: 60px; height: 60px; border-radius: 50%; margin: 0 auto 12px;
	background: linear-gradient(135deg, #1B2A4A 0%, #34456B 100%);
	color: #fff; display: flex; align-items: center; justify-content: center;
	font-weight: 800; font-size: 18px;
}
.rpnm-sidebar-author strong { display: block; color: var(--navy); font-size: 16px; }
.rpnm-sidebar-role { display: block; color: var(--green-dark); font-size: 12px; font-weight: 700; margin: 2px 0 10px; }
.rpnm-sidebar-author p { font-size: 13px; color: var(--slate); margin: 0; line-height: 1.6; }
.rpnm-sidebar-post {
	display: flex; gap: 12px; align-items: center;
	padding: 8px 0; border-bottom: 1px solid var(--light);
}
.rpnm-sidebar-post:last-child { border-bottom: none; }
.rpnm-sidebar-post-img {
	width: 56px; height: 56px; border-radius: 8px; flex-shrink: 0;
	background-size: cover; background-position: center; background-color: var(--light);
}
.rpnm-sidebar-post-text strong { display: block; color: var(--navy); font-size: 13px; line-height: 1.4; }
.rpnm-sidebar-post-text > span { display: block; color: var(--slate); font-size: 11.5px; margin-top: 3px; }
.rpnm-sidebar-post:hover .rpnm-sidebar-post-text strong { color: var(--green-dark); }
.rpnm-sidebar-cta { background: linear-gradient(135deg, var(--green) 0%, var(--green-darker) 100%); }
.rpnm-sidebar-cta h4 { color: var(--navy); }
.rpnm-sidebar-cta p { color: #2A3B1A; font-size: 13px; margin-bottom: 14px; font-weight: 500; }
.rpnm-sidebar-empty { color: var(--slate); font-size: 13px; }

@media (max-width: 1024px) {
	.rpnm-blog-featured { grid-template-columns: 1fr; }
	.rpnm-blog-featured-img { min-height: 220px; }
	.rpnm-blog-layout { grid-template-columns: 1fr; gap: 32px; }
}

/* ====================================================================
   CERTIFIED BY — badge grid with real logos
   ==================================================================== */
.rpnm-certby-grid {
	display: grid; grid-template-columns: repeat(7,1fr); gap: 16px;
}
.rpnm-certby-badge {
	background: #fff; border: 1px solid var(--border); border-radius: 14px;
	padding: 20px 12px; text-align: center;
	box-shadow: 0 2px 10px rgba(27,42,74,.05);
	transition: transform .15s, box-shadow .15s;
}
.rpnm-certby-badge:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.rpnm-certby-logo {
	width: 100%; height: 80px; margin-bottom: 10px;
	display: flex; align-items: center; justify-content: center;
}
.rpnm-certby-logo img {
	max-width: 100%; max-height: 80px; width: auto; height: auto;
	object-fit: contain;
}
.rpnm-certby-badge span {
	display: block; color: var(--navy); font-size: 12px; font-weight: 700; line-height: 1.4;
}
@media (max-width: 1024px) {
	.rpnm-certby-grid { grid-template-columns: repeat(4,1fr); }
}
@media (max-width: 600px) {
	.rpnm-certby-grid { grid-template-columns: repeat(3,1fr); gap: 10px; }
	.rpnm-certby-badge { padding: 14px 8px; }
	.rpnm-certby-logo { height: 60px; }
	.rpnm-certby-logo img { max-height: 60px; }
}

/* ====================================================================
   FOOTER — WhatsApp + Call icon buttons
   ==================================================================== */
.rpnm-footer-icons {
	display: flex; gap: 10px; margin: 14px 0;
}
.rpnm-footer-icon-btn {
	width: 44px; height: 44px; border-radius: 10px;
	display: flex; align-items: center; justify-content: center;
	color: #fff; transition: transform .15s, box-shadow .15s;
}
.rpnm-footer-icon-btn:hover { transform: translateY(-3px); color: #fff; box-shadow: var(--shadow-lg); }
.rpnm-footer-icon-wa { background: #25D366; }
.rpnm-footer-icon-call { background: var(--green); color: var(--navy); }
.rpnm-footer-icon-call:hover { color: var(--navy); }

/* Product hero CTA buttons */
.rpnm-product-hero-cta {
	display: flex; gap: 12px; flex-wrap: wrap; margin-top: 22px;
}

/* ====================================================================
   GLOBAL — kill parent-theme pink (#c36) button hover everywhere
   ==================================================================== */
.rpnm-header button:hover, .rpnm-header button:focus,
.rpnm-footer button:hover, .rpnm-footer button:focus,
.rpnm-section button:hover, .rpnm-section button:focus,
.rpnm-final-cta button:hover, .rpnm-final-cta button:focus,
.rpnm-popup button:hover, .rpnm-popup button:focus,
.rpnm-page-hero button:hover, .rpnm-page-hero button:focus,
.rpnm-product-hero button:hover, .rpnm-product-hero button:focus,
.rpnm-cat-hero button:hover, .rpnm-cat-hero button:focus {
	background-color: inherit;
}
/* Re-assert correct hover backgrounds (these win over the line above) */
.rpnm-open-pricing.rpnm-btn-green:hover { background: var(--green-darker) !important; }
.rpnm-open-pricing.rpnm-btn-navy:hover { background: var(--navy-3) !important; }
.rpnm-open-pricing.rpnm-btn-outline:hover { background: var(--light) !important; }
.rpnm-open-pricing.rpnm-btn-mini:hover { background: var(--light) !important; }
button.rpnm-faq-q:hover { background: var(--light) !important; }
.rpnm-faq-item.is-open button.rpnm-faq-q:hover { background: var(--navy-3) !important; }

/* ===== WHAT SETS APART — BlowBeast (separate, no conflict) ===== */
.rpnm-apart-section {
	padding: 80px 0;
	background: #0f1c2e;
}
.rpnm-apart-head {
	max-width: 720px;
	margin: 0 auto 50px;
	text-align: center;
}
.rpnm-apart-title {
	font-size: 34px;
	font-weight: 800;
	color: #fff;
	margin: 0 0 18px;
	line-height: 1.25;
}
.rpnm-apart-title::after {
	content: "";
	display: block;
	width: 60px; height: 4px;
	background: #c8102e;
	border-radius: 4px;
	margin: 16px auto 0;
}
.rpnm-apart-intro {
	font-size: 15.5px;
	line-height: 1.75;
	color: #b6c2d2;
	margin: 0;
}
.rpnm-apart-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	counter-reset: rpnm-apart-num;
}
.rpnm-apart-card {
	position: relative;
	background: linear-gradient(160deg, #1b2c42 0%, #16263a 100%);
	border: 1px solid rgba(255,255,255,.08);
	border-radius: 14px;
	padding: 40px 26px 30px;
	transition: transform .3s ease, border-color .3s ease;
}
.rpnm-apart-card::before {
	counter-increment: rpnm-apart-num;
	content: "0" counter(rpnm-apart-num);
	position: absolute;
	top: 22px; right: 24px;
	font-size: 34px;
	font-weight: 800;
	color: rgba(200,16,46,.35);
	line-height: 1;
}
.rpnm-apart-card:hover {
	transform: translateY(-6px);
	border-color: rgba(200,16,46,.6);
}
.rpnm-apart-card-title {
	font-size: 18px;
	font-weight: 800;
	color: #fff;
	margin: 0 0 14px;
	padding-bottom: 14px;
	border-bottom: 1px solid rgba(255,255,255,.1);
}
.rpnm-apart-card-desc {
	font-size: 14px;
	line-height: 1.7;
	color: #aab6c6;
	margin: 0;
}
@media (max-width: 860px) {
	.rpnm-apart-grid { grid-template-columns: 1fr; }
	.rpnm-apart-title { font-size: 27px; }
}
/* ===== IMAGE SHOWCASE — BrushBeast (separate, no conflict) ===== */
.rpnm-showcase-section {
	padding: 0;
	background: #000;
}
.rpnm-showcase-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 4px;
}
.rpnm-showcase-tile {
	position: relative;
	min-height: 400px;
	display: flex;
	align-items: center;
	justify-content: center;
	background-size: cover;
	background-position: center;
	overflow: hidden;
}
.rpnm-showcase-veil {
	position: absolute;
	inset: 0;
	
	transition: background .35s ease;
}

.rpnm-showcase-inner {
	position: relative;
	z-index: 2;
	text-align: center;
	padding: 44px 38px;
	max-width: 560px;
	transform: translateY(0);
	transition: transform .35s ease;
}
.rpnm-showcase-tile:hover .rpnm-showcase-inner {
	transform: translateY(-6px);
}
.rpnm-showcase-title {
	color: #fff;
	font-size: 27px;
	font-weight: 800;
	margin: 0 0 14px;
	line-height: 1.25;
}
.rpnm-showcase-title::after {
	content: "";
	display: block;
	width: 0; height: 3px;
	background: #fff;
	border-radius: 3px;
	margin: 12px auto 0;
	transition: width .35s ease;
}
.rpnm-showcase-tile:hover .rpnm-showcase-title::after {
	width: 54px;
}
.rpnm-showcase-desc {
	color: #dfe3e8;
	font-size: 14px;
	line-height: 1.7;
	margin: 0;
}
@media (max-width: 860px) {
	.rpnm-showcase-grid { grid-template-columns: 1fr; }
	.rpnm-showcase-tile { min-height: 320px; }
	.rpnm-showcase-title { font-size: 22px; }
}

/* Related products ke green badge hide */
.rpnm-related-card .rpnm-badge,
.rpnm-related-card .rpnm-product-badge,
.rpnm-related-card .rpnm-tag {
	display: none !important;
}
span.rpnm-product-badge {
    display: none;
}
button.rpnm-video-badge.rpnm-open-pricing:hover {
    background: #1e2a48;
    border: none;
    color: #fff;
}


/* ====================================================================
   ABOUT PAGE — Mission & Vision Cards
   ==================================================================== */
.rpnm-mv-grid {
	display: grid; grid-template-columns: 1fr 1fr; gap: 24px;
}
.rpnm-mv-card {
	position: relative; padding: 40px 36px; border-radius: 18px;
	box-shadow: var(--shadow-lg); overflow: hidden;
}
.rpnm-mv-mission {
	background: linear-gradient(135deg, #fff 0%, var(--off-white) 100%);
	border: 1px solid var(--border);
}
.rpnm-mv-vision {
	background: linear-gradient(135deg, var(--navy) 0%, var(--navy-3) 100%);
	color: #fff;
}
.rpnm-mv-icon {
	width: 64px; height: 64px; border-radius: 16px;
	display: inline-flex; align-items: center; justify-content: center;
	margin-bottom: 18px;
}
.rpnm-mv-mission .rpnm-mv-icon {
	background: linear-gradient(135deg, var(--green) 0%, var(--green-darker) 100%);
	color: #fff;
	box-shadow: 0 6px 18px rgba(122,193,67,.35);
}
.rpnm-mv-vision .rpnm-mv-icon {
	background: rgba(255,255,255,.12);
	color: var(--green);
}
.rpnm-mv-card h3 { font-size: 28px; margin-bottom: 12px; }
.rpnm-mv-vision h3 { color: #fff; }
.rpnm-mv-card p { font-size: 15.5px; line-height: 1.75; margin: 0; }
.rpnm-mv-mission p { color: var(--slate); }
.rpnm-mv-vision p { color: var(--silver); }

/* ====================================================================
   ABOUT PAGE — Contact Cards (WhatsApp / Email / Call)
   ==================================================================== */
.rpnm-contact-card-wa {
	background: linear-gradient(135deg, #25D366 0%, #128C7E 100%);
	border-color: #128C7E; display: block;
}
.rpnm-contact-card-wa h3,
.rpnm-contact-card-wa .rpnm-contact-line strong { color: #fff; }
.rpnm-contact-card-wa .rpnm-contact-line span { color: rgba(255,255,255,.88); }
.rpnm-contact-card-wa .rpnm-contact-link { color: #fff; font-weight: 800; }
.rpnm-contact-card-wa .rpnm-contact-ic { color: #fff; display: inline-flex; }
.rpnm-contact-card-wa .rpnm-contact-ic svg,
.rpnm-contact-card-wa .rpnm-contact-ic .rpnm-wa-svg {
	width: 22px; height: 22px;
}

/* Make whole contact card clickable on About page */
a.rpnm-contact-card { transition: transform .15s, box-shadow .15s; }
a.rpnm-contact-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }

/* Responsive */
@media (max-width: 1024px) {
	.rpnm-mv-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
	.rpnm-mv-card { padding: 30px 24px; }
	.rpnm-mv-card h3 { font-size: 22px; }
}