/* OCD Rebuild — Components. v2 (2026-06-06).
   Replaces v1 (725-line dark-theme bundle). New system: white surfaces, cyan accent,
   Inter typeface, layout-broken grids. Loaded after tokens.css.
   Source: rebuild/preview-2026-06-06.html (approved 2026-06-06).
*/

/* ---------- reset + base ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html,body{font-family:var(--font-body);font-size:var(--fs-base);color:var(--ink);background:var(--paper);line-height:1.55;-webkit-font-smoothing:antialiased}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 clamp(1rem,3vw,2rem)}
img{max-width:100%;display:block}
a{color:var(--cyan-deep);text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none}

.skip{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip:focus{position:fixed;left:1rem;top:1rem;width:auto;height:auto;background:var(--ink);color:var(--paper);padding:.6rem 1rem;border-radius:var(--r);z-index:100}

/* ---------- NAV ---------- */
.nav{background:var(--ink);border-bottom:1px solid var(--ink);position:sticky;top:0;z-index:50;transition:transform .28s cubic-bezier(.4,0,.2,1);will-change:transform}
.nav.nav-hidden{transform:translateY(-100%)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:80px;gap:2rem}
.nav .logo img{height:60px;width:auto;max-width:none}
.burger{display:none;background:transparent;border:0}
/* mega panel — show on hover/focus (desktop) OR when JS sets aria-expanded (touch) */
.has-mega > button[aria-expanded="true"] + .mega{display:grid}
.nav-links{display:flex;align-items:center;gap:2rem;font-weight:500}
.nav-links a, .nav-links button{color:#FFFFFF;font-size:var(--fs-sm);position:relative;padding:.4rem 0;transition:color var(--t-hover) var(--ease-out)}
.nav-links a:hover, .nav-links button:hover{color:var(--cyan)}
.nav-cta{background:var(--cyan);color:var(--ink) !important;padding:.7rem 1.3rem !important;border-radius:var(--r);font-weight:700 !important;font-size:var(--fs-sm)}
.nav-cta:hover{background:var(--cyan-soft);color:var(--ink) !important}
.has-mega{position:relative}
.mega{display:none;position:absolute;left:50%;transform:translateX(-50%);top:100%;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);width:min(820px,90vw);padding:1.6rem;margin-top:.5rem;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.has-mega:hover .mega, .has-mega:focus-within .mega{display:grid}
.mega-col h4{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--cyan-deep);font-weight:700;margin-bottom:.7rem}
.mega-col a{display:block;padding:.35rem 0;color:var(--ink);font-size:var(--fs-sm);font-weight:500}
.mega-col a:hover{color:var(--cyan-deep)}
.mega-col .hub-link{margin-top:.7rem;padding-top:.7rem;border-top:1px solid var(--line);font-weight:700;color:var(--cyan-deep);font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.04em}
.burger{display:none}

/* ---------- HERO ---------- */
.hero{background:var(--paper);padding:clamp(2.4rem,5vw,4rem) 0 clamp(2rem,4vw,3.4rem)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,4vw,3.5rem);align-items:start}
.hero-left .eyebrow{display:inline-flex;align-items:center;gap:.4rem;background:var(--cyan-tint);color:var(--cyan-deep);font-size:var(--fs-xs);font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:.4rem .8rem;border-radius:var(--r-pill);margin-bottom:1rem}
.hero-left h1{font-size:var(--fs-display);font-weight:800;line-height:1.05;letter-spacing:-.02em;color:var(--ink);margin-bottom:1.1rem}
.hero-left h1 .accent{color:var(--cyan-deep)}
.hero-sub{font-size:var(--fs-md);color:var(--muted);max-width:540px;margin-bottom:1.8rem}
.award-block{margin-top:1.4rem}
.award-label{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:700;margin-bottom:.8rem}
.award-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;align-items:center}
.award-row img{height:96px;width:auto;object-fit:contain;max-width:100%}
.hero-stats{display:flex;gap:1.6rem;margin-top:1.6rem;padding-top:1.4rem;border-top:1px solid var(--line);font-size:var(--fs-sm)}
.hero-stats .stat strong{display:block;font-size:var(--fs-xl);font-weight:800;color:var(--cyan-deep);letter-spacing:-.01em;line-height:1.1}
.hero-stats .stat span{color:var(--muted);font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.06em;margin-top:.2rem;display:block}

.hero-right{background:var(--band);border:1px solid var(--line);border-radius:var(--r-xl);padding:clamp(1.4rem,2.2vw,2rem);box-shadow:var(--shadow)}
.hero-right .form-eyebrow{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--cyan-deep);font-weight:700;margin-bottom:.5rem}
.hero-right h2{font-size:var(--fs-xl);font-weight:800;color:var(--ink);line-height:1.2;margin-bottom:.5rem;letter-spacing:-.01em}
.hero-right .form-sub{font-size:var(--fs-sm);color:var(--muted);margin-bottom:1.4rem}
.pay-block{margin-bottom:1.4rem;padding-bottom:1.2rem;border-bottom:1px solid var(--line)}
.pay-label{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600;margin-bottom:.6rem}
.pay-row{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}
.pay-row img{height:32px;width:auto;object-fit:contain}
.pay-row img.pay-shopee{height:64px;position:relative;top:4px}
.pay-row img.pay-grab{height:24px;margin-left:-8px}
.form-grid{display:grid;gap:.8rem}
.form-grid label{display:block;font-size:var(--fs-xs);font-weight:600;color:var(--muted);margin-bottom:.3rem;text-transform:uppercase;letter-spacing:.05em}
.form-grid input, .form-grid select{width:100%;padding:.75rem .9rem;border:1px solid var(--line);border-radius:var(--r);background:var(--paper);font:inherit;font-size:var(--fs-sm);color:var(--ink);transition:border-color var(--t-hover) var(--ease-out)}
.form-grid input:focus, .form-grid select:focus{outline:none;border-color:var(--cyan-deep);box-shadow:0 0 0 3px var(--cyan-tint)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.btn-primary{background:var(--cyan);color:var(--ink);padding:1rem 1.4rem;border-radius:var(--r);font-weight:800;font-size:var(--fs-base);width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;letter-spacing:-.005em;transition:background var(--t-hover) var(--ease-out),transform var(--t-hover) var(--ease-out);text-decoration:none}
.btn-primary:hover{background:var(--cyan-soft);transform:translateY(-1px)}
.form-foot{font-size:var(--fs-xs);color:var(--muted);text-align:center;margin-top:.7rem}

/* ---------- GOOGLE REVIEW BADGE (under H1) ---------- */
.google-badge{display:inline-flex;align-items:center;gap:.55rem;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-pill);padding:.5rem .9rem;margin-bottom:1.4rem;box-shadow:var(--shadow-sm);text-decoration:none;transition:box-shadow var(--t-hover) var(--ease-out),transform var(--t-hover) var(--ease-out)}
.google-badge:hover{box-shadow:var(--shadow);transform:translateY(-1px)}
.google-badge .gb-g{width:20px;height:20px;flex-shrink:0}
.google-badge .gb-rating{font-weight:800;font-size:var(--fs-md);color:var(--ink);letter-spacing:-.01em}
.google-badge .gb-stars{display:inline-flex;gap:1px;color:var(--star)}
.google-badge .gb-stars svg{width:15px;height:15px;fill:currentColor}
.google-badge .gb-meta{font-size:var(--fs-xs);color:var(--muted);font-weight:600;border-left:1px solid var(--line);padding-left:.6rem;white-space:nowrap}
@media (max-width:480px){.google-badge{flex-wrap:nowrap;gap:.4rem;padding:.45rem .7rem}.google-badge .gb-rating{font-size:var(--fs-sm)}.google-badge .gb-stars svg{width:13px;height:13px}.google-badge .gb-meta{padding-left:.45rem;font-size:11px}}

/* ---------- HERO JOBS STAT (single big stat) ---------- */
.hero-stats-jobs{display:block}
.stat-jobs strong{font-size:var(--fs-2xl);color:var(--cyan-deep);font-weight:800;letter-spacing:-.02em;line-height:1;display:block}
.stat-jobs span{font-size:var(--fs-sm);color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600;margin-top:.3rem;display:block}

/* ---------- CERT LOGOS (NEA + BCA, replaces text on service pages) ---------- */
.cert-logos{display:inline-flex;align-items:center;gap:1.2rem;flex-wrap:wrap;margin-top:1.1rem}
.cert-logos .cert-logo{display:inline-flex;align-items:center}
.cert-logos img{height:38px;width:auto;object-fit:contain}
.cert-logos .cert-cap{font-size:var(--fs-xs);color:var(--muted);font-weight:600}

/* ---------- HERO CREDENTIAL LOGOS (bizSAFE / NEA / BCA, below hero content) ---------- */
.hero-creds{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;margin-top:1.6rem;padding-top:1.4rem;border-top:1px solid var(--line);flex-wrap:wrap}
.hero-creds img{height:clamp(50px,6.5vw,70px);width:auto;object-fit:contain}
@media (max-width:480px){.hero-creds{gap:1.2rem;justify-content:flex-start}.hero-creds img{height:44px}}

/* ---------- JOBS BAND (About — number left, credential logos right) ---------- */
.jobs-band{padding:clamp(1.8rem,3.5vw,2.8rem) 0;background:var(--band);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.jobs-band-grid{display:grid;grid-template-columns:1fr 1.45fr;gap:2rem;align-items:center}
.jobs-band-num strong{display:block;font-size:clamp(2.2rem,5vw,3.4rem);font-weight:800;color:var(--cyan-deep);letter-spacing:-.02em;line-height:1}
.jobs-band-num span{display:block;font-size:var(--fs-sm);text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600;margin-top:.5rem}
.jobs-band-logos{display:grid;grid-template-columns:repeat(3,1fr);align-items:center;justify-items:center;gap:1.6rem}
.jobs-band-logos img{max-width:100%;max-height:clamp(72px,9vw,120px);width:auto;height:auto;object-fit:contain}
@media (max-width:680px){.jobs-band-grid{grid-template-columns:1fr;gap:1.4rem}}

/* ---------- REVIEWS SECTION (service pages, section 2) ---------- */
.reviews{padding:clamp(2.4rem,5vw,4rem) 0;background:var(--band)}
.review-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(258px,1fr));gap:1rem}

/* ---------- SCOPE TASK-LIST (room-by-room, from client scope sheets) ---------- */
.scope{padding:clamp(2.4rem,5vw,4rem) 0;background:var(--paper)}
.scope-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem}
.scope-room{border:1px solid var(--line);border-radius:var(--r-lg);padding:1.4rem 1.5rem;background:var(--paper)}
.scope-room h3{display:flex;align-items:center;gap:.6rem;font-size:var(--fs-md);font-weight:800;color:var(--ink);letter-spacing:-.005em;margin-bottom:.9rem;padding-bottom:.7rem;border-bottom:1px solid var(--line)}
.scope-room ul{list-style:none}
.scope-room li{display:flex;align-items:flex-start;gap:.6rem;padding:.4rem 0;font-size:var(--fs-sm);color:var(--ink);line-height:1.45}
.scope-room li svg{flex-shrink:0;width:16px;height:16px;stroke:var(--ok);stroke-width:3;margin-top:.15rem}
.scope-note{margin-top:1.4rem;padding:1.1rem 1.3rem;background:var(--cyan-tint);border-radius:var(--r-lg);font-size:var(--fs-sm);color:var(--ink);line-height:1.55}
.scope-note strong{color:var(--cyan-deep)}
@media (max-width:680px){.scope-grid{grid-template-columns:1fr}}

/* ---------- ADD-ON BUNDLE (post-reno) ---------- */
.bundle{padding:clamp(2.4rem,5vw,4rem) 0;background:var(--band)}
.bundle-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem;margin-top:.4rem}
.bundle-card{display:flex;gap:1.1rem;border:1px solid var(--line);border-radius:var(--r-lg);padding:1.5rem;background:var(--paper);transition:border-color var(--t-hover) var(--ease-out),transform var(--t-hover) var(--ease-out)}
.bundle-card:hover{border-color:var(--cyan-deep);transform:translateY(-2px)}
.bundle-card .b-icon{flex-shrink:0;width:46px;height:46px;border-radius:12px;background:var(--cyan-tint);display:flex;align-items:center;justify-content:center;color:var(--cyan-deep)}
.bundle-card .b-icon svg{width:24px;height:24px;stroke:currentColor;stroke-width:2;fill:none}
.bundle-card h3{font-size:var(--fs-md);font-weight:800;color:var(--ink);margin-bottom:.35rem;letter-spacing:-.005em}
.bundle-card .b-tag{display:inline-block;font-size:10px;text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--cyan-deep);background:var(--cyan-tint);padding:.2rem .55rem;border-radius:var(--r-pill);margin-bottom:.5rem}
.bundle-card p{font-size:var(--fs-sm);color:var(--muted);line-height:1.5}
.bundle-card a{color:var(--cyan-deep);font-weight:700;text-decoration:underline}
@media (max-width:680px){.bundle-grid{grid-template-columns:1fr}}

/* ---------- TRUST STRIP ---------- */
.trust-strip{background:var(--band);padding:clamp(2rem,3.5vw,3rem) 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.trust-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(2rem,4vw,3.5rem);align-items:center}
.trust-partners-block .partners-label{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:700;margin-bottom:1rem}
.trust-partners{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;align-items:center}
.trust-partners img{height:108px;width:auto;object-fit:contain;max-width:100%;opacity:.85}
.trust-reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.review-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.2rem;box-shadow:var(--shadow-sm)}
.review-head{display:flex;align-items:center;gap:.6rem;margin-bottom:.6rem}
.google-g{width:18px;height:18px;flex-shrink:0}
.review-author{font-weight:700;font-size:var(--fs-sm);color:var(--ink)}
.review-stars{display:flex;gap:2px;margin-bottom:.5rem;color:var(--star)}
.review-stars svg{width:14px;height:14px;fill:currentColor}
.review-body{font-size:var(--fs-xs);color:var(--muted);line-height:1.5}
.review-foot{margin-top:.7rem;font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--gray);font-weight:600}

/* ---------- COMPARISON CARDS ---------- */
.compare{padding:clamp(2.4rem,5vw,4rem) 0}
.compare-head{text-align:center;max-width:680px;margin:0 auto clamp(2rem,3vw,2.6rem)}
.compare-head .kicker{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--cyan-deep);font-weight:700;margin-bottom:.7rem}
.compare-head h2{font-size:var(--fs-2xl);font-weight:800;color:var(--ink);letter-spacing:-.015em;line-height:1.15;margin-bottom:.6rem}
.compare-head p{font-size:var(--fs-md);color:var(--muted)}
.compare-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;max-width:1080px;margin:0 auto;min-width:0}
.compare-grid > *{min-width:0}
.compare-card{background:var(--paper);border-radius:var(--r-xl);padding:clamp(1.6rem,2.6vw,2.2rem);position:relative}
.compare-card.ocd{border:2px solid var(--cyan-deep);box-shadow:var(--shadow-cyan)}
.compare-card.other{border:1px solid var(--line);background:var(--band)}
.compare-card .card-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.6rem;padding-bottom:1.2rem;border-bottom:1px solid var(--line)}
.compare-card.ocd .card-head{border-bottom-color:var(--cyan-tint)}
.compare-card .card-brand img{height:80px;width:auto}
.compare-card .card-brand-text{font-weight:800;font-size:var(--fs-lg);color:var(--muted);letter-spacing:-.01em}
.compare-card .card-tag{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.08em;font-weight:700;padding:.3rem .65rem;border-radius:var(--r-pill)}
.compare-card.ocd .card-tag{background:var(--cyan-tint);color:var(--cyan-deep)}
.compare-card.other .card-tag{background:var(--paper);color:var(--muted);border:1px solid var(--line)}
.compare-card ul{list-style:none}
.compare-card ul li{display:flex;align-items:flex-start;gap:.8rem;padding:.7rem 0;border-bottom:1px solid var(--line);font-size:var(--fs-sm);color:var(--ink);line-height:1.45}
.compare-card.ocd ul li{border-bottom-color:var(--cyan-tint)}
.compare-card ul li:last-child{border-bottom:0}
.compare-card .check, .compare-card .cross{flex-shrink:0;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-top:.05rem}
.compare-card .check{background:var(--ok);color:var(--paper)}
.compare-card .cross{background:var(--warn);color:var(--paper)}
.compare-card .check svg, .compare-card .cross svg{width:13px;height:13px;stroke-width:3}
.compare-card.other ul li{color:var(--muted)}

/* ---------- SERVICES BENTO ---------- */
.services{padding:clamp(2.4rem,5vw,4rem) 0;background:var(--paper)}
.section-head{max-width:680px;margin:0 auto clamp(1.8rem,3vw,2.4rem)}
.section-head.left{margin-left:0}
.section-head .kicker{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--cyan-deep);font-weight:700;margin-bottom:.6rem}
.section-head h2{font-size:var(--fs-2xl);font-weight:800;color:var(--ink);letter-spacing:-.015em;line-height:1.15;margin-bottom:.5rem}
.section-head p{font-size:var(--fs-md);color:var(--muted)}

.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(190px,auto);gap:1rem}
.bento-card{position:relative;border-radius:var(--r-lg);overflow:hidden;background:var(--paper);border:1px solid var(--line);display:flex;flex-direction:column;transition:transform var(--t-hover) var(--ease-out),box-shadow var(--t-hover) var(--ease-out);min-height:220px}
.bento-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.bento-card.feature{grid-column:span 2;grid-row:span 2;min-height:0}
.bento-card.wide{grid-column:span 2}
/* v2 (2026-06-06): meta strip moved to TOP, photo clean below — no overlay disruption */
.bento-card .meta{order:0;padding:.85rem 1rem;background:var(--paper);border-bottom:1px solid var(--line);color:var(--ink);z-index:2;flex-shrink:0}
.bento-card .meta .hub{font-size:10px;text-transform:uppercase;letter-spacing:.1em;font-weight:700;color:var(--cyan-deep);margin-bottom:.15rem;display:block}
.bento-card .meta .name{font-size:var(--fs-md);font-weight:700;line-height:1.25;letter-spacing:-.005em;color:var(--ink)}
.bento-card.feature .meta{padding:1.1rem 1.4rem}
.bento-card.feature .meta .name{font-size:var(--fs-xl)}
.bento-card .ph{position:relative;flex:1 1 auto;overflow:hidden;background:var(--band);order:1;min-height:120px}
.bento-card .ph img{width:100%;height:100%;object-fit:cover;display:block;transition:transform var(--t-state) var(--ease-out)}
.bento-card:hover .ph img{transform:scale(1.03)}
.bento-card.text-card{background:var(--cyan-deep);color:var(--paper);padding:1.4rem;justify-content:space-between}
.bento-card.text-card .ph{display:none}
.bento-card.text-card h3{font-size:var(--fs-lg);font-weight:800;line-height:1.25;letter-spacing:-.01em;margin-bottom:.5rem}
.bento-card.text-card p{font-size:var(--fs-sm);color:var(--cyan-tint);line-height:1.5}
.bento-card.text-card .cta-text{margin-top:auto;font-size:var(--fs-xs);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--cyan);display:inline-flex;align-items:center;gap:.4rem}

/* ---------- PHOTO MOAT BAND ---------- */
.moat{padding:clamp(2.4rem,5vw,4rem) 0;background:var(--band)}
.moat-grid{display:grid;grid-template-columns:1.6fr .8fr .8fr;gap:1rem;align-items:stretch}
.moat-card{position:relative;border-radius:var(--r-lg);overflow:hidden;background:var(--paper);min-height:340px}
.moat-card img{width:100%;height:100%;object-fit:cover;display:block}
.moat-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(10,20,19,.7) 100%)}
.moat-cap{position:absolute;left:0;right:0;bottom:0;padding:1.2rem 1.4rem;color:var(--paper);z-index:2}
.moat-cap .eyebrow{font-size:10px;text-transform:uppercase;letter-spacing:.1em;font-weight:700;opacity:.85;margin-bottom:.3rem;display:block;color:var(--cyan)}
.moat-cap h3{font-size:var(--fs-lg);font-weight:800;line-height:1.25;letter-spacing:-.01em;margin-bottom:.3rem}
.moat-cap p{font-size:var(--fs-xs);color:rgba(255,255,255,.85);line-height:1.45}
.moat-card.large .moat-cap h3{font-size:var(--fs-xl)}

/* ---------- NUMBERS BAND (single dark accent moment — approved 2026-06-06) ---------- */
.numbers{padding:clamp(2.4rem,5vw,4rem) 0;background:var(--ink);color:var(--paper)}
.numbers-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(2rem,4vw,3.5rem);align-items:center;min-width:0}
.numbers-grid > *{min-width:0}
.numbers-lead .label{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.1em;font-weight:700;color:var(--cyan);margin-bottom:.7rem}
.numbers-lead h2{font-size:var(--fs-2xl);font-weight:800;letter-spacing:-.015em;line-height:1.15;margin-bottom:.7rem;color:var(--paper)}
.numbers-lead p{font-size:var(--fs-md);color:rgba(255,255,255,.7);max-width:480px}
.numbers-cells{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.num-cell{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--r-lg);padding:1.4rem;transition:border-color var(--t-hover) var(--ease-out)}
.num-cell:hover{border-color:var(--cyan-soft)}
.num-cell strong{display:block;font-size:var(--fs-2xl);font-weight:800;color:var(--cyan);letter-spacing:-.02em;line-height:1.05;margin-bottom:.3rem}
.num-cell span{font-size:var(--fs-xs);color:rgba(255,255,255,.65);text-transform:uppercase;letter-spacing:.06em;font-weight:600}

/* ---------- PROCESS STRIP ---------- */
.process{padding:clamp(2.4rem,5vw,4rem) 0;background:var(--paper)}
.process-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;counter-reset:step}
.process-step{padding:1.6rem 1.4rem;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--paper);position:relative;transition:border-color var(--t-hover) var(--ease-out)}
.process-step:hover{border-color:var(--cyan-deep)}
.process-step::before{counter-increment:step;content:counter(step,decimal-leading-zero);display:block;font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--cyan-deep);font-weight:700;letter-spacing:.1em;margin-bottom:.8rem}
.process-step h3{font-size:var(--fs-md);font-weight:800;color:var(--ink);letter-spacing:-.005em;margin-bottom:.4rem}
.process-step p{font-size:var(--fs-sm);color:var(--muted);line-height:1.5}

/* ---------- FAQ ACCORDION ---------- */
.faq{padding:clamp(2.4rem,5vw,4rem) 0;background:var(--band)}
.faq-grid{display:grid;grid-template-columns:280px 1fr;gap:clamp(2rem,3vw,3rem);align-items:start}
.faq-side{position:sticky;top:90px}
.faq-side .kicker{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--cyan-deep);font-weight:700;margin-bottom:.6rem}
.faq-side h2{font-size:var(--fs-xl);font-weight:800;color:var(--ink);letter-spacing:-.01em;line-height:1.2;margin-bottom:.7rem}
.faq-side p{font-size:var(--fs-sm);color:var(--muted)}
.faq-side .faq-cta{margin-top:1rem;display:inline-flex;align-items:center;gap:.4rem;font-size:var(--fs-sm);font-weight:700;color:var(--cyan-deep)}
.faq-groups .faq-group{margin-bottom:1.8rem;scroll-margin-top:96px}
.faq-index{display:flex;flex-direction:column;gap:.1rem;margin:.4rem 0 1.1rem}
.faq-index a{font-size:var(--fs-sm);color:var(--ink);padding:.32rem 0;font-weight:500}
.faq-index a:hover{color:var(--cyan-deep)}
@media (max-width:1080px){.faq-index{flex-flow:row wrap;gap:.5rem}.faq-index a{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-pill);padding:.35rem .8rem}}
.faq-groups .faq-group-head{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.1em;font-weight:700;color:var(--cyan-deep);margin-bottom:.7rem;padding-bottom:.6rem;border-bottom:1px solid var(--line)}
.faq-item{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);margin-bottom:.6rem;overflow:hidden}
.faq-item summary{padding:1rem 1.2rem;cursor:pointer;font-weight:600;font-size:var(--fs-sm);color:var(--ink);display:flex;align-items:center;justify-content:space-between;gap:1rem;list-style:none;transition:background var(--t-hover) var(--ease-out)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-weight:300;font-size:var(--fs-lg);color:var(--cyan-deep);flex-shrink:0;transition:transform var(--t-state) var(--ease-snap)}
.faq-item[open] summary::after{content:"−"}
.faq-item summary:hover{background:var(--cyan-tint)}
.faq-item .ans{padding:0 1.2rem 1rem;font-size:var(--fs-sm);color:var(--muted);line-height:1.6}

/* ---------- FINAL CTA BAND ---------- */
.cta-band{padding:clamp(3rem,6vw,4.5rem) 0;background:linear-gradient(135deg,var(--cyan-tint) 0%,var(--paper) 100%);border-top:1px solid var(--line)}
.cta-grid{display:grid;grid-template-columns:1.4fr .6fr;gap:clamp(2rem,4vw,3.5rem);align-items:center;max-width:1080px;margin:0 auto}
.cta-grid h2{font-size:var(--fs-2xl);font-weight:800;color:var(--ink);letter-spacing:-.02em;line-height:1.1;margin-bottom:.7rem}
.cta-grid h2 .accent{color:var(--cyan-deep)}
.cta-grid p{font-size:var(--fs-md);color:var(--muted);max-width:520px;margin-bottom:1.4rem}
.cta-grid .cta-meta{display:flex;gap:1.4rem;font-size:var(--fs-xs);color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.cta-grid .cta-meta strong{color:var(--ink);font-weight:800}
.cta-grid .cta-actions{display:flex;flex-direction:column;gap:.7rem}
.cta-grid .btn-primary{width:auto;padding:1.1rem 1.6rem}
.cta-grid .btn-secondary{background:var(--paper);color:var(--ink);padding:1.1rem 1.6rem;border:2px solid var(--ink);border-radius:var(--r);font-weight:700;font-size:var(--fs-sm);text-align:center;transition:background var(--t-hover) var(--ease-out),color var(--t-hover) var(--ease-out);text-decoration:none}
.cta-grid .btn-secondary:hover{background:var(--ink);color:var(--paper)}

/* ---------- STICKY BOTTOM CTA (rule: every page, every site, no exceptions — 2026-06-06) ---------- */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;background:var(--paper);border-top:1px solid var(--line);box-shadow:0 -4px 16px -4px rgba(10,20,19,.08);padding:.7rem 1rem calc(.7rem + env(safe-area-inset-bottom,0px));z-index:40}
.sticky-cta-inner{max-width:var(--wrap);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.sticky-cta-left{display:flex;flex-direction:column;line-height:1.2}
.sticky-cta-eyebrow{font-size:10px;text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--cyan-deep)}
.sticky-cta-title{font-size:var(--fs-sm);font-weight:700;color:var(--ink)}
.sticky-cta-actions{display:flex;gap:.6rem;align-items:center}
.sticky-cta-actions .btn-primary{padding:.7rem 1.2rem;width:auto;font-size:var(--fs-sm);white-space:nowrap}
.sticky-cta-actions .btn-secondary{white-space:nowrap}
.sticky-cta-actions .btn-secondary{padding:.7rem 1.2rem;font-size:var(--fs-sm);border-width:1.5px;background:var(--paper);color:var(--ink);border:2px solid var(--ink);border-radius:var(--r);font-weight:700;text-decoration:none;text-align:center;transition:background var(--t-hover) var(--ease-out),color var(--t-hover) var(--ease-out)}
.sticky-cta-actions .btn-secondary:hover{background:var(--ink);color:var(--paper)}
/* Body padding so the sticky bar never overlaps the final content. */
body{padding-bottom:calc(88px + env(safe-area-inset-bottom,0px))}
@media (max-width:560px){
  .sticky-cta{padding:.6rem .8rem calc(.6rem + env(safe-area-inset-bottom,0px))}
  .sticky-cta-left{display:none}
  .sticky-cta-actions{flex:1}
  .sticky-cta-actions .btn-primary, .sticky-cta-actions .btn-secondary{flex:1;justify-content:center}
  body{padding-bottom:calc(76px + env(safe-area-inset-bottom,0px))}
}

/* ---------- FOOTER (universal — replaces any v1 footer styles) ---------- */
.footer{background:var(--ink);color:var(--paper);padding:clamp(2.4rem,4vw,3.4rem) 0 1.4rem}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:clamp(1.6rem,3vw,2.4rem);margin-bottom:2.2rem}
.footer-brand img{height:48px;margin-bottom:1rem}
.footer-brand p{font-size:var(--fs-sm);color:rgba(255,255,255,.7);max-width:340px;line-height:1.5;margin-bottom:1rem}
.footer-brand .certs{display:flex;gap:.6rem;flex-wrap:wrap}
.footer-brand .cert{font-size:10px;text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--cyan);padding:.3rem .6rem;border:1px solid rgba(0,229,232,.3);border-radius:var(--r-pill)}
.footer-col h4{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--cyan);font-weight:700;margin-bottom:.9rem}
.footer-col a{display:block;padding:.3rem 0;color:rgba(255,255,255,.8);font-size:var(--fs-sm);transition:color var(--t-hover) var(--ease-out)}
.footer-col a:hover{color:var(--cyan)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:1.4rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;font-size:var(--fs-xs);color:rgba(255,255,255,.55)}
.footer-bottom .legal{display:flex;gap:1.4rem}
.footer-bottom .legal a{color:rgba(255,255,255,.55)}
.footer-bottom .legal a:hover{color:var(--cyan)}

/* ---------- responsive ---------- */
@media (max-width:1080px){
  .bento{grid-template-columns:repeat(3,1fr)}
  .bento-card.feature{grid-column:span 2;grid-row:span 1}
  .moat-grid{grid-template-columns:1fr 1fr}
  .moat-grid > :nth-child(1){grid-column:span 2}
  .numbers-grid{grid-template-columns:1fr;gap:2rem}
  .process-strip{grid-template-columns:repeat(2,1fr)}
  .faq-grid{grid-template-columns:1fr;gap:2rem}
  .faq-side{position:static}
  .cta-grid{grid-template-columns:1fr;gap:1.6rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
}
@media (max-width:920px){
  .hero-grid{grid-template-columns:1fr;gap:2rem}
  .trust-grid{grid-template-columns:1fr;gap:2rem}
  .award-row{grid-template-columns:repeat(4,1fr)}
  .compare-grid{grid-template-columns:1fr}
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--ink);flex-direction:column;align-items:flex-start;padding:1.2rem 1.5rem;gap:1rem;border-top:1px solid rgba(255,255,255,.08);box-shadow:0 8px 20px -10px rgba(0,0,0,.4);max-height:calc(100vh - 80px);overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
  .nav-links.open{display:flex}
  .nav-links a, .nav-links button, .nav-links .has-mega{width:100%}
  .nav-links .nav-cta{text-align:center}
  .mega{position:static;transform:none;left:auto;top:auto;width:100%;box-shadow:none;border:1px solid var(--line);border-radius:var(--r);grid-template-columns:1fr;padding:1rem;margin-top:.5rem;text-align:left}
  /* Mobile: services mega opens with the drawer (JS sets aria-expanded) — and stays left-aligned */
  .nav-links.open .has-mega > button[aria-haspopup="true"] + .mega{display:grid}
  .nav-links .mega-col,.nav-links .mega-col h4,.nav-links .mega-col a{text-align:left}
  .nav-links{text-align:left}
  .burger{display:flex;flex-direction:column;gap:5px;padding:.6rem;border-radius:var(--r);cursor:pointer;background:transparent;border:0}
  .burger span{display:block;width:22px;height:2px;background:#FFFFFF;border-radius:2px}
}
@media (max-width:680px){
  .bento{grid-template-columns:repeat(2,1fr)}
  .bento-card.feature, .bento-card.wide{grid-column:span 2}
  .moat-grid{grid-template-columns:1fr}
  .moat-grid > :nth-child(1){grid-column:span 1}
  .numbers-cells{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
}
@media (max-width:560px){
  .award-row{grid-template-columns:repeat(4,1fr);gap:.5rem;align-items:center}
  .award-row img{height:63px;max-width:100%;object-fit:contain}
  .trust-partners{grid-template-columns:repeat(3,1fr);gap:.6rem;align-items:center}
  .trust-partners img{height:48px}
  .trust-reviews{grid-template-columns:1fr;gap:.8rem}
  .form-row{grid-template-columns:1fr}
  .hero-stats{flex-wrap:wrap;gap:1rem}
  .bento{grid-template-columns:1fr}
  .bento-card.feature, .bento-card.wide{grid-column:span 1}
  .process-strip{grid-template-columns:1fr}
}
