/* ============================================================
   Bluebonnet Legacy — shared site styles
   Tokens, layout, navigation, components, motion.
   Edit once here; every page picks it up.
   ============================================================ */

:root {
  --navy: #10263D;
  --navy-2: #0A1B2C;
  --blue: #1F4E79;
  --sage: #566B47;
  --sage-2: #445635;
  --ivory: #F7F3EA;
  --paper: #FCFAF4;
  --ink: #1E2428;
  --line: #D8D2C3;
  --gold: #B89B5E;
  --teal: #5FBFB2;          /* cyber accent — AI / Snakepit only */
  --muted: #5B6470;

  --serif: "Cormorant Garamond", Georgia, Cambria, "Times New Roman", serif;
  --sans: "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;

  --shadow-sm: 0 10px 30px rgba(16,38,61,.07);
  --shadow: 0 30px 80px rgba(16,38,61,.14);
  --radius: 18px;
  --maxw: 1200px;
}

*,*::before,*::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0; color: var(--ink); background: var(--paper);
  font-family: var(--sans); font-size: 17px; line-height: 1.6;
  -webkit-font-smoothing: antialiased; overflow-x: hidden;
}
body::before {
  content:""; position: fixed; inset: 0; z-index: -2; pointer-events: none;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(31,78,121,.06), transparent 60%),
    radial-gradient(900px 500px at -10% 20%, rgba(86,107,71,.05), transparent 60%),
    var(--paper);
}
body::after {
  content:""; position: fixed; inset: 0; z-index: -1; pointer-events: none; opacity: .03;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }
h1,h2,h3,h4 { margin: 0; font-family: var(--serif); color: var(--navy); font-weight: 600; line-height: 1.04; letter-spacing: -.01em; }
p { margin: 0; }
::selection { background: rgba(184,155,94,.28); }
:focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; border-radius: 4px; }

.wrap { width: min(var(--maxw), calc(100% - 48px)); margin-inline: auto; }
section { padding: clamp(72px, 11vh, 130px) 0; position: relative; }
[id] { scroll-margin-top: 90px; }

.eyebrow { display: inline-flex; align-items: center; gap: 12px; font-size: .72rem; font-weight: 600; letter-spacing: .22em; text-transform: uppercase; color: var(--sage-2); }
.eyebrow::before { content:""; width: 30px; height: 1px; background: var(--gold); }
.eyebrow.light { color: rgba(255,255,255,.7); }

.display { font-size: clamp(2.6rem, 6vw, 5rem); font-weight: 600; line-height: 1.02; letter-spacing: -.02em; }
.h2 { font-size: clamp(2rem, 4.2vw, 3.4rem); line-height: 1.05; }
.lede { font-size: clamp(1.05rem, 1.5vw, 1.3rem); color: var(--muted); }
.max60 { max-width: 60ch; }

/* ---------- Buttons ---------- */
.btn {
  --bx:0px; --by:0px;
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  min-height: 52px; padding: 0 26px; border-radius: 999px; border: 1px solid transparent;
  font-family: var(--sans); font-weight: 600; font-size: .98rem; cursor: pointer;
  transition: transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
  transform: translate(var(--bx), var(--by)); will-change: transform;
}
.btn svg { width: 17px; height: 17px; }
.btn-primary { background: var(--navy); color: #fff; box-shadow: 0 16px 34px rgba(16,38,61,.28); }
.btn-primary:hover { background: var(--navy-2); }
.btn-gold { background: var(--gold); color: var(--navy-2); box-shadow: 0 16px 34px rgba(184,155,94,.34); }
.btn-gold:hover { filter: brightness(1.04); }
.btn-ghost { border-color: rgba(255,255,255,.4); color: #fff; background: rgba(255,255,255,.05); }
.btn-ghost:hover { background: rgba(255,255,255,.14); }
.btn-outline { border-color: rgba(16,38,61,.2); color: var(--navy); background: #fff; }
.btn-outline:hover { box-shadow: var(--shadow-sm); border-color: var(--gold); }

/* ---------- Reveal (enabled only with JS) ---------- */
.js .reveal { opacity: 0; transform: translateY(26px); transition: opacity .9s cubic-bezier(.2,.8,.2,1), transform .9s cubic-bezier(.2,.8,.2,1); }
.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; }
.js .reveal.d4 { transition-delay: .32s; }

/* ---------- Scroll progress ---------- */
.scrollbar { position: fixed; top: 0; left: 0; height: 3px; width: 0; z-index: 80; background: linear-gradient(90deg, var(--gold), var(--sage)); box-shadow: 0 0 10px rgba(184,155,94,.5); transition: width .08s linear; }

/* ---------- Nav ---------- */
.nav { position: sticky; top: 0; z-index: 60; background: rgba(247,243,234,.72); backdrop-filter: blur(16px) saturate(1.1); border-bottom: 1px solid transparent; transition: border-color .3s ease, background .3s ease, box-shadow .3s ease; }
.nav.scrolled { border-color: rgba(216,210,195,.7); box-shadow: 0 6px 24px rgba(16,38,61,.05); }
.nav-inner { height: 74px; display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.brand { display: flex; align-items: center; gap: 12px; }
.brand img { width: 40px; height: 40px; }
.brand b { font-family: var(--serif); font-size: 1.18rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--navy); line-height: 1; }
.brand small { display:block; font-size: .6rem; letter-spacing: .34em; text-transform: uppercase; color: var(--sage); margin-top: 3px; }
.nav-links { display: flex; align-items: center; gap: 30px; }
.nav-links a { font-size: .92rem; color: #34404e; font-weight: 500; position: relative; }
.nav-links a::after { content:""; position:absolute; left:0; bottom:-6px; height:1px; width:0; background: var(--gold); transition: width .3s ease; }
.nav-links a:hover, .nav-links a.active { color: var(--navy); }
.nav-links a:hover::after, .nav-links a.active::after { width: 100%; }
.nav-cta { display: flex; align-items: center; gap: 14px; }
.nav-cta .btn { min-height: 44px; padding: 0 20px; font-size: .9rem; }
.menu-btn { display: none; width: 44px; height: 44px; border: 1px solid var(--line); border-radius: 12px; background: #fff; cursor: pointer; align-items: center; justify-content: center; }
.menu-btn span, .menu-btn span::before, .menu-btn span::after { content:""; display:block; width: 18px; height: 2px; background: var(--navy); position: relative; transition: .3s; }
.menu-btn span::before { position:absolute; top:-6px; } .menu-btn span::after { position:absolute; top:6px; }

.drawer { position: fixed; inset: 0; z-index: 70; background: rgba(10,27,44,.5); backdrop-filter: blur(4px); opacity: 0; pointer-events: none; transition: opacity .3s ease; }
.drawer.open { opacity: 1; pointer-events: auto; }
.drawer-panel { position: absolute; top: 0; right: 0; height: 100%; width: min(340px, 86%); background: var(--paper); padding: 26px; display: flex; flex-direction: column; gap: 8px; transform: translateX(100%); transition: transform .35s cubic-bezier(.2,.8,.2,1); }
.drawer.open .drawer-panel { transform: none; }
.drawer-panel a { padding: 14px 8px; font-size: 1.1rem; font-family: var(--serif); color: var(--navy); border-bottom: 1px solid var(--line); }
.drawer-panel .btn { margin-top: 16px; }
.drawer-close { align-self: flex-end; background: none; border: none; font-size: 1.6rem; color: var(--navy); cursor: pointer; line-height: 1; }

/* ---------- Hero (homepage) ---------- */
.hero {
  position: relative; color: #fff; overflow: hidden;
  background:
    radial-gradient(120% 120% at var(--hx,70%) var(--hy,20%), rgba(31,78,121,.55), transparent 55%),
    radial-gradient(90% 90% at 12% 92%, rgba(86,107,71,.40), transparent 60%),
    linear-gradient(160deg, #133050 0%, var(--navy) 46%, var(--navy-2) 100%);
}
.hero-grid-lines { position: absolute; inset: 0; opacity: .5; pointer-events: none; mask-image: linear-gradient(180deg,#000,transparent 78%); }
.hero-inner { position: relative; z-index: 2; display: grid; grid-template-columns: 1.08fr .92fr; align-items: center; gap: 40px; min-height: clamp(600px, 90vh, 900px); padding: 116px 0 100px; }
.hero h1 { color: #fff; font-weight: 600; }
.hero .lede { color: rgba(255,255,255,.82); margin-top: 22px; max-width: 36ch; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 36px; }
.hero-meta { margin-top: 38px; display: flex; gap: 26px; flex-wrap: wrap; color: rgba(255,255,255,.62); font-size: .82rem; letter-spacing: .04em; }
.hero-meta span { display:flex; align-items:center; gap:9px; }
.hero-meta i { width: 6px; height: 6px; border-radius: 50%; background: var(--gold); display:inline-block; }
.hero-visual { position: relative; display: grid; place-items: center; }
.hero-floaty { position: relative; display: grid; place-items: center; width: 100%; }
.hero-glow { position: absolute; width: 76%; aspect-ratio: 1; border-radius: 50%; background: radial-gradient(circle, rgba(31,78,121,.5), rgba(31,78,121,0) 64%); filter: blur(16px); animation: glowPulse 6s ease-in-out infinite; }
.hero-flower { position: relative; width: min(420px, 82%); filter: drop-shadow(0 24px 50px rgba(0,0,0,.45)); animation: floaty 6s ease-in-out infinite 1.3s; }
@keyframes glowPulse { 0%,100%{ opacity:.7; transform: scale(.96); } 50%{ opacity:1; transform: scale(1.05); } }
@keyframes floaty { 0%,100%{ transform: translateY(0); } 50%{ transform: translateY(-9px); } }
.scroll-cue { position: absolute; bottom: 26px; left: 50%; transform: translateX(-50%); z-index: 2; color: rgba(255,255,255,.6); font-size: .7rem; letter-spacing: .25em; text-transform: uppercase; display: grid; justify-items: center; gap: 8px; }
.scroll-cue .line { width: 1px; height: 34px; background: linear-gradient(var(--gold), transparent); animation: cue 2.4s ease-in-out infinite; }
@keyframes cue { 0%,100%{ transform: scaleY(.4); opacity:.5; } 50%{ transform: scaleY(1); opacity:1; } }

/* rotation-safe bloom: rotate on wrapper <g>, scale on .hpetal */
.hpetal { transform-box: fill-box; transform-origin: center; }
.js .hero-flower .hpetal { opacity: 0; transform: scale(.35); }
.js .hero-flower.bloom-in .hpetal { animation: hbloom .9s cubic-bezier(.2,.8,.2,1) forwards; animation-delay: var(--d, 0s); }
@keyframes hbloom { to { opacity: 1; transform: scale(1); } }

/* ---------- Masthead (sub-pages) ---------- */
.masthead { position: relative; color: #fff; overflow: hidden;
  background: radial-gradient(120% 130% at 82% -20%, rgba(31,78,121,.5), transparent 55%), linear-gradient(160deg, #133050 0%, var(--navy) 55%, var(--navy-2) 100%); }
.masthead .hero-grid-lines { mask-image: linear-gradient(180deg,#000,transparent 86%); }
.masthead-inner { position: relative; z-index: 1; padding: clamp(96px, 17vh, 160px) 0 clamp(48px, 9vh, 88px); max-width: 62ch; }
.masthead h1 { color: #fff; font-size: clamp(2.5rem, 6vw, 4.4rem); }
.masthead .lede { color: rgba(255,255,255,.82); margin-top: 18px; }
.masthead .crumb { font-size: .8rem; color: rgba(255,255,255,.55); margin-bottom: 14px; letter-spacing: .02em; }
.masthead .crumb a:hover { color: #fff; }

/* ---------- Section heads / surfaces ---------- */
.section-head { max-width: 760px; margin-bottom: 40px; }
.section-head.center { margin-inline: auto; text-align: center; }
.section-head h2 { font-size: clamp(2.1rem, 4vw, 3.4rem); letter-spacing: -.03em; }
.section-head p { margin: 16px 0 0; color: var(--muted); font-size: 1.06rem; }
.alt { background: var(--parchment, var(--ivory)); border-block: 1px solid rgba(216,210,195,.6); }
.dark { background: linear-gradient(180deg, var(--navy) 0%, var(--navy-2) 100%); color: #fff; }
.dark h1,.dark h2,.dark h3 { color: #fff; }
.dark .lede { color: rgba(255,255,255,.74); }

/* ---------- Card grids ---------- */
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius); padding: 30px; box-shadow: var(--shadow-sm); transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.card:hover { transform: translateY(-2px); box-shadow: var(--shadow); border-color: rgba(86,107,71,.55); }
.card h3 { font-size: 1.4rem; letter-spacing: -.01em; }
.card p { color: var(--muted); margin: 12px 0 0; font-size: .98rem; }
.card .num { font-family: var(--serif); color: var(--gold); font-size: 2.1rem; line-height: 1; margin-bottom: 16px; }
.icon-badge { width: 50px; height: 50px; border-radius: 13px; display: grid; place-items: center; background: linear-gradient(135deg, var(--navy), var(--blue)); margin-bottom: 18px; }
.icon-badge svg { width: 24px; height: 24px; stroke: #fff; fill: none; stroke-width: 1.7; }

/* ---------- Teaser cards (homepage hub) ---------- */
.teasers { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin-top: 44px; }
.teaser { display: flex; flex-direction: column; padding: 32px; border-radius: var(--radius); background: var(--paper); border: 1px solid var(--line); box-shadow: var(--shadow-sm); transition: transform .3s cubic-bezier(.2,.8,.2,1), box-shadow .3s ease, border-color .3s ease; }
.teaser:hover { transform: translateY(-5px); box-shadow: var(--shadow); border-color: rgba(184,155,94,.55); }
.teaser h3 { font-size: 1.5rem; margin-top: 4px; }
.teaser p { color: var(--muted); margin: 12px 0 22px; font-size: .98rem; }
.teaser .more { margin-top: auto; display: inline-flex; align-items: center; gap: 8px; color: var(--blue); font-weight: 600; font-size: .95rem; }
.teaser .more svg { width: 16px; height: 16px; transition: transform .3s ease; }
.teaser:hover .more svg { transform: translateX(4px); }

/* ---------- Framework ---------- */
.fw-grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: clamp(28px,4vw,56px); align-items: center; margin-top: 30px; }
.flower-stage { position: relative; display: grid; place-items: center; }
.flower { width: min(480px, 100%); }
.petal { cursor: pointer; transform-box: fill-box; transform-origin: center; transition: opacity .45s ease, filter .45s ease; }
.petal use { fill: var(--blue); stroke: rgba(247,243,234,.6); stroke-width: 0.045; stroke-linejoin: round; transition: fill .45s ease; }
.js .flower .petal { opacity: 0; transform: scale(.5); }
.js .flower.drawn .petal { opacity: 1; transform: scale(1); transition: opacity .6s ease, transform .7s cubic-bezier(.2,.8,.2,1), filter .45s ease; }
.petal.active use { fill: var(--gold); }
.petal.active { filter: drop-shadow(0 0 12px rgba(184,155,94,.7)); }
.flower.focused .petal:not(.active) { opacity: .42; }
.pillars { display: grid; gap: 10px; }
.pillar { width: 100%; text-align: left; cursor: pointer; color: #fff; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.12); border-radius: 14px; padding: 16px 18px; display: grid; grid-template-columns: 26px 1fr; gap: 14px; align-items: center; transition: background .3s ease, border-color .3s ease, transform .3s ease; font-family: var(--sans); }
.pillar:hover { background: rgba(255,255,255,.08); transform: translateX(3px); }
.pillar.active { border-color: var(--gold); background: rgba(184,155,94,.12); }
.pillar .pn { font-family: var(--serif); font-size: 1.05rem; color: var(--gold); }
.pillar .pt { font-weight: 600; font-size: 1rem; }
.pillar-desc { margin-top: 18px; min-height: 66px; color: rgba(255,255,255,.78); font-size: 1.02rem; border-top: 1px solid rgba(255,255,255,.12); padding-top: 18px; }
.foundation { margin-top: 40px; }
.foundation .flbl { font-size: .7rem; letter-spacing: .2em; text-transform: uppercase; color: rgba(255,255,255,.5); margin-bottom: 12px; }
.strata { display: grid; gap: 7px; }
.stratum { display: flex; align-items: center; gap: 12px; padding: 11px 16px; border-radius: 10px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08); font-size: .92rem; color: rgba(255,255,255,.82); }
.stratum b { font-weight: 600; color: #fff; }
.stratum .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--sage); flex: none; }

/* ---------- AI command layer ---------- */
.ai { background: linear-gradient(180deg, #0C2236 0%, #0A1B2C 100%); color: #fff; overflow: hidden; }
.ai .eyebrow { color: var(--teal); }
.ai .eyebrow::before { background: var(--teal); }
.ai-head { max-width: 70ch; }
.ai-layout { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px,4vw,56px); align-items: center; margin-top: 44px; }
.defs { display: grid; gap: 12px; }
.def { padding: 16px 18px; border: 1px solid rgba(95,191,178,.22); border-radius: 14px; background: rgba(95,191,178,.05); }
.def b { color: var(--teal); font-weight: 600; }
.def span { color: rgba(255,255,255,.74); }
.command { border-radius: 18px; border: 1px solid rgba(95,191,178,.28); background: linear-gradient(180deg, rgba(13,32,48,.9), rgba(8,20,32,.95)); box-shadow: 0 30px 70px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.04); overflow: hidden; }
.command .bar { display: flex; align-items: center; gap: 8px; padding: 14px 16px; border-bottom: 1px solid rgba(95,191,178,.18); font-size: .78rem; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.55); }
.command .bar i { width: 9px; height: 9px; border-radius: 50%; background: rgba(255,255,255,.18); }
.command .bar i.live { background: var(--teal); box-shadow: 0 0 10px var(--teal); animation: pulse 2s infinite; }
@keyframes pulse { 0%,100%{ opacity:.5 } 50%{ opacity:1 } }
.command .body { padding: 20px; display: grid; gap: 12px; font-family: ui-monospace, "SF Mono", Menlo, monospace; font-size: .82rem; }
.cmd-row { display: grid; grid-template-columns: 22px 1fr auto; gap: 12px; align-items: center; color: rgba(255,255,255,.82); padding: 11px 13px; border-radius: 10px; background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.06); }
.cmd-row .ico { width: 22px; height: 22px; display: grid; place-items: center; color: var(--teal); }
.cmd-row .tag { font-size: .68rem; letter-spacing: .08em; text-transform: uppercase; padding: 3px 9px; border-radius: 999px; }
.tag.ok { background: rgba(95,191,178,.16); color: var(--teal); border: 1px solid rgba(95,191,178,.3); }
.tag.hold { background: rgba(184,155,94,.16); color: var(--gold); border: 1px solid rgba(184,155,94,.3); }
.cmd-foot { padding: 14px 20px; border-top: 1px solid rgba(95,191,178,.18); color: rgba(255,255,255,.5); font-size: .76rem; display: flex; justify-content: space-between; gap: 10px; flex-wrap: wrap; }

/* ---------- Snakepit split ---------- */
.split { display: grid; grid-template-columns: 1fr 1fr; align-items: stretch; border-radius: 22px; overflow: hidden; box-shadow: var(--shadow); margin-top: 40px; border: 1px solid var(--line); }
.split-side { padding: clamp(28px,4vw,48px); }
.split-left { background: linear-gradient(180deg,#fff,var(--ivory)); }
.split-left h3 { font-size: 1.5rem; }
.split-right { background: linear-gradient(180deg,#0C2236,#0A1B2C); color: #fff; position: relative; }
.split-right h3 { color: #fff; font-size: 1.5rem; }
.split .role { font-size: .72rem; letter-spacing: .2em; text-transform: uppercase; color: var(--sage-2); margin-bottom: 10px; }
.split-right .role { color: var(--teal); }
.chip-list { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }
.chip { font-size: .82rem; padding: 8px 13px; border-radius: 999px; border: 1px solid var(--line); color: var(--navy); background: #fff; }
.split-right .chip { border-color: rgba(95,191,178,.3); color: rgba(255,255,255,.85); background: rgba(95,191,178,.06); }
.split-connector { display: flex; align-items: center; gap: 10px; margin-top: 22px; font-size: .82rem; color: var(--muted); }
.split-right .split-connector { color: rgba(255,255,255,.6); }
.split-connector .ln { height: 1px; flex: 1; background: linear-gradient(90deg, var(--gold), transparent); }
.snakepit-link { display:inline-flex; align-items:center; gap:8px; margin-top: 22px; color: var(--teal); font-weight: 600; font-size: .95rem; }
.snakepit-link:hover { text-decoration: underline; }

/* ---------- Services ---------- */
.svc-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-top: 44px; }
.svc { position: relative; padding: 30px; border-radius: var(--radius); background: var(--paper); border: 1px solid var(--line); box-shadow: var(--shadow-sm); overflow: hidden; transition: transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s ease, border-color .35s ease; }
.svc::before { content:""; position: absolute; width: 320px; height: 320px; left: var(--mx,50%); top: var(--my,0%); transform: translate(-50%,-50%); background: radial-gradient(circle, rgba(31,78,121,.10), transparent 60%); opacity: 0; transition: opacity .4s ease; pointer-events: none; }
.svc:hover { transform: translateY(-5px); box-shadow: var(--shadow); border-color: rgba(184,155,94,.55); }
.svc:hover::before { opacity: 1; }
.svc-ico { width: 48px; height: 48px; border-radius: 13px; display: grid; place-items: center; background: linear-gradient(140deg, var(--navy), var(--blue)); margin-bottom: 18px; }
.svc-ico svg { width: 22px; height: 22px; stroke: #fff; fill: none; stroke-width: 1.7; }
.svc h3 { font-size: 1.32rem; }
.svc p { margin-top: 10px; color: var(--muted); font-size: .98rem; }
.svc .num { position: absolute; top: 22px; right: 24px; font-family: var(--serif); color: rgba(16,38,61,.14); font-size: 1.5rem; }

/* ---------- Clients ---------- */
.client-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; margin-top: 40px; }
.client { padding: 22px; border-radius: 14px; border: 1px solid var(--line); background: var(--paper); display: flex; align-items: center; gap: 13px; transition: transform .3s ease, border-color .3s ease; }
.client:hover { transform: translateY(-3px); border-color: var(--sage); }
.client svg { width: 22px; height: 22px; color: var(--sage); flex: none; }
.client b { font-weight: 600; font-size: .96rem; color: var(--navy); }

/* ---------- Outcomes ---------- */
.out-grid { display: grid; grid-template-columns: repeat(5,1fr); gap: 12px; margin-top: 40px; }
.out { padding: 20px; border-radius: 14px; background: #fff; border: 1px solid var(--line); box-shadow: var(--shadow-sm); transition: transform .3s ease; }
.out:hover { transform: translateY(-4px); }
.out svg { width: 20px; height: 20px; color: var(--gold); margin-bottom: 10px; }
.out b { display: block; font-size: .94rem; color: var(--navy); line-height: 1.3; }

/* ---------- Final CTA ---------- */
.final-card { position: relative; border-radius: 26px; padding: clamp(40px,6vw,72px); color: #fff; text-align: center; overflow: hidden;
  background: radial-gradient(120% 140% at 50% -10%, rgba(31,78,121,.6), transparent 60%), linear-gradient(160deg, #143257, var(--navy) 55%, var(--navy-2)); box-shadow: var(--shadow); }
.final-card h2 { color: #fff; }
.final-card p { color: rgba(255,255,255,.78); max-width: 56ch; margin: 18px auto 0; }
.final-actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; margin-top: 34px; }

/* ---------- Footer ---------- */
footer { background: var(--navy-2); color: rgba(255,255,255,.66); padding: 60px 0 40px; }
.foot-grid { display: flex; justify-content: space-between; gap: 28px; flex-wrap: wrap; align-items: flex-start; }
.foot-brand b { font-family: var(--serif); color: #fff; font-size: 1.2rem; letter-spacing: .12em; text-transform: uppercase; }
.foot-brand p { margin-top: 8px; font-size: .9rem; color: rgba(255,255,255,.6); }
.foot-tag { margin-top: 14px; font-size: .8rem; color: var(--teal); }
.foot-cols { display: flex; gap: 56px; flex-wrap: wrap; }
.foot-col b { display: block; font-size: .72rem; letter-spacing: .18em; text-transform: uppercase; color: rgba(255,255,255,.45); margin-bottom: 14px; }
.foot-col a, .foot-col span { display: block; font-size: .92rem; color: rgba(255,255,255,.72); margin-bottom: 9px; }
.foot-col a:hover { color: #fff; }
.foot-bottom { margin-top: 44px; padding-top: 22px; border-top: 1px solid rgba(255,255,255,.1); display: flex; justify-content: space-between; gap: 14px; flex-wrap: wrap; font-size: .8rem; color: rgba(255,255,255,.45); }

.sticky-cta { position: fixed; left: 16px; right: 16px; bottom: 16px; z-index: 50; display: none; }
.sticky-cta .btn { width: 100%; box-shadow: 0 12px 30px rgba(16,38,61,.4); }

/* ============================================================
   Liquid glass + 3D depth (site-wide)
   Frosted surfaces, cursor tilt, drifting background, glossy CTAs.
   ============================================================ */

/* drifting "liquid" backdrop */
body::before { inset: -25%; animation: bgDrift 26s ease-in-out infinite alternate; }
@keyframes bgDrift {
  0%   { transform: translate3d(-2%, -1%, 0) scale(1.06) rotate(0deg); }
  50%  { transform: translate3d(2%, 2%, 0)   scale(1.13) rotate(1.4deg); }
  100% { transform: translate3d(1%, -2%, 0)  scale(1.07) rotate(-1.1deg); }
}

/* frosted-glass cards with depth + cursor tilt */
.teaser, .card, .svc {
  position: relative;
  background: linear-gradient(158deg, rgba(255,255,255,.80), rgba(252,250,244,.54));
  -webkit-backdrop-filter: blur(16px) saturate(1.2);
  backdrop-filter: blur(16px) saturate(1.2);
  border: 1px solid rgba(255,255,255,.65);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.85),
    inset 0 -1px 0 rgba(216,210,195,.35),
    0 22px 44px -22px rgba(16,38,61,.34),
    0 6px 16px -10px rgba(16,38,61,.18);
  transform: perspective(1000px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translate3d(0,var(--ty,0),0);
  transition: transform .45s cubic-bezier(.2,.8,.2,1), box-shadow .4s ease, border-color .3s ease;
  will-change: transform;
}
.teaser:hover, .card:hover, .svc:hover {
  --ty: -7px;
  border-color: rgba(184,155,94,.5);
  transform: perspective(1000px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translate3d(0,var(--ty),0);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 36px 70px -28px rgba(16,38,61,.5),
    0 12px 26px -14px rgba(16,38,61,.26);
}

/* moving specular sheen (position fed by --gx/--gy from JS) */
.teaser::before, .card::before {
  content: ""; position: absolute; inset: 0; border-radius: inherit; pointer-events: none;
  background: radial-gradient(260px circle at var(--gx,50%) var(--gy,-10%), rgba(255,255,255,.6), transparent 60%);
  opacity: 0; transition: opacity .4s ease;
}
.teaser:hover::before, .card:hover::before { opacity: .85; }
.svc::before { background: radial-gradient(circle, rgba(255,255,255,.5), transparent 60%); }

/* small surfaces: frosted + specular edge */
.client, .out {
  background: linear-gradient(158deg, rgba(255,255,255,.74), rgba(252,250,244,.5));
  -webkit-backdrop-filter: blur(10px) saturate(1.12);
  backdrop-filter: blur(10px) saturate(1.12);
  border-color: rgba(255,255,255,.6);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.75), 0 14px 28px -18px rgba(16,38,61,.3);
}

/* glossy "liquid" buttons with a sweeping sheen */
.btn { position: relative; overflow: hidden; }
.btn-primary { background: linear-gradient(180deg, #224A72, var(--navy)); box-shadow: 0 16px 34px rgba(16,38,61,.30), inset 0 1px 0 rgba(255,255,255,.16), inset 0 -3px 8px rgba(0,0,0,.22); }
.btn-primary:hover { background: linear-gradient(180deg, #1B3C5E, var(--navy-2)); }
.btn-gold { background: linear-gradient(180deg, #CDB27C, var(--gold)); box-shadow: 0 16px 34px rgba(184,155,94,.36), inset 0 1px 0 rgba(255,255,255,.55), inset 0 -3px 8px rgba(120,96,40,.28); }
.btn::before {
  content: ""; position: absolute; top: -10%; left: 0; height: 120%; width: 55%;
  background: linear-gradient(105deg, transparent, rgba(255,255,255,.45), transparent);
  transform: translateX(-180%) skewX(-16deg); pointer-events: none;
  transition: transform .75s cubic-bezier(.2,.8,.2,1);
}
.btn:hover::before { transform: translateX(320%) skewX(-16deg); }

/* glass edge-light on the dark floating panels */
.final-card, .command { box-shadow: var(--shadow), inset 0 1px 0 rgba(255,255,255,.08); }

/* ---------- Responsive ---------- */
@media (max-width: 1000px) {
  .nav-links { display: none; }
  .menu-btn { display: flex; }
  .nav-cta .btn:not(.menu-btn) { display: none; }
  .hero-inner { grid-template-columns: 1fr; min-height: auto; padding: 92px 0 76px; }
  .hero-visual { margin-top: 30px; }
  .fw-grid, .ai-layout { grid-template-columns: 1fr; }
  .split { grid-template-columns: 1fr; }
  .teasers, .svc-grid { grid-template-columns: 1fr 1fr; }
  .client-grid { grid-template-columns: 1fr 1fr; }
  .out-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 620px) {
  body { font-size: 16px; }
  .teasers, .svc-grid, .client-grid, .out-grid { grid-template-columns: 1fr; }
  .sticky-cta { display: block; }
  footer { padding-bottom: 90px; }
  .foot-grid { flex-direction: column; }
}

@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition-duration: .001ms !important; scroll-behavior: auto !important; }
  .js .reveal { opacity: 1 !important; transform: none !important; }
  .js .hero-flower .hpetal { opacity: 1 !important; transform: none !important; }
}
