/* ========================================
   EXOS — Shared stylesheet
   Used by: index.html, platform.html, advisory.html
   ======================================== */

*{margin:0;padding:0;box-sizing:border-box}
:root{
  --white:#ffffff;
  --off-white:#f8f7f4;
  --light:#f0eeea;
  --light2:#e8e5df;
  --dark:#0e0e0e;
  --dark2:#1a1a1a;
  --text1:#111111;
  --text2:#444440;
  --text3:#888882;
  --green:#1b4d35;
  --green2:#225f42;
  --green3:#2d7a55;
  --green-light:#e8f2ec;
  --green-mid:#c2dccb;
  --gold:#b8924a;
  --gold2:#c8a060;
  --gold-light:#f5ede0;
  --gold-mid:#e8d0a8;
  --border:#e0ddd8;
  --border2:#c8c4bc;
  --outfit:'Outfit',sans-serif;
  --mono:'DM Mono',monospace;
}
html{scroll-behavior:smooth}
/* Offset anchor scroll targets to clear the fixed 68px nav */
:target,
[id="architecture"],[id="governance"],[id="philosophy"],[id="cases"],[id="services"]{scroll-margin-top:84px}
body{background:var(--white);color:var(--text1);font-family:var(--outfit);overflow-x:hidden;-webkit-font-smoothing:antialiased}

/* ========================================
   NAV
   ======================================== */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:0 56px;height:68px;display:flex;align-items:center;justify-content:space-between;background:rgba(255,255,255,0.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.nav-logo{display:flex;align-items:center;gap:0;text-decoration:none}
.logo-text{font-family:var(--outfit);font-size:26px;font-weight:800;letter-spacing:-0.04em;color:var(--text1);line-height:1}
.logo-x{color:var(--green);position:relative;display:inline-block}
.logo-x::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--gold)}
.nav-center{display:flex;align-items:center;gap:4px;padding:4px;background:var(--off-white);border:1px solid var(--border);border-radius:4px}
.nav-tab{font-family:var(--outfit);font-size:12px;font-weight:600;color:var(--text2);text-decoration:none;padding:7px 16px;border-radius:3px;letter-spacing:0.01em;transition:all 0.2s;white-space:nowrap}
.nav-tab.active{background:var(--white);color:var(--green);box-shadow:0 1px 3px rgba(0,0,0,0.04)}
.nav-tab:hover:not(.active){color:var(--text1)}
.nav-cta{font-family:var(--outfit);font-size:13px;font-weight:600;padding:10px 20px;background:var(--green);color:var(--white);border-radius:3px;text-decoration:none;letter-spacing:0.01em;transition:all 0.2s}
.nav-cta:hover{background:var(--green2);transform:translateY(-1px)}

/* ========================================
   BUTTONS
   ======================================== */
.btn-primary{font-family:var(--outfit);font-size:13px;font-weight:600;padding:14px 26px;background:var(--green);color:var(--white);border-radius:3px;text-decoration:none;letter-spacing:0.01em;transition:all 0.2s;display:inline-flex;align-items:center;gap:8px}
.btn-primary:hover{background:var(--green2);transform:translateY(-1px)}
.btn-ghost{font-family:var(--outfit);font-size:13px;font-weight:500;padding:14px 26px;background:transparent;color:var(--text2);border:1.5px solid var(--border2);border-radius:3px;text-decoration:none;letter-spacing:0.01em;transition:all 0.2s}
.btn-ghost:hover{border-color:var(--green);color:var(--green)}
.btn-gold{font-family:var(--outfit);font-size:13px;font-weight:600;padding:14px 26px;background:var(--gold);color:var(--dark);border-radius:3px;text-decoration:none;letter-spacing:0.01em;transition:all 0.2s;display:inline-flex;align-items:center;gap:8px}
.btn-gold:hover{background:var(--gold2);transform:translateY(-1px)}
.btn-dark-ghost{font-family:var(--outfit);font-size:13px;font-weight:500;padding:14px 26px;background:transparent;color:rgba(255,255,255,0.85);border:1.5px solid rgba(255,255,255,0.25);border-radius:3px;text-decoration:none;letter-spacing:0.01em;transition:all 0.2s}
.btn-dark-ghost:hover{border-color:var(--gold2);color:var(--gold2)}

/* ========================================
   COMMON SECTION SCAFFOLDING
   ======================================== */
.section-wrap{padding:100px 56px}
.section-inner{max-width:1100px;margin:0 auto;width:100%}
.section-label{font-family:var(--mono);font-size:10px;color:var(--green3);letter-spacing:0.12em;text-transform:uppercase;margin-bottom:16px;display:flex;align-items:center;gap:10px}
.section-label::before{content:'';width:24px;height:1.5px;background:var(--gold)}
.section-title{font-family:var(--outfit);font-size:clamp(30px,3.5vw,48px);font-weight:800;letter-spacing:-0.02em;line-height:1.05;margin-bottom:16px;color:var(--text1)}
.section-title em{font-style:normal;color:var(--green)}
.section-sub{font-size:16px;color:var(--text2);line-height:1.7;max-width:620px;font-weight:400}

/* ========================================
   HERO (shared structure across all pages)
   ======================================== */
.hero{min-height:100vh;display:flex;align-items:center;padding:100px 0 0;background:var(--white);position:relative;overflow:hidden}
.hero.hero-short{min-height:auto;padding:140px 0 80px}
.hero-bg-shape{position:absolute;right:-80px;top:0;bottom:0;width:55%;overflow:hidden}
.hero-bg-shape::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--green) 0%,#0d3321 60%,#071a11 100%)}
.hero-bg-shape::after{content:'';position:absolute;left:-120px;top:0;bottom:0;width:240px;background:var(--white);transform:skewX(-8deg);transform-origin:top left}
.x-line{position:absolute;background:linear-gradient(135deg,var(--gold2),var(--gold));opacity:0.35}
.x-line-1{width:600px;height:3px;top:35%;left:-50px;transform:rotate(-35deg)}
.x-line-2{width:600px;height:3px;top:65%;left:-50px;transform:rotate(35deg)}
.x-line-3{width:3px;height:100%;left:50%;top:0;opacity:0.12;background:var(--gold2)}
.hero-swirl{position:absolute;right:0;top:0;bottom:0;width:100%;background:radial-gradient(ellipse at 85% 30%,rgba(184,146,74,0.25) 0%,transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(45,122,85,0.3) 0%,transparent 45%)}

.hero-inner{position:relative;z-index:2;max-width:1200px;margin:0 auto;padding:0 56px;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:center;min-height:calc(100vh - 68px)}
.hero.hero-short .hero-inner{min-height:auto}
.hero-left{padding-right:60px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10px;color:var(--green3);letter-spacing:0.1em;text-transform:uppercase;margin-bottom:28px;padding:6px 14px;border:1px solid var(--green-mid);border-radius:2px;background:var(--green-light)}
.hero-eyebrow::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--green3);animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}
.hero-headline{font-family:var(--outfit);font-size:clamp(38px,4.3vw,62px);font-weight:800;line-height:1.02;letter-spacing:-0.03em;margin-bottom:8px;color:var(--text1)}
.hero-headline-2{font-family:var(--outfit);font-size:clamp(38px,4.3vw,62px);font-weight:300;line-height:1.02;letter-spacing:-0.03em;margin-bottom:28px;color:var(--text1)}
.hero-headline-2 em{font-style:normal;color:var(--green);font-weight:700}
.hero-sub{font-size:17px;color:var(--text2);line-height:1.7;margin-bottom:36px;font-weight:400;max-width:500px}
.hero-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:24px}
.hero-meta{font-family:var(--mono);font-size:11px;color:var(--text3);letter-spacing:0.04em}
.hero-meta a{color:var(--green);text-decoration:none;font-weight:500;border-bottom:1px dotted var(--green-mid);padding-bottom:1px}
.hero-meta a:hover{color:var(--green2);border-bottom-color:var(--green)}

.hero-right{position:relative;display:flex;align-items:center;justify-content:center;height:100%}
.hero-wordmark{color:rgba(255,255,255,0.08);font-family:var(--outfit);font-size:180px;font-weight:800;letter-spacing:-0.05em;line-height:1;user-select:none;position:absolute;right:-20px}
.hero-card{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);border-radius:6px;padding:28px 32px;width:340px;backdrop-filter:blur(4px)}
.hc-label{font-family:var(--mono);font-size:9px;color:rgba(200,160,96,0.8);letter-spacing:0.1em;text-transform:uppercase;margin-bottom:18px;display:flex;align-items:center;gap:8px}
.hc-label::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--gold2);animation:blink 2s infinite}
.hc-stat{margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,0.08)}
.hc-stat:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}
.hc-stat-label{font-size:11px;color:rgba(255,255,255,0.5);margin-bottom:4px;font-weight:300}
.hc-stat-val{font-family:var(--outfit);font-size:20px;font-weight:700;color:var(--white);letter-spacing:-0.02em}
.hc-stat-val span{font-size:12px;font-weight:400;color:rgba(255,255,255,0.5);margin-left:4px}

/* ========================================
   TRUST STRIP
   ======================================== */
.trust-strip{background:var(--green);padding:32px 56px;display:flex;justify-content:center;align-items:center;gap:48px;flex-wrap:wrap}
.trust-strip-label{font-family:var(--mono);font-size:10px;color:rgba(200,160,96,0.7);letter-spacing:0.12em;text-transform:uppercase;white-space:nowrap}
.trust-strip-item{font-size:13px;color:rgba(255,255,255,0.8);font-weight:400;letter-spacing:0.01em;display:flex;align-items:center;gap:10px}
.trust-strip-item::before{content:'';width:4px;height:4px;border-radius:50%;background:var(--gold2);flex-shrink:0}

/* ========================================
   PROBLEM CARDS
   ======================================== */
.problem{background:var(--off-white)}
.problem-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1.5px solid var(--border2);border-radius:4px;overflow:hidden;margin-top:56px}
.problem-card{background:var(--white);padding:40px 32px;border-right:1.5px solid var(--border2);position:relative;overflow:hidden;min-width:0}
.problem-card:last-child{border-right:none}
.problem-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--green),var(--gold2))}
.p-num{font-family:var(--mono);font-size:10px;color:var(--text3);letter-spacing:0.08em;margin-bottom:20px}
.p-title{font-family:var(--outfit);font-size:19px;font-weight:700;color:var(--text1);margin-bottom:12px;letter-spacing:-0.01em}
.p-body{font-size:14px;color:var(--text2);line-height:1.7;font-weight:400}

/* ========================================
   PLATFORM TEASER (condensed platform preview on homepage)
   ======================================== */
.pt-section{background:var(--white);padding:100px 56px}
.pt-inner{max-width:1100px;margin:0 auto;width:100%}
.pt-header{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:end;margin-bottom:56px}
.pt-note{font-family:var(--mono);font-size:11px;color:var(--text3);letter-spacing:0.04em;margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}
.pt-note strong{color:var(--green);font-weight:600}
.pt-split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.pt-col-label{font-family:var(--mono);font-size:10px;color:var(--green3);letter-spacing:0.12em;text-transform:uppercase;margin-bottom:16px;display:flex;align-items:center;gap:10px}
.pt-col-label::before{content:'';width:18px;height:1.5px;background:var(--gold)}
/* Architecture chip row (condensed — single line per layer) */
.pt-arch{display:flex;flex-direction:column;gap:6px}
.pt-arch-row{display:grid;grid-template-columns:120px 1fr;gap:12px;padding:10px 14px;background:var(--off-white);border:1px solid var(--border);border-radius:3px;align-items:center}
.pt-arch-label{font-family:var(--mono);font-size:10px;color:var(--text2);letter-spacing:0.04em;font-weight:600}
.pt-arch-chips{display:flex;flex-wrap:wrap;gap:5px}
.pt-chip{font-family:var(--mono);font-size:9px;padding:2px 8px;border-radius:2px;background:var(--white);border:1px solid var(--border2);color:var(--text3)}
.pt-chip.green{background:var(--green-light);border-color:var(--green-mid);color:var(--green3)}
.pt-chip.gold{background:var(--gold-light);border-color:var(--gold-mid);color:var(--gold)}
/* Modes preview — 5 stacked rows */
.pt-modes{display:flex;flex-direction:column;gap:6px}
.pt-mode-row{display:grid;grid-template-columns:32px 1fr;gap:12px;padding:12px 14px;background:var(--off-white);border:1px solid var(--border);border-radius:3px;align-items:center;transition:all 0.2s}
.pt-mode-row:hover{border-color:var(--green-mid);background:var(--green-light)}
.pt-mode-letter{font-family:var(--outfit);font-size:18px;font-weight:800;color:var(--green);letter-spacing:-0.03em;text-align:center}
.pt-mode-meta{display:flex;flex-direction:column}
.pt-mode-name{font-family:var(--outfit);font-size:13px;font-weight:700;color:var(--text1);letter-spacing:-0.01em}
.pt-mode-desc{font-family:var(--mono);font-size:10px;color:var(--text3);letter-spacing:0.02em;margin-top:2px}

/* ========================================
   OUTCOMES (5 pillars)
   ======================================== */
.outcomes{background:var(--white)}
.outcomes-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:0;border:1.5px solid var(--border2);border-radius:4px;overflow:hidden;margin-top:56px}
.outcome-card{background:var(--white);padding:32px 20px;border-right:1.5px solid var(--border2);position:relative;overflow:hidden;transition:background 0.2s;min-width:0}
.outcome-card:last-child{border-right:none}
.outcome-card:hover{background:var(--off-white)}
.outcome-card::before{content:'';position:absolute;top:0;left:0;width:0;height:3px;background:linear-gradient(90deg,var(--green),var(--gold2));transition:width 0.3s}
.outcome-card:hover::before{width:100%}
.outcome-num{font-family:var(--mono);font-size:10px;color:var(--text3);letter-spacing:0.08em;margin-bottom:20px}
.outcome-title{font-family:var(--outfit);font-size:15px;font-weight:700;color:var(--text1);margin-bottom:10px;letter-spacing:-0.01em;line-height:1.25}
.outcome-body{font-size:12px;color:var(--text2);line-height:1.6;font-weight:400}

/* ========================================
   VERTICALS
   ======================================== */
.verticals{background:var(--off-white);padding:100px 56px}
.vert-inner{max-width:1100px;margin:0 auto}
.vert-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1.5px solid var(--border2);border-radius:4px;overflow:hidden;margin-top:56px}
.vert-card{background:var(--white);padding:36px 28px;border-right:1.5px solid var(--border2);transition:background 0.2s;position:relative;overflow:hidden;min-width:0}
.vert-card:last-child{border-right:none}
.vert-card:hover{background:var(--green-light)}
.vert-top-bar{height:3px;width:0;background:linear-gradient(90deg,var(--green),var(--gold2));position:absolute;top:0;left:0;transition:width 0.3s}
.vert-card:hover .vert-top-bar{width:100%}
.vert-sector{font-family:var(--mono);font-size:9px;color:var(--text3);letter-spacing:0.1em;text-transform:uppercase;margin-bottom:16px}
.vert-name{font-family:var(--outfit);font-size:19px;font-weight:800;color:var(--text1);margin-bottom:10px;letter-spacing:-0.01em}
.vert-pain{font-size:13px;color:var(--text3);line-height:1.6;margin-bottom:14px;font-style:italic;border-left:2px solid var(--gold-mid);padding-left:10px}
.vert-buyer{font-family:var(--mono);font-size:10px;color:var(--green3);letter-spacing:0.04em;margin-bottom:12px}
.vert-solution{font-size:13px;color:var(--text2);line-height:1.65;font-weight:400}

/* ========================================
   GOVERNANCE (CIO / compliance buyer section)
   ======================================== */
.gov-section{background:var(--dark);padding:100px 56px;color:var(--white);position:relative;overflow:hidden}
.gov-section::before{content:'';position:absolute;top:0;right:0;width:60%;height:100%;background:radial-gradient(ellipse at top right,rgba(27,77,53,0.35) 0%,transparent 65%)}
.gov-section::after{content:'';position:absolute;bottom:-50px;left:-50px;width:260px;height:260px;border:2px solid rgba(184,146,74,0.12);transform:rotate(45deg)}
.gov-inner{position:relative;max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:center}
.gov-label{font-family:var(--mono);font-size:10px;color:var(--gold2);letter-spacing:0.12em;text-transform:uppercase;margin-bottom:16px;display:flex;align-items:center;gap:10px}
.gov-label::before{content:'';width:24px;height:1.5px;background:var(--gold2)}
.gov-title{font-family:var(--outfit);font-size:clamp(28px,3vw,42px);font-weight:800;letter-spacing:-0.02em;line-height:1.1;margin-bottom:20px;color:var(--white)}
.gov-title em{font-style:normal;color:var(--gold2)}
.gov-body{font-size:15px;color:rgba(255,255,255,0.7);line-height:1.75;margin-bottom:32px;font-weight:400}
.gov-actions{display:flex;gap:14px;flex-wrap:wrap}
.gov-check-list{list-style:none;display:flex;flex-direction:column;gap:0}
.gov-check-list li{padding:16px 0;border-bottom:1px solid rgba(255,255,255,0.08);display:flex;gap:14px;align-items:flex-start;font-size:13px;color:rgba(255,255,255,0.85);line-height:1.55}
.gov-check-list li:first-child{border-top:1px solid rgba(255,255,255,0.08)}
.gov-check-icon{width:20px;height:20px;border-radius:50%;background:rgba(184,146,74,0.15);border:1px solid rgba(184,146,74,0.3);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.gov-check-icon svg{width:10px;height:10px;stroke:var(--gold2);fill:none;stroke-width:2.5}
.gov-check-label{font-family:var(--mono);font-size:10px;color:var(--gold2);letter-spacing:0.06em;display:block;margin-bottom:3px;text-transform:uppercase}

/* ========================================
   LEAVE-BEHIND
   ======================================== */
.lb-section{background:var(--white);padding:100px 56px}
.lb-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.lb-visual{background:var(--off-white);border:1.5px solid var(--border2);border-radius:4px;padding:40px;position:relative;overflow:hidden}
.lb-visual::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--green),var(--gold2))}
.lb-vis-label{font-family:var(--mono);font-size:9px;color:var(--text3);letter-spacing:0.1em;text-transform:uppercase;margin-bottom:20px}
.lb-layer{background:var(--white);border:1px solid var(--border);border-radius:3px;padding:12px 16px;margin-bottom:8px;font-size:12px;color:var(--text2);display:flex;justify-content:space-between;align-items:center;transition:all 0.2s}
.lb-layer.active{border-color:var(--green-mid);background:var(--green-light)}
.lb-layer.active .lb-layer-title{color:var(--green)}
.lb-layer-title{font-weight:600;color:var(--text1);font-size:12px}
.lb-layer-meta{font-family:var(--mono);font-size:10px;color:var(--text3)}
.lb-layer.active .lb-layer-meta{color:var(--green3)}

/* ========================================
   CASE STUDIES (compact teaser cards)
   ======================================== */
.cases-section{background:var(--off-white);padding:100px 56px}
.cases-inner{max-width:1100px;margin:0 auto}
.cases-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:48px}
.case-card{background:var(--white);border:1.5px solid var(--border2);border-radius:4px;padding:28px;position:relative;overflow:hidden;transition:all 0.25s;display:flex;flex-direction:column;cursor:pointer}
.case-card:hover{border-color:var(--green);transform:translateY(-2px);box-shadow:0 8px 24px rgba(27,77,53,0.06)}
.case-card.featured{grid-column:span 2;background:linear-gradient(135deg,var(--white) 0%,var(--green-light) 100%);border-color:var(--green-mid)}
.case-meta{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.case-tag{font-family:var(--mono);font-size:9px;padding:3px 9px;border-radius:2px;background:var(--green-light);border:1px solid var(--green-mid);color:var(--green3);letter-spacing:0.06em;text-transform:uppercase}
.case-tag.gold{background:var(--gold-light);border-color:var(--gold-mid);color:var(--gold)}
.case-tag.public{background:transparent;border-color:var(--green3);color:var(--green3);display:inline-flex;align-items:center;gap:5px}
.case-tag.public::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--green3)}
.case-title{font-family:var(--outfit);font-size:17px;font-weight:700;color:var(--text1);margin-bottom:10px;letter-spacing:-0.01em;line-height:1.3}
.case-card.featured .case-title{font-size:22px}
.case-card.featured .case-title em{font-style:normal;color:var(--green)}
.case-summary{font-size:13px;color:var(--text2);line-height:1.6;margin-bottom:18px;flex:1;font-weight:400}
.case-card.featured .case-summary{font-size:14px}
.case-link{display:inline-flex;align-items:center;gap:6px;font-family:var(--outfit);font-size:12px;font-weight:600;color:var(--green);text-decoration:none;letter-spacing:0.01em;align-self:flex-start;transition:gap 0.2s}
.case-card:hover .case-link{gap:10px}
.case-source{font-family:var(--mono);font-size:10px;color:var(--text3);margin-top:10px;letter-spacing:0.02em}
.case-source a{color:var(--green3);text-decoration:none}
.case-source a:hover{text-decoration:underline}

/* ========================================
   PHILOSOPHY
   ======================================== */
.philosophy{background:var(--green);padding:100px 56px}
.phil-inner{max-width:900px;margin:0 auto}
.phil-label{font-family:var(--mono);font-size:10px;color:rgba(200,160,96,0.7);letter-spacing:0.12em;text-transform:uppercase;margin-bottom:16px;display:flex;align-items:center;gap:10px}
.phil-label::before{content:'';width:24px;height:1.5px;background:var(--gold2)}
.phil-title{font-family:var(--outfit);font-size:clamp(30px,3.5vw,46px);font-weight:800;color:var(--white);letter-spacing:-0.02em;margin-bottom:48px}
.phil-quotes{display:flex;flex-direction:column;gap:0}
.pq{padding:28px 0;border-bottom:1px solid rgba(255,255,255,0.08);display:grid;grid-template-columns:48px 1fr;gap:20px;align-items:center}
.pq:first-child{border-top:1px solid rgba(255,255,255,0.08)}
.pq-num{font-family:var(--mono);font-size:11px;color:rgba(255,255,255,0.3);letter-spacing:0.06em}
.pq-text{font-family:var(--outfit);font-size:22px;font-weight:600;color:var(--white);letter-spacing:-0.01em;line-height:1.35}
.pq-text em{font-style:normal;color:var(--gold2)}

/* ========================================
   CTA
   ======================================== */
.cta-section{background:var(--white);padding:120px 56px;text-align:center;position:relative;overflow:hidden}
.cta-x{position:absolute;pointer-events:none}
.cta-x-1{top:-40px;left:-40px;width:200px;height:200px;border:2px solid var(--green-light);transform:rotate(45deg)}
.cta-x-2{bottom:-60px;right:-60px;width:280px;height:280px;border:2px solid var(--gold-light);transform:rotate(45deg)}
.cta-inner{position:relative;max-width:720px;margin:0 auto}
.cta-eyebrow{font-family:var(--mono);font-size:10px;color:var(--green3);letter-spacing:0.12em;text-transform:uppercase;margin-bottom:20px;display:flex;align-items:center;justify-content:center;gap:10px}
.cta-eyebrow::before,.cta-eyebrow::after{content:'';flex:1;max-width:60px;height:1px;background:var(--gold-mid)}
.cta-title{font-family:var(--outfit);font-size:clamp(32px,4.3vw,54px);font-weight:800;letter-spacing:-0.03em;line-height:1.02;margin-bottom:20px;color:var(--text1)}
.cta-title em{font-style:normal;color:var(--green)}
.cta-sub{font-size:16px;color:var(--text2);line-height:1.7;margin-bottom:40px;font-weight:400}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta-contact{font-family:var(--mono);font-size:12px;color:var(--text3);margin-top:28px;letter-spacing:0.02em}
.cta-contact a{color:var(--green);text-decoration:none;font-weight:500}

/* ========================================
   FOOTER
   ======================================== */
footer{background:var(--dark);color:rgba(255,255,255,0.6);padding:56px;display:grid;grid-template-columns:1fr 2fr 1fr;gap:40px;align-items:start}
.footer-logo{font-family:var(--outfit);font-size:26px;font-weight:800;letter-spacing:-0.04em;color:var(--white);text-decoration:none;display:inline-block}
.footer-logo em{font-style:normal;color:var(--gold2);position:relative}
.footer-logo em::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--gold)}
.footer-tagline{font-family:var(--mono);font-size:11px;color:rgba(255,255,255,0.4);letter-spacing:0.05em;margin-top:8px}
.footer-links{display:flex;flex-wrap:wrap;gap:32px;justify-content:center}
.footer-links a{color:rgba(255,255,255,0.6);text-decoration:none;font-size:13px;transition:color 0.2s}
.footer-links a:hover{color:var(--gold2)}
.footer-right{text-align:right;font-size:12px}
.footer-email{color:var(--white);text-decoration:none;font-weight:500}
.footer-email:hover{color:var(--gold2)}
.footer-site{color:rgba(255,255,255,0.35);font-family:var(--mono)}

/* ========================================
   ADVISORY-PAGE-SPECIFIC: Service catalog
   ======================================== */
.services-section{background:var(--white);padding:100px 56px}
.services-inner{max-width:1100px;margin:0 auto}
.services-header{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:end;margin-bottom:56px}
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:1.5px solid var(--border2);border-radius:4px;overflow:hidden}
.svc{background:var(--white);padding:38px 36px;border-bottom:1.5px solid var(--border2);border-right:1.5px solid var(--border2);position:relative;transition:background 0.2s;overflow:hidden}
.svc:nth-child(2n){border-right:none}
.svc:nth-last-child(-n+2){border-bottom:none}
.svc-full{grid-column:1/-1;border-right:none}
.svc:hover{background:var(--off-white)}
.svc::after{content:'';position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(180deg,var(--green),var(--green2));transition:width 0.25s}
.svc:hover::after{width:3px}
.svc-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px}
.svc-icon{width:42px;height:42px;border-radius:3px;background:var(--green-light);border:1px solid var(--green-mid);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.svc-icon svg{width:18px;height:18px;stroke:var(--green);fill:none;stroke-width:1.5}
.svc-num{font-family:var(--mono);font-size:10px;color:var(--text3);letter-spacing:0.06em}
.svc-name{font-family:var(--outfit);font-size:21px;font-weight:800;color:var(--text1);margin-bottom:10px;letter-spacing:-0.02em}
.svc-name em{font-style:normal;color:var(--green)}
.svc-trademark{color:var(--gold);font-size:14px}
.svc-desc{font-size:13px;color:var(--text2);line-height:1.75;margin-bottom:18px;font-weight:400}
.svc-focus{display:flex;flex-direction:column;gap:5px;margin-bottom:18px}
.fi{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text3)}
.fi-arrow{color:var(--green);font-size:11px;flex-shrink:0}
.svc-eng{padding-top:14px;border-top:1px solid var(--border)}
.svc-eng-label{font-family:var(--mono);font-size:9px;color:var(--text3);letter-spacing:0.08em;text-transform:uppercase;margin-bottom:7px}
.svc-chips{display:flex;flex-wrap:wrap;gap:5px}
.sc{font-family:var(--mono);font-size:9px;padding:3px 9px;border-radius:2px;background:var(--off-white);border:1px solid var(--border);color:var(--text3)}
.svc-full-focus{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:16px}
.svc-full-focus .fi{align-items:flex-start}

/* ========================================
   RESPONSIVE
   ======================================== */
/* Medium-large: 5-across grids are too tight at common desktop sizes; drop to 3 cols */
@media (max-width:1400px){
  .outcomes-grid{grid-template-columns:repeat(3,1fr)}
  .outcome-card{border-bottom:1.5px solid var(--border2)}
  .outcome-card:nth-child(3n){border-right:none}
  .outcome-card:nth-last-child(-n+2){border-bottom:none}
  /* pt-header two-column layout gets tight here; collapse to stacked */
  .pt-header{grid-template-columns:1fr;gap:24px;align-items:start}
}
@media (max-width:1024px){
  .hero-inner{grid-template-columns:1fr;gap:48px;min-height:auto;padding:40px 56px 80px}
  .hero-left{padding-right:0}
  .hero-bg-shape{width:100%;top:auto;bottom:0;height:40%;right:0}
  .hero-bg-shape::after{display:none}
  .outcomes-grid{grid-template-columns:repeat(2,1fr)}
  .outcome-card{border-bottom:1.5px solid var(--border2)}
  .outcome-card:nth-child(2n){border-right:none}
  .vert-grid{grid-template-columns:repeat(2,1fr)}
  .vert-card{border-bottom:1.5px solid var(--border2)}
  .vert-card:nth-child(2n){border-right:none}
  .problem-grid{grid-template-columns:1fr}
  .problem-card{border-right:none;border-bottom:1.5px solid var(--border2)}
  .problem-card:last-child{border-bottom:none}
  .pt-header{grid-template-columns:1fr;gap:24px;align-items:start}
  .pt-split{grid-template-columns:1fr;gap:40px}
  .gov-inner{grid-template-columns:1fr;gap:48px}
  .lb-inner{grid-template-columns:1fr;gap:48px}
  .cases-grid{grid-template-columns:1fr}
  .case-card.featured{grid-column:span 1}
  .services-header{grid-template-columns:1fr;gap:24px}
  .services-grid{grid-template-columns:1fr}
  .svc{border-right:none}
  .svc-full-focus{grid-template-columns:repeat(2,1fr)}
  footer{grid-template-columns:1fr;text-align:center}
  .footer-right{text-align:center}
  .footer-links{justify-content:center}
}
@media (max-width:768px){
  nav{padding:0 24px}
  .nav-center{display:none}
  .section-wrap,.verticals,.gov-section,.lb-section,.philosophy,.cta-section,.cases-section,.services-section,.pt-section{padding-left:24px;padding-right:24px}
  .trust-strip{padding:24px;gap:20px}
  footer{padding:40px 24px}
  .hero-inner{padding:32px 24px 64px}
}
