/* ===================================================================
   GULLEDGE DESIGN — shared stylesheet
   Brand: navy #0E2A47 / gold #C99A3B / cream #F8F4EA
   Fonts: Oswald (display) + Inter (body)
=================================================================== */
:root{
  --navy:#0E2A47; --navy-2:#143553; --navy-deep:#0a1f35; --navy-ink:#07182b;
  --gold:#C99A3B; --gold-dark:#b8882d; --gold-soft:#e7d3a6;
  --cream:#F8F4EA; --cream-2:#F2ECDD;
  --grey:#555A60; --grey-soft:#8a8f96;
  --white:#FFFFFF;
  --line:rgba(14,42,71,0.10);
  --line-light:rgba(255,255,255,0.14);
  --shadow:0 10px 28px rgba(14,42,71,0.10);
  --shadow-lg:0 18px 44px rgba(14,42,71,0.16);
  --shadow-xl:0 30px 70px rgba(14,42,71,0.22);
  --disp:'Oswald',sans-serif;
  --sans:'Inter',system-ui,-apple-system,sans-serif;
  --maxw:1140px;
  --bar-h:64px;
  --radius:14px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--navy);background:var(--cream);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--disp);letter-spacing:4px;font-size:.78rem;color:var(--gold-dark);font-weight:600;text-transform:uppercase;margin-bottom:14px}
.center{text-align:center}

/* scroll reveal (no-JS safe) */
.js .reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.js .reveal.in{opacity:1;transform:none}
.js .reveal.d1{transition-delay:.08s}
.js .reveal.d2{transition-delay:.16s}
.js .reveal.d3{transition-delay:.24s}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--disp);font-weight:600;letter-spacing:1px;text-transform:uppercase;font-size:.85rem;text-align:center;padding:15px 28px;border-radius:7px;border:2px solid transparent;transition:.18s;cursor:pointer}
.btn-gold{background:var(--gold);color:var(--navy)}
.btn-gold:hover{background:var(--gold-dark);transform:translateY(-2px)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-2);transform:translateY(-2px)}
.btn-outline{border-color:var(--navy);color:var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff}
.btn-ghost{border-color:rgba(255,255,255,.45);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.1);border-color:#fff}
.btn-lg{padding:17px 34px;font-size:.92rem}

/* ---------- HEADER ---------- */
header.nav{position:sticky;top:0;z-index:50;background:rgba(248,244,234,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:12px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.logo{height:42px;width:auto;flex-shrink:0}
.nav-links{display:flex;align-items:center;gap:22px}
.nav-links a{font-family:var(--disp);letter-spacing:1px;text-transform:uppercase;font-size:.82rem;font-weight:600;color:var(--navy);opacity:.85;position:relative}
.nav-links a:hover{opacity:1;color:var(--gold-dark)}
.nav-links a.active{color:var(--gold-dark);opacity:1}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--gold)}
.nav-cta{background:var(--navy);color:#fff!important;padding:10px 18px;border-radius:6px;opacity:1!important}
.nav-cta:hover{background:var(--navy-2)}
.nav-cta::after{display:none!important}
.hamburger{display:none;flex-direction:column;gap:5px;padding:8px}
.hamburger span{display:block;width:26px;height:3px;background:var(--navy);border-radius:2px;transition:.2s}

/* ---------- PAGE HERO (interior pages) ---------- */
.page-hero{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-2) 100%);color:#fff;position:relative;overflow:hidden;padding:74px 0 78px}
.page-hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:6px;background:var(--gold)}
.page-hero::before{content:"";position:absolute;top:-120px;right:-100px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(201,154,59,.16),transparent 70%)}
.page-hero .wrap{position:relative;z-index:2}
.page-hero h1{font-family:var(--disp);font-weight:700;font-size:clamp(2.2rem,5.5vw,3.4rem);line-height:1.05;letter-spacing:-.5px;margin-bottom:16px;max-width:760px}
.page-hero h1 .accent{color:var(--gold)}
.page-hero p{font-size:clamp(1rem,2.3vw,1.16rem);color:rgba(255,255,255,.84);max-width:620px}
.crumbs{font-family:var(--disp);letter-spacing:1.5px;text-transform:uppercase;font-size:.72rem;color:var(--gold-soft);margin-bottom:18px}
.crumbs a{opacity:.8}.crumbs a:hover{opacity:1;color:#fff}

/* ---------- HOME HERO + GENERATOR ---------- */
.hero{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-2) 100%);color:#fff;position:relative;overflow:hidden;padding:64px 0 84px}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:6px;background:var(--gold)}
.hero::before{content:"";position:absolute;top:-120px;right:-120px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(201,154,59,.18),transparent 70%)}
.hero-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:44px;align-items:center;position:relative;z-index:2}
.hero h1{font-family:var(--disp);font-weight:700;font-size:clamp(2.2rem,5.6vw,3.5rem);line-height:1.04;letter-spacing:-.5px;margin-bottom:16px}
.hero h1 .accent{color:var(--gold)}
.hero .lede{font-size:clamp(1rem,2.4vw,1.14rem);color:rgba(255,255,255,.85);max-width:560px;margin-bottom:22px}
.gen-controls{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px}
.gen-controls input,.gen-controls select{font-family:var(--sans);font-size:.95rem;padding:13px 14px;border-radius:8px;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.96);color:var(--navy)}
.gen-controls input{flex:1;min-width:170px}
.gen-controls input:focus,.gen-controls select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,154,59,.3)}
.gen-hint{font-size:.8rem;color:rgba(255,255,255,.6);margin-bottom:20px;display:flex;align-items:center;gap:7px}
.gen-hint .pulse{width:8px;height:8px;border-radius:50%;background:var(--gold);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(201,154,59,.6)}70%{box-shadow:0 0 0 10px rgba(201,154,59,0)}100%{box-shadow:0 0 0 0 rgba(201,154,59,0)}}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px}

/* browser-frame mock (shared) */
.frame{background:#fff;border-radius:12px;box-shadow:var(--shadow-xl);overflow:hidden;border:1px solid rgba(255,255,255,.2);transition:max-width .35s ease}
.frame .bar{background:#eef1f4;display:flex;align-items:center;gap:6px;padding:10px 12px;border-bottom:1px solid #e0e4e9}
.frame .bar i{width:11px;height:11px;border-radius:50%;display:block;flex-shrink:0}
.frame .bar .url{margin-left:10px;background:#fff;border-radius:5px;font-size:.7rem;color:#6b7280;padding:4px 10px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mock-hero{background:linear-gradient(135deg,#111,#1c1c1c);color:#fff;padding:28px 24px 32px;position:relative;transition:.3s}
.mock-hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:4px;background:var(--mock-accent,#CC0000)}
.mock-tag{font-family:var(--disp);letter-spacing:2px;font-size:.6rem;color:var(--mock-accent,#CC0000);text-transform:uppercase;font-weight:600;margin-bottom:8px}
.mock-name{font-family:var(--disp);font-size:.92rem;letter-spacing:1px;text-transform:uppercase;color:#fff;margin-bottom:14px;opacity:.9}
.mock-hero h4{font-family:var(--disp);font-size:1.4rem;line-height:1.12;margin-bottom:12px;text-transform:uppercase;min-height:2.4em}
.mock-hero h4 span{color:var(--mock-accent,#CC0000)}
.mock-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.mock-chips span{font-size:.6rem;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);padding:4px 9px;border-radius:20px;letter-spacing:.5px}
.mock-cta{display:inline-block;background:var(--mock-accent,#CC0000);color:#fff;font-family:var(--disp);font-size:.64rem;letter-spacing:1px;text-transform:uppercase;padding:9px 15px;border-radius:4px;font-weight:600}
.mock-foot{background:#fff;padding:13px 22px;display:flex;justify-content:space-between;align-items:center;font-size:.62rem;color:#6b7280;gap:10px;flex-wrap:wrap}
.mock-foot b{color:#111;font-family:var(--disp)}

/* ---------- GRI FAITHFUL HERO REPLICA ---------- */
.gri{background:#0d0d0d;color:#fff;font-family:var(--sans)}
.gri-top{background:#060606;color:rgba(255,255,255,.62);font-size:.52rem;letter-spacing:.2px;display:flex;justify-content:space-between;align-items:center;gap:8px;padding:6px 14px}
.gri-top b{color:#fff;font-weight:600}
.gri-top .sep{color:rgba(255,255,255,.25)}
.gri-nav{background:#fff;display:flex;align-items:center;justify-content:space-between;padding:9px 14px}
.gri-logo{display:flex;align-items:center;gap:6px;font-family:var(--disp);font-weight:700;font-size:.72rem;letter-spacing:.4px;color:#111;text-transform:uppercase}
.gri-logo svg{width:22px;height:14px;display:block}
.gri-free{background:#CC0000;color:#fff;font-family:var(--disp);font-size:.56rem;letter-spacing:1px;text-transform:uppercase;font-weight:700;padding:6px 11px;border-radius:4px}
.gri-hero{padding:18px 16px 20px;text-align:center;border-top:2px solid #CC0000}
.gri-pill{display:inline-block;background:rgba(204,0,0,.16);border:1px solid rgba(204,0,0,.5);color:#ff7a7a;font-size:.5rem;letter-spacing:.6px;text-transform:uppercase;font-weight:600;padding:4px 11px;border-radius:20px;margin-bottom:12px}
.gri-hero h4{font-family:var(--disp);font-weight:700;font-size:1.55rem;line-height:.96;text-transform:uppercase;margin-bottom:10px;letter-spacing:-.3px}
.gri-hero h4 span{color:#CC0000;display:block}
.gri-hero p{font-size:.6rem;color:rgba(255,255,255,.72);max-width:86%;margin:0 auto 12px;line-height:1.45}
.gri-checks{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-bottom:14px}
.gri-checks span{font-size:.52rem;color:#fff;display:flex;align-items:center;gap:4px;font-weight:500}
.gri-checks span::before{content:"✓";color:#CC0000;font-weight:700}
.gri-ctas{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.gri-ctas span{font-family:var(--disp);font-size:.56rem;letter-spacing:.5px;text-transform:uppercase;font-weight:700;padding:9px 13px;border-radius:5px}
.gri-ctas .c1{background:#CC0000;color:#fff}
.gri-ctas .c2{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.42)}
.gri-badges{display:flex;justify-content:center;gap:8px;flex-wrap:wrap}
.gri-badges span{font-size:.5rem;color:rgba(255,255,255,.82);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.13);padding:4px 9px;border-radius:20px;display:flex;align-items:center;gap:4px}
.gri-badges b{color:#f5b50a;font-weight:700}
/* GRI replica inside before/after layer: full-bleed, trim chrome to fit */
.ba-after .gri{position:absolute;inset:0;overflow:hidden}
.ba .gri-top,.ba .gri-badges{display:none}
.ba .gri-hero{padding:16px 16px 18px}
.ba .gri-hero h4{font-size:1.45rem}

/* ---------- MARQUEE (industries) ---------- */
.marquee{background:var(--navy-deep);color:rgba(255,255,255,.7);overflow:hidden;padding:18px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.marquee-track{display:flex;gap:48px;white-space:nowrap;width:max-content;animation:scroll-x 28s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee span{font-family:var(--disp);letter-spacing:2px;text-transform:uppercase;font-size:.86rem;display:inline-flex;align-items:center;gap:48px}
.marquee span::after{content:"◆";color:var(--gold);font-size:.6rem}
@keyframes scroll-x{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.marquee-track{animation:none}}

/* ---------- TRUST STRIP ---------- */
.trust{background:var(--navy-deep);color:rgba(255,255,255,.85)}
.trust .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:30px 24px;text-align:center}
.trust .stat strong{display:block;font-family:var(--disp);color:var(--gold);font-size:1.8rem;line-height:1;margin-bottom:6px}
.trust .stat span{font-size:.8rem;letter-spacing:.5px}

/* ---------- SECTIONS ---------- */
section.block{padding:78px 0}
.bg-white{background:var(--white)}
.bg-cream{background:var(--cream)}
.bg-cream2{background:var(--cream-2)}
.section-head{max-width:680px;margin:0 auto 48px;text-align:center}
.section-head h2{font-family:var(--disp);font-size:clamp(1.8rem,4.5vw,2.5rem);font-weight:700;margin-bottom:12px;line-height:1.1}
.section-head p{color:var(--grey)}

/* ---------- SPLIT (copy + card) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center}
.split h2{font-family:var(--disp);font-size:clamp(1.8rem,4.5vw,2.4rem);font-weight:700;margin-bottom:16px;line-height:1.1}
.split p{color:var(--grey);margin-bottom:16px}
.panel{background:var(--cream);border-radius:var(--radius);padding:34px;border-top:5px solid var(--gold);box-shadow:var(--shadow)}
.panel.dark{background:var(--navy);color:#fff;border-top:0;border-bottom:5px solid var(--gold)}
.panel.dark p{color:rgba(255,255,255,.8)}
.panel .kicker{font-family:var(--disp);letter-spacing:2px;text-transform:uppercase;color:var(--gold-dark);font-size:.78rem;font-weight:600;margin-bottom:6px}
.panel h3{font-family:var(--disp);font-size:1.7rem;margin-bottom:16px}
.checklist{list-style:none;display:flex;flex-direction:column;gap:14px}
.checklist li{display:flex;gap:12px;align-items:flex-start;font-size:.97rem}
.checklist .tick{flex-shrink:0;width:22px;height:22px;border-radius:50%;background:var(--navy);color:var(--gold);display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;margin-top:2px}
.panel.dark .checklist .tick{background:var(--gold);color:var(--navy)}

/* ---------- CARD GRID (capabilities/features) ---------- */
.grid-auto{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:22px}
.card{background:var(--white);padding:28px;border-radius:12px;box-shadow:var(--shadow);border-left:4px solid var(--gold);transition:transform .18s ease,box-shadow .18s ease}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.card .ico{font-family:var(--disp);font-weight:700;color:var(--gold-dark);font-size:1.1rem;margin-bottom:12px;display:flex;align-items:center;gap:10px}
.card .ico .dot{width:36px;height:36px;border-radius:9px;background:var(--navy);color:var(--gold);display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}
.card h4{font-family:var(--disp);font-size:1.12rem;margin-bottom:8px}
.card p{color:var(--grey);font-size:.92rem}

/* ---------- PORTFOLIO GRID ---------- */
.filterbar{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:38px}
.filterbar button{font-family:var(--disp);letter-spacing:1px;text-transform:uppercase;font-size:.76rem;padding:9px 18px;border-radius:24px;border:1px solid var(--line);background:var(--white);color:var(--navy);transition:.18s}
.filterbar button.active,.filterbar button:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
.port-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:26px}
.proj{background:var(--white);border-radius:14px;box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column;transition:transform .18s ease,box-shadow .18s ease;border-top:5px solid var(--gold)}
.proj:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.proj-shot{position:relative;overflow:hidden}
.proj-shot .mock-hero{padding:24px 22px 26px}
.proj-shot .mock-hero h4{font-size:1.2rem;min-height:0}
.proj .status{position:absolute;top:12px;right:12px;z-index:3;font-family:var(--disp);font-size:.62rem;letter-spacing:1.2px;text-transform:uppercase;font-weight:700;padding:4px 10px;border-radius:4px}
.status.live{background:#2faa6a;color:#fff}
.status.demo{background:var(--gold);color:var(--navy)}
.status.concept{background:rgba(14,42,71,.8);color:#fff}
.proj .body{padding:24px;flex-grow:1;display:flex;flex-direction:column}
.proj .meta{font-family:var(--disp);letter-spacing:2px;font-size:.72rem;color:var(--gold-dark);text-transform:uppercase;font-weight:600;margin-bottom:8px}
.proj h3{font-family:var(--disp);font-size:1.4rem;margin-bottom:10px;line-height:1.15}
.proj .blurb{color:var(--grey);font-size:.92rem;margin-bottom:16px;flex-grow:1}
.proj .tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px}
.proj .tag{background:var(--cream);color:var(--navy);padding:5px 10px;border-radius:4px;font-size:.72rem;font-weight:600}
.proj .actions{display:flex;gap:10px;flex-wrap:wrap}
.proj .actions .btn{flex:1;padding:11px 14px;font-size:.78rem}

/* ---------- CASE STUDY ---------- */
.case-hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:36px}
.case-hero-stats .s{background:rgba(255,255,255,.07);border:1px solid var(--line-light);border-radius:12px;padding:18px;text-align:center}
.case-hero-stats .s b{display:block;font-family:var(--disp);color:var(--gold);font-size:1.9rem;line-height:1}
.case-hero-stats .s span{font-size:.74rem;color:rgba(255,255,255,.7);letter-spacing:.4px}
.cs-body{max-width:880px;margin:0 auto}
.cs-block{margin-bottom:48px}
.cs-block .eyebrow{margin-bottom:10px}
.cs-block h2{font-family:var(--disp);font-size:1.7rem;margin-bottom:14px}
.cs-block p{color:var(--grey);margin-bottom:14px}
.cs-block ul{margin:0 0 14px 20px;color:var(--grey)}
.cs-block li{margin-bottom:8px}

/* lighthouse gauges */
.gauges{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin:8px 0}
.gauge{background:var(--white);border-radius:14px;padding:22px 14px;box-shadow:var(--shadow);text-align:center;border:1px solid var(--line)}
.gauge svg{margin:0 auto 4px}
.gauge .track{fill:none;stroke:#e7e3d8;stroke-width:9}
.gauge .fill{fill:none;stroke-width:9;stroke-linecap:round;transform:rotate(-90deg);transform-origin:60px 60px;transition:stroke-dashoffset 1.4s ease}
.gauge .num{font-family:var(--disp);font-size:1.7rem;font-weight:700;fill:var(--navy)}
.gauge .lbl{font-family:var(--disp);letter-spacing:.5px;text-transform:uppercase;font-size:.74rem;margin-top:6px;color:var(--grey)}
.gauge-note{text-align:center;font-size:.8rem;color:var(--grey-soft);margin-top:14px}

/* device toggle */
.device-toggle{display:flex;gap:6px;justify-content:center;background:rgba(14,42,71,.06);padding:5px;border-radius:24px;width:max-content;margin:0 auto 22px}
.device-toggle button{font-family:var(--disp);font-size:.72rem;letter-spacing:1px;text-transform:uppercase;color:var(--grey);padding:8px 18px;border-radius:20px;transition:.2s}
.device-toggle button.active{background:var(--navy);color:#fff;font-weight:700}
.device-stage{display:flex;justify-content:center}
.device-stage .frame{width:100%;max-width:100%}
.device-stage.tablet .frame{max-width:480px}
.device-stage.phone .frame{max-width:260px}

/* before/after */
.ba{position:relative;height:320px;border-radius:14px;overflow:hidden;box-shadow:var(--shadow);user-select:none;border:1px solid var(--line)}
.ba-layer{position:absolute;inset:0;overflow:hidden}
.ba-site{position:absolute;inset:0;padding:28px 32px;display:flex;flex-direction:column;justify-content:center}
.ba-before .ba-site{background:#e9eaec}
.ba-before .bs-logo{font-family:'Times New Roman',serif;font-size:1.2rem;color:#7a7f86;margin-bottom:14px}
.ba-before .bs-h{font-family:'Times New Roman',serif;font-size:1.5rem;color:#84888f;margin-bottom:12px;max-width:70%}
.ba-before .bs-txt{height:9px;background:#d2d4d7;border-radius:3px;margin-bottom:8px;max-width:320px}
.ba-before .bs-txt.s{max-width:200px}
.ba-before .bs-btn{margin-top:14px;width:120px;height:30px;background:#cfd2d6;border-radius:4px}
.ba-after{clip-path:inset(0 calc(100% - var(--pos,50%)) 0 0)}
.ba-after .ba-site{background:linear-gradient(135deg,var(--navy),var(--navy-2));color:#fff}
.ba-after .bs-logo{font-family:var(--disp);font-weight:700;letter-spacing:1px;color:#fff;margin-bottom:14px;font-size:1.1rem}
.ba-after .bs-logo span{color:var(--gold)}
.ba-after .bs-h{font-family:var(--disp);font-size:1.7rem;line-height:1.1;text-transform:uppercase;margin-bottom:14px;max-width:80%}
.ba-after .bs-h em{color:var(--gold);font-style:normal}
.ba-after .bs-chips{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}
.ba-after .bs-chips span{font-size:.62rem;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);padding:4px 9px;border-radius:20px}
.ba-after .bs-btn{width:160px;height:38px;background:var(--gold);border-radius:5px;display:flex;align-items:center;justify-content:center;font-family:var(--disp);font-size:.7rem;letter-spacing:1px;text-transform:uppercase;color:var(--navy);font-weight:700}
.ba-tag{position:absolute;top:12px;font-family:var(--disp);font-size:.62rem;letter-spacing:1.5px;text-transform:uppercase;padding:4px 10px;border-radius:4px;z-index:4;font-weight:700}
.ba-tag.new{left:12px;background:var(--gold);color:var(--navy)}
.ba-tag.old{right:12px;background:rgba(0,0,0,.35);color:#fff}
.ba-handle{position:absolute;top:0;bottom:0;left:var(--pos,50%);width:3px;background:var(--gold);z-index:5;transform:translateX(-50%);pointer-events:none}
.ba-handle::after{content:"⟷";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:38px;height:38px;background:var(--gold);color:var(--navy);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;box-shadow:0 4px 12px rgba(0,0,0,.25)}
.ba-range{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:ew-resize;z-index:6;margin:0}

/* ---------- ROI CALCULATOR ---------- */
.roi{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.roi::before{content:"";position:absolute;bottom:-140px;left:-120px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(201,154,59,.16),transparent 70%)}
.roi .section-head h2{color:#fff}.roi .section-head p{color:rgba(255,255,255,.75)}
.roi-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:stretch;position:relative;z-index:2;max-width:980px;margin:0 auto}
.roi-inputs{background:rgba(255,255,255,.05);border:1px solid var(--line-light);border-radius:16px;padding:32px}
.roi-fld{margin-bottom:22px}
.roi-fld label{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--disp);letter-spacing:.5px;font-size:.86rem;text-transform:uppercase;margin-bottom:10px;color:rgba(255,255,255,.85)}
.roi-fld label .val{color:var(--gold);font-size:1.05rem}
.roi-fld input[type=range]{width:100%;-webkit-appearance:none;appearance:none;height:6px;border-radius:6px;background:rgba(255,255,255,.18);outline:none}
.roi-fld input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:22px;height:22px;border-radius:50%;background:var(--gold);cursor:pointer;border:3px solid #fff;box-shadow:0 2px 6px rgba(0,0,0,.3)}
.roi-fld input[type=range]::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:var(--gold);cursor:pointer;border:3px solid #fff}
.roi-select{display:flex;gap:8px;flex-wrap:wrap}
.roi-select button{flex:1;min-width:80px;font-family:var(--disp);font-size:.78rem;letter-spacing:.5px;text-transform:uppercase;padding:11px 8px;border-radius:8px;border:1px solid var(--line-light);background:rgba(255,255,255,.05);color:#fff;transition:.2s}
.roi-select button.active{background:var(--gold);color:var(--navy);border-color:var(--gold);font-weight:700}
.roi-out{background:var(--white);color:var(--navy);border-radius:16px;padding:34px;display:flex;flex-direction:column;justify-content:center;box-shadow:var(--shadow-lg)}
.roi-out .ro-kick{font-family:var(--disp);letter-spacing:2px;text-transform:uppercase;color:var(--gold-dark);font-size:.74rem;font-weight:600;margin-bottom:6px}
.roi-out .ro-big{font-family:var(--disp);font-size:clamp(2.4rem,6vw,3.4rem);font-weight:700;line-height:1;margin-bottom:4px}
.roi-out .ro-sub{color:var(--grey);font-size:.92rem;margin-bottom:22px}
.roi-out .ro-row{display:flex;justify-content:space-between;padding:13px 0;border-bottom:1px solid var(--line);font-size:.95rem}
.roi-out .ro-row:last-of-type{border-bottom:0}
.roi-out .ro-row b{font-family:var(--disp)}
.roi-out .ro-pay{margin-top:18px;background:var(--cream);border-radius:10px;padding:16px;text-align:center;font-size:.95rem}
.roi-out .ro-pay b{font-family:var(--disp);color:var(--gold-dark);font-size:1.15rem}
.roi-note{text-align:center;color:rgba(255,255,255,.55);font-size:.8rem;margin-top:22px;position:relative;z-index:2}

/* ---------- PRICING ---------- */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch}
.price-grid.four{grid-template-columns:repeat(4,1fr)}
.price{background:var(--white);border-radius:14px;padding:30px 26px;box-shadow:var(--shadow);display:flex;flex-direction:column;border:2px solid transparent;transition:transform .18s ease}
.price:hover{transform:translateY(-4px)}
.price.feat{border-color:var(--gold);box-shadow:var(--shadow-lg);position:relative}
.price.feat::before{content:"Most Popular";position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--gold);color:var(--navy);font-family:var(--disp);font-size:.64rem;letter-spacing:1.5px;text-transform:uppercase;font-weight:700;padding:5px 14px;border-radius:20px;white-space:nowrap}
.price.premium{background:linear-gradient(160deg,var(--navy),var(--navy-2));color:#fff}
.price.premium .who,.price.premium li{color:rgba(255,255,255,.82)}
.price.premium li::before{color:var(--gold)}
.price .tier{font-family:var(--disp);letter-spacing:2px;text-transform:uppercase;color:var(--gold-dark);font-size:.8rem;font-weight:600;margin-bottom:8px}
.price.premium .tier{color:var(--gold)}
.price .amt{font-family:var(--disp);font-size:2.1rem;font-weight:700;line-height:1;margin-bottom:6px}
.price .amt small{font-size:.95rem;color:var(--grey);font-weight:500}
.price.premium .amt small{color:rgba(255,255,255,.6)}
.price .who{color:var(--grey);font-size:.86rem;margin-bottom:20px;min-height:40px}
.price ul{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:24px;flex-grow:1}
.price li{font-size:.88rem;display:flex;gap:9px;align-items:flex-start}
.price li::before{content:"✓";color:var(--gold-dark);font-weight:700;flex-shrink:0}
.price .btn{width:100%}
.price-note{text-align:center;color:var(--grey);font-size:.9rem;margin-top:26px}

/* care plans row */
.care-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.care{background:var(--cream);border-radius:12px;padding:26px;border-top:4px solid var(--gold)}
.care .tier{font-family:var(--disp);letter-spacing:1.5px;text-transform:uppercase;color:var(--gold-dark);font-size:.78rem;font-weight:600;margin-bottom:6px}
.care .amt{font-family:var(--disp);font-size:1.6rem;font-weight:700;margin-bottom:12px}
.care .amt small{font-size:.85rem;color:var(--grey);font-weight:500}
.care p{color:var(--grey);font-size:.9rem}

/* ---------- PROCESS ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.step{background:var(--cream);border:1px solid var(--line);border-radius:12px;padding:28px 24px}
.steps.on-dark .step{background:rgba(255,255,255,.05);border-color:var(--line-light)}
.step .num{font-family:var(--disp);font-size:2rem;color:var(--gold);font-weight:700;line-height:1;margin-bottom:12px}
.step h4{font-family:var(--disp);font-size:1.1rem;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}
.step p{color:var(--grey);font-size:.9rem}
.steps.on-dark .step h4{color:#fff}.steps.on-dark .step p{color:rgba(255,255,255,.72)}

/* ---------- TESTIMONIAL ---------- */
.quote-band{background:var(--navy);color:#fff;text-align:center}
.quote-band .wrap{max-width:820px;padding-top:64px;padding-bottom:64px}
.quote-band .mark{font-family:var(--disp);font-size:4rem;color:var(--gold);line-height:.6}
.quote-band blockquote{font-family:var(--disp);font-weight:500;font-size:clamp(1.3rem,3.4vw,1.9rem);line-height:1.3;margin:14px 0 22px}
.quote-band cite{font-style:normal;color:var(--gold-soft);font-size:.92rem;letter-spacing:.5px}

/* ---------- ABOUT ---------- */
.about-card{background:var(--navy);color:#fff;border-radius:16px;padding:38px;box-shadow:var(--shadow-lg);border-bottom:5px solid var(--gold)}
.about-card .name{font-family:var(--disp);font-size:1.5rem;letter-spacing:.5px}
.about-card .role{color:var(--gold);font-family:var(--disp);letter-spacing:1.5px;text-transform:uppercase;font-size:.78rem;margin:6px 0 18px}
.about-card p{color:rgba(255,255,255,.8);font-size:.92rem;margin-bottom:14px}
.values{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}
.value{padding:24px;border-left:4px solid var(--gold);background:var(--white);border-radius:0 10px 10px 0;box-shadow:var(--shadow)}
.value h4{font-family:var(--disp);font-size:1.05rem;margin-bottom:6px}
.value p{color:var(--grey);font-size:.9rem}

/* ---------- FAQ ---------- */
.faq{max-width:760px;margin:0 auto}
.faq details{background:var(--white);border:1px solid var(--line);border-radius:10px;margin-bottom:12px;overflow:hidden}
.faq summary{font-family:var(--disp);font-size:1.02rem;padding:18px 22px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--gold-dark);font-size:1.4rem;transition:.2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{padding:0 22px 20px;color:var(--grey);font-size:.95rem}

/* ---------- CONTACT ---------- */
.contact{background:var(--navy-deep);color:#fff}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:start}
.contact h2{font-family:var(--disp);font-size:clamp(1.9rem,5vw,2.6rem);font-weight:700;margin-bottom:14px;line-height:1.08}
.contact h2 .accent{color:var(--gold)}
.contact .lede{color:rgba(255,255,255,.8);margin-bottom:26px;max-width:440px}
.contact-info{display:flex;flex-direction:column;gap:16px}
.contact-info a,.contact-info div{display:flex;align-items:center;gap:12px;color:#fff;font-size:.98rem}
.contact-info .ci-ico{width:40px;height:40px;border-radius:9px;background:rgba(201,154,59,.16);color:var(--gold);display:flex;align-items:center;justify-content:center;font-family:var(--disp);font-weight:700;flex-shrink:0}
.contact-info a:hover .ci-ico{background:var(--gold);color:var(--navy)}
.next-steps{margin-top:30px;padding-top:24px;border-top:1px solid var(--line-light)}
.next-steps h4{font-family:var(--disp);letter-spacing:1px;text-transform:uppercase;font-size:.82rem;color:var(--gold-soft);margin-bottom:14px}
.next-steps ol{list-style:none;counter-reset:ns;display:flex;flex-direction:column;gap:12px}
.next-steps li{counter-increment:ns;display:flex;gap:12px;align-items:flex-start;font-size:.92rem;color:rgba(255,255,255,.82)}
.next-steps li::before{content:counter(ns);flex-shrink:0;width:24px;height:24px;border-radius:50%;background:var(--gold);color:var(--navy);font-family:var(--disp);font-weight:700;font-size:.78rem;display:flex;align-items:center;justify-content:center}
form{background:var(--white);border-radius:14px;padding:32px;box-shadow:var(--shadow-lg)}
form .fld{margin-bottom:16px}
form .row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
form label{display:block;font-family:var(--disp);letter-spacing:1px;text-transform:uppercase;font-size:.72rem;color:var(--navy);font-weight:600;margin-bottom:6px}
form input,form select,form textarea{width:100%;padding:13px 14px;border:1px solid #d7dbe0;border-radius:7px;font-family:var(--sans);font-size:.95rem;color:var(--navy);background:#fff}
form input:focus,form select:focus,form textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,154,59,.18)}
form textarea{resize:vertical;min-height:96px}
form .btn{width:100%;margin-top:6px}
form .fineprint{font-size:.78rem;color:var(--grey);margin-top:12px;text-align:center}

/* ---------- CTA BAND ---------- */
.cta-band{background:linear-gradient(135deg,var(--navy),var(--navy-2));color:#fff;text-align:center}
.cta-band .wrap{padding-top:64px;padding-bottom:64px}
.cta-band h2{font-family:var(--disp);font-size:clamp(1.9rem,4.6vw,2.6rem);margin-bottom:14px}
.cta-band h2 .accent{color:var(--gold)}
.cta-band p{color:rgba(255,255,255,.8);max-width:560px;margin:0 auto 26px}

/* ---------- FOOTER ---------- */
footer.site{background:var(--navy-ink);color:rgba(255,255,255,.6);padding:46px 0 28px;font-size:.86rem}
footer.site .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px;margin-bottom:30px}
footer.site h5{font-family:var(--disp);letter-spacing:1px;text-transform:uppercase;font-size:.8rem;color:#fff;margin-bottom:14px}
footer.site a{color:rgba(255,255,255,.65);display:block;margin-bottom:8px}
footer.site a:hover{color:var(--gold)}
footer.site .blurb{color:rgba(255,255,255,.5);max-width:300px;margin-top:12px;font-size:.84rem}
footer.site .bottom{border-top:1px solid var(--line-light);padding-top:20px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}
footer.site .legal{font-size:.78rem;color:rgba(255,255,255,.4)}
footer.site .legal a{display:inline;color:var(--gold)}

/* ---------- STICKY MOBILE CTA ---------- */
.mobile-bar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:60;background:var(--navy);border-top:3px solid var(--gold);padding:10px 14px;gap:10px}
.mobile-bar a{flex:1;text-align:center;font-family:var(--disp);letter-spacing:1px;text-transform:uppercase;font-size:.82rem;font-weight:600;padding:13px 10px;border-radius:7px}
.mobile-bar .mb-primary{background:var(--gold);color:var(--navy)}
.mobile-bar .mb-ghost{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.25)}

/* ---------- RESPONSIVE ---------- */
@media(max-width:980px){
  .case-hero-stats{grid-template-columns:repeat(2,1fr)}
  .gauges{grid-template-columns:repeat(2,1fr)}
  .price-grid.four{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:900px){
  .hero-grid,.split,.contact-grid,.roi-grid{grid-template-columns:1fr;gap:34px}
  .steps,.price-grid{grid-template-columns:repeat(2,1fr)}
  .care-grid{grid-template-columns:1fr}
  .trust .wrap{grid-template-columns:repeat(2,1fr);gap:26px}
  footer.site .cols{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--cream);flex-direction:column;align-items:stretch;gap:0;padding:8px 0;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
  .nav-links.open{display:flex}
  .nav-links a{padding:14px 24px;border-bottom:1px solid var(--line)}
  .nav-links a.active::after{display:none}
  .nav-links .nav-cta{margin:10px 24px;text-align:center}
  .hamburger{display:flex}
  .price-grid,.price-grid.four{grid-template-columns:1fr;max-width:420px;margin:0 auto}
  .gauges{grid-template-columns:repeat(2,1fr)}
  .form .row2{grid-template-columns:1fr}
  .mobile-bar{display:flex}
  body{padding-bottom:var(--bar-h)}
  section.block{padding:56px 0}
  .hero{padding:44px 0 60px}
  .panel,.roi-inputs,.roi-out,form,.about-card{padding:26px}
  .ba{height:250px}
  footer.site .cols{grid-template-columns:1fr}
}
@media(max-width:440px){
  .steps{grid-template-columns:1fr}
  .case-hero-stats{grid-template-columns:1fr 1fr}
  form .row2{grid-template-columns:1fr}
}

/* ===================================================================
   MOTION LAYER — snazzy, tasteful, performant
=================================================================== */

/* scroll progress bar (injected by app.js) */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:100;background:linear-gradient(90deg,var(--gold),var(--gold-soft));box-shadow:0 0 10px rgba(201,154,59,.6);transition:width .08s linear}

/* animated dot-grid + drifting glow on dark hero sections */
.hero,.page-hero{
  background:
    radial-gradient(rgba(201,154,59,.07) 1px, transparent 1px) 0 0 / 28px 28px,
    linear-gradient(135deg, var(--navy) 0%, var(--navy-2) 100%);
  animation:grid-pan 26s linear infinite;
}
@keyframes grid-pan{from{background-position:0 0,0 0}to{background-position:56px 56px,0 0}}
.hero::before,.page-hero::before{animation:drift 16s ease-in-out infinite alternate}
@keyframes drift{from{transform:translate(0,0) scale(1)}to{transform:translate(-46px,34px) scale(1.18)}}
@media(prefers-reduced-motion:reduce){
  .hero,.page-hero{animation:none}
  .hero::before,.page-hero::before{animation:none}
}

/* gold button shine sweep on hover */
.btn-gold{position:relative;overflow:hidden}
.btn-gold>*{position:relative;z-index:2}
.btn-gold::after{content:"";position:absolute;top:0;left:-160%;width:55%;height:100%;background:linear-gradient(120deg,transparent,rgba(255,255,255,.5),transparent);transform:skewX(-20deg);z-index:1}
.btn-gold:hover::after{animation:shine .85s ease}
@keyframes shine{from{left:-160%}to{left:160%}}

/* enriched scroll reveals */
.js .reveal{opacity:0;transform:translateY(26px) scale(.985);transition:opacity .65s cubic-bezier(.2,.7,.2,1),transform .65s cubic-bezier(.2,.7,.2,1)}
.js .reveal.in{opacity:1;transform:none}

/* animated gold underline that grows under section eyebrows */
.section-head .eyebrow{position:relative;display:inline-block;padding-bottom:12px}
.section-head .eyebrow::after{content:"";position:absolute;left:50%;bottom:0;width:0;height:2px;background:var(--gold);transform:translateX(-50%);transition:width .7s ease .15s}
.section-head.in .eyebrow::after,.reveal.in .section-head .eyebrow::after{width:46px}
.js .section-head{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.js .section-head.in{opacity:1;transform:none}

/* card lift + gold ring on hover */
.card,.proj,.price,.value,.care{transition:transform .2s cubic-bezier(.2,.7,.2,1),box-shadow .2s ease}
.card:hover,.value:hover,.care:hover{transform:translateY(-5px);box-shadow:0 16px 38px rgba(201,154,59,.16)}
.proj:hover{box-shadow:0 18px 44px rgba(14,42,71,.18),0 0 0 1px rgba(201,154,59,.35)}

/* logo hover pop */
header.nav .logo{transition:transform .25s ease}
header.nav a:hover .logo{transform:translateY(-1px) scale(1.02)}

/* animated marquee diamonds already; add gold sheen to trust numbers on view */
.trust .stat strong,.case-hero-stats .s b{transition:none}

/* floating code glyphs in home hero (decorative, behind content) */
.hero-glyphs{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.hero-glyphs span{position:absolute;font-family:var(--disp);font-weight:700;color:rgba(201,154,59,.17);font-size:2.4rem;animation:floaty linear infinite;text-shadow:0 0 18px rgba(201,154,59,.18)}
.hero-canvas{position:absolute;inset:0;z-index:1;pointer-events:none}
.hero::after{z-index:3}
@keyframes floaty{0%{transform:translateY(20px)}100%{transform:translateY(-20px)}}
@media(prefers-reduced-motion:reduce){.hero-glyphs span{animation:none}}

/* ===================================================================
   FLASH PASS 2
=================================================================== */

/* animated wordmark logo (Option C) — gold light sweep */
.logo-word{display:inline-flex;flex-direction:column;line-height:1;position:relative;overflow:hidden;padding:3px 4px}
.logo-word .lw-g{font-family:var(--disp);font-weight:700;font-size:1.5rem;letter-spacing:1px;color:var(--navy)}
.logo-word .lw-d{font-family:var(--disp);font-weight:600;font-size:.82rem;letter-spacing:7px;color:var(--gold-dark);margin-top:3px}
.logo-word::after{content:"";position:absolute;top:0;left:-65%;width:42%;height:100%;background:linear-gradient(110deg,transparent,rgba(201,154,59,.6),transparent);transform:skewX(-18deg);animation:logosweep 6s ease-in-out infinite;pointer-events:none}
@keyframes logosweep{0%{left:-65%}42%{left:135%}100%{left:135%}}
header.nav a:hover .logo-word .lw-g{color:var(--navy-2)}
@media(prefers-reduced-motion:reduce){.logo-word::after{display:none}}

/* shimmering gold accent text in headlines */
.hero h1 .accent,.page-hero h1 .accent,.cta-band h2 .accent{
  background:linear-gradient(100deg,var(--gold) 0%,#f3e3bd 45%,var(--gold) 62%);
  background-size:220% auto;-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;animation:shimmer 5s linear infinite;
}
@keyframes shimmer{to{background-position:220% center}}
@media(prefers-reduced-motion:reduce){.hero h1 .accent,.page-hero h1 .accent,.cta-band h2 .accent{animation:none}}

/* cursor-follow spotlight on cards */
.card,.proj,.value{position:relative;overflow:hidden}
.card::before,.proj::before,.value::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:0;transition:opacity .3s;
  background:radial-gradient(220px circle at var(--mx,50%) var(--my,50%),rgba(201,154,59,.18),transparent 62%)}
.card:hover::before,.proj:hover::before,.value:hover::before{opacity:1}
.card>*,.value>*{position:relative;z-index:1}
.proj>.proj-shot,.proj>.body{position:relative;z-index:1}

/* tilt base */
[data-tilt]{transition:transform .15s ease;transform-style:preserve-3d;will-change:transform}

/* ===================================================================
   PREMIUM LIVE-PREVIEW MOCK (.sp) — the generator's showpiece
=================================================================== */
.sp{background:#fff;font-family:var(--sans);--acc:#CC0000;--accL:#ff6b6b}
.sp-nav{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:11px 16px;background:#fff;border-bottom:1px solid #ededed}
.sp-logo{font-family:var(--disp);font-weight:700;font-size:.82rem;letter-spacing:.4px;text-transform:uppercase;color:#15181d;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:46%}
.sp-menu{display:flex;gap:13px}
.sp-menu i{font-style:normal;font-size:.58rem;color:#9a9ea4;letter-spacing:.3px;font-weight:500}
.sp-navcta{font-family:var(--disp);font-size:.55rem;letter-spacing:.6px;text-transform:uppercase;font-weight:700;color:#fff;background:var(--acc);padding:7px 11px;border-radius:5px;white-space:nowrap}
.sp-hero{position:relative;padding:30px 22px 28px;color:#fff;overflow:hidden;background:linear-gradient(125deg,rgba(8,11,18,.74),rgba(8,11,18,.40) 60%,rgba(8,11,18,.66)),linear-gradient(135deg,var(--acc),#0a0a0c 92%)}
.sp-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 78% 18%,rgba(255,255,255,.16),transparent 46%);pointer-events:none}
.sp-hero::after{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.07) 1px,transparent 1px);background-size:15px 15px;opacity:.55;pointer-events:none}
.sp-hero-in{position:relative;z-index:2}
.sp-tag{font-family:var(--disp);letter-spacing:1.6px;text-transform:uppercase;font-size:.53rem;font-weight:600;color:rgba(255,255,255,.9);margin-bottom:11px;display:inline-flex;gap:7px;align-items:center}
.sp-tag::before{content:"";width:16px;height:2px;background:#fff;display:inline-block;opacity:.85}
.sp-hero h3{font-family:var(--disp);font-weight:700;font-size:1.5rem;line-height:1.02;text-transform:uppercase;margin-bottom:9px;letter-spacing:-.4px;text-shadow:0 2px 16px rgba(0,0,0,.35)}
.sp-hero h3 span{color:#fff;box-shadow:inset 0 -0.28em 0 rgba(255,255,255,.16);border-bottom:3px solid var(--acc);padding-bottom:1px}
.sp-sub{font-size:.63rem;color:rgba(255,255,255,.84);max-width:90%;margin-bottom:15px;line-height:1.55}
.sp-ctas{display:flex;gap:8px;margin-bottom:15px;flex-wrap:wrap}
.sp-ctas span{font-family:var(--disp);font-size:.59rem;letter-spacing:.5px;text-transform:uppercase;font-weight:700;padding:9px 14px;border-radius:6px}
.sp-ctas .c1{color:#fff;background:var(--acc);box-shadow:0 8px 18px rgba(0,0,0,.3)}
.sp-ctas .c2{color:#fff;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.4)}
.sp-trust{display:flex;align-items:center;gap:7px;font-size:.56rem;color:rgba(255,255,255,.82)}
.sp-trust .stars{color:#ffc233;letter-spacing:1.5px;font-size:.62rem}
.sp-trust b{color:#fff}
.sp-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:13px 16px 16px;background:#fafafa}
.sp-cards span{display:flex;flex-direction:column;align-items:center;gap:5px;font-size:.55rem;color:#3c3f44;background:#fff;border:1px solid #ececec;border-radius:8px;padding:11px 6px;font-weight:600;text-align:center;box-shadow:0 3px 8px rgba(14,42,71,.05)}
.sp-cards span::before{content:"";width:24px;height:24px;border-radius:7px;background:var(--acc);opacity:.9;box-shadow:0 3px 8px rgba(0,0,0,.12)}
@media(max-width:430px){.sp-hero h3{font-size:1.28rem}.sp-menu{display:none}}

/* ===================================================================
   PORTFOLIO REAL SCREENSHOTS + COMING-SOON PLACEHOLDERS
=================================================================== */
.proj-img{width:100%;height:236px;object-fit:cover;object-position:top center;display:block;background:#0d2138;border-bottom:4px solid var(--gold)}
.frame-shot{width:100%;display:block;background:#0d2138}
.proj.placeholder{border-top-color:rgba(14,42,71,.16)}
.proj-ph{height:236px;display:flex;align-items:center;justify-content:center;background:repeating-linear-gradient(45deg,#f4f0e5,#f4f0e5 13px,#efe9da 13px,#efe9da 26px);border-bottom:1px dashed rgba(14,42,71,.2)}
.proj-ph .ph-inner{display:flex;flex-direction:column;align-items:center;gap:9px;color:var(--grey-soft);font-family:var(--disp);letter-spacing:1.5px;text-transform:uppercase;font-size:.7rem}
.proj-ph .ph-ico{width:48px;height:48px;border-radius:13px;border:2px dashed rgba(14,42,71,.28);display:flex;align-items:center;justify-content:center;font-size:1.7rem;color:var(--gold-dark);background:rgba(255,255,255,.5)}
.proj.placeholder h3{color:var(--grey-soft)}
.proj.placeholder .meta{color:var(--grey-soft)}
