
:root{
  --ink:#0A1422;
  --ink-2:#0E1B2E;
  --panel:#13233B;
  --panel-2:#182B47;
  --line:rgba(140,165,200,.16);
  --line-strong:rgba(140,165,200,.28);
  --text:#EDF2F9;
  --muted:#93A4BC;
  --faint:#5F7290;
  --orange:#FE7401;
  --orange-soft:rgba(254,116,1,.14);
  --green:#3DCB85;
  --amber:#F5B83D;
  --red:#EF5350;
  --radius:18px;
  --display:"Bricolage Grotesque",sans-serif;
  --body:"Instrument Sans",system-ui,sans-serif;
  --mono:"IBM Plex Mono",monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--ink);
  color:var(--text);
  font-family:var(--body);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--orange);color:#fff}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.eyebrow{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--orange);
  display:flex;align-items:center;gap:12px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--orange);border-radius:2px}
h2{
  font-family:var(--display);
  font-weight:700;
  font-size:clamp(30px,4.4vw,46px);
  line-height:1.12;
  letter-spacing:-.015em;
  margin:14px 0 16px;
}
.lede{color:var(--muted);max-width:620px;font-size:18px}
section{padding:96px 0}
:focus-visible{outline:2px solid var(--orange);outline-offset:3px;border-radius:6px}

/* ---------- nav ---------- */
header{
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(14px);
  background:rgba(10,20,34,.78);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.nav-logo img{height:44px;width:auto}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{font-size:15px;font-weight:500;color:var(--muted);transition:color .2s}
.nav-links a:hover{color:var(--text)}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-weight:600;font-size:15px;
  padding:12px 22px;border-radius:999px;
  transition:transform .15s ease, box-shadow .2s ease, background .2s;
  cursor:pointer;border:none;
}
.btn-primary{background:var(--orange);color:#fff;box-shadow:0 6px 24px rgba(254,116,1,.32)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(254,116,1,.42)}
.btn-ghost{border:1px solid var(--line-strong);color:var(--text)}
.btn-ghost:hover{border-color:var(--orange);color:var(--orange)}
.menu-toggle{display:none;background:none;border:none;color:var(--text);font-size:26px;cursor:pointer}

/* ---------- hero ---------- */
.hero{
  position:relative;
  padding:90px 0 110px;
  overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(900px 500px at 78% 18%, rgba(254,116,1,.10), transparent 60%),
    radial-gradient(700px 500px at 8% 90%, rgba(40,90,160,.16), transparent 60%);
  pointer-events:none;
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center;position:relative}
.hero-logo{width:min(420px,82%);margin-bottom:34px}
h1{
  font-family:var(--display);
  font-weight:800;
  font-size:clamp(40px,5.6vw,64px);
  line-height:1.05;
  letter-spacing:-.02em;
}
h1 .accent{color:var(--orange)}
.hero p.sub{margin:22px 0 34px;color:var(--muted);font-size:19px;max-width:560px}
.hero-ctas{display:flex;flex-wrap:wrap;gap:16px;align-items:center}
.appstore-btn{
  display:inline-flex;align-items:center;gap:12px;
  background:#fff;color:#0A1422;
  border-radius:14px;padding:11px 22px 11px 16px;
  transition:transform .15s ease,box-shadow .2s ease;
  box-shadow:0 6px 24px rgba(0,0,0,.35);
}
.appstore-btn:hover{transform:translateY(-2px)}
.appstore-btn svg{width:30px;height:30px;flex-shrink:0}
.appstore-btn .lines{line-height:1.15;text-align:left}
.appstore-btn .lines small{display:block;font-size:11px;font-weight:500;color:#5a6577;letter-spacing:.02em}
.appstore-btn .lines strong{font-size:18px;font-weight:700;letter-spacing:-.01em}
.android-pill{
  font-family:var(--mono);font-size:12px;letter-spacing:.08em;
  color:var(--muted);
  border:1px dashed var(--line-strong);
  border-radius:999px;padding:10px 18px;
}
.android-pill b{color:var(--text);font-weight:600}
.role-strip{display:flex;flex-wrap:wrap;gap:10px;margin-top:40px}
.role-chip{
  font-family:var(--mono);font-size:12px;letter-spacing:.06em;
  padding:7px 14px;border-radius:999px;
  background:var(--orange-soft);color:#FFB066;
  border:1px solid rgba(254,116,1,.22);
}

/* ---------- phone mockup ---------- */
.phone-stage{position:relative;display:flex;justify-content:center}
.route-bg{position:absolute;inset:-40px -20px;pointer-events:none;opacity:.9}
.phone{
  position:relative;
  width:330px;border-radius:46px;
  background:#070D17;
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 50px 100px -20px rgba(0,0,0,.7), 0 0 0 10px rgba(255,255,255,.03);
  padding:14px;
}
.phone-screen{
  background:linear-gradient(180deg,#0E1B2E 0%,#0A1626 100%);
  border-radius:34px;overflow:hidden;
  font-size:13px;
}
.notch{width:110px;height:26px;background:#070D17;border-radius:0 0 16px 16px;margin:0 auto}
.app-head{padding:14px 18px 12px;border-bottom:1px solid var(--line)}
.app-head .run-type{font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--orange)}
.app-head .run-name{font-family:var(--display);font-weight:700;font-size:18px;margin-top:3px}
.app-head .run-meta{color:var(--faint);font-size:11.5px;margin-top:2px;font-family:var(--mono)}
.acct-strip{display:grid;grid-template-columns:repeat(4,1fr);text-align:center;padding:12px 10px;background:rgba(254,116,1,.07);border-bottom:1px solid var(--line)}
.acct-strip .num{font-family:var(--display);font-weight:800;font-size:20px}
.acct-strip .lbl{font-family:var(--mono);font-size:8.5px;letter-spacing:.12em;color:var(--faint);text-transform:uppercase}
.acct-strip .on .num{color:var(--orange)}
.next-stop{margin:14px 14px 0;padding:12px 14px;border-radius:14px;background:var(--panel);border:1px solid var(--line)}
.next-stop .approach{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--green)}
.pulse{width:8px;height:8px;border-radius:50%;background:var(--green);animation:pulse 1.6s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(61,203,133,.5)}70%{box-shadow:0 0 0 9px rgba(61,203,133,0)}100%{box-shadow:0 0 0 0 rgba(61,203,133,0)}}
.next-stop .stop-name{font-weight:700;font-size:15px;margin-top:5px}
.next-stop .stop-sub{color:var(--faint);font-size:11.5px}
.manifest{padding:12px 14px 18px;display:flex;flex-direction:column;gap:8px}
.manifest-title{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;color:var(--faint);text-transform:uppercase;margin-bottom:2px}
.student{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:12px;background:rgba(255,255,255,.03);border:1px solid var(--line)}
.avatar{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:11px;flex-shrink:0}
.student .sname{font-weight:600;font-size:13px}
.student .syr{color:var(--faint);font-size:10.5px;font-family:var(--mono)}
.tag{margin-left:auto;font-family:var(--mono);font-size:9px;letter-spacing:.1em;padding:4px 9px;border-radius:999px}
.tag.boarded{background:rgba(61,203,133,.14);color:var(--green)}
.tag.tap{background:var(--orange-soft);color:var(--orange);border:1px solid rgba(254,116,1,.3)}
.tag.absent{background:rgba(239,83,80,.12);color:var(--red)}

/* ---------- run workflow / route line ---------- */
.workflow{background:var(--ink-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.run-track{position:relative;margin-top:64px;padding-left:34px}
.run-track::before{
  content:"";position:absolute;left:10px;top:8px;bottom:8px;width:0;
  border-left:3px dashed var(--line-strong);
}
.run-line{
  position:absolute;left:10px;top:8px;width:0;height:0;
  border-left:3px solid var(--orange);
  transition:height 1.1s cubic-bezier(.6,.05,.2,1);
  box-shadow:0 0 14px rgba(254,116,1,.5);
}
.run-step{position:relative;padding:0 0 52px 26px}
.run-step:last-child{padding-bottom:0}
.run-step .node{
  position:absolute;left:-34px;top:4px;
  width:22px;height:22px;border-radius:50%;
  background:var(--ink-2);
  border:3px solid var(--line-strong);
  transition:border-color .4s,background .4s, box-shadow .4s;
}
.run-step.active .node{border-color:var(--orange);background:var(--orange);box-shadow:0 0 0 6px var(--orange-soft)}
.run-step .step-k{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--orange);text-transform:uppercase}
.run-step h3{font-family:var(--display);font-weight:700;font-size:22px;margin:6px 0 6px}
.run-step p{color:var(--muted);max-width:560px;font-size:16px}
.workflow-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:start}
.workflow-aside{position:sticky;top:110px}
.guarantee{
  margin-top:34px;padding:20px 22px;border-radius:var(--radius);
  background:var(--orange-soft);border:1px solid rgba(254,116,1,.25);
  display:flex;gap:14px;align-items:flex-start;
}
.guarantee svg{flex-shrink:0;margin-top:3px}
.guarantee p{font-size:15.5px;color:#FFD3AD}
.guarantee b{color:#fff}

/* ---------- roles ---------- */
.roles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:56px}
.role-card{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:28px 26px;
  transition:transform .2s ease,border-color .2s ease;
  position:relative;overflow:hidden;
}
.role-card::after{
  content:"";position:absolute;left:26px;right:26px;top:0;height:3px;border-radius:0 0 4px 4px;
  background:var(--orange);opacity:0;transition:opacity .25s;
}
.role-card:hover{transform:translateY(-4px);border-color:var(--line-strong)}
.role-card:hover::after{opacity:1}
.role-card .ric{
  width:44px;height:44px;border-radius:12px;display:grid;place-items:center;
  background:var(--orange-soft);margin-bottom:18px;
}
.role-card h3{font-family:var(--display);font-weight:700;font-size:21px;margin-bottom:8px}
.role-card p{color:var(--muted);font-size:15.5px}
.role-card ul{list-style:none;margin-top:14px;display:flex;flex-direction:column;gap:7px}
.role-card li{color:var(--muted);font-size:14.5px;padding-left:20px;position:relative}
.role-card li::before{content:"";position:absolute;left:0;top:9px;width:9px;height:3px;border-radius:2px;background:var(--orange)}
.role-card.wide{grid-column:span 1}

/* ---------- features ---------- */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:56px}
.feat{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;transition:border-color .2s;
}
.feat:hover{border-color:rgba(254,116,1,.35)}
.feat h3{font-family:var(--display);font-size:19px;font-weight:700;margin:14px 0 8px}
.feat p{color:var(--muted);font-size:15px}
.feat .fic{width:42px;height:42px;border-radius:11px;background:var(--orange-soft);display:grid;place-items:center}
.compliance-chips{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}
.chip{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;padding:5px 11px;border-radius:999px}
.chip.g{background:rgba(61,203,133,.13);color:var(--green)}
.chip.a{background:rgba(245,184,61,.13);color:var(--amber)}
.chip.r{background:rgba(239,83,80,.13);color:var(--red)}

/* ---------- parents ---------- */
.parents{background:var(--ink-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.parent-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.parent-list{list-style:none;margin-top:26px;display:flex;flex-direction:column;gap:16px}
.parent-list li{display:flex;gap:14px;align-items:flex-start;color:var(--muted);font-size:16px}
.parent-list .dot{width:26px;height:26px;flex-shrink:0;border-radius:50%;background:var(--orange-soft);display:grid;place-items:center;margin-top:1px}
.parent-list b{color:var(--text)}
.parent-card{
  background:var(--panel);border:1px solid var(--line);border-radius:24px;
  padding:24px;max-width:400px;margin:0 auto;width:100%;
  box-shadow:0 40px 80px -30px rgba(0,0,0,.6);
}
.pc-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.pc-head .hi{font-family:var(--display);font-weight:700;font-size:19px}
.pc-head .date{font-family:var(--mono);font-size:11px;color:var(--faint)}
.trip{border:1px solid var(--line);border-radius:16px;padding:16px;margin-bottom:12px;background:rgba(255,255,255,.02)}
.trip .t-row{display:flex;justify-content:space-between;align-items:center}
.trip .t-type{font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--orange)}
.trip .t-status{font-family:var(--mono);font-size:10px;padding:4px 10px;border-radius:999px}
.trip .t-status.live{background:rgba(61,203,133,.14);color:var(--green)}
.trip .t-status.sched{background:rgba(255,255,255,.06);color:var(--muted)}
.trip .t-stop{font-weight:700;font-size:16px;margin-top:8px}
.trip .t-time{color:var(--faint);font-size:13px;font-family:var(--mono)}
.absent-btn{
  width:100%;margin-top:4px;padding:13px;border-radius:13px;
  border:1px solid rgba(254,116,1,.4);background:transparent;color:var(--orange);
  font-weight:600;font-size:14.5px;font-family:var(--body);cursor:pointer;
  transition:background .2s;
}
.absent-btn:hover{background:var(--orange-soft)}

/* ---------- differentiators ---------- */
.diff-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin-top:56px}
.diff{background:var(--ink);padding:30px 28px}
.diff h3{font-family:var(--display);font-size:18px;font-weight:700;margin-bottom:8px;display:flex;align-items:center;gap:10px}
.diff h3 span{color:var(--orange)}
.diff p{color:var(--muted);font-size:15px}

/* ---------- cta ---------- */
.final-cta{position:relative;text-align:center;padding:120px 0;overflow:hidden}
.final-cta::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(700px 400px at 50% 100%, rgba(254,116,1,.13), transparent 65%);
  pointer-events:none;
}
.final-cta img{width:min(380px,76%);margin:0 auto 36px}
.final-cta h2{margin-bottom:14px}
.final-cta .lede{margin:0 auto 40px}
.cta-row{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;align-items:center}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line);padding:40px 0;color:var(--faint);font-size:14px}
.foot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.foot .tagline{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase}
.foot .tagline b{color:var(--orange);font-weight:600}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .run-line{transition:none}
  .pulse{animation:none}
  html{scroll-behavior:auto}
}

/* ---------- responsive ---------- */
@media (max-width:1000px){
  .hero-grid,.workflow-grid,.parent-grid{grid-template-columns:1fr;gap:60px}
  .workflow-aside{position:static}
  .roles-grid{grid-template-columns:repeat(2,1fr)}
  .feat-grid{grid-template-columns:repeat(2,1fr)}
  .diff-grid{grid-template-columns:repeat(2,1fr)}
  .phone-stage{order:2}
}
@media (max-width:680px){
  section{padding:72px 0}
  .nav-links{
    display:none;position:absolute;top:72px;left:0;right:0;
    flex-direction:column;background:var(--ink-2);
    padding:24px;border-bottom:1px solid var(--line);gap:20px;
  }
  .nav-links.open{display:flex}
  .menu-toggle{display:block}
  .roles-grid,.feat-grid,.diff-grid{grid-template-columns:1fr}
  .hero{padding:60px 0 80px}
  .phone{width:290px}
  .hero p.sub{font-size:17px}
}
/* ============ multi-page additions ============ */

/* page hero (subpages) */
.page-hero{
  position:relative;
  padding:78px 0 64px;
  border-bottom:1px solid var(--line);
  overflow:hidden;
}
.page-hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(760px 360px at 82% 0%, rgba(254,116,1,.10), transparent 60%);
  pointer-events:none;
}
.page-hero h1{
  font-size:clamp(34px,4.8vw,54px);
  margin-top:14px;
}
.page-hero .lede{margin-top:18px}

/* active nav link */
.nav-links a.active{color:var(--orange)}

/* feature detail sections */
.detail{
  display:grid;grid-template-columns:.85fr 1.15fr;gap:54px;
  padding:64px 0;border-bottom:1px solid var(--line);
  align-items:start;
}
.detail:last-of-type{border-bottom:none}
.detail h2{font-size:clamp(26px,3.2vw,36px);margin:10px 0 12px}
.detail .d-intro{color:var(--muted);font-size:16.5px}
.detail ul{list-style:none;display:flex;flex-direction:column;gap:13px;margin-top:4px}
.detail li{
  color:var(--muted);font-size:16px;
  padding:16px 18px 16px 44px;position:relative;
  background:var(--panel);border:1px solid var(--line);border-radius:14px;
}
.detail li::before{
  content:"";position:absolute;left:18px;top:23px;
  width:12px;height:4px;border-radius:3px;background:var(--orange);
}
.detail li b{color:var(--text)}

/* sticky in-page toc */
.toc-layout{display:grid;grid-template-columns:230px 1fr;gap:60px;align-items:start}
.toc{position:sticky;top:100px;display:flex;flex-direction:column;gap:4px;padding-top:64px}
.toc .toc-title{font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--faint);text-transform:uppercase;margin-bottom:10px}
.toc a{
  font-size:14.5px;color:var(--muted);padding:7px 12px;border-left:2px solid var(--line);
  transition:color .2s,border-color .2s;
}
.toc a:hover,.toc a.current{color:var(--orange);border-color:var(--orange)}

/* permissions matrix */
.perm-wrap{overflow-x:auto;margin-top:56px;border:1px solid var(--line);border-radius:var(--radius)}
table.perm{width:100%;border-collapse:collapse;min-width:760px;background:var(--panel)}
table.perm th,table.perm td{
  padding:15px 18px;text-align:center;font-size:14.5px;
  border-bottom:1px solid var(--line);
}
table.perm thead th{
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--orange);background:rgba(254,116,1,.06);
}
table.perm tbody tr:last-child td{border-bottom:none}
table.perm td:first-child,table.perm th:first-child{text-align:left;color:var(--text);font-weight:600}
table.perm td{color:var(--muted)}
.p-yes{color:var(--green);font-weight:700}
.p-view{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--amber)}
.p-no{color:var(--faint)}
.perm-note{font-size:13.5px;color:var(--faint);margin-top:14px}

/* deep lists (role pages) */
.deep-list{list-style:none;display:flex;flex-direction:column;gap:13px}
.deep-list li{
  color:var(--muted);font-size:16px;
  padding:16px 18px 16px 44px;position:relative;
  background:var(--panel);border:1px solid var(--line);border-radius:14px;
}
.deep-list li::before{
  content:"";position:absolute;left:18px;top:23px;
  width:12px;height:4px;border-radius:3px;background:var(--orange);
}
.deep-list li b{color:var(--text)}

/* role deep sections */
.role-deep{
  display:grid;grid-template-columns:1fr 1fr;gap:50px;
  padding:64px 0;border-bottom:1px solid var(--line);align-items:start;
}
.role-deep:last-of-type{border-bottom:none}
.role-deep h2{font-size:clamp(26px,3.2vw,36px)}
.role-deep .quote{
  margin-top:24px;padding:20px 22px;border-radius:var(--radius);
  background:var(--orange-soft);border:1px solid rgba(254,116,1,.25);
  color:#FFD3AD;font-size:15.5px;font-style:italic;
}

/* FAQ accordion */
.faq{max-width:780px;margin:56px auto 0;display:flex;flex-direction:column;gap:12px}
details.qa{
  background:var(--panel);border:1px solid var(--line);border-radius:16px;
  overflow:hidden;transition:border-color .2s;
}
details.qa[open]{border-color:rgba(254,116,1,.35)}
details.qa summary{
  list-style:none;cursor:pointer;
  padding:20px 54px 20px 24px;
  font-weight:600;font-size:16.5px;position:relative;
}
details.qa summary::-webkit-details-marker{display:none}
details.qa summary::after{
  content:"+";position:absolute;right:22px;top:50%;transform:translateY(-50%);
  font-family:var(--display);font-size:22px;color:var(--orange);
  transition:transform .25s;
}
details.qa[open] summary::after{transform:translateY(-50%) rotate(45deg)}
details.qa .qa-body{padding:0 24px 22px;color:var(--muted);font-size:15.5px}
details.qa .qa-body a{color:var(--orange)}

/* contact cards */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:56px}
.contact-card{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px;
}
.contact-card h3{font-family:var(--display);font-size:21px;font-weight:700;margin-bottom:8px}
.contact-card p{color:var(--muted);font-size:15.5px;margin-bottom:18px}
.contact-card .mono-link{font-family:var(--mono);font-size:14px;color:var(--orange)}

/* legal docs */
.doc{max-width:760px;margin:0 auto;padding:72px 24px 96px}
.doc h1{font-family:var(--display);font-weight:800;font-size:clamp(30px,4vw,42px);margin-bottom:8px}
.doc .updated{font-family:var(--mono);font-size:12px;letter-spacing:.12em;color:var(--faint);text-transform:uppercase;margin-bottom:40px}
.doc h2{font-size:22px;margin:42px 0 12px}
.doc p,.doc li{color:var(--muted);font-size:16px;margin-bottom:14px}
.doc ul{padding-left:22px;margin-bottom:14px}
.doc li{margin-bottom:8px}
.doc b{color:var(--text)}
.doc-note{
  background:var(--orange-soft);border:1px solid rgba(254,116,1,.3);
  border-radius:14px;padding:16px 20px;color:#FFD3AD;font-size:14.5px;margin-bottom:36px;
}

/* expanded footer */
.bigfoot{border-top:1px solid var(--line);padding:64px 0 0;background:var(--ink-2)}
.bigfoot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px}
.bigfoot .f-logo img{width:170px;margin-bottom:16px}
.bigfoot .f-tag{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--faint)}
.bigfoot .f-tag b{color:var(--orange)}
.bigfoot h4{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);margin-bottom:16px}
.bigfoot .f-col{display:flex;flex-direction:column;gap:10px}
.bigfoot .f-col a{color:var(--muted);font-size:15px;transition:color .2s}
.bigfoot .f-col a:hover{color:var(--orange)}
.bigfoot .legal-row{
  border-top:1px solid var(--line);
  padding:22px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  color:var(--faint);font-size:13.5px;
}

/* mid-page CTA band */
.cta-band{
  margin:80px 0 0;padding:56px 0;
  background:var(--ink-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  text-align:center;
}
.cta-band h2{font-size:clamp(26px,3.4vw,38px)}
.cta-band .cta-row{margin-top:28px}

@media (max-width:1000px){
  .toc-layout{grid-template-columns:1fr}
  .toc{display:none}
  .detail,.role-deep{grid-template-columns:1fr;gap:28px}
  .bigfoot-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:680px){
  .contact-grid{grid-template-columns:1fr}
  .bigfoot-grid{grid-template-columns:1fr;gap:32px}
  .page-hero{padding:56px 0 48px}
}

/* ============ feature deep pages ============ */
.learn{
  display:inline-flex;align-items:center;gap:6px;
  margin-top:16px;font-size:14px;font-weight:600;color:var(--orange);
  transition:gap .2s;
}
.learn:hover{gap:10px}
.vignette{
  background:var(--panel);border:1px solid var(--line);border-radius:20px;
  padding:22px;max-width:420px;width:100%;
  box-shadow:0 30px 70px -30px rgba(0,0,0,.55);
}
.vignette .v-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.vignette .v-title{font-family:var(--display);font-weight:700;font-size:17px}
.vignette .v-sub{font-family:var(--mono);font-size:10px;letter-spacing:.14em;color:var(--faint);text-transform:uppercase}
.v-row{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;border-radius:12px;
  background:rgba(255,255,255,.03);border:1px solid var(--line);
  margin-bottom:8px;font-size:13.5px;
}
.v-row:last-child{margin-bottom:0}
.v-row .v-main{font-weight:600;font-size:13.5px}
.v-row .v-meta{color:var(--faint);font-size:11px;font-family:var(--mono)}
.v-row .chip{margin-left:auto;flex-shrink:0}
.v-cta{
  width:100%;margin-top:12px;padding:12px;border-radius:12px;
  border:1px solid rgba(254,116,1,.4);background:var(--orange-soft);color:var(--orange);
  font-weight:600;font-size:13.5px;font-family:var(--body);text-align:center;
}
.feature-hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.week-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-top:4px}
.day{
  border:1px solid var(--line);border-radius:12px;padding:12px 8px;text-align:center;
  background:rgba(255,255,255,.03);
}
.day .d-name{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;color:var(--faint)}
.day .d-state{font-size:11px;font-weight:600;margin-top:6px;color:var(--green)}
.day.off{background:rgba(245,184,61,.06);border-color:rgba(245,184,61,.3)}
.day.off .d-state{color:var(--amber)}
.related{margin-top:64px;padding-top:40px;border-top:1px solid var(--line)}
.related h4{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);margin-bottom:18px}
.related-row{display:flex;flex-wrap:wrap;gap:12px}
.related-row a{
  padding:12px 20px;border-radius:999px;border:1px solid var(--line-strong);
  font-size:14.5px;font-weight:600;color:var(--muted);transition:all .2s;
}
.related-row a:hover{border-color:var(--orange);color:var(--orange)}
@media (max-width:1000px){
  .feature-hero-grid{grid-template-columns:1fr;gap:44px}
}
