/* ==========================================================================
   Tu Sistema en 6 Semanas — Landing (Digital Skills)
   Visual style: Befocusy design system. Depends on tokens.css.
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-sans);
  color: var(--fg1);
  background: var(--bg1);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
button { font-family: inherit; cursor: pointer; border: none; background: none; }
a { color: inherit; text-decoration: none; }
img, svg { display: block; }

/* ---- module / plugin accent colors (from brief §12) ------------------- */
:root {
  --m-onboard: #6B7280;   /* gris cálido neutro */
  --m-tareas:  #0F766E;   /* verde teal */
  --m-crm:     #7C3AED;   /* púrpura */
  --m-know:    #D97706;   /* ámbar */
  --m-social:  #F2623E;   /* coral */
  --m-docs:    #2563EB;   /* azul */

  --m-onboard-bg: #F4F4F5;
  --m-tareas-bg:  #F0FDFA;
  --m-crm-bg:     #F5F3FF;
  --m-know-bg:    #FFFBEB;
  --m-social-bg:  #FFF1EE;
  --m-docs-bg:    #EFF6FF;
}

/* ---- layout primitives ------------------------------------------------ */
.wrap { max-width: 1180px; margin: 0 auto; padding: 0 28px; }
.wrap-narrow { max-width: 920px; margin: 0 auto; padding: 0 28px; }
.section { padding: 104px 0; position: relative; }
.section.tight { padding: 80px 0; }
.section.alt { background: var(--bg2); }
.section.tint { background: var(--bg-tint); }
.section.deep { background: var(--teal-900); color: #fff; }
.section.ink { background: var(--teal-950); color: #fff; }

.eyebrow { display:inline-flex; align-items:center; gap:9px; font-size:13px; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase; color:var(--brand); }
.eyebrow::before { content:""; width:22px; height:2px; background:currentColor; border-radius:2px; }
.deep .eyebrow, .ink .eyebrow { color: var(--teal-300); }

.h-display { font-family:var(--font-display); font-weight:700; letter-spacing:-.025em;
  line-height:1.06; margin:0; color:var(--brand-deep); text-wrap:balance; }
.deep .h-display, .ink .h-display { color:#fff; }
.h1 { font-size: clamp(40px, 6vw, 68px); }
.h2 { font-size: clamp(32px, 4.4vw, 50px); }
.h3 { font-size: clamp(24px, 2.6vw, 32px); }
.lead { font-size: clamp(18px,1.4vw,21px); line-height:1.6; color:var(--fg2); margin:20px 0 0; text-wrap:pretty; }
.deep .lead, .ink .lead { color: rgba(255,255,255,.78); }

.s-head { max-width: 720px; margin: 0 0 60px; }
.s-head.center { margin-left:auto; margin-right:auto; text-align:center; }

/* ---- buttons ---------------------------------------------------------- */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:9px; font-weight:600;
  font-size:15px; border:1px solid transparent; transition:all .18s cubic-bezier(.4,0,.2,1);
  white-space:nowrap; line-height:1; }
.btn:active { transform: scale(.98); }
.btn svg { width:18px; height:18px; }
.btn-pri { background:var(--teal-700); color:#fff; padding:15px 26px; border-radius:var(--radius-pill);
  box-shadow:var(--shadow-brand-sm); }
.btn-pri:hover { background:var(--teal-800); box-shadow:var(--shadow-brand); transform:translateY(-1px); }
.btn-sec { background:#fff; color:var(--fg1); border-color:var(--border-strong); padding:15px 26px;
  border-radius:var(--radius-pill); }
.btn-sec:hover { background:var(--bg-tint); border-color:var(--teal-300); }
.btn-onbrand { background:#fff; color:var(--teal-800); padding:15px 26px; border-radius:var(--radius-pill); }
.btn-onbrand:hover { background:var(--teal-50); transform:translateY(-1px); }
.btn-ghost-deep { background:rgba(255,255,255,.08); color:#fff; border-color:rgba(255,255,255,.22);
  padding:15px 26px; border-radius:var(--radius-pill); }
.btn-ghost-deep:hover { background:rgba(255,255,255,.16); }
.btn-lg { font-size:16px; padding:18px 34px; }
.btn-block { width:100%; }

/* ---- nav -------------------------------------------------------------- */
.nav { position:sticky; top:0; z-index:60; background:rgba(255,255,255,.82);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); border-bottom:1px solid var(--border); }
.nav-inner { display:flex; align-items:center; gap:30px; height:74px; }
.brand { display:flex; align-items:center; gap:11px; font-family:var(--font-display); font-weight:700;
  font-size:20px; letter-spacing:-.02em; color:var(--brand-deep); }
.brand .wordmark { height:33px; width:auto; display:block; }
.footer .brand { display:inline-flex; transition:opacity .15s; }
.footer .brand:hover { opacity:.8; }
.footer .brand .wordmark { height:36px; }
.nav-links { display:flex; gap:26px; margin-left:18px; }
.nav-links a { font-size:14.5px; font-weight:500; color:var(--fg2); transition:color .15s; }
.nav-links a:hover { color:var(--teal-700); }
.nav-right { margin-left:auto; display:flex; align-items:center; gap:14px; }
.nav-price { font-size:14px; font-weight:600; color:var(--fg1); }
.nav-price s { color:var(--fg3); font-weight:500; margin-right:6px; }

/* ---- hero ------------------------------------------------------------- */
.hero { position:relative; padding:72px 0 92px; overflow:hidden; }
.hero::before { content:""; position:absolute; top:-180px; right:-140px; width:560px; height:560px;
  border-radius:50%; background:radial-gradient(circle, rgba(20,184,166,.18), transparent 64%); z-index:0; }
.hero-inner { position:relative; z-index:1; }
.hero-grid { display:grid; grid-template-columns:1.04fr .96fr; gap:54px; align-items:center; }
.pill-row { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:26px; }
.pill { display:inline-flex; align-items:center; gap:7px; font-size:13px; font-weight:600;
  color:var(--teal-800); background:var(--teal-50); border:1px solid var(--teal-200);
  padding:7px 13px; border-radius:var(--radius-pill); }
.pill svg { width:14px; height:14px; }
.hero h1 { margin:0; }
.hero h1 em { font-style:normal; color:var(--teal-700); position:relative; white-space:nowrap; }
.hero .lead { max-width:540px; }
.hero-cta { display:flex; gap:14px; margin-top:34px; flex-wrap:wrap; align-items:center; }
.hero-cta .sub { font-size:13px; color:var(--fg3); margin-top:2px; }
.hero-proof { display:flex; gap:14px 30px; margin-top:34px; flex-wrap:wrap; }
.hero-proof .p { display:flex; align-items:center; gap:9px; font-size:14px; color:var(--fg2); font-weight:500; }
.hero-proof .p svg { width:18px; height:18px; color:var(--teal-600); flex:0 0 auto; }

/* facts strip */
.facts { display:grid; grid-template-columns:repeat(4,1fr); gap:0; margin-top:48px;
  border:1px solid var(--border); border-radius:var(--radius-lg); overflow:hidden; background:#fff;
  box-shadow:var(--shadow-sm); }
.fact { padding:20px 22px; border-right:1px solid var(--border); }
.fact:last-child { border-right:none; }
.fact .k { font-size:11px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--fg3); }
.fact .v { font-family:var(--font-display); font-size:20px; font-weight:700; color:var(--brand-deep); margin-top:6px; line-height:1.15; }

/* hero visual — Notion-style system board */
.board { background:#fff; border:1px solid var(--border); border-radius:var(--radius-xl);
  box-shadow:var(--shadow-xl); overflow:hidden; }
.board-bar { display:flex; align-items:center; gap:7px; padding:13px 16px; border-bottom:1px solid var(--border);
  background:var(--bg2); }
.board-bar .dot { width:11px; height:11px; border-radius:50%; }
.board-bar .t { margin-left:10px; font-size:12.5px; font-weight:600; color:var(--fg2); display:flex; align-items:center; gap:7px; }
.board-bar .t svg { width:14px; height:14px; color:var(--teal-600); }
.board-body { padding:18px; display:flex; flex-direction:column; gap:11px; }
.board-row { display:flex; align-items:center; gap:12px; padding:12px 14px; border:1px solid var(--border);
  border-radius:var(--radius-md); background:#fff; transition:transform .2s; }
.board-row .tag { font-size:11px; font-weight:700; padding:3px 9px; border-radius:var(--radius-pill); white-space:nowrap; }
.board-row .label { font-size:13.5px; font-weight:500; color:var(--fg1); flex:1; }
.board-row .meta { font-size:11.5px; color:var(--fg3); display:flex; align-items:center; gap:6px; }
.board-row .av { width:24px; height:24px; border-radius:50%; font-size:10px; font-weight:700; color:#fff;
  display:flex; align-items:center; justify-content:center; flex:0 0 auto; }
.board-foot { display:flex; align-items:center; gap:9px; padding:13px 18px; border-top:1px solid var(--border);
  background:var(--teal-50); font-size:12.5px; font-weight:600; color:var(--teal-800); }
.board-foot svg { width:16px; height:16px; }
.float-card { position:absolute; background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg); padding:13px 15px; display:flex; align-items:center; gap:11px; z-index:3; }
.float-card .fi { width:36px; height:36px; border-radius:10px; display:flex; align-items:center; justify-content:center; flex:0 0 auto; color:#fff; }
.float-card .fi svg { width:19px; height:19px; }
.float-card .ft b { display:block; font-size:13px; font-weight:600; color:var(--fg1); line-height:1.25; }
.float-card .ft span { font-size:11px; color:var(--fg3); }

/* ---- problem ---------------------------------------------------------- */
.prob-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.prob-card { background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:26px; box-shadow:var(--shadow-xs); transition:all .2s cubic-bezier(.4,0,.2,1); }
.prob-card:hover { box-shadow:var(--shadow-md); transform:translateY(-3px); }
.prob-card .ic { width:42px; height:42px; border-radius:var(--radius-md); background:var(--danger-bg);
  color:var(--danger); display:flex; align-items:center; justify-content:center; margin-bottom:16px; }
.prob-card .ic svg { width:21px; height:21px; }
.prob-card h3 { font-size:17px; font-weight:600; margin:0 0 8px; color:var(--fg1); line-height:1.3; }
.prob-card p { font-size:14.5px; line-height:1.6; color:var(--fg2); margin:0; }

.quotes { display:grid; grid-template-columns:repeat(2,1fr); gap:18px; margin-top:60px; }
.quote-card { display:flex; gap:16px; padding:28px 30px; background:var(--bg2); border:1px solid var(--border);
  border-radius:var(--radius-lg); align-items:flex-start; transition:box-shadow .2s, border-color .2s; }
.quote-card:hover { box-shadow:var(--shadow-sm); border-color:var(--teal-200); }
.quote-card .qm { font-family:var(--font-display); font-size:44px; font-weight:700; color:var(--teal-300);
  line-height:.7; flex:0 0 auto; }
.quote-card .qbody { display:flex; flex-direction:column; gap:16px; }
.quote-card p { margin:0; font-size:19px; line-height:1.45; color:var(--fg1); font-weight:500; letter-spacing:-.01em; text-wrap:pretty; }
.quote-card .qwho { display:flex; flex-direction:column; gap:1px; padding-top:2px; border-top:1px solid var(--border); }
.quote-card .qwho b { font-size:13px; font-weight:700; color:var(--teal-800); margin-top:10px; }
.quote-card .qwho span { font-size:12.5px; color:var(--fg3); }

/* ---- promise (deep) --------------------------------------------------- */
.promise-lead { font-family:var(--font-display); font-size:clamp(24px,3vw,36px); font-weight:600;
  line-height:1.34; color:#fff; letter-spacing:-.015em; text-wrap:balance; max-width:960px; }
.promise-lead b { color:var(--teal-300); font-weight:600; }
.diff-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:16px 40px; margin-top:56px; }
.diff { display:flex; gap:15px; align-items:flex-start; padding:4px 0; }
.diff .ck { width:30px; height:30px; border-radius:50%; background:rgba(45,212,191,.16); color:var(--teal-300);
  display:flex; align-items:center; justify-content:center; flex:0 0 auto; margin-top:2px; }
.diff .ck svg { width:17px; height:17px; }
.diff p { margin:0; font-size:16px; line-height:1.5; color:rgba(255,255,255,.9); }
.diff p b { color:#fff; font-weight:700; }

/* ---- AI comparison ---------------------------------------------------- */
.cmp-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.cmp { border-radius:var(--radius-xl); padding:32px; border:1px solid var(--border); }
.cmp.bad { background:var(--bg2); }
.cmp.good { background:var(--teal-900); border-color:var(--teal-900); box-shadow:var(--shadow-lg); }
.cmp .cmp-h { display:flex; align-items:center; gap:11px; margin-bottom:22px; }
.cmp .cmp-h .b { width:40px; height:40px; border-radius:var(--radius-md); display:flex; align-items:center; justify-content:center; flex:0 0 auto; }
.cmp.bad .cmp-h .b { background:var(--slate-200); color:var(--slate-500); }
.cmp.good .cmp-h .b { background:rgba(45,212,191,.18); color:var(--teal-300); }
.cmp .cmp-h .b svg { width:21px; height:21px; }
.cmp .cmp-h h3 { margin:0; font-size:13px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; }
.cmp.bad .cmp-h h3 { color:var(--fg3); }
.cmp.good .cmp-h h3 { color:var(--teal-300); }
.cmp .cmp-h .sub { font-family:var(--font-display); font-size:19px; font-weight:600; margin-top:2px; }
.cmp.bad .cmp-h .sub { color:var(--fg2); }
.cmp.good .cmp-h .sub { color:#fff; }
.cmp ul { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:14px; }
.cmp li { display:flex; gap:12px; font-size:15px; line-height:1.45; align-items:flex-start; }
.cmp li svg { width:19px; height:19px; flex:0 0 auto; margin-top:1px; }
.cmp.bad li { color:var(--fg2); }
.cmp.bad li svg { color:var(--slate-400); }
.cmp.good li { color:rgba(255,255,255,.88); }
.cmp.good li svg { color:var(--teal-300); }
.trust-note { margin-top:30px; padding:26px 30px; background:var(--teal-50); border:1px solid var(--teal-200);
  border-radius:var(--radius-lg); font-size:16px; line-height:1.6; color:var(--teal-900); }
.trust-note b { font-weight:700; }

/* ---- 6 weeks timeline ------------------------------------------------- */
.tl { position:relative; max-width:920px; margin:0 auto; }
.tl::before { content:""; position:absolute; left:31px; top:18px; bottom:18px; width:2px;
  background:linear-gradient(180deg,var(--teal-200),var(--slate-200)); }
.tl-item { position:relative; padding-left:84px; padding-bottom:30px; }
.tl-item:last-child { padding-bottom:0; }
.tl-node { position:absolute; left:0; top:0; width:64px; height:64px; border-radius:var(--radius-lg);
  display:flex; flex-direction:column; align-items:center; justify-content:center; flex:0 0 auto;
  color:#fff; box-shadow:var(--shadow-md); z-index:2; }
.tl-node .wk { font-size:9.5px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; opacity:.85; }
.tl-node .nn { font-family:var(--font-display); font-size:26px; font-weight:700; line-height:1; }
.tl-card { background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); padding:24px 26px;
  box-shadow:var(--shadow-xs); transition:all .2s; }
.tl-card:hover { box-shadow:var(--shadow-md); transform:translateX(3px); }
.tl-card .top { display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin-bottom:11px; }
.tl-card .mod { font-size:11px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; }
.tl-card h3 { font-family:var(--font-display); font-size:21px; font-weight:600; color:var(--brand-deep);
  margin:0 0 10px; letter-spacing:-.01em; line-height:1.2; }
.tl-card p { font-size:14.5px; line-height:1.6; color:var(--fg2); margin:0; }
.tl-plug { display:inline-flex; align-items:center; gap:7px; margin-top:15px; font-size:12.5px;
  font-weight:600; padding:6px 12px; border-radius:var(--radius-pill); }
.tl-plug svg { width:14px; height:14px; }

/* ---- plugins ---------------------------------------------------------- */
.plug-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:22px; }
.plug { border-radius:var(--radius-xl); padding:32px; border:1px solid var(--border); background:#fff;
  box-shadow:var(--shadow-sm); transition:all .2s cubic-bezier(.4,0,.2,1); position:relative; overflow:hidden; }
.plug:hover { box-shadow:var(--shadow-lg); transform:translateY(-4px); }
.plug .glow { position:absolute; top:-60px; right:-60px; width:160px; height:160px; border-radius:50%; opacity:.12; }
.plug .top { display:flex; align-items:center; gap:14px; margin-bottom:8px; }
.plug .pic { width:52px; height:52px; border-radius:var(--radius-md); display:flex; align-items:center; justify-content:center; color:#fff; flex:0 0 auto; }
.plug .pic svg { width:26px; height:26px; }
.plug .when { font-size:11px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; padding:5px 11px;
  border-radius:var(--radius-pill); margin-left:auto; }
.plug h3 { font-family:var(--font-display); font-size:23px; font-weight:600; color:var(--brand-deep); margin:6px 0 4px; }
.plug .tagline { font-size:15px; font-style:italic; font-weight:500; margin:0 0 18px; }
.plug .desc { font-size:14.5px; line-height:1.6; color:var(--fg2); margin:0 0 18px; }
.plug ul { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px; }
.plug li { display:flex; gap:10px; font-size:14px; color:var(--fg1); line-height:1.4; align-items:flex-start; }
.plug li svg { width:17px; height:17px; flex:0 0 auto; margin-top:1px; }

/* ---- savings ---------------------------------------------------------- */
.save-grid { display:grid; grid-template-columns:1.5fr 1fr; gap:40px; align-items:center; }
.save-table { width:100%; border-collapse:collapse; background:#fff; border:1px solid var(--border);
  border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-sm); }
.save-table th, .save-table td { text-align:left; padding:15px 18px; font-size:14px; border-bottom:1px solid var(--border); }
.save-table thead th { font-size:11px; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  color:var(--fg3); background:var(--bg2); }
.save-table tbody td:first-child { font-weight:600; color:var(--fg1); }
.save-table tbody td { color:var(--fg2); }
.save-table .hrs { font-family:var(--font-display); font-weight:700; color:var(--teal-700); text-align:right; white-space:nowrap; }
.save-table tbody tr:last-child td { border-bottom:none; }
.save-table tfoot td { background:var(--teal-900); color:#fff; font-weight:700; font-size:15px; }
.save-table tfoot .hrs { color:var(--teal-300); font-size:18px; }
.save-big { text-align:center; padding:36px 30px; background:var(--teal-900); border-radius:var(--radius-2xl);
  box-shadow:var(--shadow-lg); color:#fff; }
.save-big .n { font-family:var(--font-display); font-size:clamp(56px,8vw,86px); font-weight:700; line-height:.9; color:#fff; }
.save-big .n span { color:var(--teal-300); }
.save-big .u { font-size:15px; font-weight:600; color:var(--teal-300); margin-top:8px; letter-spacing:.04em; text-transform:uppercase; }
.save-big p { font-size:15px; line-height:1.6; color:rgba(255,255,255,.8); margin:18px 0 0; }

/* ---- FAQ -------------------------------------------------------------- */
.faq-list { max-width:820px; margin:0 auto; display:flex; flex-direction:column; gap:12px; }
.faq { background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); overflow:hidden;
  transition:border-color .2s, box-shadow .2s; }
.faq.open { border-color:var(--teal-300); box-shadow:var(--shadow-sm); }
.faq-q { display:flex; align-items:center; gap:16px; width:100%; text-align:left; padding:22px 26px;
  font-size:17px; font-weight:600; color:var(--fg1); line-height:1.4; }
.faq-q .ix { margin-left:auto; flex:0 0 auto; width:30px; height:30px; border-radius:50%; background:var(--bg3);
  color:var(--teal-700); display:flex; align-items:center; justify-content:center; transition:all .25s; }
.faq-q .ix svg { width:18px; height:18px; }
.faq.open .faq-q .ix { background:var(--teal-700); color:#fff; transform:rotate(45deg); }
.faq-a { max-height:0; overflow:hidden; transition:max-height .3s cubic-bezier(.4,0,.2,1); }
.faq-a-inner { padding:0 26px 24px; font-size:15.5px; line-height:1.65; color:var(--fg2); max-width:660px; }

/* ---- results 4 metrics ------------------------------------------------ */
.res-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.res { padding:30px 26px; border-radius:var(--radius-xl); background:#fff; border:1px solid var(--border);
  box-shadow:var(--shadow-sm); }
.res .ic { width:46px; height:46px; border-radius:var(--radius-md); background:var(--teal-700); color:#fff;
  display:flex; align-items:center; justify-content:center; margin-bottom:18px; }
.res .ic svg { width:23px; height:23px; }
.res .n { font-family:var(--font-display); font-size:30px; font-weight:700; color:var(--brand-deep); line-height:1.1; }
.res h4 { font-size:15px; font-weight:600; color:var(--fg1); margin:8px 0 6px; }
.res p { font-size:13.5px; line-height:1.55; color:var(--fg2); margin:0; }

/* ---- price CTA -------------------------------------------------------- */
.price-wrap { display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:stretch; }
.price-left { display:flex; flex-direction:column; justify-content:center; }
.price-num { font-family:var(--font-display); font-size:clamp(60px,9vw,96px); font-weight:700; color:#fff;
  line-height:.9; letter-spacing:-.02em; }
.price-num small { font-size:24px; font-weight:600; color:var(--teal-300); }
.price-meta { font-size:15px; color:rgba(255,255,255,.7); margin-top:16px; line-height:1.6; }
.price-cta { margin-top:34px; display:flex; flex-direction:column; gap:12px; align-items:flex-start; }
.price-cta .urg { display:flex; align-items:center; gap:9px; font-size:13.5px; color:var(--teal-300); font-weight:500; }
.price-cta .urg svg { width:16px; height:16px; flex:0 0 auto; }
.incl-card { background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.14); border-radius:var(--radius-xl); padding:32px 34px; }
.incl-card h3 { font-family:var(--font-display); font-size:18px; font-weight:600; color:#fff; margin:0 0 20px; }
.incl-list { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:13px; }
.incl-list li { display:flex; gap:12px; font-size:14.5px; color:rgba(255,255,255,.86); line-height:1.4; align-items:flex-start; }
.incl-list li svg { width:18px; height:18px; color:var(--teal-300); flex:0 0 auto; margin-top:1px; }

/* ---- footer ----------------------------------------------------------- */
.footer { background:var(--teal-950); color:rgba(255,255,255,.66); padding:72px 0 34px; }
.footer-top { display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:48px; padding-bottom:44px;
  border-bottom:1px solid rgba(255,255,255,.1); }
.footer .brand { color:#fff; margin-bottom:16px; }
.footer-bl p { font-size:14px; line-height:1.7; max-width:320px; margin:0; }
.footer-col h4 { font-size:12px; font-weight:700; color:#fff; text-transform:uppercase; letter-spacing:.07em; margin:0 0 16px; }
.footer-col a { display:block; font-size:14px; margin-bottom:12px; color:rgba(255,255,255,.66); transition:color .15s; }
.footer-col a:hover { color:var(--teal-300); }
.footer-bot { display:flex; align-items:center; justify-content:space-between; padding-top:28px;
  font-size:13px; flex-wrap:wrap; gap:12px; color:rgba(255,255,255,.5); }

/* ---- sticky mobile CTA ------------------------------------------------ */
.sticky-cta { position:fixed; left:0; right:0; bottom:0; z-index:55; background:rgba(255,255,255,.92);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); border-top:1px solid var(--border);
  padding:12px 18px; display:none; align-items:center; gap:14px; box-shadow:0 -6px 24px rgba(12,26,25,.08);
  transform:translateY(100%); transition:transform .3s cubic-bezier(.4,0,.2,1); }
.sticky-cta.show { transform:translateY(0); }
.sticky-cta .info { line-height:1.2; }
.sticky-cta .info b { display:block; font-size:15px; font-weight:700; color:var(--brand-deep); }
.sticky-cta .info span { font-size:12px; color:var(--fg3); }
.sticky-cta .btn { margin-left:auto; }

/* ---- modal ------------------------------------------------------------ */
.modal-ov { position:fixed; inset:0; background:rgba(6,37,31,.6); backdrop-filter:blur(5px);
  display:none; align-items:center; justify-content:center; z-index:120; padding:24px; }
.modal-ov.show { display:flex; animation:fadein .2s ease; }
@keyframes fadein { from{opacity:0} to{opacity:1} }
.modal { background:#fff; border-radius:var(--radius-2xl); width:100%; max-width:520px; max-height:92vh;
  overflow-y:auto; box-shadow:var(--shadow-xl); animation:popin .26s cubic-bezier(.4,0,.2,1); }
@keyframes popin { from{opacity:0; transform:translateY(16px) scale(.98)} to{opacity:1; transform:none} }
.modal-head { padding:30px 32px 0; display:flex; align-items:flex-start; justify-content:space-between; gap:16px; }
.modal-head .eyebrow { margin-bottom:10px; }
.modal-head h3 { font-family:var(--font-display); font-size:26px; font-weight:700; color:var(--brand-deep); margin:0; letter-spacing:-.01em; }
.modal-head p { font-size:14.5px; color:var(--fg2); margin:8px 0 0; line-height:1.5; }
.modal .x { width:36px; height:36px; border-radius:10px; background:var(--bg3); color:var(--fg2);
  display:flex; align-items:center; justify-content:center; flex:0 0 auto; transition:background .15s; }
.modal .x:hover { background:var(--slate-200); }
.modal .x svg { width:19px; height:19px; }
.modal-body { padding:24px 32px 32px; }
.summary { display:flex; align-items:center; gap:14px; padding:16px 18px; background:var(--teal-50);
  border:1px solid var(--teal-200); border-radius:var(--radius-lg); margin-bottom:22px; }
.summary .si { width:44px; height:44px; border-radius:var(--radius-md); background:var(--teal-700); color:#fff;
  display:flex; align-items:center; justify-content:center; flex:0 0 auto; }
.summary .si svg { width:22px; height:22px; }
.summary b { display:block; font-size:15px; color:var(--brand-deep); font-family:var(--font-display); }
.summary span { font-size:13px; color:var(--teal-800); }
.fld { margin-bottom:16px; }
.fld label { display:block; font-size:13px; font-weight:600; margin-bottom:7px; color:var(--fg1); }
.fld .inp { display:flex; align-items:center; gap:10px; background:var(--bg3); border:1px solid var(--border);
  border-radius:var(--radius-md); padding:12px 14px; transition:all .15s; }
.fld .inp:focus-within { background:#fff; border-color:var(--teal-500); box-shadow:0 0 0 3px rgba(20,184,166,.18); }
.fld .inp svg { width:18px; height:18px; color:var(--fg3); flex:0 0 auto; }
.fld input, .fld textarea { border:none; background:transparent; outline:none; width:100%;
  font-family:var(--font-sans); font-size:14.5px; color:var(--fg1); resize:none; }
.fld.row2 { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.fld .err { font-size:12px; color:var(--danger); margin-top:6px; display:none; }
.fld.invalid .inp { border-color:var(--danger); background:var(--danger-bg); }
.fld.invalid .err { display:block; }
.modal .legal { font-size:12px; color:var(--fg3); margin:14px 0 0; line-height:1.5; text-align:center; }
.modal-success { text-align:center; padding:42px 36px; }
.modal-success .sc { width:72px; height:72px; border-radius:50%; background:var(--success-bg); color:var(--success);
  display:flex; align-items:center; justify-content:center; margin:0 auto 22px; }
.modal-success .sc svg { width:36px; height:36px; }
.modal-success h3 { font-family:var(--font-display); font-size:26px; font-weight:700; color:var(--brand-deep); margin:0 0 10px; }
.modal-success p { font-size:15px; color:var(--fg2); line-height:1.6; margin:0 auto; max-width:360px; }

/* ---- founder ---------------------------------------------------------- */
.founder-grid { display:grid; grid-template-columns:minmax(0,420px) 1fr; gap:56px; align-items:center; }
.founder-photo { position:relative; }
.founder-photo .panel { position:absolute; inset:18px -18px -18px 18px; border-radius:var(--radius-2xl);
  background:linear-gradient(150deg, var(--teal-700), var(--teal-900)); z-index:0; }
.founder-photo .frame { position:relative; z-index:1; border-radius:var(--radius-2xl); overflow:hidden;
  border:1px solid var(--border); box-shadow:var(--shadow-lg); background:var(--teal-50); aspect-ratio:1/1; }
.founder-photo .frame img { width:100%; height:100%; object-fit:cover; display:block; }
.founder-photo .sig { position:absolute; z-index:2; left:-12px; bottom:6px; display:flex; align-items:center; gap:11px;
  background:#fff; border:1px solid var(--border); border-radius:var(--radius-pill); padding:9px 16px 9px 11px;
  box-shadow:var(--shadow-md); }
.founder-photo .sig .g { width:30px; height:30px; flex:0 0 auto; }
.founder-photo .sig b { font-family:var(--font-display); font-size:14px; color:var(--brand-deep); display:block; line-height:1.15; }
.founder-photo .sig span { font-size:11.5px; color:var(--fg3); }
.founder-copy .eyebrow { margin-bottom:16px; }
.founder-copy h2 { margin-bottom:22px; }
.founder-copy p { font-size:17px; line-height:1.65; color:var(--fg2); margin:0 0 18px; text-wrap:pretty; max-width:560px; }
.founder-copy p b { color:var(--fg1); font-weight:600; }
.founder-chips { display:flex; flex-wrap:wrap; gap:10px; margin:26px 0 28px; }
.founder-chips .c { display:inline-flex; align-items:center; gap:8px; font-size:13px; font-weight:600;
  color:var(--teal-800); background:#fff; border:1px solid var(--teal-200); padding:9px 14px; border-radius:var(--radius-pill); }
.founder-chips .c svg { width:15px; height:15px; color:var(--teal-600); }
.founder-links { display:flex; gap:14px; flex-wrap:wrap; }
.founder-links a { display:inline-flex; align-items:center; gap:9px; font-size:14.5px; font-weight:600; color:var(--teal-800);
  padding:11px 18px; border-radius:var(--radius-pill); border:1px solid var(--border-strong); background:#fff; transition:all .15s; }
.founder-links a:hover { border-color:var(--teal-300); background:var(--teal-50); transform:translateY(-1px); }
.founder-links a svg { width:17px; height:17px; }

/* ---- scroll reveal (opacity flips instantly for reliability; only transform animates) -- */
.reveal { opacity:0; transform:translateY(16px); transition:transform .6s cubic-bezier(.4,0,.2,1); }
.reveal.in { opacity:1; transform:none; }
.reveal.d1 { transition-delay:.06s; }
.reveal.d2 { transition-delay:.12s; }
.reveal.d3 { transition-delay:.18s; }

/* ---- responsive ------------------------------------------------------- */
@media (max-width: 940px) {
  .section { padding:76px 0; }
  .hero-grid { grid-template-columns:1fr; gap:44px; }
  .hero-visual { order:-1; }
  .facts { grid-template-columns:1fr 1fr; }
  .fact:nth-child(2) { border-right:none; }
  .fact:nth-child(1), .fact:nth-child(2) { border-bottom:1px solid var(--border); }
  .prob-grid, .plug-grid, .cmp-grid, .res-grid, .quotes, .diff-grid, .save-grid, .price-wrap { grid-template-columns:1fr; }
  .founder-grid { grid-template-columns:1fr; gap:54px; max-width:480px; margin:0 auto; }
  .founder-photo .panel { inset:14px -14px -14px 14px; }
  .res-grid { grid-template-columns:1fr 1fr; }
  .nav-links { display:none; }
  .nav-price { display:none; }
  .sticky-cta { display:flex; }
  .footer-top { grid-template-columns:1fr 1fr; }
}
@media (max-width: 560px) {
  .facts { grid-template-columns:1fr; }
  .fact { border-right:none; border-bottom:1px solid var(--border); }
  .res-grid { grid-template-columns:1fr; }
  .quotes { margin-top:40px; }
  .tl-item { padding-left:72px; }
  .fld.row2 { grid-template-columns:1fr; }
  .footer-top { grid-template-columns:1fr; gap:32px; }
}
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity:1; transform:none; transition:none; }
  * { scroll-behavior:auto !important; }
}
