/* ============================================================
   TaLi — Shared Design System  (D-01 · "Market Ledger")
   Warm paper + ink, one terracotta accent · Fraunces + Hanken Grotesk
   Light is default; dark is a warm paper-on-ink reverse via [data-theme="dark"].
   Brand colour = terracotta. WhatsApp green / Telegram blue are CTA-only.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400..600;1,9..144,400..600&family=Hanken+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@500;700&display=swap');

:root{
  /* ── brand signature (theme-independent) — terracotta is THE brand colour ── */
  --brand:#C2562F; --brand-dark:#A8401F; --brand-soft:rgba(194,86,47,.10);
  --accent:#C2562F; --accent-soft:#E7C9B6;
  --glow:rgba(194,86,47,.22);
  --mint:#E7C9B6;                       /* legacy alias → accent-soft */
  /* channel colours — used ONLY on their CTA buttons, never as page/brand colour */
  --wa:#1FAA53; --wa-strong:#178B43; --tg:#2AABEE; --tg-strong:#1E90D4;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --display:'Fraunces',Georgia,'Times New Roman',serif;
  --r-sm:10px; --r-md:14px; --r-lg:20px; --r-xl:28px;
  --fast:.2s cubic-bezier(.4,0,.2,1); --bounce:.5s cubic-bezier(.34,1.56,.64,1);

  /* LIGHT · warm paper (default) */
  --paper:#FBF7EF; --paper-2:#F3EADA; --ink:#241F1A; --ink-soft:#6B6258; --line:#E3D8C6;
  --bg:#FBF7EF; --bg2:#F3EADA; --bg3:#ECE4D5;
  --card:#FFFFFF; --card-h:#FCFAF4;
  --bord:#E3D8C6; --bord2:#D8CBB4;
  --tp:#241F1A; --ts:#6B6258; --tm:#9A9080;
  --danger:#C0392B;
  --nav-bg:rgba(251,247,239,.82);
  --shadow:0 30px 60px -38px rgba(60,40,20,.35);
  --paper-glow:#FFF6E9;
  --hl:linear-gradient(120deg,var(--brand),#D8743F);
}

:root[data-theme="dark"]{
  /* DARK · warm ink (paper-on-ink reverse); terracotta accent unchanged */
  --paper:#1A1611; --paper-2:#221C16; --ink:#F3EADA; --ink-soft:#B8AD9C; --line:#3A3127;
  --bg:#1A1611; --bg2:#221C16; --bg3:#2A2219;
  --card:#221C16; --card-h:#2A2219;
  --bord:#3A3127; --bord2:#4A4030;
  --tp:#F3EADA; --ts:#B8AD9C; --tm:#857B6C;
  --danger:#E8705F;
  --nav-bg:rgba(26,22,17,.82);
  --shadow:0 18px 44px rgba(0,0,0,.5);
  --paper-glow:transparent;
  --brand-soft:rgba(194,86,47,.16);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:'Hanken Grotesk',system-ui,sans-serif;background:var(--bg);color:var(--tp);line-height:1.55;overflow-x:hidden;
  background-image:radial-gradient(1200px 500px at 80% -10%, var(--paper-glow) 0%, transparent 60%);background-attachment:fixed;
  transition:background .3s ease,color .3s ease}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ambient background glows */
body::before{content:'';position:fixed;inset:-50%;width:200%;height:200%;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 700px 620px at 18% 8%,var(--glow),transparent 70%),
    radial-gradient(ellipse 620px 520px at 88% 55%,var(--glow),transparent 72%);
  opacity:.5;animation:drift 22s ease-in-out infinite alternate}
@keyframes drift{0%{transform:translate(0,0)}100%{transform:translate(-1.5%,1%)}}

.wrap{position:relative;z-index:1;max-width:1180px;margin:0 auto;padding:0 28px}
.narrow{max-width:820px}

/* ---------- icons ---------- */
.ic{width:22px;height:22px;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.ic-sm{width:16px;height:16px}
.ic-lg{width:28px;height:28px}

/* ---------- logo + brand mark ---------- */
.logo{display:inline-flex;align-items:center;gap:11px;font-weight:800;font-size:1.18rem;letter-spacing:-.02em}
.mark{background:linear-gradient(135deg,var(--brand),var(--brand-dark));display:grid;place-items:center;
  border-radius:12px;box-shadow:0 4px 14px var(--glow)}
.mark .ic{stroke:#fff}
.logo .mark{width:34px;height:34px;border-radius:10px}
.logo .mark .ic{width:21px;height:21px}
.logo .name b{font-weight:800}

/* ---------- theme toggle ---------- */
.theme-btn{width:38px;height:38px;border-radius:10px;background:var(--card);border:1px solid var(--bord);
  color:var(--ts);display:grid;place-items:center;cursor:pointer;transition:var(--fast)}
.theme-btn:hover{color:var(--tp);border-color:var(--bord2)}
.theme-btn .ic{width:18px;height:18px}
/* toggle icon reflects the chosen preference (dark / light / system) */
.theme-btn .moon,.theme-btn .sun,.theme-btn .sys{display:none}
:root[data-theme-pref="dark"] .theme-btn .moon{display:block}
:root[data-theme-pref="light"] .theme-btn .sun{display:block}
:root[data-theme-pref="system"] .theme-btn .sys{display:block}
:root:not([data-theme-pref]) .theme-btn .moon{display:block}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:inherit;font-weight:600;font-size:.95rem;
  padding:13px 24px;border-radius:12px;cursor:pointer;border:none;transition:var(--fast);white-space:nowrap}
.btn .ic{width:18px;height:18px}
.btn-p{background:linear-gradient(135deg,var(--brand),var(--brand-dark));color:#fff;box-shadow:0 4px 20px var(--glow)}
.btn-p:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(194,86,47,.45)}
.btn-g{background:var(--card);border:1px solid var(--bord);color:var(--tp)}
.btn-g:hover{background:var(--card-h);border-color:var(--bord2)}
.btn-sm{padding:10px 18px;font-size:.88rem;border-radius:10px}

/* ---------- tags / pills ---------- */
.tag{display:inline-flex;align-items:center;gap:7px;font-size:.72rem;font-weight:600;letter-spacing:.08em;
  text-transform:uppercase;color:var(--brand);background:var(--brand-soft);border:1px solid rgba(194,86,47,.18);
  padding:6px 13px;border-radius:100px}
.tag .ic{width:13px;height:13px}
.tag .dot{width:7px;height:7px;border-radius:50%;background:var(--brand);box-shadow:0 0 10px var(--brand);animation:blink 1.6s infinite}
@keyframes blink{50%{opacity:.35}}

/* ---------- nav ---------- */
nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(20px);background:var(--nav-bg);border-bottom:1px solid var(--bord)}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px}
.nav-links{display:flex;gap:30px;font-size:.9rem;color:var(--ts);font-weight:500}
.nav-links a{transition:var(--fast)}.nav-links a:hover{color:var(--tp)}
.nav-cta{display:flex;gap:10px;align-items:center}

/* ---------- section shell ---------- */
section{padding:84px 0;position:relative;z-index:1}
.shead{text-align:center;max-width:640px;margin:0 auto 54px}
.shead h2{font-size:clamp(1.85rem,3.2vw,2.5rem);font-weight:800;letter-spacing:-.03em;margin:16px 0 12px}
.shead p{color:var(--ts);font-size:1.05rem}

/* ---------- cards / steps / features ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}

.step{background:var(--card);border:1px solid var(--bord);border-radius:var(--r-lg);padding:30px 26px}
.step .n{width:42px;height:42px;border-radius:12px;background:var(--brand-soft);border:1px solid rgba(194,86,47,.2);
  color:var(--brand);display:grid;place-items:center;margin-bottom:18px}
.step h3{font-size:1.15rem;font-weight:700;margin-bottom:8px}
.step p{color:var(--ts);font-size:.92rem}
.step .ex{margin-top:14px;font-family:var(--mono);font-size:.78rem;color:var(--brand);background:var(--brand-soft);
  border:1px dashed rgba(194,86,47,.25);padding:9px 12px;border-radius:9px}

.fcard{background:var(--card);border:1px solid var(--bord);border-radius:18px;padding:26px;transition:var(--fast)}
.fcard:hover{border-color:rgba(194,86,47,.3);transform:translateY(-4px)}
.fcard .ico{width:48px;height:48px;border-radius:13px;background:var(--bg2);border:1px solid var(--bord);
  display:grid;place-items:center;margin-bottom:16px;color:var(--brand)}
.fcard h3{font-size:1.05rem;font-weight:700;margin-bottom:7px}
.fcard p{color:var(--ts);font-size:.88rem}

/* ---------- pricing ---------- */
.price{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
.pcard{background:var(--card);border:1px solid var(--bord);border-radius:22px;padding:34px 28px;display:flex;flex-direction:column;position:relative}
.pcard.hot{border-color:var(--brand);box-shadow:0 0 50px rgba(194,86,47,.12)}
.pcard.hot::before{content:'Most popular';position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--brand);color:#06120b;font-size:.7rem;font-weight:800;padding:5px 14px;border-radius:100px;letter-spacing:.04em}
.pcard h3{font-size:.95rem;font-weight:700;color:var(--ts);text-transform:uppercase;letter-spacing:.06em}
.pcard .pr{font-size:2.6rem;font-weight:800;letter-spacing:-.03em;margin:14px 0 4px}
.pcard .pr span{font-size:.95rem;color:var(--tm);font-weight:500}
.pcard .desc{color:var(--ts);font-size:.9rem;margin-bottom:6px}
.pcard ul{list-style:none;margin:22px 0 26px;display:flex;flex-direction:column;gap:12px;flex:1}
.pcard li{color:var(--ts);font-size:.9rem;display:flex;gap:10px;align-items:flex-start}
.pcard li .ic{width:18px;height:18px;color:var(--brand);margin-top:1px}

/* ---------- comparison table ---------- */
.cmp{width:100%;border-collapse:collapse;margin-top:20px;border:1px solid var(--bord);border-radius:16px;overflow:hidden}
.cmp th,.cmp td{padding:16px 20px;text-align:left;border-bottom:1px solid var(--bord);font-size:.92rem}
.cmp thead th{background:var(--bg2);font-weight:700;font-size:.95rem}
.cmp thead th:not(:first-child){text-align:center;width:160px}
.cmp td:not(:first-child){text-align:center;color:var(--ts)}
.cmp tr:last-child td{border-bottom:none}
.cmp .yes{color:var(--brand)}.cmp .yes .ic{width:18px;height:18px}
.cmp .no{color:var(--tm)}
.cmp .hotcol{background:var(--brand-soft)}

/* ---------- FAQ ---------- */
.faq{max-width:760px;margin:0 auto}
.qa{border-bottom:1px solid var(--bord);padding:22px 0}
.qa h3{font-size:1.05rem;font-weight:700;margin-bottom:8px;display:flex;gap:10px;align-items:center}
.qa h3 .ic{color:var(--brand);width:18px;height:18px}
.qa p{color:var(--ts);font-size:.94rem;line-height:1.6;padding-left:28px}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--bord);padding:56px 0 40px;position:relative;z-index:1}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;margin-bottom:40px}
.foot-grid h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--tm);margin-bottom:16px}
.foot-grid a{display:block;color:var(--ts);font-size:.9rem;padding:5px 0;transition:var(--fast)}
.foot-grid a:hover{color:var(--tp)}
.foot-grid p{color:var(--ts);font-size:.9rem;max-width:260px;margin-top:14px}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;
  padding-top:28px;border-top:1px solid var(--bord);color:var(--tm);font-size:.84rem}

/* ---------- cta band ---------- */
.cta-band{text-align:center;background:linear-gradient(135deg,rgba(194,86,47,.1),rgba(194,86,47,.02));
  border:1px solid rgba(194,86,47,.2);border-radius:28px;padding:64px 30px;margin:30px 0}
.cta-band h2{font-size:2.2rem;font-weight:800;letter-spacing:-.03em;margin-bottom:14px}
.cta-band p{color:var(--ts);margin-bottom:28px;font-size:1.05rem}

/* ---------- chat bubbles (shared: hero + features) — on-brand, paper & ink ---------- */
.bub{max-width:84%;padding:9px 13px;border-radius:15px;font-size:.85rem;line-height:1.45;color:var(--ink);animation:pop .5s both}
.bub.out{align-self:flex-end;background:var(--brand);color:#fff;border-bottom-right-radius:5px}
.bub.in{align-self:flex-start;background:var(--paper-2);color:var(--ink);border:1px solid var(--line);border-bottom-left-radius:5px}
.bub small{display:block;text-align:right;font-size:.6rem;opacity:.6;margin-top:3px}
.bub.out small{color:rgba(255,255,255,.75)}
.bub b{font-weight:700}
.bub.in b{color:var(--brand)}
@keyframes pop{from{opacity:0;transform:translateY(10px) scale(.96)}to{opacity:1;transform:none}}

/* ---------- hero device — an iPhone alternating between the WhatsApp & Telegram chats ----------
   The phone shows the SAME TaLi exchange in each app; the Telegram screen cross-fades in and out
   over the WhatsApp one (one animated element). Channel green/blue here depict the real apps —
   they are not page/brand chrome (the D-01 rule), so the mockup stays faithful. */
.device{position:relative;width:min(300px,78vw);aspect-ratio:300/620;background:#0c0c10;
  border-radius:46px;padding:11px;box-shadow:0 34px 70px -30px rgba(40,25,10,.55),
  0 0 0 2px #25252c, inset 0 0 0 2px rgba(255,255,255,.05)}
.device-island{position:absolute;top:20px;left:50%;transform:translateX(-50%);
  width:92px;height:26px;background:#000;border-radius:100px;z-index:5}
.device-home{position:absolute;bottom:9px;left:50%;transform:translateX(-50%);
  width:118px;height:5px;border-radius:3px;background:rgba(255,255,255,.55);z-index:5}
.app-screen{position:absolute;inset:11px;border-radius:36px;overflow:hidden;
  display:flex;flex-direction:column}
.app-tg{animation:tg-alt 11s ease-in-out infinite}        /* WhatsApp is the base; Telegram fades over it */
@keyframes tg-alt{0%,5%{opacity:0} 12%,46%{opacity:1} 53%,95%{opacity:0} 100%{opacity:0}}
@media (prefers-reduced-motion: reduce){.app-tg{animation:none;opacity:1}}
/* app header */
.app-bar{display:flex;align-items:center;gap:9px;padding:40px 14px 11px;color:#fff;flex-shrink:0}
.app-bar .a-av{width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.22);
  display:grid;place-items:center;flex-shrink:0}
.app-bar .a-av .ic{stroke:#fff;fill:none;width:16px;height:16px}
.app-bar .a-id{font-weight:600;font-size:.84rem;line-height:1.15}
.app-bar .a-id small{display:block;font-weight:400;font-size:.64rem;opacity:.85}
.app-bar .a-tag{margin-left:auto;font-size:.58rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;opacity:.92}
/* chat + bubbles */
.app-chat{flex:1;display:flex;flex-direction:column;gap:7px;padding:14px 11px;overflow:hidden}
.msg{max-width:84%;padding:7px 10px;border-radius:12px;font-size:.75rem;line-height:1.4;color:#10231b;
  box-shadow:0 1px 1px rgba(0,0,0,.07)}
.msg.in{align-self:flex-start;background:#fff;border-top-left-radius:4px;color:#111}
.msg.out{align-self:flex-end;border-top-right-radius:4px}
.msg b{font-weight:700}
.msg i{display:block;text-align:right;font-style:normal;font-size:.56rem;opacity:.45;margin-top:2px}
/* input bar */
.app-input{display:flex;align-items:center;gap:8px;padding:9px 12px;flex-shrink:0}
.app-input .a-field{flex:1;background:#fff;border-radius:100px;padding:8px 13px;font-size:.7rem;
  color:#8a98a5;box-shadow:0 1px 2px rgba(0,0,0,.06)}
.app-send{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;flex-shrink:0}
.app-send .ic{width:15px;height:15px}
/* WhatsApp skin */
.app-wa{background:#ece5dd}
.app-wa .app-bar{background:#075e54}
.app-wa .app-chat{background:#ece5dd}
.app-wa .app-input{background:#ece5dd}
.app-wa .msg.out{background:#dcf8c6}
.app-wa .app-send{background:#25d366}
.app-wa .app-send .ic{stroke:#fff;fill:none}
/* Telegram skin */
.app-tg{background:#cfe0ee}
.app-tg .app-bar{background:#3390ec}
.app-tg .app-chat{background:linear-gradient(180deg,#d8e8f5,#c8dcef)}
.app-tg .app-input{background:#fff}
.app-tg .msg.out{background:#eeffde}
.app-tg .app-send{background:#3390ec}
.app-tg .app-send .ic{fill:#fff;stroke:none}

/* ---------- dashboard preview ---------- */
.dash{background:linear-gradient(180deg,var(--card),transparent);border:1px solid var(--bord);border-radius:24px;
  padding:34px;display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center}
.dash-card{background:var(--bg2);border:1px solid var(--bord);border-radius:18px;padding:24px}
.dash-row{display:flex;justify-content:space-between;padding:13px 0;border-bottom:1px solid var(--bord);font-size:.9rem}
.dash-row:last-child{border:none;font-weight:700}
.dash-row .amt.in{color:var(--brand)}.dash-row .amt.ex{color:var(--danger)}
.bars{display:flex;align-items:flex-end;gap:10px;height:120px;margin-top:18px}
.bar{flex:1;background:linear-gradient(180deg,var(--brand),var(--brand-dark));border-radius:6px 6px 0 0;opacity:.85}
.dash h2{font-size:1.9rem;font-weight:800;letter-spacing:-.03em;margin-bottom:14px}
.dash ul{list-style:none;margin-top:18px;display:flex;flex-direction:column;gap:13px}
.dash li{display:flex;gap:11px;align-items:flex-start;color:var(--ts);font-size:.95rem}
.dash li .ic{width:18px;height:18px;color:var(--brand);margin-top:2px}

/* ---------- auth card ---------- */
.auth-stage{display:flex;flex-wrap:wrap;gap:32px;justify-content:center;align-items:flex-start;padding:40px 0}
.auth-col{display:flex;flex-direction:column;align-items:center;gap:12px}
.auth-label{font-size:.8rem;color:var(--tm);font-style:italic}
.acard{width:380px;max-width:90vw;background:var(--card);backdrop-filter:blur(40px);border:1px solid var(--bord);
  border-radius:var(--r-xl);padding:40px 34px;box-shadow:var(--shadow)}
.acard .abrand{text-align:center;margin-bottom:30px}
.acard .abrand .mark{width:60px;height:60px;border-radius:18px;margin-bottom:16px}
.acard .abrand .mark .ic{width:30px;height:30px}
.acard .abrand h1{font-size:1.6rem;font-weight:800;letter-spacing:-.03em}
.acard .abrand p{color:var(--ts);font-size:.9rem;margin-top:6px}
.field{margin-bottom:18px}
.field label{display:block;font-size:.78rem;font-weight:600;color:var(--ts);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}
.field .inp{width:100%;background:var(--bg2);border:1.5px solid var(--bord);border-radius:var(--r-sm);
  padding:14px 16px;color:var(--tp);font-family:inherit;font-size:.95rem}
.field .inp::placeholder{color:var(--tm)}
.row-inp-wrap{display:flex;gap:10px}
.cc{background:var(--bg2);border:1.5px solid var(--bord);border-radius:var(--r-sm);padding:14px 14px;color:var(--tp);font-size:.92rem;font-weight:500;min-width:96px}
.otp-row{display:flex;gap:10px;justify-content:center;margin:6px 0}
.otp-box{width:48px;height:58px;background:var(--bg2);border:1.5px solid var(--bord);border-radius:var(--r-sm);
  display:grid;place-items:center;font-size:1.4rem;font-weight:700}
.otp-box.filled{border-color:var(--brand);background:var(--brand-soft);color:var(--brand)}
.code-row{display:flex;gap:9px;justify-content:center;margin:26px 0}
.code-digit{width:50px;height:64px;background:var(--bg2);border:1.5px solid rgba(194,86,47,.25);border-radius:var(--r-sm);
  display:grid;place-items:center;font-size:1.7rem;font-weight:800;color:var(--brand);text-shadow:0 0 20px var(--glow)}
.amsg{padding:13px 16px;border-radius:var(--r-sm);font-size:.85rem;font-weight:500;margin-bottom:20px;display:flex;gap:9px;align-items:center}
.amsg.ok{background:var(--brand-soft);border:1px solid rgba(194,86,47,.18);color:var(--brand)}
.amsg.err{background:rgba(255,107,129,.08);border:1px solid rgba(255,107,129,.18);color:var(--danger)}
.amsg .ic{width:18px;height:18px}
.steps-mini{margin-top:24px;padding-top:22px;border-top:1px solid var(--bord);display:flex;flex-direction:column;gap:14px}
.steps-mini .s{display:flex;gap:13px;align-items:flex-start;font-size:.86rem;color:var(--ts)}
.steps-mini .s .n{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:var(--brand-soft);border:1px solid rgba(194,86,47,.2);
  color:var(--brand);display:grid;place-items:center;font-size:.74rem;font-weight:700}
.btn-full{width:100%;justify-content:center}
.back-link{display:inline-flex;align-items:center;gap:6px;font-size:.82rem;color:var(--tm);margin-bottom:18px}
.back-link:hover{color:var(--tp)}
.err-icon{width:78px;height:78px;border-radius:50%;background:rgba(255,107,129,.08);border:1px solid rgba(255,107,129,.16);
  display:inline-grid;place-items:center;margin-bottom:20px}
.err-icon .ic{width:36px;height:36px;color:var(--danger)}

/* ---------- legal pages ---------- */
.legal{display:grid;grid-template-columns:230px 1fr;gap:48px;padding:60px 0 80px}
.legal-nav{position:sticky;top:90px;align-self:start}
.legal-nav .lh{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:var(--tm);margin-bottom:14px}
.legal-nav a{display:block;color:var(--ts);font-size:.9rem;padding:8px 12px;border-radius:9px;border-left:2px solid transparent;transition:var(--fast)}
.legal-nav a:hover,.legal-nav a.active{color:var(--tp);background:var(--card);border-left-color:var(--brand)}
.legal-body{max-width:720px}
.legal-body .doc-head{margin-bottom:36px;padding-bottom:24px;border-bottom:1px solid var(--bord);scroll-margin-top:96px}
.legal-body h1{font-size:2.2rem;font-weight:800;letter-spacing:-.03em;margin-bottom:8px;scroll-margin-top:96px}
.legal-body .upd{color:var(--tm);font-size:.85rem}
.legal-body h2{font-size:1.25rem;font-weight:700;margin:36px 0 12px;scroll-margin-top:96px}
.legal-body h3{font-size:1rem;font-weight:700;margin:22px 0 8px;color:var(--tp)}
.legal-body p,.legal-body li{color:var(--ts);font-size:.95rem;line-height:1.7;margin-bottom:12px}
.legal-body ul{padding-left:22px;margin-bottom:14px}
.legal-body li{margin-bottom:6px}
.legal-body strong{color:var(--tp)}

/* ---------- hero ---------- */
.hero{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding:78px 0 90px}
.hero h1{font-size:clamp(2.4rem,4.6vw,3.6rem);font-weight:800;letter-spacing:-.035em;line-height:1.05;margin:22px 0 20px}
.hero h1 .hl{background:var(--hl);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero .lead{font-size:1.12rem;color:var(--ts);max-width:480px;margin-bottom:30px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-meta{display:flex;gap:26px;margin-top:34px;color:var(--tm);font-size:.82rem}
.hero-meta b{color:var(--tp);font-size:1.35rem;font-weight:800;display:block;letter-spacing:-.02em}
.hero-sub{display:inline-flex;align-items:center;gap:6px;margin-top:16px;color:var(--ts);font-weight:600;font-size:.9rem;transition:var(--fast)}
.hero-sub:hover{color:var(--brand)}.hero-sub .ic{width:15px;height:15px}
.center-x{justify-self:center}

/* ---------- generic page header ---------- */
.phead{text-align:center;padding:70px 0 10px;max-width:720px;margin:0 auto}
.phead h1{font-size:clamp(2.2rem,4.4vw,3.2rem);font-weight:800;letter-spacing:-.035em;line-height:1.06;margin:18px 0 16px}
.phead h1 .hl{background:var(--hl);-webkit-background-clip:text;background-clip:text;color:transparent}
.phead p{color:var(--ts);font-size:1.1rem}

@media(max-width:920px){
  .hero{grid-template-columns:1fr;text-align:center}
  .hero .lead,.hero-cta{margin-left:auto;margin-right:auto}
  .hero-cta{justify-content:center}
  .hero-meta{justify-content:center}
  .hero-meta > div{text-align:center}
  .grid-3,.grid-2,.price,.dash{grid-template-columns:1fr}
  .nav-links{display:none}
  .foot-grid{grid-template-columns:1fr 1fr}
  .legal{grid-template-columns:1fr}.legal-nav{position:static}
  .dash{padding:24px 18px}
  .cmp{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .cta-band{padding:40px 20px;margin:20px 0;border-radius:20px}
  .foot-bottom{justify-content:center;text-align:center}
}

@media(max-width:520px){
  .nav-cta .btn-g{display:none}
  .wrap{padding:0 18px}
}

@media(max-width:480px){
  .foot-grid{grid-template-columns:1fr;text-align:center}
  .foot-grid p{margin:14px auto 0}
}

/* ============================================================
   D-01 brand layer (WP-06) — wordmark, display type, channel CTAs
   ============================================================ */
/* Fraunces display on headings + the wordmark */
h1,h2,h3,h4,.shead h2,.phead h1,.hero h1{font-family:var(--display);letter-spacing:-.02em}
/* the typeset wordmark IS the mark: TaLi. with a terracotta dot + ledger-rule */
.wordmark{font-family:var(--display);font-weight:600;font-size:1.5rem;letter-spacing:-.01em;
  color:var(--ink);position:relative;display:inline-block;line-height:1;padding-bottom:6px}
.wordmark .dot{color:var(--brand)}
.wordmark::after{content:"";position:absolute;left:1px;right:14px;bottom:2px;height:2px;
  background:var(--brand);opacity:.5;border-radius:2px}
.wordmark.lg{font-size:2rem}.wordmark.sm{font-size:1.18rem}
/* terracotta ledger-rule — section divider + signature motif */
.ledger-rule{height:2px;border:0;border-radius:2px;background:var(--brand);opacity:.5;margin:0}
/* channel CTA buttons — the ONLY place WhatsApp green / Telegram blue appear */
.btn-wa{background:var(--wa);color:#fff;border:none}
.btn-wa:hover{background:var(--wa-strong);color:#fff;box-shadow:0 8px 24px rgba(31,170,83,.32)}
.btn-tg{background:var(--tg);color:#fff;border:none}
.btn-tg:hover{background:var(--tg-strong);color:#fff;box-shadow:0 8px 24px rgba(42,171,238,.32)}
/* channel brand glyphs are filled (the rest of the icon set is stroked) */
.btn-wa .ic,.btn-tg .ic{fill:currentColor;stroke:none}
