/* ============================================================
   Sector Growth · Implementation Intake — shared design system
   LIGHT "ambient" design language (effects shared with book.sectorgrowth.com,
   re-skinned light): soft white/blue base, drifting mesh/grid/orb/aura/grain,
   glass-white cards, Space Grotesk / Inter / JetBrains Mono, blue accent.
   Powered by Sector Labs.
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --bg-top:#FFFFFF; --bg-mid:#EDF3FB; --bg-bottom:#E4EDF8;
  --ink:#0E2236; --text-primary:#0E2236; --text-muted:#5B6B7E;
  --blue:#174FA2; --blue-deep:#123E82; --blue-mid:#2A85C4; --accent-cyan:#33CCFF;
  --breeze:#FF7A59; --breeze-deep:#E8602F; --breeze-warm:#FF9D5C;
  --border-subtle:rgba(16,35,54,0.09); --border-strong:rgba(16,35,54,0.18);
  --panel:#FFFFFF; --field-bg:#F3F8FD;
  --radius-card:20px; --radius-sm:10px;
  --shadow-card:0 1px 2px rgba(16,35,54,0.05),0 12px 30px -18px rgba(23,79,162,0.20);
  --shadow-soft:0 24px 60px -24px rgba(23,79,162,0.34);
  --font-display:'Manrope',ui-sans-serif,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-body:'Inter',ui-sans-serif,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --maxw:880px; --gutter:clamp(20px,4vw,40px);
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; text-rendering:optimizeLegibility; scroll-behavior:smooth; scroll-padding-top:78px; }
img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:none; cursor:pointer; }
body{
  font-family:var(--font-body); font-size:15.5px; line-height:1.55; color:var(--ink);
  background:radial-gradient(ellipse at top,var(--bg-top) 0%,var(--bg-mid) 46%,var(--bg-bottom) 100%);
  background-attachment:fixed; min-height:100vh; overflow-x:hidden; position:relative;
}
h1,h2,h3,h4{ font-family:var(--font-display); line-height:1.1; letter-spacing:-.01em; font-weight:600; }
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 var(--gutter); }

/* ---------- Ambient layers (re-tuned for light bg) ---------- */
.ambient{ position:fixed; inset:0; z-index:0; overflow:hidden; pointer-events:none; }
.ambient__mesh{ position:absolute; inset:-20%;
  background:
    radial-gradient(60% 50% at 20% 30%,rgba(51,204,255,0.16) 0%,transparent 60%),
    radial-gradient(50% 50% at 80% 20%,rgba(42,133,196,0.16) 0%,transparent 65%),
    radial-gradient(60% 60% at 60% 80%,rgba(23,79,162,0.18) 0%,transparent 60%),
    radial-gradient(40% 50% at 10% 90%,rgba(51,204,255,0.12) 0%,transparent 60%);
  filter:blur(46px); animation:meshDrift 28s ease-in-out infinite alternate; will-change:transform; }
@keyframes meshDrift{ 0%{transform:translate3d(0,0,0) scale(1);} 50%{transform:translate3d(-2%,1%,0) scale(1.05);} 100%{transform:translate3d(2%,-2%,0) scale(1.02);} }
.ambient__grid{ position:absolute; inset:0;
  background-image:linear-gradient(to right,rgba(23,79,162,0.055) 1px,transparent 1px),linear-gradient(to bottom,rgba(23,79,162,0.055) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(ellipse at center,black 28%,transparent 78%); mask-image:radial-gradient(ellipse at center,black 28%,transparent 78%); }
.ambient__orb{ position:absolute; top:24%; left:50%; width:520px; height:520px; margin-left:-260px; margin-top:-260px;
  background:radial-gradient(circle,rgba(51,204,255,0.16) 0%,rgba(42,133,196,0.08) 35%,transparent 70%); filter:blur(22px); border-radius:50%;
  animation:orbDrift 32s ease-in-out infinite; will-change:transform; }
@keyframes orbDrift{ 0%{transform:translate(0,0);} 25%{transform:translate(8%,-4%);} 50%{transform:translate(-6%,6%);} 75%{transform:translate(4%,4%);} 100%{transform:translate(0,0);} }
.ambient__aura{ position:absolute; inset:-10%; opacity:0; transform:scale(.95); background:transparent;
  transition:opacity 900ms cubic-bezier(.2,.8,.2,1),transform 1200ms cubic-bezier(.2,.8,.2,1),background 900ms cubic-bezier(.2,.8,.2,1); }
.ambient__mesh,.ambient__orb,.ambient__grid{ transition:filter 900ms cubic-bezier(.2,.8,.2,1),opacity 900ms cubic-bezier(.2,.8,.2,1); }
.ambient__grain{ position:absolute; inset:0; opacity:.035; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='300' height='300'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix type='matrix' values='0 0 0 0 0.09  0 0 0 0 0.18  0 0 0 0 0.32  0 0 0 0.5 0'/></filter><rect width='300' height='300' filter='url(%23n)' opacity='0.5'/></svg>"); }

/* reactive mood when hovering an intake card / interactive panel */
body.is-hovering .ambient__mesh{ filter:blur(42px) saturate(1.58) brightness(1.07); }
body.is-hovering .ambient__orb{ filter:blur(22px) saturate(1.48); opacity:1; transform:scale(1.06); }
body.is-hovering .ambient__aura{ opacity:1; transform:scale(1.1);
  background:
    radial-gradient(ellipse 90% 70% at 70% 55%,rgba(23,79,162,0.22) 0%,transparent 60%),
    radial-gradient(circle at 50% 45%,rgba(42,133,196,0.17) 0%,transparent 55%),
    radial-gradient(ellipse 100% 60% at 20% 30%,rgba(51,204,255,0.19) 0%,transparent 60%); }

/* Breeze-agent hover: warm orange mood (Breeze brand colour) */
body.is-hovering-breeze .ambient__mesh{ filter:blur(42px) saturate(1.4) brightness(1.03) hue-rotate(178deg); }
body.is-hovering-breeze .ambient__orb{ filter:blur(22px) saturate(1.3) hue-rotate(178deg); opacity:1; transform:scale(1.05); }
body.is-hovering-breeze .ambient__aura{ opacity:1; transform:scale(1.1);
  background:
    radial-gradient(ellipse 90% 70% at 70% 55%,rgba(255,122,89,0.25) 0%,transparent 60%),
    radial-gradient(circle at 50% 45%,rgba(255,138,76,0.18) 0%,transparent 55%),
    radial-gradient(ellipse 100% 60% at 20% 30%,rgba(255,176,120,0.15) 0%,transparent 60%); }

/* ---------- Top nav ---------- */
.topnav{ position:sticky; top:0; z-index:50; background:rgba(255,255,255,.78); backdrop-filter:saturate(150%) blur(10px); border-bottom:1px solid var(--border-subtle); }
.topnav .wrap{ display:flex; align-items:center; justify-content:space-between; height:62px; }
.brand-logo{ display:flex; align-items:center; }
.brand-logo img{ height:34px; width:auto; }
.hp{ position:absolute !important; left:-9999px !important; width:1px; height:1px; overflow:hidden; }
.topnav__link{ font-family:var(--font-mono); font-size:11.5px; letter-spacing:.06em; color:var(--blue); font-weight:500;
  padding:7px 15px; border:1.5px solid rgba(23,79,162,.45); border-radius:999px; transition:color .2s,border-color .2s,background .2s; }
.topnav__link:hover{ color:var(--blue-deep); border-color:rgba(23,79,162,.75); background:rgba(23,79,162,.07); }

/* ---------- Hero ---------- */
.hero{ position:relative; z-index:2; padding:clamp(40px,6vh,70px) 0 30px; }
.hero .kicker, .eyebrow{ font-family:var(--font-mono); font-weight:500; font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--blue); display:inline-flex; align-items:center; padding:7px 15px; border:1px solid rgba(23,79,162,.22); border-radius:999px; background:rgba(23,79,162,.05); }
.hero h1{ font-size:clamp(38px,5.6vw,62px); font-weight:600; line-height:1.04; letter-spacing:-.02em; margin-top:18px;
  background:linear-gradient(180deg,#0E2236 0%,#1E4DA8 100%); -webkit-background-clip:text; background-clip:text; color:transparent; }
.hero h1 .accent{ background:linear-gradient(180deg,#2A85C4 0%,#174FA2 100%); -webkit-background-clip:text; background-clip:text; color:transparent; }
.hero .lede{ margin-top:18px; max-width:640px; color:var(--text-muted); font-size:clamp(15px,1.5vw,17.5px); }
.hero .meta{ margin-top:24px; display:flex; flex-wrap:wrap; gap:9px; }
.hero .meta .pill{ font-family:var(--font-mono); font-size:11px; letter-spacing:.04em; color:#3a5572; border:1px solid var(--border-subtle); border-radius:999px; padding:7px 13px; background:rgba(255,255,255,.6); }

/* ---------- Section nav (form) ---------- */
.secnav{ position:sticky; top:62px; z-index:40; background:rgba(255,255,255,.8); backdrop-filter:saturate(150%) blur(10px); border-bottom:1px solid var(--border-subtle); }
.secnav .wrap{ display:flex; align-items:center; gap:10px; padding:8px var(--gutter); }
.secnav__tabs{ display:flex; gap:4px; flex:1 1 auto; min-width:0; overflow-x:auto; scroll-behavior:smooth; scrollbar-width:none; -ms-overflow-style:none; }
.secnav__tabs::-webkit-scrollbar{ display:none; }
.secnav a{ flex:none; font-family:var(--font-mono); font-size:11.5px; letter-spacing:.03em; color:var(--text-muted); padding:7px 11px; border-radius:8px; white-space:nowrap; transition:color .15s,background .15s; }
.secnav a:hover{ background:rgba(23,79,162,.05); color:var(--blue); }
.secnav a.is-active{ color:var(--blue); background:rgba(23,79,162,.1); font-weight:500; }

/* sticky-nav action cluster (injected by intake.js): fades in on scroll */
.secnav__actions{ flex:none; display:flex; align-items:center; gap:8px; opacity:0; transform:translateY(-4px); pointer-events:none; transition:opacity .25s ease,transform .25s ease; }
.secnav__actions.is-shown{ opacity:1; transform:none; pointer-events:auto; }
.secnav__status{ display:inline-flex; align-items:center; gap:6px; font-family:var(--font-mono); font-size:10.5px; letter-spacing:.04em; color:var(--text-muted);
  padding:5px 10px; border-radius:999px; border:1px solid var(--border-subtle); background:rgba(255,255,255,.65); white-space:nowrap; transition:color .3s,border-color .3s,background .3s; }
.secnav__status .dot{ width:7px; height:7px; border-radius:50%; background:var(--text-muted); transition:background .3s,box-shadow .3s; }
.secnav__status.is-saved{ color:#1f7a3d; border-color:rgba(31,122,61,.4); background:rgba(34,161,85,.09); }
.secnav__status.is-saved .dot{ background:#22a155; box-shadow:0 0 0 3px rgba(34,161,85,.18); }
.secnav__status.is-info{ color:var(--blue); border-color:rgba(23,79,162,.35); background:rgba(23,79,162,.07); }
.secnav__btn{ flex:none; font-family:var(--font-mono); font-size:10.5px; letter-spacing:.05em; color:var(--blue); background:transparent;
  border:1px solid rgba(23,79,162,.4); border-radius:999px; padding:5px 11px; cursor:pointer; display:inline-flex; align-items:center; gap:5px;
  transition:color .2s,border-color .2s,background .2s; }
.secnav__btn:hover{ border-color:rgba(23,79,162,.7); background:rgba(23,79,162,.07); color:var(--blue-deep); }
.secnav__btn svg{ display:block; }
.secnav__save.is-saved{ color:#1f7a3d; border-color:rgba(31,122,61,.5); background:rgba(34,161,85,.1); }
.secnav__clear.is-armed{ color:#8a1f2b; border-color:#f3b5bb; background:#fdecec; }
@media (max-width:560px){ .secnav__status{ display:none; } }

/* keep anchored sections clear of the sticky topnav + secnav when jumped to */
html{ scroll-behavior:smooth; }
.section{ scroll-margin-top:116px; }

/* ---------- Intro ---------- */
.intro{ position:relative; z-index:2; padding:34px 0 4px; }
.landing .hero{ padding-bottom:0; }
.landing .intro{ padding-top:8px; }
.intro .rule{ width:64px; height:4px; background:linear-gradient(90deg,var(--blue),var(--accent-cyan)); border-radius:3px; margin-bottom:16px; }
.intro p{ color:#33485c; max-width:680px; }
.legend{ margin-top:14px; display:flex; flex-wrap:wrap; gap:16px; font-size:12.5px; color:var(--text-muted); font-family:var(--font-mono); }
.legend b{ color:var(--ink); font-weight:600; }

/* ---------- Form ---------- */
form{ position:relative; z-index:2; padding:8px 0 0; }
.section{ background:var(--panel); border:1px solid var(--border-subtle); border-radius:var(--radius-card); overflow:hidden; margin:18px 0; box-shadow:var(--shadow-card);
  transition:border-color .32s ease,transform .5s cubic-bezier(.2,.8,.2,1),opacity .5s ease,box-shadow .32s ease; }
.section.pre-reveal{ opacity:0; transform:translateY(18px); }
.section.is-visible{ opacity:1; transform:translateY(0); }
.section:hover{ border-color:rgba(23,79,162,.28); box-shadow:var(--shadow-soft); }
.section > .topbar{ height:3px; background:linear-gradient(90deg,var(--blue),var(--accent-cyan)); }
.section .pad{ padding:24px 26px 26px; }
.shead{ display:flex; align-items:flex-start; gap:14px; }
.shead .num{ flex:none; width:36px; height:36px; border-radius:11px; background:rgba(23,79,162,.08); border:1px solid rgba(23,79,162,.22); color:var(--blue);
  font-family:var(--font-mono); font-weight:500; font-size:15px; display:flex; align-items:center; justify-content:center; }
.shead h2{ font-size:21px; font-weight:600; }
.shead .desc{ color:var(--text-muted); font-size:13.5px; margin-top:5px; }
.shead .desc b{ color:var(--ink); font-weight:600; }

.fields{ margin-top:18px; }
.field-row{ margin-bottom:16px; }
.field-row:last-child{ margin-bottom:0; }
label.q{ display:block; font-family:var(--font-display); font-weight:500; font-size:14px; margin-bottom:6px; color:var(--ink); }
label.q .req{ color:var(--blue); }
.hint{ font-size:12.5px; color:var(--text-muted); margin:-2px 0 8px; }
input[type=text],input[type=email],input[type=url],input[type=number],select,textarea{
  width:100%; font-family:var(--font-body); font-size:14.5px; color:var(--ink);
  background:var(--field-bg); border:1px solid var(--border-subtle); border-radius:10px; padding:11px 13px; transition:border-color .2s,box-shadow .2s,background .2s; }
input::placeholder,textarea::placeholder{ color:#9aa7b6; }
select{ appearance:none; -webkit-appearance:none; background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235B6B7E' stroke-width='2.5'><path d='M6 9l6 6 6-6'/></svg>"); background-repeat:no-repeat; background-position:right 13px center; padding-right:34px; }
textarea{ min-height:84px; resize:vertical; line-height:1.5; }
input:focus,select:focus,textarea:focus{ outline:none; border-color:rgba(23,79,162,.55); box-shadow:0 0 0 3px rgba(23,79,162,.13); background:#fff; }
.two{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }

.choices{ display:flex; flex-direction:column; gap:9px; }
.choices.inline{ flex-direction:row; flex-wrap:wrap; gap:10px; }
.choice{ display:flex; align-items:flex-start; gap:10px; background:var(--field-bg); border:1px solid var(--border-subtle); border-radius:11px; padding:11px 13px; cursor:pointer; font-size:14px; transition:border-color .18s,background .18s; }
.choice:hover{ border-color:rgba(23,79,162,.32); background:rgba(23,79,162,.04); }
.choice input{ margin-top:2px; accent-color:var(--blue); width:16px; height:16px; flex:none; }
.choice .ctext b{ font-family:var(--font-display); font-weight:500; }
.choice .ctext span{ display:block; color:var(--text-muted); font-size:12.5px; }
.choice.beta .ctext b::after{ content:"BETA"; font-family:var(--font-mono); font-size:9px; letter-spacing:.08em; background:rgba(23,79,162,.12); color:var(--blue); padding:2px 6px; border-radius:4px; margin-left:8px; vertical-align:middle; }

.callout{ margin:14px 0; border-left:3px solid var(--blue); background:linear-gradient(180deg,rgba(23,79,162,.06),rgba(23,79,162,.01)); padding:13px 16px; border-radius:0 10px 10px 0; }
.callout p{ margin:0; font-size:13.5px; color:#33485c; }
.callout b{ color:var(--blue); font-weight:600; }

.defaults{ background:#f6f9fd; border:1px dashed var(--border-strong); border-radius:11px; padding:13px 15px; font-size:13.5px; color:#33485c; margin-bottom:10px; }
.defaults .dlab{ font-family:var(--font-mono); font-weight:500; font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--blue); margin-bottom:7px; }
.defaults ul{ margin:0; padding-left:18px; } .defaults li{ margin-bottom:3px; }

.proptable .prow{ display:grid; grid-template-columns:1fr 90px 90px 1fr; gap:10px; align-items:center; margin-bottom:9px; }
.proptable .ph{ font-family:var(--font-mono); font-weight:500; font-size:10.5px; text-transform:uppercase; letter-spacing:.06em; color:var(--text-muted); }
.proptable .center{ text-align:center; }
.addrow{ font-family:var(--font-mono); font-weight:500; font-size:12px; color:var(--blue); background:none; border:1px dashed rgba(23,79,162,.4); border-radius:9px; padding:8px 13px; cursor:pointer; margin-top:4px; transition:background .18s; }
.addrow:hover{ background:rgba(23,79,162,.05); }

.gate{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; background:#f6f9fd; border:1px solid var(--border-subtle); border-radius:11px; padding:12px 14px; }
.gate .glab{ font-family:var(--font-display); font-weight:500; font-size:13.5px; }
.gate label{ display:flex; align-items:center; gap:7px; font-size:14px; cursor:pointer; }
.gate input{ accent-color:var(--blue); width:16px; height:16px; }
.conditional{ margin-top:16px; }
.conditional[hidden]{ display:none; }

/* ---------- Submit well ---------- */
.submit-well{ position:relative; z-index:2; background:linear-gradient(180deg,rgba(23,79,162,.07),#FFFFFF); border:1px solid var(--border-subtle); border-radius:var(--radius-card); padding:30px 28px; margin:26px 0; box-shadow:var(--shadow-card); }
.submit-well h2{ font-size:23px; font-weight:600; }
.submit-well .next{ margin-top:12px; color:var(--text-muted); font-size:14px; }
.submit-well ol{ margin:10px 0 0 18px; color:#33485c; font-size:13.5px; }
.submit-well ol li{ margin-bottom:4px; }
.ctas{ margin-top:22px; display:flex; gap:13px; flex-wrap:wrap; align-items:center; }
.btn{ font-family:var(--font-body); font-weight:500; font-size:14px; padding:13px 24px; border-radius:999px; transition:transform .2s,background .2s,border-color .2s,box-shadow .2s; }
.btn.solid{ background:var(--blue); color:#fff; font-weight:600; }
.btn.solid:hover{ transform:translateY(-2px); background:#1a59b8; box-shadow:0 16px 38px -16px rgba(23,79,162,.55); }
.btn.ghost{ background:#fff; border:1px solid var(--border-subtle); color:var(--ink); }
.btn.ghost:hover{ border-color:var(--border-strong); }
.btn[disabled]{ opacity:.5; cursor:not-allowed; }
.formnote{ font-size:12px; color:var(--text-muted); font-family:var(--font-mono); }
.status{ margin-top:16px; font-size:14px; padding:13px 15px; border-radius:11px; display:none; }
.status.ok{ display:block; background:rgba(23,79,162,.08); border:1px solid rgba(23,79,162,.3); color:#123E82; }
.status.err{ display:block; background:#fdecec; border:1px solid #f3b5bb; color:#8a1f2b; }

/* ---------- Auto-save progress bar (injected by intake.js) ---------- */
.progress-bar{ display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap;
  margin:0 0 26px; padding:10px 14px; border:1px solid var(--border-subtle); border-radius:11px;
  background:rgba(23,79,162,.045); }
.progress-bar__msg{ flex:1 1 auto; min-width:0; font-family:var(--font-mono); font-size:11.5px; letter-spacing:.03em; color:var(--text-muted); }
.progress-bar__clear{ font-family:var(--font-mono); font-size:11px; letter-spacing:.06em; color:var(--blue);
  background:transparent; border:1px solid rgba(23,79,162,.35); border-radius:999px; padding:6px 13px; cursor:pointer;
  transition:color .2s,border-color .2s,background .2s; }
.progress-bar__clear:hover{ border-color:rgba(23,79,162,.7); background:rgba(23,79,162,.07); color:var(--blue-deep); }
.progress-bar__clear.is-armed{ color:#8a1f2b; border-color:#f3b5bb; background:#fdecec; }

/* ---------- Auto-fill with AI: trigger button + modal ---------- */
.aifill-btn{ flex:none; display:inline-flex; align-items:center; gap:6px; font-family:var(--font-mono); font-size:11px; letter-spacing:.04em;
  color:#fff; background:linear-gradient(120deg,var(--blue),var(--blue-mid)); border:1px solid rgba(23,79,162,.5); border-radius:999px;
  padding:6px 13px; cursor:pointer; white-space:nowrap; transition:filter .2s,transform .2s,box-shadow .2s; box-shadow:0 6px 16px -8px rgba(23,79,162,.6); }
.aifill-btn:hover{ filter:brightness(1.07); transform:translateY(-1px); box-shadow:0 10px 22px -8px rgba(23,79,162,.7); }
.aifill-btn .spark{ font-size:12px; line-height:1; }
.aifill-btn--compact{ padding:5px 10px; }

.aimodal{ position:fixed; inset:0; z-index:100; display:flex; align-items:flex-start; justify-content:center; padding:6vh 18px 18px; }
.aimodal[hidden]{ display:none; }
.aimodal__backdrop{ position:absolute; inset:0; background:rgba(13,24,38,.5); backdrop-filter:saturate(140%) blur(3px); }
.aimodal__card{ position:relative; z-index:1; width:100%; max-width:600px; max-height:86vh; overflow-y:auto;
  background:var(--panel); border:1px solid var(--border-subtle); border-radius:18px; box-shadow:0 40px 120px -30px rgba(13,24,38,.6); padding:28px 28px 26px; }
.aimodal__close{ position:absolute; top:14px; right:16px; width:30px; height:30px; border-radius:8px; border:1px solid var(--border-subtle);
  background:#fff; color:var(--text-muted); font-size:18px; line-height:1; cursor:pointer; transition:color .2s,border-color .2s; }
.aimodal__close:hover{ border-color:var(--border-strong); color:var(--ink); }
.aimodal__head{ margin-bottom:18px; padding-right:30px; }
.aimodal__head .aimodal__spark{ font-size:22px; }
.aimodal__head h2{ font-size:22px; font-weight:600; margin:6px 0 6px; }
.aimodal__head p{ color:var(--text-muted); font-size:13.5px; line-height:1.5; }
.aimodal__steps{ list-style:none; counter-reset:ai; padding:0; margin:0; display:flex; flex-direction:column; gap:16px; }
.aimodal__steps li{ position:relative; padding-left:38px; font-size:13.5px; line-height:1.5; color:#33485c; counter-increment:ai; }
.aimodal__steps li::before{ content:counter(ai); position:absolute; left:0; top:-2px; width:26px; height:26px; border-radius:8px;
  background:rgba(23,79,162,.08); border:1px solid rgba(23,79,162,.22); color:var(--blue); font-family:var(--font-mono); font-weight:500;
  display:flex; align-items:center; justify-content:center; font-size:13px; }
.aimodal__steps b{ font-family:var(--font-display); font-weight:600; color:var(--ink); }
.aimodal__row{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-top:10px; }
.aimodal .btn{ padding:10px 18px; font-size:13px; }
.aimodal__copied, .aimodal__result{ font-family:var(--font-mono); font-size:11.5px; color:#1f7a3d; }
.aimodal__result.err{ color:#8a1f2b; }
.aimodal__paste{ width:100%; min-height:120px; margin-top:10px; font-family:var(--font-mono); font-size:12px; }
.aimodal__share{ margin-top:20px; padding-top:18px; border-top:1px solid var(--border-subtle); }
.aimodal__share > label{ display:block; font-family:var(--font-display); font-weight:500; font-size:13px; margin-bottom:7px; color:var(--ink); }
.aimodal__sharerow{ display:flex; gap:8px; }
.aimodal__shareurl{ flex:1 1 auto; min-width:0; font-family:var(--font-mono); font-size:11.5px; }
.aimodal__share .hint{ margin-top:9px; }
@media (max-width:560px){ .aimodal__sharerow{ flex-direction:column; } }

/* ---------- Toast (animated in/out notice, e.g. pre-filled-from-link) ---------- */
.sg-toast{ position:fixed; left:50%; bottom:28px; z-index:120; transform:translateX(-50%) translateY(18px);
  display:flex; align-items:center; gap:15px; min-width:min(440px, calc(100vw - 32px)); max-width:min(560px, calc(100vw - 32px));
  background:linear-gradient(125deg,var(--blue),var(--blue-mid)); border:1px solid rgba(23,79,162,.6); border-radius:14px;
  box-shadow:0 24px 70px -18px rgba(23,79,162,.7); color:#fff;
  padding:17px 22px; opacity:0; transition:opacity .4s ease, transform .4s cubic-bezier(.2,.8,.2,1); }
.sg-toast.is-in{ opacity:1; transform:translateX(-50%) translateY(0); }
.sg-toast__icon{ flex:none; width:30px; height:30px; border-radius:9px; display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.18); border:1px solid rgba(255,255,255,.42); color:#fff; }
.sg-toast__icon svg{ display:block; }
.sg-toast__msg{ font-size:13.5px; color:#fff; line-height:1.35; }
.sg-toast__msg b{ font-family:var(--font-display); font-weight:600; color:#fff; }
.sg-toast__msg span{ display:block; color:rgba(255,255,255,.85); font-size:12.5px; margin-top:1px; }
.sg-toast__close{ flex:none; margin-left:4px; width:22px; height:22px; border-radius:6px; border:1px solid rgba(255,255,255,.38);
  background:rgba(255,255,255,.14); color:rgba(255,255,255,.9); font-size:14px; line-height:1; cursor:pointer; transition:background .2s,border-color .2s,color .2s; }
.sg-toast__close:hover{ background:rgba(255,255,255,.26); border-color:rgba(255,255,255,.6); color:#fff; }
@media (prefers-reduced-motion: reduce){
  .sg-toast{ transition:opacity .25s ease; transform:translateX(-50%); }
  .sg-toast.is-in{ transform:translateX(-50%); }
}

/* ---------- Success screen ---------- */
#thanks{ display:none; text-align:center; padding:70px 0; position:relative; z-index:2; }
#thanks .mark2{ width:64px; height:64px; border-radius:16px; margin:0 auto 22px; background:rgba(23,79,162,.07); border:1px solid rgba(23,79,162,.22); display:flex; align-items:center; justify-content:center; }
#thanks .mark2 img{ width:40px; height:40px; }
#thanks h2{ font-size:30px; font-weight:600; background:linear-gradient(180deg,#0E2236,#1E4DA8); -webkit-background-clip:text; background-clip:text; color:transparent; }
#thanks p{ color:var(--text-muted); max-width:520px; margin:12px auto 0; }
#thanks a{ color:var(--blue); }

/* ---------- Landing cards ---------- */
.cat-head{ position:relative; z-index:2; display:flex; align-items:center; gap:13px; margin:38px 0 16px; }
.cat-head .emblem{ width:40px; height:40px; border-radius:12px; display:flex; align-items:center; justify-content:center; flex:none; }
.cat-head .emblem svg{ width:21px; height:21px; }
.cat-head .emblem.breeze{ background:rgba(23,79,162,.08); border:1px solid rgba(23,79,162,.22); color:var(--blue); }
.cat-head .emblem.custom{ background:rgba(51,204,255,.12); border:1px solid rgba(51,204,255,.34); color:var(--blue-mid); }
.cat-head .lab{ font-family:var(--font-display); font-weight:700; font-size:19px; letter-spacing:0; text-transform:none; color:var(--ink); }
.cat-head .line{ flex:1; height:1px; background:var(--border-subtle); }
/* lighter sub-row label inside a category (e.g. File-Based / API Integration) */
.subhead{ position:relative; z-index:2; display:flex; align-items:center; gap:9px; margin:20px 0 2px; padding-left:46px;
  font-family:var(--font-mono); font-weight:500; font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--text-muted); }
.subhead::before{ content:""; width:12px; height:1px; background:var(--border-strong); flex:none; }
.intake-grid{ position:relative; z-index:2; display:grid; grid-template-columns:1fr 1fr; gap:22px; padding:6px 0 8px; }
.card{ position:relative; display:flex; flex-direction:column; align-items:flex-start; gap:9px; padding:26px; background:var(--panel);
  border:1px solid var(--border-subtle); border-radius:var(--radius-card); color:var(--ink); overflow:hidden; isolation:isolate; box-shadow:var(--shadow-card);
  transition:transform .32s cubic-bezier(.2,.8,.2,1),border-color .32s ease,box-shadow .32s ease; }
.card__icon{ display:inline-flex; align-items:center; justify-content:center; width:52px; height:52px; border-radius:14px; background:rgba(23,79,162,.05); border:1px solid var(--border-subtle); color:var(--blue); margin-bottom:6px; transition:transform .4s cubic-bezier(.2,.8,.2,1),background .32s,border-color .32s; }
.card__eyebrow{ font-family:var(--font-mono); font-size:11px; font-weight:500; letter-spacing:.18em; color:var(--blue); }
.card__title{ font-family:var(--font-display); font-size:21px; font-weight:600; line-height:1.18; color:var(--ink); }
.card__sub{ font-size:13.5px; color:var(--text-muted); line-height:1.5; flex-grow:1; }
.card__cta{ display:inline-flex; align-items:center; gap:7px; margin-top:14px; padding:11px 17px; font-size:13.5px; font-weight:500; border-radius:999px; background:#f3f8fd; border:1px solid var(--border-subtle); color:var(--blue); transition:background .3s,border-color .3s,transform .3s; }
a.card:hover{ transform:translateY(-6px); border-color:rgba(23,79,162,.25); box-shadow:var(--shadow-soft),0 24px 70px -18px rgba(23,79,162,.4); }
a.card:hover .card__icon{ transform:scale(1.08) rotate(-6deg); background:rgba(23,79,162,.1); border-color:rgba(23,79,162,.3); }
a.card:hover .card__cta{ background:#eaf2fb; border-color:var(--border-strong); transform:translateX(2px); }
.card::before{ content:""; position:absolute; inset:-1px; border-radius:inherit; padding:1px;
  background:conic-gradient(from var(--shimmer-angle,0deg),transparent 0deg,rgba(51,204,255,.7) 90deg,transparent 180deg,transparent 360deg);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0); -webkit-mask-composite:xor; mask-composite:exclude;
  opacity:0; transition:opacity .32s ease; pointer-events:none; z-index:1; }
@property --shimmer-angle{ syntax:'<angle>'; inherits:false; initial-value:0deg; }
@keyframes shimmerSpin{ to{ --shimmer-angle:360deg; } }
a.card:hover::before{ opacity:1; animation:shimmerSpin 4s linear infinite; }
/* Breeze-agent cards: warm-orange hover accents to match the orange background mood */
.card.breeze::before{ background:conic-gradient(from var(--shimmer-angle,0deg),transparent 0deg,rgba(255,122,89,.75) 90deg,transparent 180deg,transparent 360deg); }
a.card.breeze:hover{ border-color:rgba(255,122,89,.3); box-shadow:var(--shadow-soft),0 24px 70px -18px rgba(255,122,89,.42); }
a.card.breeze:hover .card__icon{ background:rgba(255,122,89,.12); border-color:rgba(255,122,89,.32); color:var(--breeze-deep); }
a.card.breeze:hover .card__cta{ background:rgba(255,122,89,.10); color:var(--breeze-deep); }
.card.soon{ opacity:.62; }
.card.soon .card__icon{ color:var(--text-muted); }
.card.soon .card__eyebrow{ color:var(--text-muted); }
.badge{ font-family:var(--font-mono); font-size:9.5px; font-weight:500; letter-spacing:.08em; text-transform:uppercase; padding:3px 8px; border-radius:5px; vertical-align:middle; margin-left:8px; }
.badge.soon{ background:rgba(16,35,54,.08); color:var(--text-muted); }
.badge.presales{ background:rgba(51,204,255,.18); color:#0d6b8a; }
.badge.clients{ background:rgba(23,79,162,.12); color:var(--blue); }

/* file picker (API collection / spec convenience input) */
input[type=file]{ width:100%; font-family:var(--font-mono); font-size:12px; color:var(--text-muted); padding:8px 11px; background:var(--field-bg); border:1px dashed var(--border-strong); border-radius:11px; cursor:pointer; }
input[type=file]::file-selector-button{ font-family:var(--font-mono); font-size:11px; margin-right:10px; padding:6px 10px; border-radius:8px; border:1px solid rgba(23,79,162,.4); background:#fff; color:var(--blue); cursor:pointer; }
input[type=file]:hover{ border-color:rgba(23,79,162,.45); }

/* ---------- Footer ---------- */
.pagefoot{ position:relative; z-index:2; border-top:1px solid var(--border-subtle); margin-top:8px; padding:24px 0 44px; color:var(--text-muted); font-size:12px; font-family:var(--font-mono); letter-spacing:.03em; display:flex; align-items:center; flex-wrap:wrap; gap:6px 16px; }
.pagefoot .labs{ display:flex; align-items:center; gap:9px; margin-bottom:0; flex:none; }
.pagefoot .labs img{ width:24px; height:24px; border-radius:6px; }
.pagefoot .labs b{ color:var(--ink); font-weight:600; font-family:var(--font-display); letter-spacing:0; }
.pagefoot .labs span{ color:var(--text-muted); }
.pagefoot .foot-meta{ color:#8595a6; }

/* ---------- Entrance (hero/landing) ---------- */
@keyframes fadeUp{ from{ opacity:0; transform:translateY(18px); } to{ opacity:1; transform:translateY(0); } }
.hero .kicker,.hero h1,.hero .lede,.hero .meta,.intake-grid .card{ opacity:0; animation:fadeUp 760ms cubic-bezier(.2,.8,.2,1) forwards; }
.hero .kicker{ animation-delay:80ms; } .hero h1{ animation-delay:200ms; } .hero .lede{ animation-delay:340ms; } .hero .meta{ animation-delay:460ms; }
.intake-grid .card:nth-child(1){ animation-delay:560ms; } .intake-grid .card:nth-child(2){ animation-delay:660ms; }
.intake-grid .card:nth-child(3){ animation-delay:760ms; } .intake-grid .card:nth-child(4){ animation-delay:860ms; }

/* ---------- Responsive ---------- */
@media (max-width:720px){
  .hero h1{ font-size:34px; }
  .two{ grid-template-columns:1fr; }
  .intake-grid{ grid-template-columns:1fr; }
  .proptable .prow{ grid-template-columns:1fr 1fr; } .proptable .ph{ display:none; }
  .section .pad{ padding:20px 18px 22px; }
  .ambient__orb{ width:360px; height:360px; margin-left:-180px; margin-top:-180px; }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; }
  .ambient__mesh,.ambient__orb{ animation:none !important; }
  .hero .kicker,.hero h1,.hero .lede,.hero .meta,.intake-grid .card,.section{ opacity:1 !important; transform:none !important; }
}
