/* ============================================================
   Gavrun — Damson
   Display: Instrument Serif · Body: Hanken Grotesk · Mono: JetBrains Mono
   Warm cream surfaces · plum signature · apricot secondary
   ============================================================ */
:root{
  --paper:#F2EAE0; --paper-2:#ECE1D3; --surface:#FCF7F1; --surface-2:#F6EDE2;
  --ink:#281B22; --ink-2:#5E4E54; --ink-3:#94838A; --line:#E2D5C6; --line-2:#EBE0D2;
  --plum:#883255; --plum-deep:#642340; --plum-soft:#F0DCE4; --plum-line:#E6C6D4;
  --apricot:#DE9356; --apricot-soft:#F7E3CE;
  --allow:#4F7A52; --allow-bg:#E3EEDD; --allow-line:#C2D9B8;
  --hold:#A9781A;  --hold-bg:#F5E9C9;  --hold-line:#E6CF98;
  --block:#B23A47; --block-bg:#F5DBDE; --block-line:#E8BAC0;
  --disp:"Instrument Serif",Georgia,serif;
  --sans:"Hanken Grotesk",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
  --dark:#1E1219; --dark-2:#281A22; --dark-line:#43303A; --dark-ink-2:#C2AEB7; --dark-ink-3:#8E7782;
  --r-sm:11px; --r:14px; --r-lg:20px; --r-xl:28px;
  --container:1180px;
  --shadow-sm:0 1px 2px rgba(50,30,40,.06), 0 1px 1px rgba(50,30,40,.04);
  --shadow:0 4px 14px -4px rgba(60,30,50,.12), 0 2px 6px -2px rgba(60,30,50,.07);
  --shadow-lg:0 30px 70px -28px rgba(60,25,45,.36), 0 10px 24px -14px rgba(60,25,45,.2);
  --shadow-xl:0 50px 100px -34px rgba(40,18,30,.5), 0 16px 40px -16px rgba(40,18,30,.26);
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
img,svg{display:block;max-width:100%;} a{color:inherit;text-decoration:none;}
::selection{background:var(--plum-soft);}
.wrap{width:100%;max-width:var(--container);margin:0 auto;padding:0 40px;}

/* typography helpers */
.eyebrow{font-family:var(--mono);font-size:11.5px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--plum);display:inline-flex;align-items:center;gap:10px;}
.eyebrow::before{content:"";width:20px;height:1.5px;background:var(--plum);}
.eyebrow .num{color:var(--ink-3);}
h1,h2,h3{font-family:var(--disp);font-weight:400;color:var(--ink);margin:0;letter-spacing:0;}
.sec{padding:clamp(64px,8vw,118px) 0;}
.sec-head{max-width:680px;}
.sec-head .eyebrow{margin-bottom:18px;}
.sec-head h2{font-size:clamp(38px,5vw,62px);line-height:1.05;margin:0;text-wrap:balance;}
.sec-head h2 em{font-style:italic;color:var(--plum);}
.sec-head p{font-size:18px;color:var(--ink-2);margin:clamp(50px,4.8vw,68px) 0 0;max-width:58ch;text-wrap:pretty;}
.sec-head p strong{color:var(--ink);font-weight:600;}
/* Decision section: keep the headline on a single line on desktop */
#decision .sec-head{max-width:none;}
#decision .sec-head h2{font-size:clamp(26px,3.1vw,40px);}
@media (min-width:760px){ #decision .sec-head h2{white-space:nowrap;} }
.center{margin-left:auto;margin-right:auto;text-align:center;}
.center p{margin-left:auto;margin-right:auto;}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--sans);font-size:15px;font-weight:600;padding:12px 22px;border-radius:10px;border:1px solid transparent;cursor:pointer;transition:transform .14s ease,box-shadow .2s,background .2s,border-color .2s,color .2s;white-space:nowrap;}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--plum);color:#fff;box-shadow:0 1px 2px rgba(100,35,64,.4),inset 0 1px 0 rgba(255,255,255,.12);}
.btn-primary:hover{background:var(--plum-deep);box-shadow:0 10px 24px -10px rgba(136,50,85,.7);}
.btn-ghost{color:var(--ink);background:transparent;}
.btn-ghost:hover{color:var(--plum);}
.btn-line{background:var(--surface);color:var(--ink);border-color:var(--line);box-shadow:var(--shadow-sm);}
.btn-line:hover{border-color:var(--plum);color:var(--plum);}
.btn-lg{padding:15px 28px;font-size:16px;}
.btn-dark{background:#fff;color:var(--dark);}
.btn-dark:hover{background:var(--plum-soft);}
.btn-outline-dark{background:transparent;color:#fff;border-color:var(--dark-line);}
.btn-outline-dark:hover{border-color:#5C4350;background:rgba(255,255,255,.04);}
.link-sign{font-weight:600;font-size:14.5px;}
.link-arrow{display:inline-flex;align-items:center;gap:7px;font-weight:600;font-size:14.5px;color:var(--ink);}
.link-arrow span{transition:transform .18s;} .link-arrow:hover{color:var(--plum);} .link-arrow:hover span{transform:translateX(3px);}

/* chips */
.chip{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:11.5px;font-weight:500;padding:4px 10px;border-radius:100px;border:1px solid transparent;}
.chip .dot{width:7px;height:7px;border-radius:50%;flex:none;}
.chip.allow{color:var(--allow);background:var(--allow-bg);border-color:var(--allow-line);} .chip.allow .dot{background:var(--allow);}
.chip.hold{color:var(--hold);background:var(--hold-bg);border-color:var(--hold-line);} .chip.hold .dot{background:var(--hold);}
.chip.block{color:var(--block);background:var(--block-bg);border-color:var(--block-line);} .chip.block .dot{background:var(--block);}
.chip.info{color:var(--plum);background:var(--plum-soft);border-color:var(--plum-line);} .chip.info .dot{background:var(--plum);}

/* topbar */
.topbar{background:var(--ink);color:#fff;font-size:13px;text-align:center;padding:9px 20px;font-family:var(--mono);letter-spacing:.01em;}
.topbar a{color:#fff;font-weight:500;border-bottom:1px solid rgba(255,255,255,.4);padding-bottom:1px;}
.topbar a:hover{border-color:#fff;}
.topbar .sep{color:var(--dark-ink-3);margin:0 12px;}

/* nav */
.nav{position:sticky;top:0;z-index:50;background:rgba(242,234,224,.82);backdrop-filter:saturate(160%) blur(14px);-webkit-backdrop-filter:saturate(160%) blur(14px);border-bottom:1px solid var(--line-2);}
.nav-in{display:flex;align-items:center;gap:30px;height:74px;}
.brand{display:flex;align-items:center;gap:12px;}
.mark{width:38px;height:38px;border-radius:50%;background:var(--plum);color:#fff;font-family:var(--disp);font-size:25px;display:grid;place-items:center;box-shadow:inset 0 1px 0 rgba(255,255,255,.2);}
.brand .nm{font-family:var(--disp);font-size:26px;line-height:1;}
.brand .tag{font-size:11px;color:var(--ink-3);font-family:var(--mono);display:block;margin-top:1px;}
.nav-links{display:flex;gap:26px;margin-left:8px;}
.nav-links a{font-size:14.5px;color:var(--ink-2);font-weight:500;}
.nav-links a:hover{color:var(--ink);}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:16px;}
.badge-preview{font-family:var(--mono);font-size:10.5px;font-weight:500;letter-spacing:.1em;color:var(--plum);background:var(--plum-soft);border:1px solid var(--plum-line);padding:5px 11px;border-radius:100px;text-transform:uppercase;white-space:nowrap;}
@media (max-width:1180px){.brand .tag{display:none;}}
@media (max-width:920px){.nav-links{display:none;}}
@media (max-width:560px){.badge-preview{display:none;}}

/* hero */
.hero{padding:clamp(44px,5vw,76px) 0 clamp(40px,5vw,72px);position:relative;overflow:hidden;}
.hero::before{content:"";position:absolute;top:-180px;right:-120px;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(136,50,85,.14),transparent 66%);pointer-events:none;z-index:0;}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(34px,4vw,64px);align-items:center;position:relative;z-index:1;}
.tag-row{display:flex;align-items:center;gap:14px;margin-bottom:24px;flex-wrap:wrap;}
.preview-tag{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--plum);background:var(--plum-soft);border:1px solid var(--plum-line);padding:5px 12px;border-radius:100px;}
h1{font-size:clamp(48px,5.8vw,78px);line-height:1.05;margin:0;text-wrap:balance;}
h1 em{font-style:italic;color:var(--plum);}
.hero-sub{font-size:clamp(17px,1.3vw,19.5px);color:var(--ink-2);max-width:46ch;margin:clamp(54px,5.4vw,78px) 0 0;text-wrap:pretty;}
.hero-cta{display:flex;align-items:center;gap:22px;margin:32px 0 0;flex-wrap:wrap;}
.hero-note{margin-top:18px;font-family:var(--mono);font-size:12.5px;color:var(--ink-3);}

/* decision triad — inline editorial pill */
.triad{display:inline-flex;align-items:center;gap:0;margin-top:28px;font-family:var(--mono);font-size:13.5px;font-weight:500;border:1px solid var(--line);border-radius:100px;background:var(--surface);padding:4px;box-shadow:var(--shadow);}
.triad .t{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:100px;}
.triad .dot{width:8px;height:8px;border-radius:50%;}
.triad .allow{color:var(--allow);} .triad .allow .dot{background:var(--allow);}
.triad .hold{color:var(--hold);} .triad .hold .dot{background:var(--hold);}
.triad .block{color:var(--block);} .triad .block .dot{background:var(--block);}
.triad .sep{width:1px;height:16px;background:var(--line);}

/* product window (shared chrome) */
.window{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);overflow:hidden;}
.wbar{display:flex;align-items:center;gap:9px;padding:13px 16px;border-bottom:1px solid var(--line-2);background:linear-gradient(180deg,var(--plum-soft),var(--surface-2));}
.dots{display:flex;gap:7px;} .dots i{width:11px;height:11px;border-radius:50%;display:block;}
.dots i:nth-child(1){background:#D098AC;}.dots i:nth-child(2){background:#E3C08C;}.dots i:nth-child(3){background:#A9C088;}
.wtitle{font-family:var(--mono);font-size:12px;color:var(--ink-3);margin-left:6px;} .wtitle b{color:var(--ink);font-weight:600;}
.wbar .right{margin-left:auto;display:flex;align-items:center;gap:10px;}
.live{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:11px;color:var(--allow);}
.live i{width:7px;height:7px;border-radius:50%;background:var(--allow);box-shadow:0 0 0 0 rgba(79,122,82,.5);animation:pulse 2s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(79,122,82,.45);}70%{box-shadow:0 0 0 7px rgba(79,122,82,0);}100%{box-shadow:0 0 0 0 rgba(79,122,82,0);}}

/* hero console */
.hero-visual{position:relative;z-index:1;}
.console-body{padding:20px;}
.approval{border:1px solid var(--hold-line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);}
.appr-top{background:linear-gradient(180deg,var(--hold-bg),var(--surface));padding:14px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--line-2);}
.appr-top .decid{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--ink-3);}
.appr-body{padding:16px;}
.appr-action{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;}
.appr-action .lbl{font-family:var(--mono);font-size:12px;color:var(--ink-3);}
.appr-action .v{font-family:var(--disp);font-size:25px;}
.appr-action .v b{color:var(--plum);font-weight:400;}
.amt{font-family:var(--mono);font-size:19px;font-weight:600;background:var(--surface-2);border:1px solid var(--line);border-radius:9px;padding:7px 12px;}
.kv{display:grid;grid-template-columns:auto 1fr;gap:8px 16px;margin:14px 0;padding:14px 0;border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2);}
.kv .k{font-family:var(--mono);font-size:11.5px;color:var(--ink-3);}
.kv .v2{font-size:13px;color:var(--ink);font-family:var(--mono);} .kv .v2 b{color:var(--hold);}
.appr-actions{display:flex;gap:9px;}
.btn-approve{background:var(--allow);color:#fff;font-size:14px;padding:10px 18px;}
.btn-approve:hover{filter:brightness(1.06);}
.btn-reject{background:var(--surface);color:var(--block);border-color:var(--block-line);font-size:14px;padding:10px 18px;}
.btn-reject:hover{background:var(--block-bg);}
.btn-mini{background:transparent;color:var(--ink-2);font-size:14px;padding:10px 14px;}
.feed{margin-top:16px;}
.feed-h{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin-bottom:8px;}
.feed-row{display:grid;grid-template-columns:64px 1fr auto;align-items:center;gap:12px;padding:9px 2px;border-top:1px solid var(--line-2);font-family:var(--mono);font-size:12px;}
.feed-row .tm{color:var(--ink-3);} .feed-row .ac{color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;} .feed-row .ac small{color:var(--ink-3);}

/* frameworks strip */
.stack{border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2);background:var(--surface);}
.stack .wrap{padding-top:30px;padding-bottom:30px;}
.stack-label{font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);text-align:center;margin-bottom:18px;}
.stack-row{display:flex;flex-wrap:wrap;gap:14px 34px;justify-content:center;align-items:center;}
.stack-row .fw{display:inline-flex;align-items:center;gap:9px;font-family:var(--disp);font-size:21px;color:var(--ink);opacity:.78;}
.stack-row .fw svg{width:20px;height:20px;color:var(--ink-2);}

/* lifecycle */
.lc{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:54px;}
.lc-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px 24px;position:relative;box-shadow:var(--shadow-sm);}
.lc-card[data-s="pre"]{--ac:var(--allow);} .lc-card[data-s="in"]{--ac:var(--hold);} .lc-card[data-s="post"]{--ac:var(--plum);}
.lc-top{display:flex;align-items:center;gap:12px;}
.lc-num{font-family:var(--disp);font-size:38px;color:var(--ac);line-height:1;}
.lc-phase{font-family:var(--mono);font-size:13px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--ac);padding:5px 11px;border:1px solid var(--ac);border-radius:100px;}
.lc-when{font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);margin-top:12px;}
.lc-card h3{font-size:27px;margin:5px 0 8px;}
.lc-card p{font-size:14.5px;color:var(--ink-2);margin:0 0 18px;line-height:1.55;}
.lc-eg{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-radius:10px;background:var(--surface-2);border:1px solid var(--line-2);font-family:var(--mono);font-size:12px;color:var(--ink);}
/* pipeline connectors: preflight → inflight → postflight */
@media (min-width:921px){
  .lc-card[data-s="pre"]::after,.lc-card[data-s="in"]::after{
    content:"\2192";position:absolute;right:-22px;top:34px;z-index:3;
    width:30px;height:30px;border-radius:50%;background:var(--surface);border:1px solid var(--line);
    display:grid;place-items:center;font-family:var(--mono);font-size:15px;color:var(--ink-2);box-shadow:var(--shadow-sm);
  }
}
.chip.live{color:var(--hold);background:var(--hold-bg);border-color:var(--hold-line);} .chip.live .dot{background:var(--hold);}
.band{margin-top:42px;background:var(--ink);color:#fff;border-radius:var(--r-lg);padding:24px 30px;display:flex;align-items:center;gap:18px;box-shadow:var(--shadow-lg);}
.band .bz{width:42px;height:42px;border-radius:50%;background:var(--plum);display:grid;place-items:center;font-family:var(--disp);font-size:24px;flex:none;}
.band .bt{font-family:var(--disp);font-size:24px;} .band .bt em{font-style:italic;color:var(--apricot);}
.band .bd{margin-left:auto;font-family:var(--mono);font-size:12px;color:#B19AA4;letter-spacing:.03em;}

/* policies editor */
.pol-wrap{max-width:1000px;margin:clamp(34px,4.5vw,54px) auto 0;}
.role-badge{font-family:var(--mono);font-size:11px;color:var(--ink-2);background:var(--surface);border:1px solid var(--line);border-radius:100px;padding:4px 11px;white-space:nowrap;}
.pol-body{padding:clamp(20px,2.4vw,32px);}
.pol-head{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;margin-bottom:22px;}
.pol-head h3{font-size:27px;}
.pol-sub{color:var(--ink-3);font-size:12.5px;margin-left:auto;font-family:var(--mono);}
.pol-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 18px;margin-bottom:16px;}
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px;}
.field label{font-family:var(--mono);font-size:12px;color:var(--ink-2);font-weight:500;}
.field .lbl-note{color:var(--ink-3);font-weight:400;}
.control{border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface-2);padding:11px 13px;font-family:var(--mono);font-size:13.5px;color:var(--ink);}
.control-tools{display:flex;flex-wrap:wrap;gap:8px;padding:9px 10px;background:var(--surface);}
.tok{font-family:var(--mono);font-size:12.5px;color:var(--ink);background:var(--surface-2);border:1px solid var(--line-2);border-radius:7px;padding:4px 9px;}
.tok-review{color:var(--hold);background:var(--hold-bg);border-color:var(--hold-line);}
.control-approval{border-color:var(--hold-line);background:linear-gradient(0deg,var(--hold-bg),transparent 130%);}
.pol-guards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:6px 0 24px;}
.pol-guards .field{margin-bottom:0;}
.control-select{display:flex;align-items:center;justify-content:space-between;gap:8px;font-weight:600;}
.control-select svg{width:13px;height:13px;opacity:.65;flex:none;}
.sel-review{color:var(--hold);background:var(--hold-bg);border-color:var(--hold-line);}
.sel-block{color:var(--block);background:var(--block-bg);border-color:var(--block-line);}
.pol-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap;}
.pol-hint{font-family:var(--mono);font-size:12px;color:var(--ink-3);}
.pol-inv{margin-top:28px;border-top:1px solid var(--line-2);padding-top:22px;}
.pol-inv-h{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:12px;}
.pol-inv-h span:first-child{font-family:var(--disp);font-size:22px;color:var(--ink);}
.pol-count{font-family:var(--mono);font-size:12px;color:var(--ink-3);white-space:nowrap;}
.pol-table-wrap{overflow-x:auto;}
table.pol-table{width:100%;border-collapse:collapse;min-width:560px;}
.pol-table th{text-align:left;font-family:var(--mono);font-size:10.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-3);font-weight:500;padding:8px 12px;border-bottom:1px solid var(--line-2);}
.pol-table td{padding:13px 12px;border-bottom:1px solid var(--line-2);font-size:13.5px;color:var(--ink-2);vertical-align:middle;}
.pol-table tbody tr:last-child td{border-bottom:none;}
.pol-table td code{font-family:var(--mono);font-size:12.5px;color:var(--ink);}
.pol-table .chip{font-size:11px;}

/* capabilities */
.dotgrid{background-image:radial-gradient(rgba(40,27,34,.06) 1px,transparent 1px);background-size:22px 22px;}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:54px;}
.feat{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px 24px 28px;box-shadow:var(--shadow-sm);transition:transform .18s,box-shadow .22s,border-color .2s;}
.feat:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--plum-line);}
.feat .fic{width:44px;height:44px;border-radius:12px;background:var(--plum-soft);border:1px solid var(--plum-line);display:grid;place-items:center;margin-bottom:18px;}
.feat .fic svg{width:21px;height:21px;color:var(--plum);}
.feat h3{font-size:24px;margin-bottom:8px;}
.feat p{font-size:14.5px;color:var(--ink-2);margin:0;line-height:1.55;}
.feat .tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px;}
.feat .tags span{font-family:var(--mono);font-size:11px;color:var(--ink-2);background:var(--surface-2);border:1px solid var(--line-2);padding:3px 8px;border-radius:6px;}
@media (max-width:900px){.feat-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:620px){.feat-grid{grid-template-columns:1fr;}}

/* audit (light cream variant) */
.audit-sec{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.audit{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);margin-top:48px;}
.audit-bar{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--line-2);background:var(--surface-2);}
.seg{margin-left:auto;display:flex;gap:5px;}
.seg span{font-family:var(--mono);font-size:11px;padding:5px 11px;border-radius:7px;color:var(--ink-3);}
.seg span.on{background:var(--plum-soft);color:var(--plum-deep);}
table.audit-table{width:100%;border-collapse:collapse;font-size:13px;}
.audit-table thead th{text-align:left;font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);font-weight:500;padding:12px 18px;border-bottom:1px solid var(--line-2);}
.audit-table tbody td{padding:13px 18px;border-bottom:1px solid var(--line-2);font-family:var(--mono);font-size:12.5px;color:var(--ink-2);vertical-align:middle;}
.audit-table tbody tr:last-child td{border-bottom:none;}
.audit-table tbody tr:hover{background:var(--surface-2);}
.audit-table td.agent{color:var(--ink);} .audit-table td.agent small{display:block;color:var(--ink-3);}
.audit-table td.when{color:var(--ink-3);white-space:nowrap;}
.rf{font-family:var(--mono);font-size:10.5px;padding:2px 8px;border-radius:6px;}
.rf.warn{color:var(--hold);background:var(--hold-bg);} .rf.bad{color:var(--block);background:var(--block-bg);} .rf.none{color:var(--ink-3);}
.audit-foot{display:flex;align-items:center;gap:14px;padding:14px 18px;border-top:1px solid var(--line-2);font-family:var(--mono);font-size:12px;color:var(--ink-3);}
.audit-foot .legend{display:flex;gap:16px;margin-left:auto;flex-wrap:wrap;}
.audit-foot .legend span{display:inline-flex;align-items:center;gap:7px;}
.audit-foot .legend i{width:8px;height:8px;border-radius:50%;}
@media (max-width:760px){.audit-table .hide-sm{display:none;}}

/* developers / code */
.dev-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:56px;align-items:center;}
.dev-steps{display:flex;flex-direction:column;gap:22px;margin-top:34px;}
.dev-step{display:flex;gap:16px;}
.dev-step .n{width:34px;height:34px;border-radius:50%;flex:none;background:var(--ink);color:#fff;font-family:var(--disp);font-size:18px;display:grid;place-items:center;}
.dev-step h3{font-size:21px;margin-bottom:3px;}
.dev-step p{font-size:14.5px;color:var(--ink-2);margin:0;}
.dev-step p code{font-family:var(--mono);font-size:12.5px;background:var(--plum-soft);color:var(--plum-deep);padding:1px 6px;border-radius:5px;}
.code{background:var(--dark-2);border:1px solid var(--dark-line);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);overflow:hidden;}
.code-bar{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--dark-line);background:rgba(255,255,255,.03);}
.code-bar .fname{font-family:var(--mono);font-size:12.5px;color:#B7A1AC;margin-left:4px;}
.code-bar .lang{margin-left:auto;font-family:var(--mono);font-size:11px;color:#7A6470;letter-spacing:.08em;text-transform:uppercase;}
.code pre{margin:0;padding:22px;overflow-x:auto;}
.code code{font-family:var(--mono);font-size:13.5px;line-height:1.85;color:#E6D7DF;white-space:pre;}
.code .c{color:#8A7480;font-style:italic;}
.code .k{color:#E58FB4;}
.code .s{color:#9FD6A6;}
.code .f{color:#E3B07A;}
.code .n{color:#F0C56B;}
.code .cm{color:#FF9BA8;}

/* use cases */
.uc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.uc{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px 22px;box-shadow:var(--shadow-sm);transition:transform .18s,box-shadow .22s,border-color .2s;}
.uc:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--plum-line);}
.uc .uic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;margin-bottom:16px;}
.uc .uic svg{width:21px;height:21px;}
.uc.r .uic{background:var(--block-bg);border:1px solid var(--block-line);} .uc.r .uic svg{color:var(--block);}
.uc.a .uic{background:var(--hold-bg);border:1px solid var(--hold-line);} .uc.a .uic svg{color:var(--hold);}
.uc.b .uic{background:var(--plum-soft);border:1px solid var(--plum-line);} .uc.b .uic svg{color:var(--plum);}
.uc.g .uic{background:var(--allow-bg);border:1px solid var(--allow-line);} .uc.g .uic svg{color:var(--allow);}
.uc h3{font-size:22px;margin-bottom:6px;}
.uc p{font-size:13.5px;color:var(--ink-2);margin:0;line-height:1.5;}
.uc .tag{margin-top:14px;}
@media (max-width:1000px){.uc-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:540px){.uc-grid{grid-template-columns:1fr;}}

/* CTA (dark plum) */
.cta{background:var(--dark);color:#fff;position:relative;overflow:hidden;}
.cta::before{content:"";position:absolute;inset:0;background:radial-gradient(820px 420px at 50% 120%,rgba(136,50,85,.42),transparent 62%);}
.cta .wrap{position:relative;z-index:1;text-align:center;}
.cta h2{font-size:clamp(40px,6vw,72px);line-height:1.0;color:#fff;max-width:18ch;margin:0 auto;text-wrap:balance;}
.cta h2 em{font-style:italic;color:var(--apricot);}
.cta p{color:var(--dark-ink-2);font-size:19px;max-width:54ch;margin:22px auto 0;}
.cta .hero-cta{margin-top:34px;justify-content:center;}
.cta .hero-note{color:var(--dark-ink-3);text-align:center;width:100%;}

/* footer */
.footer{background:var(--dark-2);color:var(--dark-ink-2);padding:64px 0 40px;}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;padding-bottom:44px;border-bottom:1px solid var(--dark-line);}
.footer .mark{box-shadow:none;}
.footer .nm{color:#fff;}
.footer-blurb{font-size:14px;color:var(--dark-ink-3);margin:18px 0 0;max-width:32ch;line-height:1.6;}
.fcol h4{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--dark-ink-3);margin:0 0 16px;font-weight:500;}
.fcol a{display:block;font-size:14px;color:var(--dark-ink-2);padding:6px 0;transition:color .15s;}
.fcol a:hover{color:#fff;}
.footer-bot{display:flex;align-items:center;gap:16px;padding-top:28px;flex-wrap:wrap;}
.footer-bot .cp{font-family:var(--mono);font-size:12.5px;color:var(--dark-ink-3);}
.footer-bot .compliance{margin-left:auto;display:flex;gap:10px;flex-wrap:wrap;}
.footer-bot .compliance span{font-family:var(--mono);font-size:11px;color:var(--dark-ink-2);border:1px solid var(--dark-line);padding:5px 10px;border-radius:7px;}

/* product shots — the live console embedded as browser-framed screenshots */
.shot{border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-xl);background:var(--surface);}
.shot-chrome{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--surface-2);border-bottom:1px solid var(--line-2);}
.shot-chrome .dots{display:flex;gap:7px;}
.shot-chrome .dots i{width:11px;height:11px;border-radius:50%;display:block;}
.shot-chrome .dots i:nth-child(1){background:#D098AC;}
.shot-chrome .dots i:nth-child(2){background:#E3C08C;}
.shot-chrome .dots i:nth-child(3){background:#A9C088;}
.shot-url{flex:1;max-width:420px;margin:0 auto;text-align:center;font-family:var(--mono);font-size:12px;color:var(--ink-3);background:var(--surface);border:1px solid var(--line);border-radius:100px;padding:5px 14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.shot-url b{color:var(--ink-2);font-weight:500;}
.shot-tag{font-family:var(--mono);font-size:11px;color:var(--allow);display:inline-flex;align-items:center;gap:6px;white-space:nowrap;}
.shot-tag i{width:7px;height:7px;border-radius:50%;background:var(--allow);box-shadow:0 0 0 0 rgba(79,122,82,.5);animation:pulse 2s infinite;}
.shot-stage{position:relative;width:100%;overflow:hidden;background:var(--paper);}
.shot-frame{border:0;transform-origin:top left;display:block;background:var(--paper);}
.shot-frame.lock{pointer-events:none;}
.shot-actions{display:flex;justify-content:center;margin-top:22px;}
@media (max-width:600px){.shot-tag{display:none;}}

/* motion — visible is the BASE state; .in only plays an entrance animation
   on top, so captures, print, PDF export and no-JS never hide content. */
@media (prefers-reduced-motion:no-preference){
  [data-reveal].in{animation:revealUp .7s cubic-bezier(.2,.7,.3,1) both;}
  @keyframes revealUp{from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:none;}}
}

@media (max-width:920px){
  .hero-grid{grid-template-columns:1fr;gap:44px;}
  .lc{grid-template-columns:1fr;}
  .dev-grid{grid-template-columns:1fr;gap:36px;}
}
@media (max-width:760px){
  body{font-size:16px;} .wrap{padding:0 22px;}
  .pol-grid{grid-template-columns:1fr;} .pol-guards{grid-template-columns:1fr 1fr;} .pol-sub{display:none;}
  .footer-top{grid-template-columns:1fr 1fr;gap:28px;}
}
@media (max-width:480px){.footer-top{grid-template-columns:1fr;}}
