/* Kakapo Consent — shared styles for Features hub & detail pages */
:root{
  --ink:#0e1626;--tx:#1c2638;--tx2:#5a6677;--mu:#8a94a6;
  --line:#e7ebf2;--line2:#eef1f7;--canvas:#f4f6fb;--surface:#fff;
  --pri:#1A63D8;--pri-d:#154FB0;--pri-t:#E8F1FF;--green:#16a34a;
  --rad:14px;--rad-sm:10px;
  --shadow-sm:0 1px 2px rgba(16,22,38,.05),0 2px 8px rgba(16,22,38,.05);
  --shadow:0 1px 2px rgba(16,22,38,.04),0 12px 34px rgba(16,22,38,.08);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Hanken Grotesk',system-ui,sans-serif;background:var(--surface);color:var(--tx);
  -webkit-font-smoothing:antialiased;line-height:1.55}
a{color:inherit;text-decoration:none}
.mono{font-family:'JetBrains Mono',monospace}
.wrap{max-width:1140px;margin:0 auto;padding:0 28px}
.eyebrow{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;color:var(--pri)}

/* nav */
nav.top{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;gap:28px;height:64px}
.brand{display:flex;align-items:center;gap:10px}
.brand .wm{font-size:21px;font-weight:800;letter-spacing:-.035em;color:var(--ink)}
.nav-links{display:flex;gap:26px;margin-left:14px}
.nav-links a{font-size:14px;font-weight:500;color:var(--tx2)}
.nav-links a:hover,.nav-links a.on{color:var(--ink)}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:14px}
.lang{display:flex;background:var(--canvas);border:1px solid var(--line);border-radius:var(--rad-sm);padding:3px}
.lang button{padding:5px 9px;border:none;background:transparent;border-radius:7px;cursor:pointer;
  font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;color:var(--mu)}
.lang button.on{background:#fff;color:var(--pri);box-shadow:0 1px 3px rgba(16,22,38,.1)}
.btn{font-family:inherit;font-size:14px;font-weight:600;padding:11px 20px;border-radius:var(--rad-sm);border:none;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:filter .14s,transform .1s,border-color .14s,color .14s;white-space:nowrap}
.btn-primary{background:var(--pri);color:#fff}
.btn-primary:hover{filter:brightness(.96);transform:translateY(-1px)}
.btn-ghost{background:#fff;color:var(--tx);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--pri);color:var(--pri)}
.btn-lg{padding:14px 26px;font-size:15px}

/* hero */
.fhero{padding:64px 0 40px;text-align:center;background:radial-gradient(120% 80% at 50% -20%,var(--pri-t),transparent 62%)}
.fhero .eyebrow{margin-bottom:14px}
.fhero h1{font-size:clamp(30px,4.4vw,48px);font-weight:800;letter-spacing:-.035em;line-height:1.05;color:var(--ink);max-width:18ch;margin:0 auto}
.fhero p{font-size:clamp(15px,1.8vw,18px);color:var(--tx2);max-width:56ch;margin:18px auto 0}

/* feature group + cards (hub) */
.fgroup{padding:40px 0 8px}
.fgroup-head{display:flex;align-items:baseline;gap:12px;margin-bottom:20px}
.fgroup-head h2{font-size:22px;font-weight:800;letter-spacing:-.02em;color:var(--ink)}
.fgroup-head .c{margin-left:auto;font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--mu)}
.fgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.fcard{display:block;background:#fff;border:1px solid var(--line);border-radius:var(--rad);padding:22px;box-shadow:var(--shadow-sm);
  transition:transform .15s,box-shadow .15s,border-color .15s}
.fcard:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--pri-t)}
.fcard .ic{width:42px;height:42px;border-radius:11px;background:var(--pri-t);color:var(--pri);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.fcard h3{font-size:16px;font-weight:700;color:var(--ink);margin-bottom:6px;display:flex;align-items:center;gap:7px}
.fcard h3 .arr{margin-left:auto;color:var(--mu);transition:transform .15s,color .15s}
.fcard:hover h3 .arr{color:var(--pri);transform:translateX(3px)}
.fcard .tag{font-size:13px;color:var(--pri);font-weight:600;margin-bottom:8px}
.fcard p{font-size:13.5px;color:var(--tx2);line-height:1.55}

/* detail */
.dwrap{max-width:880px;margin:0 auto;padding:0 28px}
.crumb{display:flex;align-items:center;gap:8px;font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--mu);padding:24px 0 0}
.crumb a:hover{color:var(--pri)}
.dhero{padding:26px 0 10px}
.dhero .ic{width:60px;height:60px;border-radius:16px;background:var(--pri-t);color:var(--pri);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.dhero .eyebrow{margin-bottom:10px}
.dhero h1{font-size:clamp(30px,4.2vw,44px);font-weight:800;letter-spacing:-.03em;line-height:1.05;color:var(--ink)}
.dhero .tag{font-size:19px;color:var(--pri);font-weight:600;margin-top:12px}
.dhero .p{font-size:16px;color:var(--tx2);line-height:1.65;margin-top:16px;max-width:60ch}
.dsection{padding:32px 0;border-top:1px solid var(--line);margin-top:32px}
.dsection h2{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--mu);margin-bottom:18px;font-family:'JetBrains Mono',monospace}
.bullets{display:grid;gap:12px}
.bullet{display:flex;gap:12px;align-items:flex-start;font-size:15px;color:var(--tx)}
.bullet .chk{flex-shrink:0;width:24px;height:24px;border-radius:7px;background:var(--pri-t);color:var(--pri);display:flex;align-items:center;justify-content:center;margin-top:1px}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.step{background:var(--canvas);border:1px solid var(--line);border-radius:var(--rad);padding:20px}
.step .n{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:700;color:var(--pri);background:#fff;border:1px solid var(--pri-t);
  width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.step p{font-size:14px;color:var(--tx);font-weight:500}
.related{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.rel{display:flex;align-items:center;gap:11px;background:#fff;border:1px solid var(--line);border-radius:var(--rad-sm);padding:14px 16px;transition:border-color .15s}
.rel:hover{border-color:var(--pri)}
.rel .ic{width:34px;height:34px;border-radius:9px;background:var(--pri-t);color:var(--pri);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.rel .t{font-size:13.5px;font-weight:600;color:var(--ink)}
.dcta{text-align:center;background:linear-gradient(135deg,var(--ink),#16213d);border-radius:18px;padding:44px 28px;color:#fff;margin:40px 0 0}
.dcta h3{font-size:24px;font-weight:800;letter-spacing:-.02em;margin-bottom:10px}
.dcta p{font-size:15px;opacity:.8;margin-bottom:22px}

/* footer */
footer{background:var(--ink);color:#fff;padding:54px 0 30px;margin-top:64px}
.foot-in{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.foot-in .wm{font-size:20px;font-weight:800;letter-spacing:-.035em;color:#fff;display:flex;align-items:center;gap:10px}
.foot-in .copy{font-family:'JetBrains Mono',monospace;font-size:11px;color:rgba(255,255,255,.45)}
.foot-grid{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;padding-bottom:30px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-brand{max-width:260px}
.foot-brand .wm{font-size:21px;font-weight:800;letter-spacing:-.035em;color:#fff;display:flex;align-items:center;gap:10px;margin-bottom:10px}
.foot-brand p{font-size:13px;color:rgba(255,255,255,.5);line-height:1.6}
.foot-cols{display:flex;gap:52px;flex-wrap:wrap}
.foot-col h5{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:13px}
.foot-col a{display:block;font-size:13px;color:rgba(255,255,255,.7);padding:4px 0;transition:color .14s}
.foot-col a:hover{color:#fff}
.foot-bot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-top:22px;font-family:'JetBrains Mono',monospace;font-size:11px;color:rgba(255,255,255,.4)}
.nav-login{font-size:14px;font-weight:500;color:var(--tx2);display:flex;align-items:center;gap:6px}
.nav-login:hover{color:var(--ink)}

/* ── page section + simple hero (sub-pages) ── */
.page-hero{padding:54px 0 8px;text-align:center;background:radial-gradient(120% 80% at 50% -25%,var(--pri-t),transparent 60%)}
.page-hero .eyebrow{margin-bottom:12px}
.page-hero h1{font-size:clamp(28px,4vw,44px);font-weight:800;letter-spacing:-.03em;line-height:1.06;color:var(--ink);max-width:18ch;margin:0 auto}
.page-hero p{font-size:clamp(15px,1.7vw,17px);color:var(--tx2);max-width:54ch;margin:16px auto 0}
.sec{padding:48px 0}

/* ── pricing ── */
.bill{display:flex;justify-content:center;margin:8px 0 30px}
.bill-in{display:flex;background:var(--canvas);border:1px solid var(--line);border-radius:var(--rad-sm);padding:4px;gap:3px}
.bill-in button{padding:9px 18px;border:none;background:transparent;border-radius:8px;cursor:pointer;font-family:inherit;
  font-size:13.5px;font-weight:600;color:var(--mu);display:flex;align-items:center;gap:7px}
.bill-in button.on{background:#fff;color:var(--pri);box-shadow:0 1px 3px rgba(16,22,38,.1)}
.bill-in .save{font-family:'JetBrains Mono',monospace;font-size:9px;font-weight:800;background:rgba(22,163,74,.15);color:#15803d;padding:2px 6px;border-radius:6px}
.deal{display:flex;align-items:center;gap:18px;flex-wrap:wrap;background:linear-gradient(135deg,var(--pri-t),#f4f7ff);
  border:1px solid var(--pri);border-radius:var(--rad);padding:20px 24px;margin-bottom:30px}
.deal .lbl{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:800;letter-spacing:.12em;color:var(--pri)}
.deal .main{font-size:17px;font-weight:800;color:var(--ink);margin-top:4px}
.deal .main s{font-weight:400;opacity:.45;margin-right:6px}
.deal .main b{color:var(--pri)}
.deal .sub{font-size:12.5px;color:var(--tx2);margin-top:3px}
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:start}
.pcard{background:#fff;border:1px solid var(--line);border-radius:var(--rad);padding:28px 26px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.pcard.pop{border:1.5px solid var(--pri);box-shadow:0 16px 44px rgba(47,92,240,.16);position:relative}
.pcard .tier{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--mu)}
.pcard.pop .tier{color:var(--pri)}
.ptag{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--pri);color:#fff;
  font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;letter-spacing:.08em;padding:4px 12px;border-radius:20px}
.pprice{display:flex;align-items:baseline;gap:5px;margin:14px 0 2px}
.pprice .n{font-family:'JetBrains Mono',monospace;font-size:42px;font-weight:800;color:var(--ink);letter-spacing:-.03em}
.pprice .u{font-size:14px;color:var(--mu);font-weight:600}
.pnote{font-size:12px;color:var(--mu);min-height:18px;margin-bottom:14px}
.pdesc{font-size:12.5px;color:var(--tx2);margin-bottom:16px;min-height:34px}
.plist{display:flex;flex-direction:column;gap:9px;margin-bottom:22px;flex:1}
.plist .li{display:flex;gap:9px;align-items:flex-start;font-size:13px;color:var(--tx)}
.plist .li svg{flex-shrink:0;margin-top:2px;color:var(--pri)}
.ptrust{display:flex;gap:24px;justify-content:center;flex-wrap:wrap;margin-top:34px}
.ptrust .t{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--tx2)}

/* ── comparison ── */
.cmp-wrap{overflow-x:auto}
.cmp-table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border:1px solid var(--line);border-radius:var(--rad);overflow:hidden;min-width:680px}
.cmp-table th,.cmp-table td{padding:13px 18px;text-align:center;font-size:14px;border-bottom:1px solid var(--line2)}
.cmp-table th:first-child,.cmp-table td:first-child{text-align:left;color:var(--tx2)}
.cmp-table thead th{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:700;color:var(--ink);background:var(--canvas)}
.cmp-table thead th.us{color:var(--pri)}
.cmp-table td.us{background:var(--pri-t)}
.cmp-table tr:last-child td{border-bottom:none}
.cmp-table tbody tr:hover td{background:var(--canvas)}
.cmp-table tbody tr:hover td.us{background:#dfe8ff}
.yes{color:var(--green);font-weight:700}.no{color:#c2cbdb}.dash{color:var(--mu)}

/* ── faq ── */
.faq-list{max-width:740px;margin:0 auto}
.faq{border-bottom:1px solid var(--line);padding:18px 0}
.faq summary{cursor:pointer;font-weight:700;font-size:16px;color:var(--ink);list-style:none;display:flex;justify-content:space-between;gap:14px;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary svg{flex-shrink:0;transition:transform .2s;color:var(--mu)}
.faq[open] summary svg{transform:rotate(180deg)}
.faq p{margin-top:11px;font-size:14px;color:var(--tx2);line-height:1.65}

/* ── final cta ── */
.fcta{text-align:center;background:linear-gradient(135deg,var(--ink),#16213d);border-radius:20px;padding:50px 32px;color:#fff;margin:48px 0 0}
.fcta h2{font-size:clamp(24px,3.2vw,34px);font-weight:800;letter-spacing:-.02em;margin-bottom:12px}
.fcta p{font-size:16px;opacity:.8;max-width:540px;margin:0 auto 24px}
.fcta .note{font-family:'JetBrains Mono',monospace;font-size:12px;opacity:.6;margin-top:16px}

@media(max-width:900px){
  .fgrid,.steps,.related,.price-grid{grid-template-columns:1fr}
  .nav-links{display:none}
}

/* scroll reveal (shared) */
.reveal{transform:translateY(18px);transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.reveal.in{transform:none}
@media(prefers-reduced-motion:reduce){.reveal{transform:none;transition:none}}
