/* AppsGenii Technologies — appsgenii.us
   Production stylesheet */

/* ==========================================================================
   Variables — brand tokens (AG-Logo.pdf)
   Charcoal #1F2121 · Amber #FAAF15 · White #FFFFFF
   ========================================================================== */
:root {
  --char:   #1F2121;   /* Primary — logo charcoal */
  --char2:  #2C2F2F;   /* Slightly lighter charcoal */
  --char3:  #383C3C;   /* Surface charcoal */
  --amber:  #FAAF15;   /* Brand gold/amber accent */
  --amber2: #E09E0F;   /* Darker amber for hover */
  --amber3: #FFC84A;   /* Lighter amber for tints */
  --smoke:  #F7F7F5;   /* Near-white background */
  --mist:   #EFEFEC;   /* Light gray surface */
  --border: #E2E2DC;   /* Border */
  --mid:    #6B6E6E;   /* Mid gray text */
  --muted:  #8A8D8D;   /* Muted text */
  --white:  #FFFFFF;
  --success:#1A7A4A;
  --warn:   #C07800;
  --ff:     'Manrope', sans-serif;
  --mono:   'Space Mono', monospace;
  --r:      8px;
  --r2:     14px;
  --r3:     22px;
  --sh:     0 1px 3px rgba(31,33,33,.07),0 4px 14px rgba(31,33,33,.05);
  --sh2:    0 4px 24px rgba(31,33,33,.12),0 1px 4px rgba(31,33,33,.07);
}

/* ==========================================================================
   Reset
   ========================================================================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}
body{font-family:var(--ff);color:var(--char);background:var(--white);-webkit-font-smoothing:antialiased;line-height:1.6;}
a{text-decoration:none;color:inherit;}
img{max-width:100%;display:block;}

/* ==========================================================================
   Layout
   ========================================================================== */
.w{max-width:1160px;margin:0 auto;padding:0 32px;}

/* ==========================================================================
   Typography
   ========================================================================== */
.eyebrow{font-family:var(--mono);font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;color:var(--amber2);margin-bottom:10px;}
.eyebrow.light{color:var(--amber3);}
.eyebrow.muted{color:var(--muted);}
.t-hero{font-size:clamp(2.3rem,4.2vw,3.6rem);font-weight:800;line-height:1.06;letter-spacing:-.03em;}
.t-lg{font-size:clamp(1.7rem,3vw,2.4rem);font-weight:800;line-height:1.1;letter-spacing:-.025em;}
.t-md{font-size:1.1rem;font-weight:700;}
.sub{font-size:.98rem;color:var(--mid);line-height:1.72;margin-top:14px;}
.sub.sm{font-size:.85rem;}
.hl{color:var(--amber);}
.bar{width:44px;height:3px;background:var(--amber);border-radius:3px;margin:18px 0;}

/* ==========================================================================
   Buttons
   ========================================================================== */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:var(--r);font-size:.88rem;font-weight:700;transition:all .18s;border:none;font-family:var(--ff);cursor:pointer;}
.btn-amber{background:var(--amber);color:var(--char);box-shadow:0 2px 14px rgba(250,175,21,.4);}
.btn-amber:hover{background:var(--amber2);transform:translateY(-2px);box-shadow:0 6px 22px rgba(250,175,21,.5);}
.btn-char{background:var(--char);color:#fff;}
.btn-char:hover{background:var(--char2);transform:translateY(-1px);}
.btn-outline{background:transparent;color:var(--char);border:1.5px solid var(--border);}
.btn-outline:hover{border-color:var(--amber);color:var(--amber2);background:rgba(250,175,21,.04);}
.btn-outline-w{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.25);}
.btn-outline-w:hover{border-color:var(--amber);color:var(--amber);background:rgba(250,175,21,.06);}
.btn-sm{padding:9px 18px;font-size:.8rem;}

/* ── PILLS ──────────────────────────────────────────────────────────── */
.pill{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:99px;font-family:var(--mono);font-size:.64rem;letter-spacing:.04em;}
.pill-amber{background:rgba(250,175,21,.12);color:var(--warn);border:1px solid rgba(250,175,21,.3);}
.pill-char{background:rgba(31,33,33,.08);color:var(--char);border:1px solid rgba(31,33,33,.15);}
.pill-green{background:rgba(26,122,74,.08);color:var(--success);border:1px solid rgba(26,122,74,.2);}
.pill-muted{background:var(--mist);color:var(--mid);border:1px solid var(--border);}
.pill .dot{width:5px;height:5px;border-radius:50%;background:currentColor;}

/* ==========================================================================
   Header — top bar & navigation
   ========================================================================== */
#topbar{background:var(--char);padding:8px 32px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;}
.tb-l{display:flex;align-items:center;gap:24px;flex-wrap:wrap;}
.tb-i{font-size:.72rem;color:rgba(255,255,255,.55);display:flex;align-items:center;gap:6px;}
.tb-i strong,.tb-i a{color:rgba(255,255,255,.85);}
.tb-i a:hover{color:var(--amber);}
.tb-back{font-size:.72rem;color:rgba(255,255,255,.4);border:1px solid rgba(255,255,255,.15);padding:4px 12px;border-radius:6px;transition:all .15s;}
.tb-back:hover{color:#fff;border-color:rgba(255,255,255,.4);}

/* ── NAV ────────────────────────────────────────────────────────────── */
#nav{position:sticky;top:0;z-index:200;background:var(--char);border-bottom:1px solid rgba(255,255,255,.06);padding:0 32px;height:64px;display:flex;align-items:center;justify-content:space-between;}
.nav-logo img{height: auto; width: 190px;}
.nav-links{display:flex;gap:24px;list-style:none;}
.nav-links a{font-size:.82rem;font-weight:500;color:rgba(255,255,255,.6);transition:color .15s;white-space:nowrap;}
.nav-links a:hover{color:var(--amber);}
.nav-right{display:flex;align-items:center;gap:14px;}
.nav-phone{font-size:.82rem;font-weight:600;color:var(--amber);}

/* ==========================================================================
   Hero
   ========================================================================== */
#hero{background:var(--char);padding:80px 32px 72px;position:relative;overflow:hidden;}
.hero-pattern{position:absolute;inset:0;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23FAAF15' fill-opacity='1'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");}
.hero-glow{position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(250,175,21,.12),transparent 70%);right:-60px;top:-60px;pointer-events:none;}
.hero-glow2{position:absolute;width:400px;height:400px;background:radial-gradient(circle,rgba(250,175,21,.06),transparent 70%);left:-80px;bottom:-80px;pointer-events:none;}
.hero-inner{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:1fr 420px;gap:72px;align-items:center;position:relative;z-index:2;}
.hero-pills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:22px;}
.hero-title{font-size:clamp(2.3rem,4vw,3.5rem);font-weight:800;line-height:1.07;letter-spacing:-.03em;color:#fff;}
.hero-title .hl{color:var(--amber);}
.hero-sub{font-size:1rem;color:rgba(255,255,255,.6);line-height:1.74;margin:20px 0 32px;max-width:540px;}
.hero-sub strong{color:rgba(255,255,255,.85);}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:44px;}
.hero-trust{display:flex;flex-wrap:wrap;gap:16px;padding-top:28px;border-top:1px solid rgba(255,255,255,.08);}
.ht{display:flex;align-items:center;gap:7px;font-size:.76rem;color:rgba(255,255,255,.5);}
.ht strong{color:rgba(255,255,255,.8);}
.ht-check{width:16px;height:16px;border-radius:50%;background:rgba(250,175,21,.2);display:flex;align-items:center;justify-content:center;font-size:.55rem;color:var(--amber);flex-shrink:0;}

/* CRED CARD */
.cred-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:20px;overflow:hidden;}
.cc-head{background:rgba(250,175,21,.1);border-bottom:1px solid rgba(250,175,21,.15);padding:15px 20px;display:flex;align-items:center;justify-content:space-between;}
.cc-head-title{font-family:var(--mono);font-size:.63rem;color:rgba(255,255,255,.45);letter-spacing:.1em;text-transform:uppercase;}
.cc-grade{background:var(--amber);color:var(--char);font-family:var(--mono);font-size:.7rem;font-weight:700;padding:3px 10px;border-radius:5px;}
.cc-body{padding:20px;}
.cc-sec{margin-bottom:14px;}
.cc-label{font-family:var(--mono);font-size:.6rem;color:rgba(255,255,255,.3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px;}
.uei-box{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:7px;padding:11px 13px;display:flex;align-items:center;justify-content:space-between;}
.uei-v{font-family:var(--mono);font-size:.85rem;color:#fff;}
.uei-s{font-size:.68rem;color:var(--amber3);display:flex;align-items:center;gap:4px;}
.code-rows{display:flex;flex-direction:column;gap:5px;}
.code-r{display:flex;align-items:center;gap:10px;padding:7px 11px;border-radius:6px;}
.naics-r{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);}
.nigp-r{background:rgba(250,175,21,.06);border:1px solid rgba(250,175,21,.12);}
.code-v{font-family:var(--mono);font-size:.72rem;font-weight:700;color:var(--amber3);min-width:50px;}
.code-d{font-size:.7rem;color:rgba(255,255,255,.45);}
.comp-tags{display:flex;flex-wrap:wrap;gap:4px;}
.ctag{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:5px;padding:3px 8px;font-family:var(--mono);font-size:.6rem;color:rgba(255,255,255,.5);}
.ctag.ok{color:rgba(250,175,21,.85);border-color:rgba(250,175,21,.2);background:rgba(250,175,21,.06);}
.ctag.ip{color:rgba(255,255,255,.4);}

/* ── SCORE BAR ──────────────────────────────────────────────────────── */
#scorebar{background:var(--mist);border-bottom:1px solid var(--border);padding:26px 32px;}
.sb-inner{max-width:1160px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:18px;}
.sb-grade{display:flex;align-items:center;gap:14px;padding:10px 20px;background:var(--char);border-radius:var(--r2);}
.sb-g-num{font-size:1.5rem;font-weight:800;color:var(--amber);font-family:var(--mono);}
.sb-g-text{font-size:.75rem;color:rgba(255,255,255,.55);}
.sb-g-text strong{color:#fff;display:block;font-size:.85rem;}
.sb-stat{text-align:center;}
.sb-n{font-size:1.7rem;font-weight:800;color:var(--char);line-height:1;font-family:var(--mono);}
.sb-n span{color:var(--amber2);}
.sb-l{font-size:.72rem;color:var(--muted);margin-top:2px;}
.sb-div{width:1px;height:36px;background:var(--border);}

/* ── COMPLIANCE STRIP ───────────────────────────────────────────────── */
#compstrip{background:var(--char2);padding:28px 32px;}
.cs-in{max-width:1160px;margin:0 auto;display:flex;align-items:center;gap:28px;flex-wrap:wrap;justify-content:center;}
.cs-lbl{font-family:var(--mono);font-size:.62rem;color:rgba(255,255,255,.28);letter-spacing:.1em;text-transform:uppercase;white-space:nowrap;}
.cs-bs{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;}
.cs-b{padding:7px 14px;border-radius:7px;text-align:center;border:1px solid;}
.cs-b.ok{background:rgba(250,175,21,.08);border-color:rgba(250,175,21,.2);}
.cs-b.ip{background:rgba(255,255,255,.03);border-color:rgba(255,255,255,.1);}
.cs-bt{font-size:.76rem;font-weight:700;}
.cs-b.ok .cs-bt{color:var(--amber3);}
.cs-b.ip .cs-bt{color:rgba(255,255,255,.4);}
.cs-bs2{font-family:var(--mono);font-size:.58rem;color:rgba(255,255,255,.28);margin-top:1px;}

/* ==========================================================================
   Sections — opportunities
   ========================================================================== */
#opportunities{padding:88px 32px;background:var(--white);}
.opp-intro{max-width:680px;margin-bottom:52px;}
.opp-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;}
.opp-card{border-radius:var(--r2);overflow:hidden;border:1px solid var(--border);transition:all .22s;}
.opp-card:hover{transform:translateY(-5px);box-shadow:var(--sh2);border-color:var(--amber);}
.opp-top{padding:24px 18px 18px;position:relative;}
.opp-top.c1{background:var(--char);}
.opp-top.c2{background:var(--char2);}
.opp-top.c3{background:var(--char3);}
.opp-top.c4{background:#242727;}
.opp-top.c5{background:#1A1C1C;}
.opp-stripe{position:absolute;top:0;left:0;right:0;height:3px;background:var(--amber);}
.opp-num{font-family:var(--mono);font-size:1.8rem;font-weight:700;color:rgba(255,255,255,.08);line-height:1;margin-bottom:10px;}
.opp-icon{font-size:1.5rem;margin-bottom:10px;}
.opp-title{font-size:.85rem;font-weight:700;color:#fff;line-height:1.3;}
.opp-body{padding:14px 18px;background:#fff;}
.opp-desc{font-size:.76rem;color:var(--mid);line-height:1.55;margin-bottom:10px;}
.opp-tags{display:flex;flex-wrap:wrap;gap:4px;}
.opp-tag{background:var(--smoke);color:var(--mid);font-size:.6rem;font-family:var(--mono);padding:2px 7px;border-radius:4px;}

/* ── CASE STUDY ─────────────────────────────────────────────────────── */
#caseStudy{padding:88px 32px;background:var(--smoke);}
.cs-featured{background:var(--char);border-radius:24px;overflow:hidden;margin-top:52px;display:grid;grid-template-columns:1fr 1fr;border:1px solid rgba(255,255,255,.05);}
.csf-l{padding:44px;position:relative;overflow:hidden;}
.csf-bg{position:absolute;inset:0;background:radial-gradient(circle at 90% 10%,rgba(250,175,21,.1),transparent 60%);}
.csf-rfp-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(250,175,21,.1);border:1px solid rgba(250,175,21,.2);border-radius:6px;padding:5px 11px;margin-bottom:14px;position:relative;z-index:1;}
.csf-rfp-t{font-family:var(--mono);font-size:.66rem;color:var(--amber3);}
.csf-title{font-size:1.25rem;font-weight:800;color:#fff;line-height:1.25;margin-bottom:10px;position:relative;z-index:1;}
.csf-agency{font-size:.8rem;color:rgba(255,255,255,.45);margin-bottom:24px;position:relative;z-index:1;}
.csf-meta{display:grid;grid-template-columns:1fr 1fr;gap:10px;position:relative;z-index:1;}
.csf-mi{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:8px;padding:11px 13px;}
.csf-ml{font-family:var(--mono);font-size:.58rem;color:rgba(255,255,255,.3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:2px;}
.csf-mv{font-size:.83rem;font-weight:600;color:#fff;}
.csf-role{margin-top:10px;background:rgba(250,175,21,.08);border:1px solid rgba(250,175,21,.18);border-radius:8px;padding:11px 13px;position:relative;z-index:1;}
.csf-rl{font-family:var(--mono);font-size:.58rem;color:rgba(250,175,21,.6);text-transform:uppercase;letter-spacing:.07em;margin-bottom:2px;}
.csf-rv{font-size:.8rem;color:rgba(255,255,255,.75);}
.csf-r{padding:44px;background:rgba(255,255,255,.02);border-left:1px solid rgba(255,255,255,.06);}
.csf-rt{font-size:.78rem;font-weight:700;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.06em;margin-bottom:14px;}
.csf-tech{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:22px;}
.csf-tt{background:rgba(250,175,21,.08);border:1px solid rgba(250,175,21,.18);border-radius:5px;padding:4px 9px;font-family:var(--mono);font-size:.65rem;color:var(--amber3);}
.csf-outs{display:flex;flex-direction:column;gap:9px;}
.csf-out{display:flex;align-items:flex-start;gap:10px;padding:11px 13px;background:rgba(250,175,21,.06);border:1px solid rgba(250,175,21,.12);border-radius:7px;}
.csf-oc{width:17px;height:17px;border-radius:50%;background:rgba(250,175,21,.2);display:flex;align-items:center;justify-content:center;font-size:.55rem;color:var(--amber);flex-shrink:0;margin-top:1px;}
.csf-ot{font-size:.76rem;color:rgba(255,255,255,.65);line-height:1.45;}
.csf-ot strong{color:var(--amber3);}
/* locked */
.cs-locked-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px;}
.cs-locked{border:1.5px dashed var(--border);border-radius:var(--r2);padding:28px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;background:#fff;}
.cs-lock-ico{font-size:1.6rem;color:var(--muted);}
.cs-lock-t{font-size:.85rem;font-weight:700;color:var(--char);}
.cs-lock-s{font-size:.74rem;color:var(--muted);line-height:1.5;}

/* ── SERVICES ───────────────────────────────────────────────────────── */
#services{padding:88px 32px;background:var(--white);}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:52px;}
.svc-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r2);padding:28px;transition:all .22s;position:relative;overflow:hidden;}
.svc-stripe{position:absolute;top:0;left:0;right:0;height:3px;background:var(--amber);transform:scaleX(0);transform-origin:left;transition:transform .3s;}
.svc-card:hover{box-shadow:var(--sh2);transform:translateY(-3px);border-color:rgba(250,175,21,.3);}
.svc-card:hover .svc-stripe{transform:scaleX(1);}
.svc-ico{width:44px;height:44px;border-radius:12px;background:rgba(250,175,21,.1);display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin-bottom:4px;}
.svc-naics{font-family:var(--mono);font-size:.6rem;color:var(--amber2);letter-spacing:.05em;margin:10px 0 6px;}
.svc-title{font-size:.95rem;font-weight:700;color:var(--char);margin-bottom:7px;}
.svc-desc{font-size:.8rem;color:var(--mid);line-height:1.65;margin-bottom:14px;}
.svc-tags{display:flex;flex-wrap:wrap;gap:4px;}
.svc-tag{background:var(--smoke);color:var(--mid);font-size:.62rem;font-family:var(--mono);padding:3px 8px;border-radius:4px;}

/* ── STATES ─────────────────────────────────────────────────────────── */
#states{padding:88px 32px;background:var(--char);}
.state-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:52px;}
.state-tile{border-radius:var(--r2);padding:18px;border:1px solid rgba(255,255,255,.07);transition:all .2s;}
.state-tile:hover{border-color:rgba(250,175,21,.4);background:rgba(250,175,21,.04);transform:translateY(-3px);}
.st-abbr{font-family:var(--mono);font-size:.6rem;color:rgba(255,255,255,.3);letter-spacing:.1em;margin-bottom:3px;}
.st-name{font-size:.95rem;font-weight:700;color:#fff;margin-bottom:4px;}
.st-spend{font-size:.7rem;color:rgba(255,255,255,.4);margin-bottom:6px;}
.st-spend strong{color:rgba(255,255,255,.7);}
.st-focus{font-size:.67rem;color:rgba(255,255,255,.28);line-height:1.45;border-top:1px solid rgba(255,255,255,.06);padding-top:7px;margin-top:4px;}
.st-ph{display:inline-block;margin-top:7px;font-family:var(--mono);font-size:.58rem;font-weight:700;padding:2px 8px;border-radius:99px;}
.ph1{background:rgba(250,175,21,.2);color:var(--amber3);}
.ph2{background:rgba(255,255,255,.07);color:rgba(255,255,255,.45);}
.coop-row{margin-top:48px;padding-top:40px;border-top:1px solid rgba(255,255,255,.07);}
.coop-row-t{font-size:.95rem;font-weight:700;color:#fff;margin-bottom:16px;}
.coop-pills{display:flex;flex-wrap:wrap;gap:9px;}
.coop-pill{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.09);border-radius:9px;padding:9px 15px;transition:all .18s;}
.coop-pill:hover{border-color:rgba(250,175,21,.3);}
.coop-n{font-size:.8rem;font-weight:700;color:#fff;margin-bottom:1px;}
.coop-d{font-size:.66rem;color:rgba(255,255,255,.3);}

/* ── HOW + WHY ──────────────────────────────────────────────────────── */
#howwework{padding:88px 32px;background:var(--smoke);}
.hww-inner{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:400px 1fr;gap:64px;align-items:start;}
.hww-left{position:sticky;top:80px;}
.hww-steps{display:flex;flex-direction:column;margin-top:40px;}
.hww-step{display:flex;gap:18px;padding-bottom:28px;position:relative;}
.hww-step:not(:last-child)::before{content:'';position:absolute;left:17px;top:40px;bottom:0;width:2px;background:linear-gradient(to bottom,var(--amber),transparent);}
.hww-num{width:36px;height:36px;border-radius:50%;background:var(--char);border:2px solid var(--amber);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:.75rem;font-weight:700;color:var(--amber);flex-shrink:0;z-index:1;}
.hww-t{font-size:.9rem;font-weight:700;color:var(--char);margin-bottom:4px;}
.hww-d{font-size:.78rem;color:var(--mid);line-height:1.6;}
.why-pts{display:flex;flex-direction:column;gap:12px;margin-top:16px;}
.why-pt{display:flex;gap:13px;padding:15px 17px;border-radius:var(--r2);background:var(--white);border:1px solid var(--border);transition:all .18s;}
.why-pt:hover{border-color:rgba(250,175,21,.35);box-shadow:var(--sh);}
.why-ico{width:36px;height:36px;border-radius:9px;background:rgba(250,175,21,.1);display:flex;align-items:center;justify-content:center;font-size:.95rem;flex-shrink:0;}
.why-t{font-size:.86rem;font-weight:700;color:var(--char);margin-bottom:3px;}
.why-d{font-size:.77rem;color:var(--mid);line-height:1.58;}

/* ── CAPABILITY STMT ────────────────────────────────────────────────── */
#capstmt{padding:52px 32px;background:var(--white);border-top:1px solid var(--border);}
.cap-in{max-width:1160px;margin:0 auto;background:var(--char);border-radius:22px;padding:44px 48px;display:grid;grid-template-columns:1fr auto;gap:44px;align-items:center;}
.cap-title{font-size:1.45rem;font-weight:800;color:#fff;margin-bottom:8px;letter-spacing:-.02em;}
.cap-sub{font-size:.85rem;color:rgba(255,255,255,.45);line-height:1.65;max-width:520px;}
.cap-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:16px;}
.cap-chip{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:5px;padding:4px 10px;font-size:.7rem;color:rgba(255,255,255,.55);}
.cap-btns{display:flex;flex-direction:column;gap:10px;flex-shrink:0;}

/* ==========================================================================
   Forms — contact
   ========================================================================== */
#contact{padding:88px 32px;background:var(--smoke);}
.contact-inner{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:1fr 420px;gap:52px;align-items:start;}
.contact-form{position:relative;background:var(--white);border:1px solid var(--border);border-radius:var(--r3);padding:34px;box-shadow:var(--sh);}
.f-honeypot{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none;white-space:nowrap;}
.recaptcha-wrap{position:absolute;width:0;height:0;left:0;top:0;overflow:visible;opacity:0;pointer-events:none;z-index:-1;margin:0;padding:0;}
.contact-form,#contact{overflow:visible;}
.cf-title{font-size:1.05rem;font-weight:700;color:var(--char);margin-bottom:4px;}
.cf-sub{font-size:.8rem;color:var(--muted);margin-bottom:20px;}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px;}
.f-field{margin-bottom:12px;}
.f-field label{display:block;font-size:.74rem;font-weight:600;color:var(--char);margin-bottom:4px;}
.f-field input,.f-field select,.f-field textarea{width:100%;padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--r);font-size:.83rem;font-family:var(--ff);color:var(--char);background:var(--white);transition:border-color .15s;}
.f-field input:focus,.f-field select:focus,.f-field textarea:focus{outline:none;border-color:var(--amber);}
.f-field textarea{resize:vertical;min-height:84px;}
.f-field.is-invalid input,.f-field.is-invalid textarea{border-color:#c0392b;}
.f-field.is-invalid input:focus,.f-field.is-invalid textarea:focus{border-color:#c0392b;}
.f-error{display:none;font-size:.72rem;color:#c0392b;margin-top:4px;line-height:1.4;}
.f-field.is-invalid .f-error{display:block;}
.cf-alert{display:none;font-size:.8rem;padding:12px 14px;border-radius:var(--r);margin-top:14px;line-height:1.5;}
.cf-alert.is-visible{display:block;}
.cf-alert--success{background:rgba(26,122,74,.08);border:1px solid rgba(26,122,74,.2);color:var(--success);}
.cf-alert--error{background:rgba(192,57,43,.06);border:1px solid rgba(192,57,43,.2);color:#a93226;}
#contactSubmit:disabled{opacity:.65;cursor:not-allowed;transform:none;box-shadow:none;}
#contactSubmit.is-loading{pointer-events:none;}
.ci-title{font-size:1rem;font-weight:700;color:var(--char);margin-bottom:18px;}
.ci-list{display:flex;flex-direction:column;gap:14px;margin-bottom:22px;}
.ci-item{display:flex;gap:12px;align-items:flex-start;}
.ci-ico{width:36px;height:36px;border-radius:9px;background:rgba(250,175,21,.1);display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0;}
.ci-lbl{font-size:.68rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1px;}
.ci-val{font-size:.86rem;color:var(--char);font-weight:500;}
.ci-val a{color:var(--amber2);}
.collabp-box{background:rgba(250,175,21,.06);border:1px solid rgba(250,175,21,.2);border-radius:var(--r2);padding:16px 18px;}
.cb-top{display:flex;align-items:center;gap:8px;margin-bottom:7px;}
.cb-ico{font-size:1rem;}
.cb-title{font-size:.8rem;font-weight:700;color:var(--amber2);}
.cb-body{font-size:.76rem;color:var(--mid);line-height:1.55;}
.cb-body strong{color:var(--warn);}

/* ==========================================================================
   Footer
   ========================================================================== */
footer{background:var(--char);padding:48px 32px 28px;border-top:1px solid rgba(255,255,255,.06);}
.footer-grid{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:40px;margin-bottom:36px;}
.fb-desc{font-size:.77rem;color:rgba(255,255,255,.3);line-height:1.65;margin:10px 0 12px;}
.fb-addr{font-family:var(--mono);font-size:.64rem;color:rgba(255,255,255,.2);line-height:1.7;}
.fc-title{font-size:.7rem;font-weight:700;color:rgba(255,255,255,.38);text-transform:uppercase;letter-spacing:.07em;margin-bottom:13px;}
.fc-links{list-style:none;display:flex;flex-direction:column;gap:8px;}
.fc-links a{font-size:.77rem;color:rgba(255,255,255,.28);transition:color .15s;}
.fc-links a:hover{color:var(--amber);}
.footer-bottom{max-width:1160px;margin:0 auto;padding-top:20px;border-top:1px solid rgba(255,255,255,.05);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;}
.footer-copy{font-size:.7rem;color:rgba(255,255,255,.17);}
.footer-note{font-family:var(--mono);font-size:.6rem;color:rgba(255,255,255,.15);text-align:center;max-width:1160px;margin:12px auto 0;}

/* ==========================================================================
   Animations
   ========================================================================== */
.rv{opacity:0;transform:translateY(20px);transition:opacity .55s ease,transform .55s ease;}
.rv.in{opacity:1;transform:none;}
.rv:nth-child(2){transition-delay:.08s;}
.rv:nth-child(3){transition-delay:.15s;}
.rv:nth-child(4){transition-delay:.22s;}
.rv:nth-child(5){transition-delay:.29s;}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media(max-width:1020px){
  .hero-inner,.hww-inner,.cap-in,.contact-inner{grid-template-columns:1fr;gap:36px;}
  .opp-grid{grid-template-columns:repeat(3,1fr);}
  .svc-grid{grid-template-columns:1fr 1fr;}
  .cs-featured{grid-template-columns:1fr;}
  .state-grid{grid-template-columns:1fr 1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px;}
  .nav-links{display:none;}

}
@media(max-width:640px){
  .opp-grid{grid-template-columns:1fr 1fr;}
  .svc-grid{grid-template-columns:1fr;}
  .cs-locked-grid{grid-template-columns:1fr;}
  .state-grid{grid-template-columns:1fr 1fr;}
  .f-row{grid-template-columns:1fr;}
  .hero-inner{gap:40px;}
  .nav-phone {
      display: none;
  }
  #nav {
      padding-bottom: 10px !important;
  }
   .tb-l {
      gap: 6px !important;
   }
}

/* Utilities */
.cc-sec-last { margin-bottom: 0; }
.sub-narrow { max-width: 560px; }
.intro-narrow { max-width: 600px; }
.intro-wide { max-width: 640px; }
.t-lg-light { color: #fff; }
.sub-on-dark { color: rgba(255,255,255,.45); }
.ci-list-spaced { margin-top: 24px; }
.btn-mt { margin-top: 8px; }
.btn-full { width: 100%; justify-content: center; padding: 14px 0; }
.footer-logo { margin-bottom: 10px; width: 200px; height: auto; }
.footer-note a { color: rgba(255,255,255,.2); transition: color 0.15s; }
.footer-note a:hover { color: var(--amber); }

/* ==========================================================================
   Google reCAPTCHA badge — stable rendering (no flicker / clip)
   ========================================================================== */
.grecaptcha-badge,
body > .grecaptcha-badge,
body > div > .grecaptcha-badge {
  position: fixed !important;
  bottom: 20px !important;
  right: 20px !important;
  z-index: 999999 !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  animation: none !important;
  transition: none !important;
  filter: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  will-change: auto !important;
  contain: layout style !important;
  isolation: isolate !important;
  backface-visibility: visible !important;
  box-shadow: none !important;
  pointer-events: auto !important;
}

.grecaptcha-badge iframe,
iframe[src*="recaptcha"],
iframe[src*="google.com/recaptcha"],
iframe[title*="reCAPTCHA"] {
  transform: none !important;
  animation: none !important;
  transition: none !important;
  filter: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  opacity: 1 !important;
  visibility: visible !important;
  will-change: auto !important;
}

div[style*="recaptcha"] iframe {
  transform: none !important;
  animation: none !important;
  transition: none !important;
}

#hero .cred-card {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.grecaptcha-badge,
.grecaptcha-badge iframe,
iframe[src*="recaptcha"] {
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
}