/* ============================================================
   FORTGREENE — SITE STYLESHEET
   The autopilot for everyone else.
   ============================================================ */

/* ---- TOKENS ------------------------------------------------ */
:root{
  --evergreen:#103D2E; --evergreen-deep:#0A2A1F; --night:#07211A;
  --signal:#2BC56A; --signal-bright:#2FD173; --signal-soft:#D7F2E2;
  --limestone:#F7F5EF; --mist:#EDEBE1; --hairline:#E4E1D4;
  --ink:#13211A; --stone:#5B6159; --stone-light:#9AA095;
  --clay:#B5805A; --amber:#E0A340; --brick:#C75D47;
  --display:'Space Grotesk','Helvetica Neue',Arial,sans-serif;
  --body:'Inter','Helvetica Neue',Arial,sans-serif;
  --mono:'JetBrains Mono','SF Mono',ui-monospace,monospace;
  --r-sm:8px; --r-md:14px; --r-lg:20px; --r-xl:28px; --r-pill:999px;
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s5:24px; --s6:32px;
  --s7:48px; --s8:64px; --s9:96px;
  --shadow-sm:0 1px 2px rgba(16,61,46,.06);
  --shadow-md:0 8px 24px rgba(16,61,46,.08);
  --shadow-lg:0 24px 60px rgba(16,61,46,.12);
  --glow:0 0 0 6px rgba(47,209,115,.16);
  --ease:cubic-bezier(.22,.61,.36,1);
  --breath:3.2s;
  --maxw:1140px;
  --gutter:24px;
}

/* ---- RESET ------------------------------------------------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%}
body{
  font-family:var(--body); background:var(--limestone); color:var(--ink);
  line-height:1.6; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{display:block; max-width:100%}
a{color:inherit; text-decoration:none}
button{font-family:inherit; cursor:pointer}
:focus-visible{outline:3px solid var(--signal); outline-offset:2px; border-radius:4px}
::selection{background:var(--signal-soft); color:var(--evergreen)}

.skip{position:absolute; left:-999px; top:0; z-index:200; background:var(--evergreen); color:#fff;
  padding:12px 18px; border-radius:0 0 var(--r-md) 0; font-weight:600; font-family:var(--display)}
.skip:focus{left:0}

/* ---- LAYOUT ------------------------------------------------ */
.wrap{max-width:var(--maxw); margin:0 auto; padding-left:var(--gutter); padding-right:var(--gutter)}
.section{padding:72px 0; position:relative}
.section + .section{border-top:1px solid var(--hairline)}
.section.dark{background:var(--evergreen-deep); color:var(--limestone); border-top:none}
.section.deep{background:var(--evergreen); color:var(--limestone); border-top:none}
.section.night{background:var(--night); color:var(--limestone); border-top:none}
@media(min-width:760px){ .section{padding:96px 0} }

/* ---- SHARED TYPE ------------------------------------------- */
.eyebrow{
  font-family:var(--mono); font-size:.72rem; font-weight:500; letter-spacing:.14em;
  text-transform:uppercase; color:var(--stone); display:inline-flex; align-items:center; gap:9px;
}
.dark .eyebrow,.deep .eyebrow,.night .eyebrow{color:#8FB6A0}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--signal);
  box-shadow:0 0 0 0 rgba(47,209,115,.5); animation:breathe var(--breath) var(--ease) infinite}
h1,h2,h3,h4{font-family:var(--display); letter-spacing:-.02em; line-height:1.08; font-weight:600; color:var(--ink)}
.dark h1,.dark h2,.dark h3,.dark h4,.deep h1,.deep h2,.deep h3,.deep h4,
.night h1,.night h2,.night h3,.night h4{color:#fff}
.h-display{font-size:clamp(2.4rem,6vw,4.2rem); line-height:1.04}
.h-section{font-size:clamp(1.9rem,3.6vw,2.7rem)}
.h-sub{font-size:clamp(1.35rem,2.4vw,1.75rem)}
.g{color:var(--signal)}
.deep .g,.dark .g,.night .g,.hero .g{color:var(--signal-bright)}
.lead{font-size:clamp(1.08rem,1.6vw,1.22rem); color:var(--stone); max-width:60ch; margin-top:18px; line-height:1.6}
.dark .lead,.deep .lead,.night .lead{color:#A9C6B6}
.mono{font-family:var(--mono)}
.section-head{margin-bottom:44px; max-width:none}
@media(min-width:760px){ .section-head{margin-bottom:56px} }

/* ---- BUTTONS ----------------------------------------------- */
.btn{font-family:var(--display); font-weight:600; font-size:.97rem; border:none; border-radius:var(--r-md);
  padding:14px 26px; transition:transform .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease), border-color .2s var(--ease);
  display:inline-flex; align-items:center; justify-content:center; gap:9px; line-height:1}
.btn-primary{background:var(--evergreen); color:#fff}
.btn-primary:hover{background:#0B3326; transform:translateY(-2px); box-shadow:var(--shadow-md)}
.btn-signal{background:var(--signal); color:var(--night)}
.btn-signal:hover{background:var(--signal-bright); transform:translateY(-2px); box-shadow:0 10px 26px rgba(47,209,115,.32)}
.btn-ghost{background:transparent; color:var(--evergreen); border:1.5px solid var(--hairline)}
.btn-ghost:hover{border-color:var(--evergreen); transform:translateY(-2px)}
.deep .btn-ghost,.dark .btn-ghost,.night .btn-ghost,.hero .btn-ghost{color:#fff; border-color:rgba(255,255,255,.28)}
.deep .btn-ghost:hover,.dark .btn-ghost:hover,.night .btn-ghost:hover,.hero .btn-ghost:hover{border-color:#fff; background:rgba(255,255,255,.06)}
.btn .dot{width:7px;height:7px;border-radius:50%;background:var(--signal-bright);animation:breathe var(--breath) var(--ease) infinite}
.btn-signal .dot{background:var(--night)}
.btn-row{display:flex; gap:12px; flex-wrap:wrap; align-items:center}

/* ---- BREATHING PRESENCE ------------------------------------ */
@keyframes breathe{
  0%,100%{transform:scale(1); box-shadow:0 0 0 0 rgba(47,209,115,.45)}
  50%{transform:scale(1.06); box-shadow:0 0 0 8px rgba(47,209,115,0)}
}
@media (prefers-reduced-motion:reduce){
  @keyframes breathe{0%,100%{transform:none;box-shadow:none}}
  html{scroll-behavior:auto}
  *{animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important}
}

/* ---- NAV --------------------------------------------------- */
.nav{position:sticky; top:0; z-index:100; background:rgba(247,245,239,.82);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); border-bottom:1px solid var(--hairline)}
.nav .wrap{display:flex; align-items:center; justify-content:space-between; height:66px; gap:16px}
.nav-logo{display:flex; align-items:center; gap:10px; font-family:var(--display);
  font-weight:600; font-size:1.18rem; letter-spacing:-.02em; color:var(--ink); flex:none}
.nav-logo svg{width:30px;height:30px}
.nav-mid{display:none}
@media(min-width:940px){
  .nav-mid{display:flex; gap:28px; align-items:center}
  .nav-mid a{font-size:.9rem; color:var(--stone); transition:color .2s; position:relative; padding:4px 0}
  .nav-mid a:hover,.nav-mid a[aria-current="page"]{color:var(--evergreen)}
  .nav-mid a[aria-current="page"]::after{content:""; position:absolute; left:0; right:0; bottom:-2px; height:2px; background:var(--signal); border-radius:2px}
}
.nav-cta{display:none}
@media(min-width:940px){ .nav-cta{display:inline-flex} }
.nav-toggle{display:inline-flex; align-items:center; justify-content:center; width:42px; height:42px;
  border:1.5px solid var(--hairline); border-radius:var(--r-sm); background:#fff}
@media(min-width:940px){ .nav-toggle{display:none} }
.nav-toggle svg{width:20px;height:20px}
.nav-drawer{display:none; border-top:1px solid var(--hairline); background:rgba(247,245,239,.98); backdrop-filter:blur(14px)}
.nav-drawer.open{display:block}
.nav-drawer .wrap{flex-direction:column; height:auto; align-items:stretch; padding-top:14px; padding-bottom:20px; gap:2px}
.nav-drawer a{padding:13px 4px; font-size:1.05rem; color:var(--ink); border-bottom:1px solid var(--hairline); font-family:var(--display); font-weight:500}
.nav-drawer a:last-of-type{border-bottom:none}
.nav-drawer .btn{margin-top:14px}
@media(min-width:940px){ .nav-drawer{display:none !important} }

.nav-badge{font-family:var(--mono); font-size:.62rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--evergreen); background:var(--signal-soft); border:1px solid rgba(43,197,106,.3);
  padding:3px 9px; border-radius:var(--r-pill); display:none; align-items:center; gap:6px}
@media(min-width:600px){ .nav-badge{display:inline-flex} }
.nav-badge .d{width:6px;height:6px;border-radius:50%;background:var(--signal);animation:breathe var(--breath) var(--ease) infinite}

/* ---- HERO -------------------------------------------------- */
.hero{background:var(--evergreen); color:var(--limestone); position:relative; overflow:hidden}
.hero::after{content:""; position:absolute; inset:0;
  background:radial-gradient(120% 80% at 88% -10%, rgba(47,209,115,.20), transparent 55%); pointer-events:none}
.hero .wrap{position:relative; z-index:1; padding-top:56px; padding-bottom:56px}
@media(min-width:760px){ .hero .wrap{padding-top:80px; padding-bottom:80px} }
.hero-grid{display:grid; grid-template-columns:1fr; gap:44px; align-items:center}
@media(min-width:980px){ .hero-grid{grid-template-columns:1.05fr .95fr; gap:56px} }
.hero-status{font-family:var(--mono); font-size:.74rem; letter-spacing:.14em; text-transform:uppercase;
  color:#9FD9B6; display:inline-flex; align-items:center; gap:10px; margin-bottom:24px}
.hero-status .dot{width:8px;height:8px;border-radius:50%;background:var(--signal-bright);animation:breathe var(--breath) var(--ease) infinite}
.hero h1{font-size:clamp(2.5rem,6.4vw,4.3rem); max-width:15ch; color:#fff}
.hero-sub{font-size:clamp(1.12rem,1.8vw,1.3rem); color:#BFD9C9; max-width:52ch; margin-top:22px; line-height:1.55}
.hero-cta{margin-top:34px}
.hero-trust{display:grid; grid-template-columns:repeat(2,1fr); gap:18px 28px; margin-top:44px; max-width:520px}
@media(min-width:560px){ .hero-trust{grid-template-columns:repeat(4,1fr)} }
.hero-trust div{font-family:var(--mono); font-size:.72rem; color:#8FB6A0; letter-spacing:.03em; line-height:1.4}
.hero-trust strong{display:block; font-family:var(--display); font-size:clamp(1.4rem,2.4vw,1.7rem); color:#fff; letter-spacing:-.02em; margin-bottom:4px; font-weight:600}

/* ---- AGENT CONVERSATION ------------------------------------ */
.agent-shell{background:#fff; border:1px solid var(--hairline); border-radius:var(--r-xl);
  overflow:hidden; box-shadow:var(--shadow-lg); max-width:480px; margin:0 auto; width:100%}
.agent-top{display:flex; align-items:center; gap:13px; padding:16px 20px; border-bottom:1px solid var(--hairline); background:var(--limestone)}
.agent-av{width:40px;height:40px;border-radius:13px;background:var(--evergreen); flex:none; position:relative;
  display:flex; align-items:center; justify-content:center}
.agent-av svg{width:22px;height:22px}
.agent-av .d{width:10px;height:10px;border-radius:50%;background:var(--signal-bright); position:absolute; bottom:-2px; right:-2px;
  border:2.5px solid var(--limestone); animation:breathe var(--breath) var(--ease) infinite}
.agent-name{font-family:var(--display); font-weight:600; font-size:1rem; color:var(--ink)}
.agent-state{font-family:var(--mono); font-size:.66rem; letter-spacing:.06em; color:var(--signal); text-transform:uppercase; margin-top:1px}
.agent-body{padding:22px 20px; display:flex; flex-direction:column; gap:14px; background:#fff; min-height:280px}
.bubble{max-width:84%; padding:13px 16px; border-radius:16px; font-size:.93rem; line-height:1.5}
.bubble.agent{background:var(--mist); color:var(--ink); border-bottom-left-radius:5px; align-self:flex-start}
.bubble.owner{background:var(--evergreen); color:#fff; border-bottom-right-radius:5px; align-self:flex-end}
.bubble.proactive{background:var(--signal-soft); color:var(--evergreen); border-bottom-left-radius:5px; align-self:flex-start; border:1px solid rgba(43,197,106,.25)}
.bubble .ptag{font-family:var(--mono); font-size:.6rem; letter-spacing:.1em; text-transform:uppercase; color:var(--signal); display:flex; align-items:center; gap:7px; margin-bottom:7px}
.bubble .ptag .d{width:6px;height:6px;border-radius:50%;background:var(--signal); animation:breathe var(--breath) var(--ease) infinite}
.agent-input{display:flex; align-items:center; gap:10px; padding:13px 16px; border-top:1px solid var(--hairline); background:var(--limestone)}
.agent-input .box{flex:1; font-size:.88rem; color:var(--stone-light)}
.agent-input .voice{width:38px;height:38px;border-radius:50%;background:var(--evergreen); flex:none; display:flex; align-items:center; justify-content:center}
.agent-input .voice svg{width:17px;height:17px}
.typing{display:inline-flex; gap:4px; align-self:flex-start; background:var(--mist); padding:14px 16px; border-radius:16px; border-bottom-left-radius:5px}
.typing span{width:7px;height:7px;border-radius:50%;background:var(--stone-light); animation:typedot 1.2s var(--ease) infinite}
.typing span:nth-child(2){animation-delay:.18s}
.typing span:nth-child(3){animation-delay:.36s}
@keyframes typedot{0%,60%,100%{opacity:.35; transform:translateY(0)} 30%{opacity:1; transform:translateY(-3px)}}

/* channels */
.channel-row{display:flex; gap:10px; justify-content:center; margin-top:26px; flex-wrap:wrap}
.channel{font-family:var(--mono); font-size:.7rem; letter-spacing:.08em; text-transform:uppercase; color:var(--stone);
  background:#fff; border:1px solid var(--hairline); border-radius:var(--r-pill); padding:8px 16px}
.dark .channel,.deep .channel,.night .channel{background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.16); color:#BFD9C9}

/* ---- CREDIBILITY STRIP ------------------------------------- */
.cred{background:var(--evergreen-deep); color:#fff; padding:34px 0}
.cred .wrap{display:flex; flex-direction:column; gap:24px; align-items:center; text-align:center}
@media(min-width:840px){ .cred .wrap{flex-direction:row; justify-content:space-between; text-align:left} }
.cred-label{font-family:var(--mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:#8FB6A0; max-width:24ch}
.cred-stats{display:grid; grid-template-columns:repeat(2,auto); gap:24px 40px}
@media(min-width:560px){ .cred-stats{grid-template-columns:repeat(4,auto)} }
.cred-stats div{font-family:var(--mono); font-size:.7rem; color:#8FB6A0; letter-spacing:.04em}
.cred-stats strong{display:block; font-family:var(--display); font-size:1.5rem; color:#fff; letter-spacing:-.02em; margin-bottom:3px; font-weight:600}

/* ---- CARD GRIDS -------------------------------------------- */
.grid{display:grid; gap:20px}
.grid-2{grid-template-columns:1fr}
.grid-3{grid-template-columns:1fr}
.grid-4{grid-template-columns:1fr}
@media(min-width:680px){ .grid-2{grid-template-columns:1fr 1fr} .grid-4{grid-template-columns:1fr 1fr} }
@media(min-width:900px){ .grid-3{grid-template-columns:repeat(3,1fr)} .grid-4{grid-template-columns:repeat(4,1fr)} }

.card{background:#fff; border:1px solid var(--hairline); border-radius:var(--r-lg); padding:30px}
.dark .card,.deep .card,.night .card{background:rgba(255,255,255,.04); border-color:rgba(255,255,255,.12)}
.card h3{font-size:1.18rem; margin-bottom:10px}
.card p{color:var(--stone); font-size:.97rem}
.dark .card p,.deep .card p,.night .card p{color:#A9C6B6}
.card .tag{font-family:var(--mono); font-size:.66rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--signal); margin-bottom:16px; display:block}
.card .ic{width:46px;height:46px;border-radius:var(--r-md); background:var(--signal-soft); display:flex; align-items:center; justify-content:center; margin-bottom:18px}
.card .ic svg{width:24px;height:24px; stroke:var(--evergreen)}
.dark .card .ic,.deep .card .ic,.night .card .ic{background:rgba(47,209,115,.14)}
.dark .card .ic svg,.deep .card .ic svg,.night .card .ic svg{stroke:var(--signal-bright)}

.pcard{position:relative}
.pcard .pnum{font-family:var(--mono); font-size:.7rem; letter-spacing:.1em; color:var(--brick); margin-bottom:14px; display:block; text-transform:uppercase}

/* ---- FEATURE / PILLAR LIST --------------------------------- */
.pillars{display:grid; gap:20px; grid-template-columns:1fr}
@media(min-width:680px){ .pillars{grid-template-columns:1fr 1fr} }
.pillar{display:flex; gap:18px; align-items:flex-start; padding:24px; background:#fff; border:1px solid var(--hairline); border-radius:var(--r-lg)}
.pillar .pic{width:48px;height:48px;border-radius:var(--r-md); flex:none; background:var(--evergreen); display:flex; align-items:center; justify-content:center}
.pillar .pic svg{width:24px;height:24px; stroke:var(--signal-bright)}
.pillar h3{font-size:1.12rem; margin-bottom:7px}
.pillar p{color:var(--stone); font-size:.95rem}

/* ---- THE LOOP ---------------------------------------------- */
.loop{display:grid; gap:16px; grid-template-columns:1fr; counter-reset:loop}
@media(min-width:640px){ .loop{grid-template-columns:1fr 1fr} }
@media(min-width:980px){ .loop{grid-template-columns:repeat(3,1fr)} }
.loop-step{background:#fff; border:1px solid var(--hairline); border-radius:var(--r-lg); padding:26px; position:relative}
.dark .loop-step,.deep .loop-step,.night .loop-step{background:rgba(255,255,255,.04); border-color:rgba(255,255,255,.12)}
.loop-step .n{font-family:var(--mono); font-size:.74rem; color:var(--signal); letter-spacing:.1em; font-weight:700; margin-bottom:12px; display:block}
.loop-step h3{font-size:1.12rem; margin-bottom:8px}
.loop-step p{color:var(--stone); font-size:.92rem}
.dark .loop-step p,.deep .loop-step p,.night .loop-step p{color:#A9C6B6}

/* ---- METRICS ----------------------------------------------- */
.metrics{display:grid; gap:18px; grid-template-columns:1fr 1fr}
@media(min-width:760px){ .metrics{grid-template-columns:repeat(4,1fr)} }
.metric{background:#fff; border:1px solid var(--hairline); border-radius:var(--r-lg); padding:26px}
.dark .metric,.deep .metric,.night .metric{background:rgba(255,255,255,.05); border-color:rgba(255,255,255,.12)}
.metric .label{font-family:var(--mono); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--stone)}
.dark .metric .label,.deep .metric .label,.night .metric .label{color:#8FB6A0}
.metric .num{font-family:var(--display); font-weight:600; font-size:clamp(2rem,4vw,2.7rem); letter-spacing:-.03em; margin:10px 0 4px; color:var(--evergreen)}
.dark .metric .num,.deep .metric .num,.night .metric .num{color:var(--signal-bright)}
.metric .note{font-size:.82rem; color:var(--stone); margin-top:8px; line-height:1.45}
.dark .metric .note,.deep .metric .note,.night .metric .note{color:#A9C6B6}

/* ---- POSITION / QUOTE BLOCK -------------------------------- */
.statement{background:var(--mist); border-left:3px solid var(--signal); border-radius:0 var(--r-md) var(--r-md) 0;
  padding:30px 34px; font-size:clamp(1.15rem,1.8vw,1.4rem); line-height:1.5; color:var(--ink); font-family:var(--display); font-weight:500}
.statement b{color:var(--evergreen)}
.deep .statement,.dark .statement,.night .statement{background:rgba(255,255,255,.05); color:#fff; border-left-color:var(--signal-bright)}
.deep .statement b,.dark .statement b,.night .statement b{color:var(--signal-bright)}

/* ---- COMPARISON TABLE -------------------------------------- */
.cmp{width:100%; border-collapse:collapse; font-size:.92rem; margin-top:8px}
.cmp-wrap{overflow-x:auto; border:1px solid var(--hairline); border-radius:var(--r-lg); background:#fff; -webkit-overflow-scrolling:touch}
.cmp th,.cmp td{padding:16px 18px; text-align:left; border-bottom:1px solid var(--hairline); vertical-align:top}
.cmp thead th{font-family:var(--mono); font-size:.68rem; letter-spacing:.08em; text-transform:uppercase; color:var(--stone); white-space:nowrap; background:var(--limestone)}
.cmp tbody th{font-family:var(--display); font-weight:600; color:var(--ink); white-space:nowrap}
.cmp .fg{background:var(--signal-soft)}
.cmp .fg, .cmp thead th.fg{color:var(--evergreen)}
.cmp tr:last-child td,.cmp tr:last-child th{border-bottom:none}
.cmp .yes{color:var(--evergreen); font-weight:600}
.cmp .no{color:var(--stone-light)}

/* ---- PRICING ----------------------------------------------- */
.tiers{display:grid; gap:22px; grid-template-columns:1fr; align-items:start}
@media(min-width:880px){ .tiers{grid-template-columns:repeat(3,1fr)} }
.tier{background:#fff; border:1px solid var(--hairline); border-radius:var(--r-xl); padding:32px; display:flex; flex-direction:column}
.tier.featured{border:1.5px solid var(--signal); box-shadow:var(--shadow-lg); position:relative}
.tier.featured::before{content:"Most chosen"; position:absolute; top:-12px; left:32px; font-family:var(--mono); font-size:.62rem; letter-spacing:.12em; text-transform:uppercase; background:var(--signal); color:var(--night); padding:5px 12px; border-radius:var(--r-pill)}
.tier .tname{font-family:var(--display); font-weight:600; font-size:1.3rem}
.tier .tfor{font-size:.86rem; color:var(--stone); margin-top:6px; min-height:2.6em}
.tier .price{font-family:var(--display); font-weight:600; font-size:2.6rem; letter-spacing:-.03em; color:var(--evergreen); margin:22px 0 2px}
.tier .price span{font-family:var(--mono); font-size:.8rem; color:var(--stone); letter-spacing:.04em; font-weight:400}
.tier .pnote{font-size:.78rem; color:var(--stone-light); margin-bottom:24px}
.tier ul{list-style:none; display:flex; flex-direction:column; gap:12px; margin-bottom:28px; flex:1}
.tier li{display:flex; gap:11px; align-items:flex-start; font-size:.92rem; color:var(--stone)}
.tier li svg{width:18px;height:18px;flex:none; margin-top:2px; stroke:var(--signal)}
.tier li b{color:var(--ink); font-weight:600}
.tier .btn{width:100%}

/* ---- FAQ (native details) ---------------------------------- */
.faq{display:flex; flex-direction:column; gap:0; border:1px solid var(--hairline); border-radius:var(--r-lg); overflow:hidden; background:#fff}
.faq details{border-bottom:1px solid var(--hairline)}
.faq details:last-child{border-bottom:none}
.faq summary{list-style:none; cursor:pointer; padding:22px 24px; font-family:var(--display); font-weight:600;
  font-size:1.05rem; color:var(--ink); display:flex; justify-content:space-between; align-items:center; gap:18px; transition:background .2s}
.faq summary:hover{background:var(--limestone)}
.faq summary::-webkit-details-marker{display:none}
.faq summary .chev{flex:none; width:22px; height:22px; transition:transform .25s var(--ease); stroke:var(--signal)}
.faq details[open] summary .chev{transform:rotate(180deg)}
.faq .ans{padding:0 24px 24px; color:var(--stone); font-size:.97rem; line-height:1.6; max-width:72ch}
.faq .ans p + p{margin-top:12px}
.faq-cat{font-family:var(--mono); font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; color:var(--signal);
  margin:40px 0 16px; display:flex; align-items:center; gap:10px}
.faq-cat::after{content:""; flex:1; height:1px; background:var(--hairline)}
.faq-cat:first-of-type{margin-top:0}

/* ---- DAY-IN-LIFE BEATS ------------------------------------- */
.beats{display:grid; gap:16px; grid-template-columns:1fr}
@media(min-width:680px){ .beats{grid-template-columns:1fr 1fr} }
.beat{display:flex; gap:16px; align-items:flex-start; padding:22px; background:#fff; border:1px solid var(--hairline); border-radius:var(--r-lg)}
.dark .beat,.deep .beat,.night .beat{background:rgba(255,255,255,.04); border-color:rgba(255,255,255,.12)}
.beat .bn{font-family:var(--mono); font-size:.7rem; color:var(--signal); flex:none; padding-top:3px; letter-spacing:.08em}
.beat h4{font-size:1rem; margin-bottom:5px}
.beat p{font-size:.88rem; color:var(--stone)}
.dark .beat p,.deep .beat p,.night .beat p{color:#A9C6B6}

/* ---- GATING (A/B/C) ---------------------------------------- */
.gates{display:grid; gap:18px; grid-template-columns:1fr}
@media(min-width:900px){ .gates{grid-template-columns:repeat(3,1fr)} }
.gate{background:#fff; border:1px solid var(--hairline); border-radius:var(--r-lg); padding:28px; position:relative; overflow:hidden}
.gate .glabel{display:flex; align-items:center; gap:12px; margin-bottom:14px}
.gate .gk{width:38px;height:38px;border-radius:var(--r-md); display:flex; align-items:center; justify-content:center; font-family:var(--display); font-weight:700; font-size:1.1rem; color:#fff; flex:none}
.gate.a .gk{background:var(--signal); color:var(--night)}
.gate.b .gk{background:var(--amber)}
.gate.c .gk{background:var(--clay)}
.gate h3{font-size:1.12rem}
.gate .gmeta{font-family:var(--mono); font-size:.66rem; letter-spacing:.08em; text-transform:uppercase; color:var(--stone); margin-top:2px}
.gate p{color:var(--stone); font-size:.92rem; margin-top:6px}
.gate .ex{font-family:var(--mono); font-size:.78rem; color:var(--evergreen); margin-top:16px; padding-top:16px; border-top:1px solid var(--hairline); line-height:1.5}

/* ---- LAYERS (stack) ---------------------------------------- */
.stack{display:flex; flex-direction:column; gap:12px}
.layer{display:flex; gap:20px; align-items:center; background:#fff; border:1px solid var(--hairline); border-radius:var(--r-lg); padding:22px 26px}
.layer .lnum{font-family:var(--display); font-weight:700; font-size:1.6rem; color:var(--hairline); flex:none; width:34px}
.layer .lmain{flex:1}
.layer h3{font-size:1.1rem; margin-bottom:4px}
.layer p{color:var(--stone); font-size:.9rem}
.layer .lbadge{font-family:var(--mono); font-size:.62rem; letter-spacing:.1em; text-transform:uppercase; padding:5px 11px; border-radius:var(--r-pill); flex:none; white-space:nowrap}
.layer .lbadge.build{background:var(--signal-soft); color:var(--evergreen)}
.layer .lbadge.core{background:var(--evergreen); color:#fff}
.layer .lbadge.partner{background:var(--mist); color:var(--stone)}
@media(max-width:600px){ .layer{flex-wrap:wrap; gap:12px} .layer .lnum{width:auto} .layer .lbadge{order:3} }

/* ---- ROSTER ------------------------------------------------ */
.roster{display:grid; gap:16px; grid-template-columns:1fr}
@media(min-width:560px){ .roster{grid-template-columns:1fr 1fr} }
.agent-card{background:#fff; border:1px solid var(--hairline); border-radius:var(--r-lg); padding:24px; display:flex; gap:18px}
.dark .agent-card,.deep .agent-card,.night .agent-card{background:rgba(255,255,255,.04); border-color:rgba(255,255,255,.12)}
.ac-av{width:48px;height:48px;border-radius:var(--r-md); flex:none; background:var(--evergreen); display:flex; align-items:center; justify-content:center; position:relative}
.ac-av svg{width:26px;height:26px}
.ac-av .d{position:absolute; bottom:-2px; right:-2px; width:11px;height:11px; border-radius:50%; background:var(--signal-bright); border:2.5px solid #fff; animation:breathe var(--breath) var(--ease) infinite}
.dark .ac-av .d,.deep .ac-av .d{border-color:rgba(255,255,255,.1)}
.ac-body{flex:1}
.ac-name{font-family:var(--display); font-weight:600; font-size:1.05rem}
.ac-role{font-family:var(--mono); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--signal); margin-top:2px}
.dark .ac-role,.deep .ac-role,.night .ac-role{color:var(--signal-bright)}
.ac-note{font-size:.88rem; color:var(--stone); margin-top:8px; line-height:1.5}
.dark .ac-note,.deep .ac-note,.night .ac-note{color:#A9C6B6}

/* ---- TEAM -------------------------------------------------- */
.team{display:grid; gap:24px; grid-template-columns:1fr}
@media(min-width:760px){ .team{grid-template-columns:1fr 1fr} }
.team-member{display:flex; gap:20px; align-items:flex-start}
.tm-av{width:56px;height:56px;border-radius:var(--r-md); flex:none; background:var(--evergreen); display:flex; align-items:center; justify-content:center; font-family:var(--display); font-weight:700; font-size:1.2rem; color:#fff}
.tm-body{flex:1}
.tm-name{font-family:var(--display); font-weight:600; font-size:1.12rem}
.tm-role{font-family:var(--mono); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--signal); margin-top:3px; margin-bottom:10px}
.tm-bio{font-size:.92rem; color:var(--stone); line-height:1.6}

/* ---- CTA BAND ---------------------------------------------- */
.cta-band{background:var(--evergreen); color:var(--limestone); border-radius:var(--r-xl); padding:52px 44px; text-align:center}
.cta-band h2{color:#fff; font-size:clamp(1.7rem,3.2vw,2.4rem); max-width:26ch; margin:0 auto 14px}
.cta-band p{color:#BFD9C9; max-width:52ch; margin:0 auto 32px; font-size:1.05rem}
@media(max-width:560px){ .cta-band{padding:36px 24px} }

/* ---- FORM -------------------------------------------------- */
.form{display:grid; gap:16px; max-width:460px}
@media(min-width:700px){ .form{grid-template-columns:1fr 1fr} }
.form-full{grid-column:1/-1}
.field{display:flex; flex-direction:column; gap:6px}
.field label{font-family:var(--mono); font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; color:var(--stone-light)}
.dark .field label,.deep .field label,.night .field label{color:#A9C6B6}
.field input,.field select,.field textarea{font-family:var(--body); font-size:.97rem; padding:13px 16px; border:1.5px solid var(--hairline); border-radius:var(--r-md); background:#fff; color:var(--ink); transition:border-color .2s, box-shadow .2s; width:100%}
.field textarea{resize:vertical; line-height:1.5}
.field textarea.mono{font-family:var(--mono); font-size:.86rem}
.dark .field input,.deep .field input,.night .field input,.dark .field select,.deep .field select,.night .field select,.dark .field textarea,.deep .field textarea,.night .field textarea{background:rgba(255,255,255,.07); border-color:rgba(255,255,255,.15); color:#fff}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--signal); box-shadow:0 0 0 4px rgba(47,209,115,.14); outline:none}
.field input::placeholder,.field textarea::placeholder{color:var(--stone-light)}
.field .hint{text-transform:none; letter-spacing:0; font-family:var(--body); font-weight:400; color:var(--stone-light); font-size:.78rem}
.seo-group-hd{font-family:var(--display); font-size:1.02rem; margin:30px 0 16px; padding-bottom:8px; border-bottom:1px solid var(--hairline); color:var(--evergreen)}
.seo-group-hd:first-child{margin-top:0}
.dark .seo-group-hd,.deep .seo-group-hd,.night .seo-group-hd{color:var(--signal-bright); border-color:rgba(255,255,255,.12)}
.flash-ok{padding:14px 20px; border-radius:var(--r-md); margin-bottom:20px; font-size:.92rem; font-family:var(--display); background:#D7F2E2; color:var(--evergreen); border:1px solid rgba(43,197,106,.3)}
.flash-err{padding:14px 20px; border-radius:var(--r-md); margin-bottom:20px; font-size:.92rem; font-family:var(--display); background:#FCE8E5; color:#C75D47; border:1px solid rgba(199,93,71,.25)}
.form-sub{font-size:.8rem; color:var(--stone-light)}
.dark .form-sub,.deep .form-sub,.night .form-sub{color:#A9C6B6}
.success-msg{text-align:center; padding:32px 20px; display:none}
.success-msg.show{display:block}
.success-msg .ok{width:52px;height:52px;border-radius:50%;background:var(--signal-soft); display:flex; align-items:center; justify-content:center; margin:0 auto 16px}
.success-msg .ok svg{width:28px;height:28px; stroke:var(--evergreen)}
.success-msg h3{font-size:1.3rem; margin-bottom:8px}
.success-msg p{color:var(--stone); font-size:.95rem}

/* ---- BREADCRUMB -------------------------------------------- */
.breadcrumb{font-family:var(--mono); font-size:.72rem; letter-spacing:.08em; color:var(--stone); display:flex; align-items:center; gap:8px; margin-bottom:24px}
.breadcrumb a{color:var(--stone); transition:color .2s}
.breadcrumb a:hover{color:var(--evergreen)}
.breadcrumb .sep{color:var(--hairline)}

/* ---- PAGE HEAD --------------------------------------------- */
.page-head{padding:56px 0 44px}
@media(min-width:760px){ .page-head{padding:72px 0 56px} }
.page-head .eyebrow{margin-bottom:18px}
.page-head h1{font-size:clamp(2.1rem,4.8vw,3.4rem)}
.page-head .lead{margin-top:16px; max-width:56ch}

/* ---- UTILITY ----------------------------------------------- */
.ta-c{text-align:center}
.mt-s{margin-top:14px}
.mt-md{margin-top:28px}
.mt-m{margin-top:28px}
.mt-l{margin-top:44px}
.muted{color:var(--stone)}
.dark .muted,.deep .muted,.night .muted{color:#A9C6B6}
.kicker{font-family:var(--mono); font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; color:var(--signal)}
.dark .kicker,.deep .kicker,.night .kicker{color:var(--signal-bright)}
.sep{color:var(--hairline); margin:0 4px}

/* ---- FOOTER ------------------------------------------------ */
.foot{background:var(--evergreen-deep); color:var(--limestone); padding:56px 0 40px}
.foot-grid{display:grid; gap:32px; grid-template-columns:1fr; margin-bottom:40px}
@media(min-width:760px){ .foot-grid{grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px} }
.foot-brand .mk{display:flex; align-items:center; gap:10px; font-family:var(--display); font-weight:600; font-size:1.1rem; color:#fff; margin-bottom:12px}
.foot-brand .mk svg{width:28px;height:28px}
.foot-brand p{font-size:.9rem; color:#8FB6A0; max-width:26ch; line-height:1.6}
.foot-col h4{font-family:var(--mono); font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:#8FB6A0; margin-bottom:16px}
.foot-col a{display:block; font-size:.9rem; color:#A9C6B6; margin-bottom:10px; transition:color .2s}
.foot-col a:hover{color:#fff}
.foot-bot{border-top:1px solid rgba(255,255,255,.1); padding-top:24px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; font-size:.82rem; color:#5A7A6A}

/* ---- UTILS ------------------------------------------------- */
.mt-sm{margin-top:20px} .mt-md{margin-top:32px} .mt-lg{margin-top:48px}
.ta-c{text-align:center}
.reveal{opacity:0; transform:translateY(18px); transition:opacity .55s var(--ease), transform .55s var(--ease)}
.reveal.in{opacity:1; transform:translateY(0)}
@media(prefers-reduced-motion:reduce){.reveal,.reveal.in{opacity:1; transform:none; transition:none}}
@media print{.nav,.foot{display:none} body{background:#fff; color:#000}}

/* ---- ADMIN FLASH MESSAGES ---------------------------------- */
.flash{padding:14px 20px; border-radius:var(--r-md); margin-bottom:20px; font-size:.92rem; font-family:var(--display)}
.flash.success{background:#D7F2E2; color:var(--evergreen); border:1px solid rgba(43,197,106,.3)}
.flash.error{background:#FCE8E5; color:#C75D47; border:1px solid rgba(199,93,71,.25)}

/* ---- CMS CUSTOM PAGE SECTIONS ------------------------------ */
.rich{font-size:1.04rem; line-height:1.75; color:var(--ink)}
.rich > * + *{margin-top:1em}
.rich h2{font-family:var(--display); font-size:1.6rem; margin-top:1.4em}
.rich h3{font-family:var(--display); font-size:1.25rem; margin-top:1.2em}
.rich ul,.rich ol{padding-left:1.3em}
.rich li + li{margin-top:.4em}
.rich a{color:var(--signal-ink, #1f9e56); text-decoration:underline; text-underline-offset:2px}
.rich img{max-width:100%; height:auto; border-radius:var(--r-md)}
.rich blockquote{border-left:3px solid var(--signal, #2FD173); padding-left:18px; color:var(--muted, #5B6159); font-style:italic}
.section-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:22px}
.section-custom-html img{max-width:100%; height:auto}
