/* ============================================================
   SendToHub — design system
   Warm-neutral base + per-service accent. Light theme.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap');

/* ---------- tokens ---------- */
:root{
  --bg:#FAFAF8;
  --surface:#FFFFFF;
  --surface-2:#F2F1EC;
  --surface-3:#EAE8E1;
  --ink:#1A1917;
  --ink-2:#56534C;
  --ink-3:#8C887E;
  --border:#E7E4DC;
  --border-2:#D8D4CA;

  /* default accent = Telegram azure (hub) */
  --accent:#229ED9;
  --accent-ink:#0E6EA0;
  --accent-soft:#E4F2FA;
  --on-accent:#FFFFFF;

  --maxw:1180px;
  --radius:18px;       /* tweakable */
  --radius-sm:12px;
  --radius-lg:26px;

  --font-sans:'Manrope',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,'SF Mono',Menlo,monospace;

  --shadow-sm:0 1px 2px rgba(26,25,23,.05), 0 1px 1px rgba(26,25,23,.04);
  --shadow-md:0 4px 14px rgba(26,25,23,.07), 0 1px 3px rgba(26,25,23,.05);
  --shadow-lg:0 24px 60px -18px rgba(26,25,23,.20), 0 8px 24px -12px rgba(26,25,23,.12);
  --hero-scale:1;
}

/* per-service accents */
body[data-service="todoist"]{
  --accent:#E44332; --accent-ink:#C2301F; --accent-soft:#FCE9E5; --on-accent:#FFFFFF;
}
body[data-service="ticktick"]{
  --accent:#577DE9; --accent-ink:#3759C6; --accent-soft:#E8EDFC; --on-accent:#FFFFFF;
}
body[data-service="notion"]{
  --accent:#37352F; --accent-ink:#201F1B; --accent-soft:#ECEBE7; --on-accent:#FFFFFF;
}

/* tweak: corner style */
body[data-corners="sharp"]{ --radius:6px; --radius-sm:4px; --radius-lg:8px; }
body[data-corners="round"]{ --radius:26px; --radius-sm:16px; --radius-lg:36px; }

/* tweak: background tone */
body[data-bg="paper"]{ --bg:#F6F2EA; --surface-2:#EEE9DF; --surface-3:#E5DFD2; --border:#E5DECF; --border-2:#D6CDBA; }
body[data-bg="cool"]{ --bg:#F7F8FA; --surface-2:#EEF0F3; --surface-3:#E4E7EC; --border:#E3E6EB; --border-2:#D2D7DE; }

/* ---------- reset / base ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-sans);
  font-size:17px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer;border:none;background:none}
::selection{background:var(--accent);color:var(--on-accent)}

h1,h2,h3{line-height:1.05;letter-spacing:-.02em;font-weight:800}
p{text-wrap:pretty}

.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{padding:96px 0}
.section-sm{padding:64px 0}

.eyebrow{
  font-family:var(--font-mono);font-size:12.5px;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;color:var(--accent-ink);
  display:inline-flex;align-items:center;gap:8px;
}
.eyebrow::before{content:"";width:18px;height:1.5px;background:currentColor;opacity:.6}

.section-head{max-width:640px;margin-bottom:48px}
.section-head h2{font-size:clamp(30px,4vw,46px);margin-bottom:16px}
.section-head p{font-size:18px;color:var(--ink-2);line-height:1.6}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-weight:700;font-size:16px;letter-spacing:-.01em;
  padding:14px 22px;border-radius:var(--radius-sm);
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
  white-space:nowrap;
}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--accent);color:var(--on-accent);box-shadow:var(--shadow-sm)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 22px -8px color-mix(in oklab,var(--accent) 60%,transparent)}
.btn-ghost{background:var(--surface);color:var(--ink);border:1px solid var(--border-2)}
.btn-ghost:hover{background:var(--surface-2);transform:translateY(-2px)}
.btn-lg{padding:17px 28px;font-size:17px}
.btn-block{width:100%}

/* ---------- badges / chips ---------- */
.badge{
  display:inline-flex;align-items:center;gap:7px;
  font-size:13px;font-weight:600;color:var(--ink-2);
  background:var(--surface);border:1px solid var(--border);
  padding:7px 13px;border-radius:999px;
}
.badge .dot{width:7px;height:7px;border-radius:50%;background:var(--accent)}
.badge-soft{background:var(--accent-soft);color:var(--accent-ink);border:none}
.badge-soon{background:var(--surface-3);color:var(--ink-2);border:none}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:sticky;top:0;z-index:50;
  background:color-mix(in srgb,var(--bg) 82%,transparent);
  backdrop-filter:blur(14px) saturate(1.4);
  border-bottom:1px solid transparent;transition:border-color .2s,box-shadow .2s;
}
.nav.scrolled{border-color:var(--border);box-shadow:var(--shadow-sm)}
.nav-inner{display:flex;align-items:center;gap:22px;height:68px}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;font-size:18px;letter-spacing:-.02em}
.brand .mark{
  width:34px;height:34px;border-radius:10px;flex:none;
  display:flex;align-items:center;justify-content:center;
  background:var(--accent);color:var(--on-accent);box-shadow:var(--shadow-sm);
}
.brand .mark.logo-img{background:none;box-shadow:none;border-radius:50%;overflow:hidden}
.brand .mark.logo-img img{width:100%;height:100%;object-fit:cover}
.brand .sub{color:var(--ink-3);font-weight:600}
.nav-links{display:flex;gap:4px;margin-left:8px}
.nav-links a{
  font-size:15px;font-weight:600;color:var(--ink-2);padding:8px 13px;border-radius:9px;
  transition:color .15s,background .15s;
}
.nav-links a:hover{color:var(--ink);background:var(--surface-2)}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:10px}

.lang-toggle{
  display:flex;background:var(--surface-2);border-radius:9px;padding:3px;border:1px solid var(--border);
}
.lang-toggle button{
  font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--ink-3);
  padding:5px 10px;border-radius:6px;transition:.15s;letter-spacing:.04em;
}
.lang-toggle button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}

.nav-menu-btn{display:none;width:42px;height:42px;border-radius:10px;border:1px solid var(--border-2);
  background:var(--surface);align-items:center;justify-content:center}

/* ============================================================
   HERO (shared)
   ============================================================ */
.hero{position:relative;overflow:hidden}
.hero .container{position:relative;z-index:2}
.hero-grid-bg{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:
    radial-gradient(120% 80% at 80% -10%, var(--accent-soft) 0%, transparent 55%),
    linear-gradient(to bottom, color-mix(in srgb,var(--accent-soft) 40%,transparent), transparent 40%);
  opacity:.9;
}
.hero h1{font-size:clamp(38px,calc(5.4vw * var(--hero-scale)),74px);letter-spacing:-.035em}
.hero h1 .accent{color:var(--accent)}
.hero-sub{font-size:clamp(17px,1.4vw,20px);color:var(--ink-2);line-height:1.6;max-width:46ch}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;align-items:center}

/* hub: one CTA per task manager */
.hub-cta{display:flex;flex-wrap:wrap;gap:11px}
.svc-btn{position:relative;background:var(--surface);color:var(--ink);border:1px solid var(--border-2);
  box-shadow:var(--shadow-sm);padding:13px 20px 13px 16px;font-size:16px}
.svc-btn img,.svc-btn .svc-n{width:24px;height:24px;border-radius:6px;object-fit:cover;flex:none}
.svc-btn .svc-n{background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:14px}
.svc-btn:not(.svc-soon){border-color:color-mix(in srgb,var(--svc) 35%,var(--border-2))}
.svc-btn:not(.svc-soon):hover{transform:translateY(-2px);border-color:var(--svc);
  box-shadow:0 12px 24px -12px color-mix(in srgb,var(--svc) 60%,transparent)}
.svc-soon{color:var(--ink-3);background:var(--surface-2)}
.svc-soon .svc-n{background:var(--ink-3)}
.svc-soon:hover{transform:translateY(-2px)}
.svc-soon-tag{font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.06em;
  color:var(--ink-3);background:var(--surface);border:1px solid var(--border-2);
  padding:2px 7px;border-radius:999px;margin-left:2px}
.hero-trust{display:flex;align-items:center;gap:18px;flex-wrap:wrap;color:var(--ink-3);font-size:14px;font-weight:500}
.hero-trust .sep{width:4px;height:4px;border-radius:50%;background:var(--border-2)}

/* A — split */
.hero-split .hero-inner{
  display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;
  padding:78px 0 96px;
}
.hero-split .copy{display:flex;flex-direction:column;gap:24px;align-items:flex-start}

/* B — chat centric */
.hero-chat .hero-inner{display:flex;flex-direction:column;align-items:center;text-align:center;
  gap:24px;padding:44px 0 0}
.hero-chat .copy{display:flex;flex-direction:column;gap:22px;align-items:center;max-width:760px}
.hero-chat .hero-sub{max-width:54ch}
.hero-chat .hero-cta{justify-content:center}
.hero-chat .stage{margin-top:30px;width:100%;display:flex;justify-content:center;
  padding-bottom:90px;position:relative}

/* C — editorial */
.hero-editorial .hero-inner{padding:90px 0 70px;display:flex;flex-direction:column;gap:30px}
.hero-editorial h1{font-size:clamp(44px,calc(8vw * var(--hero-scale)),118px);max-width:14ch;letter-spacing:-.045em;line-height:.98}
.hero-editorial .copy{display:flex;flex-direction:column;gap:28px;align-items:flex-start;max-width:none}
.hero-editorial .ed-row{display:grid;grid-template-columns:1fr auto;gap:40px;align-items:end;width:100%}
.hero-editorial .ed-foot{display:grid;grid-template-columns:1.1fr 1fr;gap:40px;align-items:start;
  margin-top:18px;border-top:1px solid var(--border);padding-top:34px}
.hero-editorial .stage{margin-top:8px}

/* ============================================================
   TELEGRAM CHAT MOCKUP
   ============================================================ */
.tg{
  /* authentic Telegram palette, scoped so brand accent never leaks into the chat */
  --tg-out:#effdde;          /* outgoing bubble (light green) */
  --tg-out-tick:#5bb381;     /* time + read ticks inside green bubble */
  --tg-blue:#3390ec;         /* links, forwarded-from label */
  --tg-header:#ffffff;
  --tg-wall-a:#a9c6a0;       /* doodle wallpaper gradient */
  --tg-wall-b:#8fb59a;
  width:100%;max-width:420px;background:var(--surface);
  border-radius:var(--radius-lg);border:1px solid var(--border);
  box-shadow:var(--shadow-lg);overflow:hidden;
  display:flex;flex-direction:column;text-align:left;
}
.tg-wide{max-width:480px}
.tg-head{
  display:flex;align-items:center;gap:11px;padding:10px 14px;
  background:var(--tg-header);border-bottom:1px solid var(--border);
}
.tg-head .back{color:var(--tg-blue);flex:none;display:flex;align-items:center;margin-right:-2px}
.tg-ava{width:40px;height:40px;border-radius:50%;flex:none;overflow:hidden;
  background:linear-gradient(135deg,#5ec3f0,#229ED9);
  display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:15px}
.tg-ava img{width:100%;height:100%;object-fit:cover}
.tg-head .name{font-weight:600;font-size:15px;line-height:1.25;color:var(--ink)}
.tg-head .status{font-size:12.5px;color:var(--tg-blue);font-weight:500}
.tg-head .hd-actions{margin-left:auto;display:flex;align-items:center;gap:16px;color:#aeb7bd}
.tg-body{
  position:relative;
  background-color:#a9c6a0;
  background-image:url('assets/tg-pattern.svg'),linear-gradient(160deg,#aecaa4,#8fb59a);
  background-size:150px 150px,cover;background-repeat:repeat,no-repeat;
  padding:16px 13px 14px;display:flex;flex-direction:column;gap:8px;min-height:340px;
}
.tg-day{align-self:center;background:rgba(0,0,0,.28);color:#fff;backdrop-filter:blur(2px);
  font-size:12px;font-weight:600;padding:4px 12px;border-radius:999px;margin:2px 0 4px}
.msg{max-width:82%;padding:7px 11px 6px;border-radius:14px;font-size:14.5px;line-height:1.4;
  position:relative;box-shadow:0 1px 1.5px rgba(0,0,0,.13);
  animation:msgIn .45s cubic-bezier(.2,.7,.3,1) both}
.msg .time{font-size:11px;color:var(--ink-3);float:right;margin:5px 0 -1px 10px;font-weight:500;position:relative;top:3px}
.msg .checks{margin-left:3px;color:var(--tg-blue);font-weight:600;letter-spacing:-2px}
.msg.out{align-self:flex-end;background:var(--tg-out);color:#15202b}
.msg.out .time{color:var(--tg-out-tick)}
.msg.out .checks{color:var(--tg-out-tick)}
.msg.in{align-self:flex-start;background:var(--surface);color:var(--ink)}
.msg.fwd .fwd-from{font-size:12.5px;font-weight:600;color:var(--tg-blue);margin-bottom:3px;display:block}
.msg.fwd .fwd-lead{font-size:11.5px;font-weight:400;color:var(--tg-blue);opacity:.85;display:block;margin-bottom:-1px}
.msg.typing{display:inline-flex;gap:4px;padding:13px 15px;align-self:flex-start;background:var(--surface)}
.msg.typing span{width:7px;height:7px;border-radius:50%;background:var(--ink-3);animation:blink 1.2s infinite}
.msg.typing span:nth-child(2){animation-delay:.2s}
.msg.typing span:nth-child(3){animation-delay:.4s}

/* document attachment (outgoing) */
.msg.has-doc{position:relative;padding:8px 11px 6px}
.msg .doc{display:flex;align-items:center;gap:10px;padding-right:34px}
.msg .doc-ic{width:38px;height:38px;border-radius:50%;background:#4aa57a;color:#fff;flex:none;
  display:flex;align-items:center;justify-content:center}
.msg .doc-info{display:flex;flex-direction:column;line-height:1.35;min-width:0}
.msg .doc-info b{font-size:14px;font-weight:600;color:#15202b}
.msg .doc-info span{font-size:11.5px;color:var(--tg-out-tick)}
.msg.has-doc .time{position:absolute;right:10px;bottom:5px;float:none;margin:0;top:auto}

/* bot reply rendered as a real Telegram message (no buttons, no card chrome) */
.task-msg{max-width:90%;line-height:1.42}
.task-msg .tm-head{display:flex;align-items:center;gap:6px;font-weight:700;font-size:13px;
  letter-spacing:.03em;color:var(--ink);margin-bottom:8px}
.task-msg .tm-badge{font-size:15px}
.task-msg .tm-title{font-weight:700;font-size:14.5px;color:var(--ink);margin-bottom:6px;line-height:1.32}
.task-msg .tm-meta{font-size:13.5px;color:var(--ink-2);line-height:1.55}
.task-msg .tm-date{color:var(--tg-blue)}
.task-msg .tm-list{margin-top:9px;display:flex;flex-direction:column;gap:4px}
.task-msg .tm-li{font-size:14px;color:var(--ink);line-height:1.42}
.task-msg .time{display:block;text-align:right;float:none;margin:7px 0 -1px;position:static;top:0}

.tg-input{display:flex;align-items:center;gap:11px;padding:9px 12px;background:var(--surface);border-top:1px solid var(--border)}
.tg-input .emoji{color:#aeb7bd;font-size:21px;flex:none;display:flex;align-items:center}
.tg-input .field{flex:1;color:var(--ink-3);font-size:14.5px;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tg-input .field.typed{color:var(--ink)}
.tg-input .field .caret{display:inline-block;width:1.5px;height:15px;background:var(--tg-blue);
  margin-left:1px;vertical-align:-2px;animation:caretBlink 1s steps(1) infinite}
@keyframes caretBlink{0%,50%{opacity:1}50.01%,100%{opacity:0}}
.tg-input .clip{color:#aeb7bd;display:flex;align-items:center;flex:none}
.tg-input .send{flex:none;width:36px;height:36px;border-radius:50%;background:var(--tg-blue);
  color:#fff;display:flex;align-items:center;justify-content:center;transition:transform .12s ease}
.tg-input .send.pulse{transform:scale(.82);box-shadow:0 0 0 5px color-mix(in srgb,var(--tg-blue) 24%,transparent)}

/* floating accent chips around chat in hero B */
.float-chip{position:absolute;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-md);
  border-radius:12px;padding:9px 13px;font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px;
  z-index:3;animation:floaty 5s ease-in-out infinite}
.float-chip .ic{width:24px;height:24px;border-radius:7px;background:var(--accent-soft);color:var(--accent-ink);
  display:flex;align-items:center;justify-content:center;font-size:13px;flex:none}

/* ============================================================
   SYNCED DEMO  (Telegram chat  ->  destination app window)
   ============================================================ */
.sync-stage{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;flex-wrap:wrap}
.sync-stage.solo{gap:0}
.sync-pane{display:flex}
.chat-pane{flex:none}
.chat-pane .tg{width:360px;max-width:none;height:500px}
.tg-compact .tg-body{flex:1;min-height:0;overflow:hidden;justify-content:flex-end}
.app-pane{flex:none}
.app-pane .appwin{height:500px}

/* connector */
.sync-link{flex:none;display:flex;align-items:center;justify-content:center;width:66px;color:var(--accent)}
.sl-line{position:relative;width:46px;height:2px;
  background:repeating-linear-gradient(90deg,currentColor 0 6px,transparent 6px 12px);opacity:.55}
.sl-spark{position:absolute;top:50%;left:0;width:9px;height:9px;border-radius:50%;background:var(--accent);
  transform:translate(-50%,-50%);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 22%,transparent);
  animation:spark 2.6s cubic-bezier(.5,0,.5,1) infinite}
.sl-tip{display:flex;margin-left:-5px}
@keyframes spark{0%{left:0;opacity:0}12%{opacity:1}50%{left:100%;opacity:1}50.01%{opacity:0}60%{left:0;opacity:0}}

/* the app window chrome */
.appwin{width:392px;max-width:100%;background:#fff;border:1px solid #ececec;border-radius:14px;
  box-shadow:0 26px 56px -26px rgba(20,20,20,.42),0 5px 16px -10px rgba(20,20,20,.25);
  overflow:hidden;display:flex;flex-direction:column;color:#202020;text-align:left;
  font-family:-apple-system,"Segoe UI",Roboto,system-ui,sans-serif}
.aw-chrome{display:flex;align-items:center;gap:11px;padding:9px 13px;border-bottom:1px solid #f0f0f0;background:#fafafa}
.aw-dots{display:flex;gap:6px}
.aw-dots i{width:11px;height:11px;border-radius:50%;background:#e0625b}
.aw-dots i:nth-child(2){background:#e8b13a}
.aw-dots i:nth-child(3){background:#54b84a}
.aw-appname{display:flex;align-items:center;gap:7px;font-weight:600;font-size:13px;color:#555;margin-left:3px}
.aw-appname img{width:18px;height:18px;border-radius:5px;object-fit:cover}
.aw-generic-ic{width:18px;height:18px;border-radius:5px;background:var(--aw-accent);color:#fff;
  display:flex;align-items:center;justify-content:center;flex:none}
.aw-top{display:flex;align-items:center;gap:9px;padding:15px 17px 9px}
.aw-top .aw-listic{color:#9a9a9a;display:flex}
.aw-top h4{font-size:21px;font-weight:800;letter-spacing:-.02em;margin:0;color:#1f1f1f}
.aw-count{font-size:12px;font-weight:600;color:#9a9a9a;background:#f1f1f1;border-radius:6px;padding:2px 7px}
.aw-tools{margin-left:auto;display:flex;align-items:center;gap:13px;color:#b6b6b6}
.aw-more{font-size:18px;letter-spacing:1px;line-height:1}
.aw-add{display:flex;align-items:center;gap:9px;margin:0 13px 2px;padding:9px 11px;color:#a9a9a9;font-size:14px}
.aw-add span{color:var(--aw-accent);font-weight:700;font-size:17px;line-height:1}
.aw-list{display:flex;flex-direction:column;padding:2px 5px 10px;flex:1;overflow:hidden}
.aw-row{display:flex;gap:11px;padding:11px 12px;border-bottom:1px solid #f3f3f3;align-items:flex-start}
.aw-row:last-child{border-bottom:none}
.aw-check{width:19px;height:19px;border-radius:50%;border:1.7px solid #c9897f;flex:none;margin-top:1px}
.aw-check.sq{border-radius:6px;border-color:#c6c6c6}
.appwin-tt .aw-check{border-color:#c6c6c6}
.aw-main{flex:1;min-width:0}
.aw-row-top{display:flex;align-items:flex-start;gap:10px}
.aw-title{font-size:14.5px;color:#2b2b2b;line-height:1.36;flex:1}
.aw-date-r{font-size:12.5px;color:#9c9c9c;flex:none;white-space:nowrap;margin-top:1px}
.aw-date-r.soon{color:var(--aw-accent)}
.aw-meta{display:flex;align-items:center;gap:14px;margin-top:5px;flex-wrap:wrap}
.aw-date{display:inline-flex;align-items:center;gap:4px;font-size:12.5px;color:#7c7c7c}
.aw-date.soon{color:var(--aw-accent)}
.aw-tg{display:inline-flex;align-items:center;gap:4px;font-size:12.5px;color:#2f80d6;font-weight:500;white-space:nowrap}
.aw-date{display:inline-flex;align-items:center;gap:4px;font-size:12.5px;color:#7c7c7c;white-space:nowrap}
.aw-new{animation:awIn .6s cubic-bezier(.2,.8,.3,1)}
@keyframes awIn{
  0%{transform:translateY(-9px);background:color-mix(in srgb,var(--aw-accent) 18%,#fff)}
  60%{background:color-mix(in srgb,var(--aw-accent) 9%,#fff)}
  100%{transform:translateY(0);background:transparent}
}
@media (max-width:860px){
  .sync-stage{flex-direction:column}
  .sync-link{width:auto;height:54px;transform:rotate(90deg)}
}

/* Telegram window chrome (matches the app window) */
.tg-chrome{flex:none}
.tglogo{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;
  background:linear-gradient(160deg,#37b3ec,#1d93d2);color:#fff;flex:none;padding-right:1px}
.tglogo svg{transform:translateX(-0.5px)}
/* eyebrow with leading Telegram logo */
.eyebrow-tg{display:inline-flex;align-items:center;gap:8px}
.hero-chat .eyebrow-tg{justify-content:center}

/* ============================================================
   LOGOS STRIP / providers
   ============================================================ */
.providers{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.prov{display:flex;align-items:center;gap:9px;font-weight:700;font-size:14px;color:var(--ink-2);
  background:var(--surface);border:1px solid var(--border);padding:8px 14px 8px 9px;border-radius:999px}
.prov .pl{width:24px;height:24px;border-radius:50%;overflow:hidden;flex:none}
.prov .pl img{width:100%;height:100%;object-fit:cover}
.prov .pl.notion{background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800}
.prov.soon{opacity:.62}
.prov .soon-tag{font-family:var(--font-mono);font-size:10px;color:var(--ink-3);font-weight:500;
  background:var(--surface-2);padding:2px 6px;border-radius:5px;letter-spacing:.05em}

/* ============================================================
   FEATURES
   ============================================================ */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.feat{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:26px 24px;display:flex;flex-direction:column;gap:14px;transition:.2s;
}
.feat:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--border-2)}
.feat .fi{width:46px;height:46px;border-radius:12px;background:var(--accent-soft);color:var(--accent-ink);
  display:flex;align-items:center;justify-content:center}
.feat .fi svg{width:24px;height:24px}
.feat h3{font-size:19px;font-weight:800}
.feat p{font-size:15px;color:var(--ink-2);line-height:1.55}
.feat.span2{grid-column:span 2}
.feat-wide{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center}

/* ============================================================
   STEPS
   ============================================================ */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;counter-reset:s}
.step{position:relative;padding:28px 24px;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);display:flex;flex-direction:column;gap:12px}
.step .num{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--accent-ink);
  width:34px;height:34px;border-radius:10px;background:var(--accent-soft);
  display:flex;align-items:center;justify-content:center}
.step h3{font-size:18px}
.step-once{position:absolute;top:24px;right:22px;font-family:var(--font-mono);font-size:11px;font-weight:600;
  letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);background:var(--surface-2);
  border:1px solid var(--border);padding:3px 9px;border-radius:999px}
.step p{font-size:14.5px;color:var(--ink-2)}
.step code{font-family:var(--font-mono);font-size:13px;background:var(--surface-2);padding:2px 7px;
  border-radius:6px;color:var(--accent-ink);font-weight:600}

/* ============================================================
   PRIVACY
   ============================================================ */
.privacy{background:var(--ink);color:#fff;border-radius:var(--radius-lg);padding:54px 50px;position:relative;overflow:hidden}
.privacy::after{content:"";position:absolute;right:-80px;top:-80px;width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle,color-mix(in srgb,var(--accent) 40%,transparent),transparent 70%);opacity:.5}
.privacy .p-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:46px}
.privacy .eyebrow{color:color-mix(in srgb,var(--accent) 70%,white)}
.privacy h2{font-size:clamp(28px,3.4vw,40px);margin:14px 0 16px;color:#fff}
.privacy .lead{color:rgba(255,255,255,.7);font-size:17px;line-height:1.6}
.privacy ul{list-style:none;display:flex;flex-direction:column;gap:16px}
.privacy li{display:flex;gap:13px;align-items:flex-start}
.privacy li .pc{width:26px;height:26px;border-radius:8px;flex:none;
  background:color-mix(in srgb,var(--accent) 30%,transparent);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:14px;margin-top:1px}
.privacy li .pt b{display:block;font-size:15.5px;font-weight:700;margin-bottom:2px}
.privacy li .pt span{font-size:14px;color:rgba(255,255,255,.62);line-height:1.5}

/* ============================================================
   FAQ
   ============================================================ */
.faq{display:flex;flex-direction:column;gap:0;max-width:760px;margin:0 auto;
  border-top:1px solid var(--border)}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{width:100%;display:flex;align-items:center;gap:18px;padding:24px 6px;text-align:left;
  font-size:18px;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.faq-q .qx{margin-left:auto;flex:none;width:28px;height:28px;border-radius:8px;background:var(--surface-2);
  display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--ink-2);transition:.25s}
.faq-item.open .qx{background:var(--accent);color:var(--on-accent);transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-a .inner{padding:0 6px 26px;font-size:16px;color:var(--ink-2);line-height:1.6;max-width:64ch}
.faq-a code{font-family:var(--font-mono);font-size:13.5px;background:var(--surface-2);padding:2px 6px;border-radius:5px;color:var(--accent-ink)}

/* ============================================================
   SERVICE CARDS (hub)
   ============================================================ */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc{position:relative;display:flex;flex-direction:column;gap:18px;padding:30px 28px;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  transition:.22s;overflow:hidden}
.svc:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.svc::before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:var(--svc-accent,var(--accent))}
.svc .svc-logo{width:56px;height:56px;border-radius:50%;overflow:hidden;box-shadow:var(--shadow-sm)}
.svc .svc-logo img{width:100%;height:100%;object-fit:cover}
.svc .svc-logo.notion{background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:24px;font-weight:800;border-radius:16px}
.svc h3{font-size:22px}
.svc p{font-size:15px;color:var(--ink-2);flex:1}
.svc .svc-go{display:flex;align-items:center;gap:8px;font-weight:700;font-size:15px;color:var(--svc-accent,var(--accent))}
.svc.soon{opacity:.92}
.svc.soon .svc-logo{filter:grayscale(.15)}
.svc-soon-badge{position:absolute;top:20px;right:20px;font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:.06em;color:var(--ink-2);background:var(--surface-2);padding:5px 10px;border-radius:7px}

/* ============================================================
   CTA band
   ============================================================ */
.cta-band{background:var(--accent);color:var(--on-accent);border-radius:var(--radius-lg);
  padding:56px 50px;display:grid;grid-template-columns:1.3fr auto;gap:32px;align-items:center;position:relative;overflow:hidden}
.cta-band h2{font-size:clamp(28px,3.4vw,42px);color:var(--on-accent)}
.cta-band.cta-hub{grid-template-columns:1fr;justify-items:center;text-align:center;gap:28px}
.cta-band.cta-hub .hub-cta{justify-content:center}
.cta-band p{color:color-mix(in srgb,var(--on-accent) 82%,transparent);font-size:18px;margin-top:10px;max-width:46ch}
.cta-band .btn-primary{background:#fff;color:var(--accent-ink)}
.cta-band .btn-primary:hover{background:#fff;box-shadow:0 12px 28px -10px rgba(0,0,0,.35)}
.cta-band::after{content:"";position:absolute;left:-60px;bottom:-120px;width:320px;height:320px;border-radius:50%;
  background:color-mix(in srgb,#fff 16%,transparent)}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{border-top:1px solid var(--border);padding:60px 0 40px;background:var(--surface)}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;margin-bottom:46px}
.footer .brand{margin-bottom:14px}
.footer .f-about{color:var(--ink-2);font-size:14.5px;max-width:34ch;line-height:1.6}
.footer h4{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);margin-bottom:16px;font-weight:700}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.footer ul a{color:var(--ink-2);font-size:14.5px;font-weight:500;transition:.15s;display:inline-flex;align-items:center;gap:8px}
.footer ul a:hover{color:var(--accent-ink)}
.footer-bottom{display:flex;align-items:center;gap:16px;padding-top:26px;border-top:1px solid var(--border);
  color:var(--ink-3);font-size:13.5px;flex-wrap:wrap}
.footer-bottom .disc{margin-left:auto;font-size:12.5px;max-width:54ch;text-align:right}

/* ============================================================
   animations
   ============================================================ */
@keyframes msgIn{to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes blink{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.2,.7,.3,1),transform .7s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}
body[data-motion="off"] .msg,body[data-motion="off"] .task-card{animation:none!important;opacity:1!important;transform:none!important}
body[data-motion="off"] .float-chip{animation:none!important}
body[data-motion="off"] .reveal{opacity:1!important;transform:none!important}

/* ============================================================
   responsive
   ============================================================ */
@media (max-width:980px){
  .hero-split .hero-inner{grid-template-columns:1fr;gap:40px;padding:56px 0 70px}
  .hero-split .stage{justify-self:start}
  .features-grid,.steps,.svc-grid{grid-template-columns:1fr 1fr}
  .privacy .p-inner,.footer-top{grid-template-columns:1fr}
  .footer-top{gap:34px}
  .cta-band{grid-template-columns:1fr}
  .hero-editorial .ed-row,.hero-editorial .ed-foot{grid-template-columns:1fr}
}
@media (max-width:680px){
  .section{padding:64px 0}
  .nav-links{display:none}
  .nav-menu-btn{display:flex}
  .features-grid,.steps,.svc-grid{grid-template-columns:1fr}
  .feat.span2{grid-column:auto}
  .feat-wide{grid-template-columns:1fr}
  .privacy,.cta-band{padding:38px 26px}
  .footer-bottom .disc{margin-left:0;text-align:left}
  .hero h1{letter-spacing:-.03em}
  .container{padding:0 20px}
}
