/* ══════════════════════════════════════════════════════════════════════════
   SHOWER CUBICLES ZIMBABWE — app.css
   Font: Play (Google Fonts) — loaded via <link> in layouts/main.php
   ══════════════════════════════════════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:           #f0fdf4;
  --surface:      #ffffff;
  --surface2:     #f8fffe;
  --surface3:     #f1faf3;
  --border:       #d1fae5;
  --border2:      #a7f3d0;
  --accent:       #16a34a;
  --accent2:      #22c55e;
  --accent3:      #4ade80;
  --accent-light: #dcfce7;
  --text:         #14532d;
  --text2:        #166534;
  --muted:        #6b7280;
  --muted2:       #9ca3af;
  --white:        #ffffff;
  --gray50:       #f9fafb;
  --gray100:      #f3f4f6;
  --gray200:      #e5e7eb;
  --gray300:      #d1d5db;
  --warn:         #d97706;
  --warn-light:   #fef3c7;
  --warn-border:  #fcd34d;
  --error:        #dc2626;
  --error-light:  #fee2e2;
  --error-border: #fca5a5;
  --info:         #0369a1;
  --info-light:   #e0f2fe;
  --info-border:  #7dd3fc;
  --green-dark:   #14532d;
  --orange:       #e76f2a;
  --r-sm:  6px;
  --r-md:  12px;
  --r-lg:  18px;
  --r-xl:  24px;
  --sh-sm:  0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  --sh-md:  0 4px 16px rgba(0,0,0,.07), 0 2px 6px rgba(0,0,0,.04);
  --sh-lg:  0 10px 36px rgba(0,0,0,.10), 0 4px 12px rgba(0,0,0,.05);
  --sh-grn: 0 6px 24px rgba(22,163,74,.22);
}

html { scroll-behavior: smooth; font-size: 16px; }
body { font-family: 'Play', Arial, sans-serif; font-weight: 400; color: var(--muted); background: var(--bg); overflow-x: hidden; line-height: 1.6; }
img { display: block; max-width: 100%; }
a   { text-decoration: none; color: inherit; }

/* ── Buttons ─────────────────────────────────────────────────────────────── */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:0.45rem; font-family:'Play',Arial,sans-serif; font-weight:700; border:none; cursor:pointer; transition:all 0.2s; border-radius:var(--r-md); text-decoration:none; white-space:nowrap; }
.btn-md  { padding:0.7rem 1.5rem;   font-size:0.875rem; }
.btn-lg  { padding:0.875rem 1.9rem; font-size:0.95rem; }
.btn-xl  { padding:1rem 2.2rem;     font-size:1rem; }
.btn-accent  { background:var(--accent); color:#fff; }
.btn-accent:hover  { background:var(--text); transform:translateY(-1px); box-shadow:var(--sh-grn); }
.btn-warn    { background:var(--orange); color:#fff; }
.btn-warn:hover    { background:#c85e1f; transform:translateY(-1px); }
.btn-outline { background:transparent; color:var(--accent); border:1.5px solid var(--accent2); }
.btn-outline:hover { background:var(--accent-light); }
.btn-white { background:var(--white); color:var(--text); }
.btn-white:hover { background:var(--accent-light); color:var(--accent); transform:translateY(-1px); }

.section    { padding:5rem 6%; }
.section-bg { background:var(--bg); }
.section-wh { background:var(--surface); }

.chip { display:inline-flex; align-items:center; gap:0.4rem; font-size:0.72rem; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; color:var(--accent); background:var(--accent-light); border:1px solid var(--border2); padding:0.3rem 0.8rem; border-radius:100px; margin-bottom:0.85rem; }
.chip-warn { color:var(--warn); background:var(--warn-light); border-color:var(--warn-border); }

.sec-title { font-size:clamp(1.75rem,2.8vw,2.6rem); font-weight:400; line-height:1.18; color:var(--text); }
.sec-title em { font-style:italic; color:var(--accent); }
.sec-sub { font-size:0.97rem; color:var(--muted); line-height:1.8; max-width:40rem; }
.sec-header { display:flex; justify-content:space-between; align-items:flex-end; gap:1rem; margin-bottom:2.25rem; flex-wrap:wrap; }
.link-more { display:inline-flex; align-items:center; gap:0.35rem; font-size:0.83rem; font-weight:700; color:var(--accent); white-space:nowrap; transition:gap 0.2s; }
.link-more::after { content:'→'; }
.link-more:hover { gap:0.6rem; }

/* ── Header ─────────────────────────────────────────────────────────────── */
.site-header { background:var(--green-dark); position:sticky; top:0; z-index:100; }
.header-top { background:rgba(0,0,0,.25); display:flex; justify-content:flex-end; align-items:center; gap:16px; padding:6px 6%; font-size:13px; }
.header-top a { color:rgba(255,255,255,.65); transition:color 0.2s; }
.header-top a:hover { color:#fff; }
.header-top .btn-wa-top { background:#25D366; color:#fff !important; padding:4px 14px; border-radius:20px; font-size:12px; font-weight:700; }
.header-main { display:flex; align-items:center; height:64px; padding:0 6%; gap:24px; }
.site-logo { font-size:17px; font-weight:700; color:#fff; white-space:nowrap; }
.site-nav { margin-left:auto; }
.site-nav > ul { display:flex; gap:2px; align-items:center; }
.site-nav > ul > li { position:relative; }
.site-nav a { color:rgba(255,255,255,.75); font-size:13.5px; font-weight:700; padding:8px 12px; border-radius:var(--r-md); display:block; transition:color 0.2s,background 0.2s; }
.site-nav a:hover { color:#fff; background:rgba(255,255,255,.08); }
.site-nav .nav-sale { color:#fbbf24; }
.has-dropdown .dropdown { display:none; position:absolute; top:100%; left:0; background:var(--green-dark); border-radius:var(--r-md); min-width:200px; padding:8px 0; box-shadow:var(--sh-lg); z-index:200; border:1px solid rgba(255,255,255,.1); }
.has-dropdown:hover .dropdown { display:block; }
.dropdown li a { padding:8px 16px; font-size:13px; }
.nav-cta { background:var(--accent) !important; color:#fff !important; padding:8px 18px !important; border-radius:var(--r-md); font-size:13.5px !important; margin-left:8px; }
.nav-cta:hover { background:var(--text) !important; }
.nav-toggle { display:none; flex-direction:column; gap:5px; padding:8px; margin-left:auto; }
.nav-toggle span { display:block; width:22px; height:2px; background:#fff; border-radius:2px; }

/* ── Hero ────────────────────────────────────────────────────────────────── */
.hero { background:var(--green-dark); position:relative; overflow:hidden; }
.hero::before { content:''; position:absolute; inset:0; pointer-events:none; background:radial-gradient(ellipse 55% 70% at 25% 55%,rgba(34,197,94,.14) 0%,transparent 65%),radial-gradient(ellipse 40% 50% at 75% 30%,rgba(74,222,128,.07) 0%,transparent 60%); }
.hero-inner { display:grid; grid-template-columns:1fr 1fr; min-height:92vh; position:relative; z-index:1; }
.hero-copy { display:flex; flex-direction:column; justify-content:center; padding:5rem 3.5rem 5rem 6%; }
.hero-badge { display:inline-flex; align-items:center; gap:0.5rem; background:rgba(74,222,128,.12); border:1px solid rgba(74,222,128,.28); border-radius:100px; padding:0.38rem 1rem; font-size:0.72rem; font-weight:700; color:var(--accent3); letter-spacing:0.07em; text-transform:uppercase; width:fit-content; margin-bottom:1.5rem; }
.hero-dot { width:6px; height:6px; border-radius:50%; background:var(--accent3); animation:blink 2s ease-in-out infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.3} }
.hero-h1 { font-size:clamp(2.4rem,4vw,4rem); font-weight:400; line-height:1.08; color:var(--white); margin-bottom:1.25rem; }
.hero-h1 em { font-style:italic; color:var(--accent3); }
.hero-desc { font-size:1rem; color:rgba(255,255,255,.62); line-height:1.82; max-width:30rem; margin-bottom:2.25rem; }
.hero-ctas { display:flex; gap:0.75rem; flex-wrap:wrap; }
.hero-pills { margin-top:2.5rem; padding-top:2rem; border-top:1px solid rgba(255,255,255,.1); display:grid; grid-template-columns:1fr 1fr; gap:0.65rem; }
.hero-pill { display:flex; align-items:center; gap:0.6rem; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.11); border-radius:var(--r-lg); padding:0.7rem 1rem; transition:background 0.2s,border-color 0.2s; }
.hero-pill:hover { background:rgba(74,222,128,.1); border-color:rgba(74,222,128,.28); }
.pill-icon { width:34px; height:34px; border-radius:50%; background:rgba(34,197,94,.18); display:flex; align-items:center; justify-content:center; font-size:0.95rem; flex-shrink:0; }
.pill-num { font-size:1.1rem; font-weight:700; color:var(--white); display:block; }
.pill-lbl { font-size:0.67rem; color:rgba(255,255,255,.48); display:block; }
.hero-mosaic { display:grid; grid-template-columns:1fr 1fr; grid-template-rows:60% 40%; gap:3px; background:rgba(0,0,0,.3); }
.mosaic-cell { overflow:hidden; position:relative; background:#1a3a2a; }
.mosaic-cell img { width:100%; height:100%; object-fit:cover; transition:transform 0.7s; }
.mosaic-cell:hover img { transform:scale(1.05); }
.mosaic-cell.wide { grid-column:1/3; }
.mosaic-lbl { position:absolute; bottom:0.65rem; left:0.65rem; background:rgba(20,83,45,.82); backdrop-filter:blur(6px); color:rgba(255,255,255,.9); font-size:0.68rem; font-weight:700; padding:0.28rem 0.65rem; border-radius:var(--r-sm); border:1px solid rgba(74,222,128,.25); }

/* ── Trust strip ─────────────────────────────────────────────────────────── */
.trust-strip { background:var(--surface); border-bottom:1px solid var(--border); display:flex; flex-wrap:wrap; justify-content:center; }
.trust-item { display:flex; align-items:center; gap:0.55rem; padding:1.1rem 1.8rem; font-size:0.82rem; font-weight:700; color:var(--text2); border-right:1px solid var(--border); }
.trust-item:last-child { border-right:none; }
.trust-ico { width:26px; height:26px; border-radius:50%; background:var(--accent-light); color:var(--accent); display:flex; align-items:center; justify-content:center; font-size:0.75rem; flex-shrink:0; }

/* ── Stats ───────────────────────────────────────────────────────────────── */
.stats-row { background:var(--accent); display:grid; grid-template-columns:repeat(4,1fr); }
.stat-cell { display:flex; flex-direction:column; align-items:center; padding:2.25rem 1rem; border-right:1px solid rgba(255,255,255,.14); text-align:center; }
.stat-cell:last-child { border-right:none; }
.stat-icon { width:44px; height:44px; border-radius:50%; background:rgba(255,255,255,.15); display:flex; align-items:center; justify-content:center; font-size:1.1rem; margin-bottom:0.8rem; }
.stat-num { font-size:2.6rem; font-weight:700; color:var(--white); line-height:1; margin-bottom:0.28rem; }
.stat-num sup { font-size:1.1rem; vertical-align:super; }
.stat-lbl { font-size:0.78rem; color:rgba(255,255,255,.62); line-height:1.4; }

/* ── Category grid ───────────────────────────────────────────────────────── */
.cat-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:1rem; }
.cat-card { background:var(--surface); border:1.5px solid var(--border); border-radius:var(--r-xl); overflow:hidden; display:block; box-shadow:var(--sh-sm); transition:all 0.25s; }
.cat-card:hover { transform:translateY(-5px); box-shadow:var(--sh-lg); border-color:var(--border2); }
.cat-img { width:100%; aspect-ratio:4/3; overflow:hidden; background:var(--gray100); }
.cat-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s; }
.cat-card:hover .cat-img img { transform:scale(1.07); }
.cat-body { padding:0.9rem 1rem 1.1rem; }
.cat-name { font-size:0.85rem; font-weight:700; color:var(--text); margin-bottom:0.18rem; }
.cat-sub  { font-size:0.73rem; color:var(--muted2); margin-bottom:0.65rem; }
.cat-cta  { font-size:0.74rem; font-weight:700; color:var(--accent); display:flex; align-items:center; gap:0.28rem; transition:gap 0.2s; }
.cat-cta::after { content:'→'; }
.cat-card:hover .cat-cta { gap:0.5rem; }

/* ── Product grid ────────────────────────────────────────────────────────── */
.prod-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.1rem; }
.prod-card { background:var(--surface); border:1.5px solid var(--border); border-radius:var(--r-xl); overflow:hidden; display:flex; flex-direction:column; box-shadow:var(--sh-sm); transition:all 0.25s; }
.prod-card:hover { transform:translateY(-4px); box-shadow:var(--sh-lg); border-color:var(--border2); }
.prod-img { aspect-ratio:1; overflow:hidden; background:var(--gray50); position:relative; }
.prod-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s; }
.prod-card:hover .prod-img img { transform:scale(1.06); }
.prod-badge { position:absolute; top:0.7rem; left:0.7rem; font-size:0.62rem; font-weight:700; letter-spacing:0.05em; text-transform:uppercase; padding:0.25rem 0.6rem; border-radius:100px; }
.badge-g { background:var(--accent); color:#fff; }
.badge-o { background:var(--orange); color:#fff; }
.badge-l { background:var(--accent-light); color:var(--text); border:1px solid var(--border2); }
.prod-stars { position:absolute; bottom:0.65rem; right:0.65rem; background:rgba(255,255,255,.9); backdrop-filter:blur(4px); border-radius:100px; padding:0.2rem 0.55rem; font-size:0.7rem; font-weight:700; color:var(--text); display:flex; align-items:center; gap:0.2rem; }
.star { color:#f59e0b; }
.prod-body { padding:0.9rem 1rem 1rem; flex:1; display:flex; flex-direction:column; }
.prod-name { font-size:0.85rem; font-weight:700; color:var(--text); line-height:1.35; flex:1; margin-bottom:0.2rem; }
.prod-size { font-size:0.72rem; color:var(--muted2); margin-bottom:0.7rem; }
.prod-foot { display:flex; align-items:center; justify-content:space-between; padding-top:0.65rem; border-top:1px solid var(--gray200); margin-top:auto; }
.prod-price { font-size:0.98rem; font-weight:700; color:var(--text); }
.prod-price del { font-size:0.76rem; font-weight:400; color:var(--gray300); margin-right:0.25rem; }
.prod-add { width:30px; height:30px; border-radius:50%; background:var(--accent); color:#fff; border:none; cursor:pointer; font-size:1.1rem; display:flex; align-items:center; justify-content:center; transition:all 0.2s; flex-shrink:0; }
.prod-add:hover { background:var(--text); transform:scale(1.1); }

/* ── How steps ───────────────────────────────────────────────────────────── */
.how-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:0; position:relative; }
.how-grid::before { content:''; position:absolute; top:2.75rem; left:calc(12.5% + 1.5rem); right:calc(12.5% + 1.5rem); height:2px; background:linear-gradient(to right,var(--border2),var(--accent2),var(--border2)); z-index:0; }
.how-step { display:flex; flex-direction:column; align-items:center; text-align:center; padding:0 1.5rem 1rem; position:relative; z-index:1; }
.how-num-wrap { position:relative; margin-bottom:1.25rem; }
.how-num { width:56px; height:56px; border-radius:50%; background:var(--accent); color:white; display:flex; align-items:center; justify-content:center; font-size:1.4rem; font-weight:700; box-shadow:0 0 0 6px var(--accent-light),0 0 0 8px var(--border2); }
.how-icon { position:absolute; bottom:-6px; right:-6px; width:22px; height:22px; border-radius:50%; background:var(--warn); color:white; display:flex; align-items:center; justify-content:center; font-size:0.65rem; border:2px solid var(--white); }
.how-title { font-size:0.95rem; font-weight:700; color:var(--text); margin-bottom:0.4rem; }
.how-desc { font-size:0.81rem; color:var(--muted); line-height:1.7; }

/* ── Video section ───────────────────────────────────────────────────────── */
.video-wrap { display:grid; grid-template-columns:1fr 1fr; gap:3.5rem; align-items:center; }
.video-embed { position:relative; border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--sh-lg); background:#000; aspect-ratio:9/16; max-height:520px; }
.video-embed iframe { position:absolute; inset:0; width:100%; height:100%; border:none; }
.video-copy p { font-size:0.93rem; color:var(--muted); line-height:1.85; margin-top:0.75rem; margin-bottom:1.5rem; }
.video-proof-points { display:flex; flex-direction:column; gap:0.75rem; margin-bottom:1.75rem; }
.vpp { display:flex; align-items:flex-start; gap:0.85rem; padding:0.85rem 1rem; background:var(--surface); border:1.5px solid var(--border); border-radius:var(--r-md); }
.vpp-ico { width:32px; height:32px; flex-shrink:0; background:var(--accent-light); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:0.85rem; }
.vpp-title { font-size:0.85rem; font-weight:700; color:var(--text); margin-bottom:0.1rem; }
.vpp-desc  { font-size:0.78rem; color:var(--muted); line-height:1.6; }

/* ── Why section ─────────────────────────────────────────────────────────── */
.why-layout { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
.why-reasons { display:flex; flex-direction:column; }
.why-reason { display:flex; gap:1.1rem; align-items:flex-start; padding:1.25rem 0; border-bottom:1px solid var(--border); }
.why-reason:last-child { border-bottom:none; }
.why-reason-ico { width:44px; height:44px; flex-shrink:0; border-radius:var(--r-md); background:var(--accent-light); border:1px solid var(--border2); display:flex; align-items:center; justify-content:center; font-size:1.1rem; margin-top:0.1rem; }
.why-reason-title { font-size:0.92rem; font-weight:700; color:var(--text); margin-bottom:0.25rem; }
.why-reason-desc { font-size:0.82rem; color:var(--muted); line-height:1.7; }
.why-img-col { position:relative; }
.why-img-col img { width:100%; border-radius:var(--r-xl); object-fit:cover; aspect-ratio:3/4; box-shadow:var(--sh-lg); }
.why-img-float { position:absolute; top:1.5rem; right:-1rem; background:var(--accent); color:white; border-radius:var(--r-lg); padding:1rem 1.25rem; box-shadow:var(--sh-lg); text-align:center; min-width:110px; }
.why-float-num { font-size:2rem; font-weight:700; line-height:1; color:white; }
.why-float-lbl { font-size:0.68rem; color:rgba(255,255,255,.75); margin-top:0.2rem; line-height:1.3; }

/* ── Pricing ─────────────────────────────────────────────────────────────── */
.price-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; }
.price-card { background:var(--surface); border:1.5px solid var(--border); border-radius:var(--r-xl); padding:1.5rem 1.25rem 1.75rem; display:flex; flex-direction:column; box-shadow:var(--sh-sm); transition:all 0.25s; position:relative; overflow:hidden; }
.price-card:hover { transform:translateY(-4px); box-shadow:var(--sh-lg); border-color:var(--border2); }
.price-card.featured { border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-light),var(--sh-md); }
.price-popular { position:absolute; top:0; right:0; background:var(--accent); color:white; font-size:0.62rem; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; padding:0.3rem 0.85rem; border-bottom-left-radius:var(--r-md); }
.price-category { font-size:0.7rem; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; color:var(--accent); margin-bottom:0.6rem; }
.price-card-title { font-size:1.08rem; font-weight:700; color:var(--text); margin-bottom:0.9rem; line-height:1.3; }
.price-from { font-size:0.72rem; color:var(--muted2); margin-bottom:0.2rem; }
.price-amount { font-size:2rem; font-weight:700; color:var(--text); line-height:1; margin-bottom:1rem; }
.price-amount span { font-size:0.85rem; font-weight:400; color:var(--muted); }
.price-features { list-style:none; flex:1; display:flex; flex-direction:column; gap:0.45rem; margin-bottom:1.25rem; }
.price-features li { font-size:0.79rem; color:var(--muted); display:flex; align-items:flex-start; gap:0.5rem; line-height:1.5; }
.price-features li::before { content:'✓'; color:var(--accent); font-size:0.72rem; font-weight:700; flex-shrink:0; margin-top:0.15rem; }
.price-cta { display:block; text-align:center; padding:0.65rem; border-radius:var(--r-md); font-size:0.82rem; font-weight:700; background:var(--accent-light); color:var(--text); border:1px solid var(--border2); transition:all 0.2s; }
.price-cta:hover { background:var(--accent); color:white; }
.price-card.featured .price-cta { background:var(--accent); color:white; }

/* ── Testimonials ────────────────────────────────────────────────────────── */
.test-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.1rem; }
.test-card { background:var(--surface); border:1.5px solid var(--border); border-radius:var(--r-xl); padding:1.6rem; box-shadow:var(--sh-sm); transition:all 0.25s; position:relative; }
.test-card:hover { transform:translateY(-3px); box-shadow:var(--sh-md); border-color:var(--border2); }
.test-card::before { content:'"'; position:absolute; top:1rem; right:1.25rem; font-size:4rem; color:var(--border2); line-height:1; pointer-events:none; }
.test-stars { color:#f59e0b; font-size:0.85rem; letter-spacing:0.05em; margin-bottom:0.9rem; }
.test-text  { font-size:0.88rem; color:var(--muted); line-height:1.8; margin-bottom:1.2rem; }
.test-auth  { display:flex; align-items:center; gap:0.7rem; }
.test-av    { width:36px; height:36px; border-radius:50%; background:var(--accent); color:#fff; display:flex; align-items:center; justify-content:center; font-size:0.72rem; font-weight:700; flex-shrink:0; }
.test-name { font-size:0.84rem; font-weight:700; color:var(--text); }
.test-loc  { font-size:0.72rem; color:var(--muted2); }

/* ── Blog ────────────────────────────────────────────────────────────────── */
.blog-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.1rem; }
.blog-card { background:var(--surface); border:1.5px solid var(--border); border-radius:var(--r-xl); overflow:hidden; display:flex; flex-direction:column; box-shadow:var(--sh-sm); transition:all 0.25s; }
.blog-card:hover { transform:translateY(-4px); box-shadow:var(--sh-lg); border-color:var(--border2); }
.blog-img { aspect-ratio:4/3; overflow:hidden; background:var(--gray100); }
.blog-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s; }
.blog-card:hover .blog-img img { transform:scale(1.06); }
.blog-body { padding:1rem; flex:1; display:flex; flex-direction:column; }
.blog-date  { font-size:0.7rem; color:var(--muted2); margin-bottom:0.45rem; }
.blog-title { font-size:0.86rem; font-weight:700; color:var(--text); line-height:1.45; flex:1; margin-bottom:0.75rem; }
.blog-link  { font-size:0.77rem; font-weight:700; color:var(--accent); display:flex; align-items:center; gap:0.3rem; margin-top:auto; transition:gap 0.2s; }
.blog-link::after { content:'→'; }
.blog-card:hover .blog-link { gap:0.55rem; }

/* ── Flash banner ────────────────────────────────────────────────────────── */
.flash-banner { background:linear-gradient(135deg,var(--warn) 0%,#f59e0b 100%); padding:2rem 6%; display:flex; align-items:center; justify-content:space-between; gap:1.5rem; flex-wrap:wrap; }
.flash-left { display:flex; align-items:center; gap:1.25rem; }
.flash-icon { font-size:2.2rem; flex-shrink:0; display:inline-block; }
.flash-eyebrow { font-size:0.68rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:rgba(255,255,255,.75); margin-bottom:0.15rem; }
.flash-title { font-size:1.4rem; font-weight:700; color:white; line-height:1.2; }
.flash-sub { font-size:0.82rem; color:rgba(255,255,255,.8); margin-top:0.2rem; }
.btn-flash { background:white; color:var(--warn); font-weight:700; border-radius:var(--r-md); padding:0.85rem 2rem; font-size:0.9rem; white-space:nowrap; flex-shrink:0; transition:all 0.2s; border:none; cursor:pointer; text-decoration:none; display:inline-flex; align-items:center; gap:0.4rem; }
.btn-flash:hover { background:var(--warn-light); transform:scale(1.02); }

/* ── FAQ ─────────────────────────────────────────────────────────────────── */
.faq-grid { display:grid; grid-template-columns:1fr 1fr; gap:0.75rem; }
.faq-item { background:var(--surface); border:1.5px solid var(--border); border-radius:var(--r-lg); overflow:hidden; transition:border-color 0.2s,box-shadow 0.2s; }
.faq-item.open { border-color:var(--border2); box-shadow:var(--sh-sm); }
.faq-q { width:100%; background:none; border:none; padding:1.1rem 1.25rem; display:flex; align-items:center; justify-content:space-between; gap:1rem; cursor:pointer; font-size:0.87rem; font-weight:700; color:var(--text); text-align:left; transition:background 0.2s; font-family:'Play',Arial,sans-serif; }
.faq-q:hover { background:var(--bg); }
.faq-item.open .faq-q { background:var(--accent-light); }
.faq-chevron { width:20px; height:20px; flex-shrink:0; border-radius:50%; background:var(--accent-light); color:var(--accent); display:flex; align-items:center; justify-content:center; font-size:0.65rem; transition:transform 0.3s,background 0.2s; }
.faq-item.open .faq-chevron { transform:rotate(180deg); background:var(--accent); color:white; }
.faq-a { max-height:0; overflow:hidden; transition:max-height 0.35s ease,padding 0.2s; font-size:0.84rem; color:var(--muted); line-height:1.75; padding:0 1.25rem; }
.faq-item.open .faq-a { max-height:200px; padding:0 1.25rem 1.1rem; }

/* ── Contact & payment strips ────────────────────────────────────────────── */
.contact-strip { background:var(--surface); border-top:1px solid var(--border); border-bottom:1px solid var(--border); padding:2.5rem 6%; display:grid; grid-template-columns:1fr 1fr 1fr; }
.contact-cell { display:flex; align-items:center; gap:1rem; padding:0.5rem 2rem; border-right:1px solid var(--border); }
.contact-cell:first-child { padding-left:0; }
.contact-cell:last-child { border-right:none; }
.contact-ico { width:48px; height:48px; flex-shrink:0; border-radius:var(--r-md); background:var(--accent-light); border:1px solid var(--border2); display:flex; align-items:center; justify-content:center; font-size:1.2rem; }
.contact-lbl { font-size:0.7rem; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; color:var(--muted2); margin-bottom:0.2rem; }
.contact-val { font-size:0.92rem; font-weight:700; color:var(--text); transition:color 0.2s; }
.contact-cell:hover .contact-val { color:var(--accent); }
.payment-strip { background:var(--surface3); border-top:1px solid var(--border); border-bottom:1px solid var(--border); padding:1.5rem 6%; display:flex; align-items:center; gap:1.5rem; flex-wrap:wrap; }
.payment-label { font-size:0.75rem; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; color:var(--text2); flex-shrink:0; white-space:nowrap; }
.payment-methods { display:flex; flex-wrap:wrap; gap:0.5rem; flex:1; }
.pay-chip { display:flex; align-items:center; gap:0.4rem; background:var(--white); border:1.5px solid var(--border2); border-radius:100px; padding:0.32rem 0.85rem; font-size:0.78rem; font-weight:700; color:var(--text); white-space:nowrap; }

/* ── CTA section ─────────────────────────────────────────────────────────── */
.cta-section { background:linear-gradient(135deg,#0a2e1a 0%,#14532d 40%,#1a5c35 70%,#0d3d22 100%); padding:5.5rem 6%; position:relative; overflow:hidden; }
.cta-bg-orb { position:absolute; border-radius:50%; pointer-events:none; }
.cta-orb1 { width:500px;height:500px;top:-200px;right:-100px;background:radial-gradient(circle,rgba(34,197,94,.12) 0%,transparent 70%); }
.cta-orb2 { width:350px;height:350px;bottom:-150px;left:5%;background:radial-gradient(circle,rgba(74,222,128,.08) 0%,transparent 70%); }
.cta-inner { position:relative; z-index:1; display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
.cta-title { font-size:clamp(1.9rem,3.2vw,2.9rem); font-weight:400; color:var(--white); line-height:1.2; margin-bottom:0.75rem; }
.cta-title em { font-style:italic; color:var(--accent3); }
.cta-sub { font-size:0.97rem; color:rgba(255,255,255,.6); max-width:34rem; line-height:1.85; margin-bottom:1.5rem; }
.cta-features { list-style:none; display:flex; flex-direction:column; gap:0.7rem; }
.cta-features li { display:flex; align-items:flex-start; gap:0.75rem; font-size:0.88rem; color:rgba(255,255,255,.72); line-height:1.5; }
.cta-feat-ico { font-size:1rem; flex-shrink:0; margin-top:0.05rem; }
.cta-btns { display:flex; gap:0.85rem; flex-wrap:wrap; margin-top:2rem; }

/* ── Footer ─────────────────────────────────────────────────────────────── */
.site-footer { background:var(--green-dark); color:rgba(255,255,255,.65); padding:64px 6% 0; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:40px; }
.footer-brand { color:#fff; font-size:18px; font-weight:700; display:block; margin-bottom:12px; }
.footer-col h4 { color:#fff; font-size:13px; font-weight:700; margin-bottom:14px; text-transform:uppercase; letter-spacing:1px; }
.footer-col p  { font-size:13px; margin-bottom:8px; }
.footer-col a  { color:rgba(255,255,255,.65); transition:color 0.2s; }
.footer-col a:hover { color:#fff; }
.footer-col ul li { margin-bottom:8px; font-size:13px; }
.hours-table { font-size:13px; border-collapse:collapse; }
.hours-table td { padding:4px 12px 4px 0; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.12); margin-top:48px; padding:20px 0; }
.footer-bottom-inner { display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; font-size:13px; color:rgba(255,255,255,.4); }
.footer-links a { color:rgba(255,255,255,.4); margin-left:4px; }
.footer-links a:hover { color:#fff; }
.btn-wa-footer { display:inline-flex; align-items:center; gap:8px; background:#25D366; color:#fff; padding:10px 20px; border-radius:var(--r-md); font-weight:700; margin-top:12px; font-size:14px; transition:background 0.2s; }
.btn-wa-footer:hover { background:#1da851; color:#fff; }

/* ── Mobile sticky ───────────────────────────────────────────────────────── */
.mobile-sticky-cta { display:none; position:fixed; bottom:0; left:0; right:0; z-index:500; background:var(--surface); border-top:1.5px solid var(--border); padding:0.75rem 1.25rem; box-shadow:0 -4px 20px rgba(0,0,0,.1); gap:0.6rem; align-items:center; }
.mobile-sticky-cta a { flex:1; text-align:center; padding:0.8rem 1rem; border-radius:var(--r-md); font-size:0.88rem; font-weight:700; text-decoration:none; transition:all 0.2s; }
.sticky-quote { background:var(--accent); color:white; }
.sticky-wa { background:#25d366; color:white; flex:0 0 auto; width:46px; height:46px; border-radius:50%; padding:0; display:flex; align-items:center; justify-content:center; }
.sticky-wa svg { width:22px; height:22px; fill:white; }

/* ── Animations ──────────────────────────────────────────────────────────── */
@keyframes fadeUp { from{opacity:0;transform:translateY(18px)} to{opacity:1;transform:translateY(0)} }
.hero-badge { animation:fadeUp .55s .05s both; }
.hero-h1    { animation:fadeUp .55s .18s both; }
.hero-desc  { animation:fadeUp .55s .30s both; }
.hero-ctas  { animation:fadeUp .55s .40s both; }
.hero-pills { animation:fadeUp .55s .52s both; }

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width:1024px) {
  .cat-grid    { grid-template-columns:repeat(3,1fr); }
  .prod-grid   { grid-template-columns:repeat(3,1fr); }
  .footer-grid { grid-template-columns:repeat(2,1fr); }
  .why-layout  { grid-template-columns:1fr; }
  .why-img-col { order:-1; }
  .why-img-col img { aspect-ratio:16/9; }
  .why-img-float { top:1rem; right:1rem; }
  .cta-inner   { grid-template-columns:1fr; }
  .video-wrap  { grid-template-columns:1fr; }
}
@media (max-width:900px) {
  .hero-inner  { grid-template-columns:1fr; min-height:auto; }
  .hero-copy   { padding:3.5rem 5% 2.5rem; order:1; }
  .hero-mosaic { order:2; height:60vw; min-height:260px; max-height:400px; }
  .how-grid    { grid-template-columns:repeat(2,1fr); gap:1.5rem 0.5rem; }
  .how-grid::before { display:none; }
  .price-grid  { grid-template-columns:repeat(2,1fr); }
  .test-grid   { grid-template-columns:1fr; }
  .blog-grid   { grid-template-columns:repeat(2,1fr); }
  .faq-grid    { grid-template-columns:1fr; }
  .contact-strip { grid-template-columns:1fr; }
  .contact-cell  { border-right:none; padding:0.5rem 0; border-bottom:1px solid var(--border); }
  .contact-cell:last-child { border-bottom:none; }
}
@media (max-width:768px) {
  .site-nav,.nav-cta { display:none; }
  .nav-toggle { display:flex; }
  .site-nav.open { display:block; position:absolute; top:64px; left:0; right:0; background:var(--green-dark); padding:12px 0 20px; border-top:1px solid rgba(255,255,255,.1); }
  .site-nav.open > ul { flex-direction:column; }
  .has-dropdown .dropdown { display:none !important; }
  .cat-grid,.prod-grid { grid-template-columns:repeat(2,1fr); }
  .stats-row { grid-template-columns:1fr 1fr; }
  .stat-cell:nth-child(2) { border-right:none; }
  .mobile-sticky-cta { display:flex; }
  body { padding-bottom:76px; }
}
@media (max-width:480px) {
  .cat-grid,.prod-grid,.blog-grid,.price-grid { grid-template-columns:1fr; }
  .section { padding:3.5rem 5%; }
  .hero-pills { grid-template-columns:1fr; }
}
