
/* =====================================================================
   KENSORA HOMEPAGE, Direction A (warm editorial calm-luxury)
   fused with Direction C (modern product precision).
   Light = warm paper (primary). Dark (no .theme-light) = deep warm ink.
   Plus Jakarta Sans only. WCAG AA in both modes.
   ===================================================================== */

/* ---------- Home-only token overrides ----------
   The shared palette (paper / ink / line / shadows / triad tints, both themes), plus --ease, --sans,
   --serif and the rest, all live in web/styles.css now (single source — loaded before this file). This
   file only overrides what is genuinely home-specific: a wider hero canvas, and the product-mockup
   surface colors. Dark is the default; light values sit under .theme-light, matching styles.css's
   convention. (Web mobile council 2026-06-28 — chrome de-duplication; canonical width = Josh-set:
   global 1080, home keeps a wider 1180.) */
:root{
  --maxw:1180px;             /* wider canvas for the marketing home; content pages keep styles.css's 1080 */
  /* product-mockup surfaces (home-only) — DARK default */
  --device-shell:#050403;
  --screen-top:#1A1712;
  --screen-bot:#120F0B;
  --screen-line:#2A241B;
  --screen-ink:#F3EDE2;
  --screen-ink-2:#9A8F7C;
}
html.theme-light{
  /* product-mockup surfaces (home-only) — LIGHT */
  --device-shell:#1A1611;
  --screen-top:#FFFFFF;
  --screen-bot:#F6F3EE;
  --screen-line:#ECE7DC;
  --screen-ink:#211C16;
  --screen-ink-2:#766C5D;
}

/* The reset (* / html / body / h-/p-margins), .wrap / .narrow, .skip, :focus-visible and .svgdefs are
   all defined identically in styles.css now — single-sourced there. Kept here only: the home's element
   defaults that differ from styles.css (global no-underline links + block images). */
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}

/* ---------- Brandmark + triangle glyphs (LOCKED shapes) ---------- */
.brandmark{width:30px;height:30px;display:inline-block;flex:0 0 auto;}

.tri{display:inline-block;width:15px;height:15px;vertical-align:middle;background:currentColor;
  -webkit-mask:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='140%20140%20720%20720'%3E%3Cpath%20d='M565%20300.81Q500%20188.23%20435%20300.81L205%20699.19Q140%20811.77%20270%20811.77L730%20811.77Q860%20811.77%20795%20699.19Z'/%3E%3C/svg%3E") center/contain no-repeat;mask:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='140%20140%20720%20720'%3E%3Cpath%20d='M565%20300.81Q500%20188.23%20435%20300.81L205%20699.19Q140%20811.77%20270%20811.77L730%20811.77Q860%20811.77%20795%20699.19Z'/%3E%3C/svg%3E") center/contain no-repeat}
.tri-up{}
.tri-down{transform:rotate(180deg)}
.tri-left{transform:rotate(-90deg)}
.tri-right{transform:rotate(90deg)}

/* ---------- Eyebrow / pill ---------- */
.eyebrow{
  font-size:12px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink-mute);display:inline-flex;align-items:center;gap:10px;
}
.eyebrow .seed{width:7px;height:7px;border-radius:50%;
  background:conic-gradient(from 90deg,var(--red),var(--green),var(--blue),var(--red));}
.pill{
  display:inline-flex;align-items:center;gap:9px;
  font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-mute);
  border:1px solid var(--line);border-radius:999px;padding:7px 15px;
  background:var(--paper-raised);
}
.pill .seed{width:7px;height:7px;border-radius:50%;
  background:conic-gradient(from 90deg,var(--red),var(--green),var(--blue),var(--red));}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--sans);font-weight:600;font-size:15px;line-height:1;
  border-radius:999px;padding:13px 24px;cursor:pointer;
  border:1px solid var(--ink);background:var(--ink);color:var(--paper-raised);
  transition:transform .4s var(--ease),background .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease);
  box-shadow:var(--shadow-sm);white-space:nowrap;
}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);}
html:not(.theme-light) .btn{background:var(--ink);color:#14110D;border-color:var(--ink);}
.btn .arr{transition:transform .4s var(--ease);}
.btn:hover .arr{transform:translateX(3px);}
.btn.big{padding:15px 28px;font-size:16px;}
.btn.ghost{
  background:transparent;color:var(--ink);border:1px solid var(--line-strong);box-shadow:none;
}
.btn.ghost:hover{background:var(--paper-raised);border-color:var(--ink-mute);box-shadow:var(--shadow-sm);}

/* ---------- Header / nav (preserves hooks for nav.js + theme.js) ---------- */
#hd{position:sticky;top:0;z-index:80;
  background:color-mix(in srgb, var(--paper) 80%, transparent);
  backdrop-filter:saturate(1.4) blur(16px);
  -webkit-backdrop-filter:saturate(1.4) blur(16px);
  border-bottom:1px solid transparent;
  transition:border-color .5s var(--ease),background .5s var(--ease);
}
#hd.scrolled{border-bottom-color:var(--line);
  background:color-mix(in srgb, var(--paper) 92%, transparent);}
/* tri-color gradient seam under the nav (from Direction C) */
#hd::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;
  background:linear-gradient(90deg,transparent 0%,var(--red) 22%,var(--green) 50%,var(--blue) 78%,transparent 100%);
  background-size:200% 100%;opacity:0;transition:opacity .6s var(--ease);}
#hd.scrolled::after{opacity:.9;animation:seamShift 9s linear infinite;}
@keyframes seamShift{to{background-position:200% 0;}}

.nav{display:flex;align-items:center;gap:28px;height:74px;}
.brand{display:flex;align-items:center;gap:12px;font-weight:700;font-size:21px;letter-spacing:-.01em;color:var(--ink);}
/* Logo mark stays static (no rotation). */

.navtoggle{display:none;background:none;border:1px solid var(--line);border-radius:11px;
  width:44px;height:44px;cursor:pointer;color:var(--ink);align-items:center;justify-content:center;margin-left:auto;}
.navtoggle svg{width:22px;height:22px;}

.links{display:flex;align-items:center;gap:26px;margin-left:auto;}
.links > a{font-size:15px;font-weight:500;color:var(--ink-soft);position:relative;transition:color .3s var(--ease);}
.links > a:hover,.links > a.active{color:var(--ink);}
.links .nav-login{color:var(--ink-soft);}

/* dropdowns */
.dd{position:relative;}
.dd-t{display:inline-flex;align-items:center;gap:5px;background:none;border:0;cursor:pointer;
  font-family:var(--sans);font-size:15px;font-weight:500;color:var(--ink-soft);padding:0;transition:color .3s var(--ease);}
.dd-t:hover,.dd-t.active,.dd:hover .dd-t{color:var(--ink);}
.dd-t .caret{width:15px;height:15px;transition:transform .3s var(--ease);}
.dd:hover .dd-t .caret,.dd.open .dd-t .caret{transform:rotate(180deg);}
.dd-m{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);
  min-width:230px;background:var(--paper-raised);border:1px solid var(--line);border-radius:16px;
  padding:10px;box-shadow:var(--shadow-md);
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .25s var(--ease),transform .25s var(--ease);z-index:90;}
.dd:hover .dd-m,.dd.open .dd-m{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0);}
.dd-m a{display:flex;align-items:center;gap:10px;font-size:14.5px;font-weight:500;color:var(--ink-soft);
  padding:9px 13px;border-radius:10px;transition:background .2s var(--ease),color .2s var(--ease);}
.dd-m a:hover{background:var(--tint);color:var(--ink);}
.dd-m .tri{width:13px;height:13px;}
.ddtag{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute);
  border:1px solid var(--line);border-radius:999px;padding:2px 7px;margin-left:auto;}
.dd-sep{height:1px;background:var(--line);margin:8px 6px;}
.dd-all{font-weight:600;color:var(--ink);}

.themetoggle{background:none;border:1px solid var(--line);border-radius:50%;width:40px;height:40px;
  cursor:pointer;color:var(--ink-soft);display:inline-flex;align-items:center;justify-content:center;
  transition:color .3s var(--ease),border-color .3s var(--ease);flex:0 0 auto;}
.themetoggle:hover{color:var(--ink);border-color:var(--ink-mute);}
.themetoggle svg{width:18px;height:18px;}
.themetoggle .moon{display:none;}
.themetoggle .sun{display:block;}
html:not(.theme-light) .themetoggle .moon{display:block;}
html:not(.theme-light) .themetoggle .sun{display:none;}

/* sticky mobile CTA */
.sticky-cta{position:fixed;left:50%;bottom:18px;transform:translateX(-50%) translateY(120%);
  z-index:70;opacity:0;pointer-events:none;transition:transform .4s var(--ease),opacity .4s var(--ease);
  box-shadow:var(--shadow-md);}
.sticky-cta.show{transform:translateX(-50%) translateY(0);opacity:1;pointer-events:auto;}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;}
.hero::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(62% 52% at 74% 30%, color-mix(in srgb,var(--paper-raised) 90%, transparent) 0%, transparent 60%),
    radial-gradient(90% 70% at 50% 0%, color-mix(in srgb,var(--paper-deep) 55%, transparent) 0%, transparent 55%);
}
html:not(.theme-light) .hero::before{
  background:
    radial-gradient(60% 55% at 72% 26%, rgba(77,104,204,.12) 0%, transparent 60%),
    radial-gradient(70% 60% at 18% 92%, rgba(0,137,57,.10) 0%, transparent 62%),
    radial-gradient(50% 50% at 50% 0%, rgba(188,68,55,.07) 0%, transparent 60%);
}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr;align-content:center;min-height:calc(100svh - 76px);padding:40px 0 80px;}
.hero-copy{max-width:920px;}
.hero .eyebrow{margin-bottom:26px;}
.hero h1{
  font-weight:800;font-size:clamp(46px,7.4vw,98px);line-height:1.0;letter-spacing:-.04em;
  margin:0 0 28px;color:var(--ink);
}
.hero h1 .grad{
  background:linear-gradient(105deg,var(--red),var(--green) 52%,var(--blue));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.lede{font-size:clamp(17.5px,1.5vw,19.5px);line-height:1.6;color:var(--ink-soft);max-width:640px;margin:0 0 36px;}
.hero-actions{display:flex;align-items:center;gap:18px;flex-wrap:wrap;}
.play{display:inline-flex;align-items:center;gap:11px;font-weight:600;font-size:15px;color:var(--ink);cursor:pointer;}
.play .disc{width:40px;height:40px;border-radius:50%;border:1px solid var(--line-strong);background:var(--paper-raised);
  display:flex;align-items:center;justify-content:center;
  transition:transform .4s var(--ease),border-color .4s var(--ease),box-shadow .4s var(--ease);}
.play:hover .disc{transform:scale(1.06);border-color:var(--ink-mute);box-shadow:var(--shadow-sm);}
.play .disc svg{margin-left:2px;}
.hero-trust{display:flex;gap:26px;margin-top:46px;padding-top:26px;border-top:1px solid var(--line);flex-wrap:wrap;}
.hero-trust .t{font-size:14px;color:var(--ink-soft);line-height:1.5;}
.hero-trust .t b{display:block;font-weight:700;font-size:15px;color:var(--ink);margin-bottom:1px;}

/* ---------- Hero product mockup (Direction C iPhone "Today") ---------- */
.stage{position:relative;display:grid;place-items:center;min-height:560px;}
.stage .glow{position:absolute;width:430px;height:430px;border-radius:50%;filter:blur(76px);opacity:.42;z-index:0;
  background:
    radial-gradient(circle at 30% 28%,var(--blue),transparent 60%),
    radial-gradient(circle at 72% 70%,var(--green),transparent 60%),
    radial-gradient(circle at 50% 92%,var(--red),transparent 60%);}
html:not(.theme-light) .stage .glow{opacity:.55;}
.phone{position:relative;z-index:2;width:288px;height:586px;border-radius:48px;background:var(--device-shell);
  padding:11px;box-shadow:var(--shadow-lg),0 4px 14px rgba(0,0,0,.18);transition:transform .6s var(--ease);}
.screen{width:100%;height:100%;border-radius:38px;overflow:hidden;position:relative;display:flex;flex-direction:column;
  background:linear-gradient(180deg,var(--screen-top),var(--screen-bot));}
.notch{position:absolute;top:11px;left:50%;transform:translateX(-50%);width:104px;height:26px;
  background:var(--device-shell);border-radius:0 0 17px 17px;z-index:5;}
.app-top{padding:36px 20px 8px;display:flex;align-items:center;justify-content:space-between;}
.app-top .greet{font-size:12px;color:var(--screen-ink-2);font-weight:600;letter-spacing:.01em;}
.app-top .name{font-size:19px;font-weight:800;letter-spacing:-.02em;margin-top:2px;color:var(--screen-ink);}
.app-top .avatar{width:34px;height:34px;border-radius:50%;
  background:conic-gradient(from 220deg,var(--red),var(--green),var(--blue),var(--red));}
.app-body{padding:6px 16px 14px;flex:1;overflow:hidden;}
.bl-card{background:var(--screen-top);border:1px solid var(--screen-line);border-radius:18px;padding:14px 14px 10px;
  box-shadow:0 6px 18px -14px rgba(0,0,0,.45);}
.bl-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px;}
.bl-head .t{font-size:13px;font-weight:800;letter-spacing:-.01em;color:var(--screen-ink);}
.bl-head .tag{font-size:10px;font-weight:800;color:#fff;background:var(--green);padding:3px 9px;border-radius:999px;}
.bl-sub{font-size:10.5px;color:var(--screen-ink-2);font-weight:500;margin-bottom:8px;}
.spark{width:100%;height:62px;display:block;}
.mchips{display:flex;gap:7px;margin-top:13px;}
.mchip{flex:1;border-radius:13px;padding:9px 9px;}
.mchip .lab{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;}
.mchip .val{font-size:13px;font-weight:800;margin-top:3px;letter-spacing:-.01em;}
.mchip.r{background:var(--red-tint);}  .mchip.r .lab{color:var(--red);}   .mchip.r .val{color:var(--red-ink);}
.mchip.g{background:var(--green-tint);}.mchip.g .lab{color:var(--green);} .mchip.g .val{color:var(--green-ink);}
.mchip.b{background:var(--blue-tint);} .mchip.b .lab{color:var(--blue);}  .mchip.b .val{color:var(--blue-ink);}
.mnote{margin-top:13px;background:var(--screen-bot);border:1px solid var(--screen-line);border-radius:14px;padding:11px 12px;}
.mnote .nh{display:flex;align-items:center;gap:7px;font-size:10.5px;font-weight:800;color:var(--screen-ink-2);}
.mnote .nh .d{width:7px;height:7px;border-radius:50%;background:var(--green);}
.mnote p{font-size:11.5px;color:var(--screen-ink);line-height:1.5;margin-top:5px;}
.mtab{display:flex;justify-content:space-around;align-items:center;padding:12px 0 16px;border-top:1px solid var(--screen-line);}
.mtab .ti{width:16px;height:16px;display:inline-block;background:var(--screen-ink-2);opacity:.5;}
.mtab .ti.act{opacity:1;}
.float{position:absolute;z-index:3;background:var(--paper-raised);border:1px solid var(--line);border-radius:14px;
  padding:10px 13px;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:9px;font-size:12.5px;font-weight:600;color:var(--ink);}
.float .d{width:9px;height:9px;border-radius:50%;flex:0 0 auto;}
.float.f1{top:48px;left:-10px;animation:drift 9s ease-in-out infinite;}
.float.f2{bottom:104px;right:-18px;animation:drift 11s ease-in-out infinite reverse;}
@keyframes drift{0%,100%{transform:translateY(0);}50%{transform:translateY(-9px);}}

/* ---------- Bands / sections ---------- */
.band{padding:100px 0;}
.band.tint{background:var(--tint);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.section-title{font-weight:800;font-size:clamp(30px,3.6vw,46px);line-height:1.08;letter-spacing:-.03em;color:var(--ink);}
.prose h2{font-weight:800;font-size:clamp(28px,3.2vw,42px);line-height:1.1;letter-spacing:-.028em;margin:18px 0 22px;color:var(--ink);}
.prose p{font-size:18px;color:var(--ink-soft);line-height:1.65;margin-bottom:18px;}
.prose p:last-child{margin-bottom:0;}

/* ---------- Film sections ---------- */
.filmband{background:var(--film-bg);color:#F3EDE2;position:relative;overflow:hidden;}
.filmband::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.6;
  background:
    radial-gradient(46% 56% at 82% 14%,rgba(188,68,55,.18),transparent 60%),
    radial-gradient(46% 56% at 14% 90%,rgba(77,104,204,.18),transparent 62%),
    radial-gradient(40% 50% at 50% 50%,rgba(0,137,57,.10),transparent 60%);}
.filmband > .wrap{position:relative;z-index:2;}
.vintro{text-align:center;max-width:680px;margin:0 auto 38px;}
.filmband .vintro .section-title{color:#FBF7EF;}
.filmband .vintro .lead{color:#CDC5B6;font-size:18px;line-height:1.6;margin-top:14px;}
.filmband .pill{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.16);color:#CDC5B6;}
.vframe{max-width:960px;margin:0 auto;border-radius:20px;overflow:hidden;
  box-shadow:0 50px 110px -36px rgba(0,0,0,.7);border:1px solid rgba(255,255,255,.08);background:#000;}
.vframe video{display:block;width:100%;height:auto;aspect-ratio:16/9;background:#000;}
.vcaption{text-align:center;color:#A39B8D;font-size:14px;margin-top:18px;}
.filmband .btn.ghost{color:#F3EDE2;border-color:rgba(255,255,255,.24);}
.filmband .btn.ghost:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.42);}

/* In-motion section uses tint band rather than full film treatment */
.motionband .vintro .section-title{color:var(--ink);}
.motionband .vintro .lead{color:var(--ink-soft);}
.motionband .vframe{box-shadow:var(--shadow-lg);border-color:var(--line);}

/* ---------- Photo band ---------- */
.photoband .pbframe{margin:0;border-radius:20px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-md);position:relative;}
.photoband .pbframe img{width:100%;height:auto;display:block;}
.photoband figcaption{font-size:14.5px;color:var(--ink-mute);text-align:center;margin-top:16px;}

/* ---------- Triad cards (Direction C, refined) ---------- */
.triad-head{max-width:720px;margin-bottom:46px;}
.triad-head h2{margin:16px 0 14px;}
.triad-head p{font-size:18px;color:var(--ink-soft);line-height:1.6;}
.triad{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;}
.tcard{position:relative;background:var(--paper-raised);border:1px solid var(--line);border-radius:22px;
  padding:30px 28px 32px;overflow:hidden;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease);}
.tcard::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;}
.tcard.r::before{background:var(--red);}
.tcard.g::before{background:var(--green);}
.tcard.b::before{background:var(--blue);}
.tcard.n::before{background:var(--neutral);}
.tcard:hover{transform:translateY(-4px);}
.tcard.r:hover{box-shadow:0 24px 50px -26px rgba(188,68,55,.4);border-color:color-mix(in srgb,var(--red) 36%,var(--line));}
.tcard.g:hover{box-shadow:0 24px 50px -26px rgba(0,137,57,.4);border-color:color-mix(in srgb,var(--green) 36%,var(--line));}
.tcard.b:hover{box-shadow:0 24px 50px -26px rgba(77,104,204,.4);border-color:color-mix(in srgb,var(--blue) 36%,var(--line));}
.tcard.n:hover{box-shadow:0 24px 50px -26px rgba(154,161,172,.45);border-color:var(--line-strong);}
.tcard .ic{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;margin-bottom:18px;}
.tcard.r .ic{background:var(--red-tint);color:var(--red);}
.tcard.g .ic{background:var(--green-tint);color:var(--green);}
.tcard.b .ic{background:var(--blue-tint);color:var(--blue);}
.tcard.n .ic{background:var(--tint);color:var(--ink-mute);}
.tcard .ic .tri{width:20px;height:20px;}
.tcard .kicker{font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;}
.tcard.r .kicker{color:var(--red-ink);}
.tcard.g .kicker{color:var(--green-ink);}
.tcard.b .kicker{color:var(--blue-ink);}
.tcard.n .kicker{color:var(--ink-mute);}
.tcard h3{font-size:22px;font-weight:800;letter-spacing:-.02em;margin:8px 0 0;color:var(--ink);}
.tcard p{font-size:15.5px;color:var(--ink-soft);margin-top:10px;line-height:1.6;}
.tcard.integ{grid-column:1 / -1;background:var(--ink);color:var(--paper-raised);border:none;}
html:not(.theme-light) .tcard.integ{background:#0B0907;}
.tcard.integ::before{background:linear-gradient(90deg,var(--red),var(--green),var(--blue));}
.integ-grid{display:grid;grid-template-columns:1fr auto;gap:30px;align-items:center;}
.tcard.integ .kicker{color:#CDC5B6;}
.tcard.integ h3{color:#FBF7EF;font-size:26px;}
.tcard.integ p{color:#CDC5B6;font-size:16px;max-width:600px;}
.tcard.integ .mini{width:118px;height:118px;flex:none;}
.tcard.integ .ic{display:none;}
.triad-cta{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap;}

/* ---------- Privacy ---------- */
.privacy{display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center;}
.privacy h2{font-weight:800;font-size:clamp(28px,3.2vw,42px);line-height:1.1;letter-spacing:-.028em;margin:18px 0 18px;color:var(--ink);}
.privacy > div > p{font-size:18px;color:var(--ink-soft);line-height:1.65;}
.plist{list-style:none;padding:0;margin:26px 0 0;display:grid;gap:14px;}
.plist li{display:flex;align-items:flex-start;gap:13px;font-size:16px;color:var(--ink-soft);line-height:1.55;}
.plist .check{flex:0 0 auto;width:24px;height:24px;border-radius:50%;display:grid;place-items:center;
  background:var(--green-tint);color:var(--green);font-size:13px;font-weight:800;margin-top:1px;}
.privacy-actions{margin-top:26px;display:flex;gap:14px;flex-wrap:wrap;}
.privacy .art{display:grid;place-items:center;}
.privacy .art svg{width:min(320px,80%);height:auto;
  filter:drop-shadow(0 30px 60px rgba(33,28,22,.18));animation:floaty 12s ease-in-out infinite;}
html:not(.theme-light) .privacy .art svg{filter:drop-shadow(0 30px 70px rgba(0,0,0,.6));}
@keyframes floaty{0%,100%{transform:translateY(0) rotate(0);}50%{transform:translateY(-12px) rotate(2deg);}}

/* ---------- Follow / social ---------- */
.fintro{max-width:640px;margin-bottom:38px;}
.fintro h2{font-weight:800;font-size:clamp(28px,3vw,40px);letter-spacing:-.025em;line-height:1.1;margin:16px 0 14px;color:var(--ink);}
.fintro p{font-size:18px;color:var(--ink-soft);line-height:1.6;}
.followgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.fchip{display:flex;align-items:center;gap:13px;background:var(--paper-raised);border:1px solid var(--line);
  border-radius:16px;padding:18px 20px;font-weight:600;font-size:16px;color:var(--ink);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease);}
.fchip:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--line-strong);}
.fchip svg{width:22px;height:22px;flex:0 0 auto;fill:var(--ink);}
.fchip .handle{margin-left:auto;font-size:13px;font-weight:500;color:var(--ink-mute);}

/* ---------- FAQ ---------- */
.faq{margin-top:14px;border-top:1px solid var(--line);}
.faq h3{font-size:19px;font-weight:700;letter-spacing:-.01em;color:var(--ink);
  padding:26px 0 10px;border-top:1px solid var(--line);}
.faq h3:first-child{border-top:none;}
.faq p{font-size:16.5px;color:var(--ink-soft);line-height:1.65;padding-bottom:8px;}
.faq a{color:var(--blue-ink);font-weight:600;}
.faq a:hover{text-decoration:underline;}

/* ---------- Waitlist ---------- */
.signup{max-width:720px;margin:0 auto;text-align:center;}
.signup h2{font-weight:800;font-size:clamp(28px,3.2vw,44px);letter-spacing:-.028em;line-height:1.08;margin:18px 0 16px;color:var(--ink);}
.signup > p{font-size:18px;color:var(--ink-soft);line-height:1.6;max-width:560px;margin:0 auto;}
form.js-waitlist{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;max-width:500px;margin:30px auto 0;}
form.js-waitlist input[type=email]{flex:1;min-width:230px;padding:14px 20px;border-radius:999px;
  border:1px solid var(--line-strong);background:var(--paper-raised);color:var(--ink);
  font-family:inherit;font-size:16px;outline:none;transition:border-color .25s var(--ease),box-shadow .25s var(--ease);}
form.js-waitlist input[type=email]::placeholder{color:var(--ink-mute);}
form.js-waitlist input[type=email]:focus{border-color:var(--blue);box-shadow:0 0 0 3px color-mix(in srgb,var(--blue) 18%,transparent);}
form.js-waitlist .ok{flex-basis:100%;color:var(--green-ink);font-weight:600;font-size:15px;margin-top:6px;display:none;}
form.js-waitlist .ok.show{display:block;}
.signup .note{font-size:14px;color:var(--ink-mute);margin-top:18px;}
.feedback-block{margin-top:36px;padding-top:28px;border-top:1px solid var(--line);}
.feedback-block p{color:var(--ink-soft);font-size:16px;margin-bottom:16px;}

/* Footer is single-sourced in styles.css now (the 6-col grid is the canonical, site-wide footer
   as of the 2026-06-28 mobile council; was previously duplicated here). */

/* ---------- Reveal motion ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .9s var(--ease),transform .9s var(--ease);}
.reveal.in{opacity:1;transform:none;}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:48px;padding:54px 0 72px;}
  .stage{min-height:0;order:2;}
  .triad{grid-template-columns:1fr;}
  .integ-grid{grid-template-columns:1fr;gap:22px;}
  .tcard.integ .mini{display:none;}
  .privacy{grid-template-columns:1fr;gap:36px;}
  .privacy .art{order:-1;}
  .followgrid{grid-template-columns:repeat(2,1fr);}
  .links{display:none;}
  .navtoggle{display:flex;}

  /* nav wraps to a new full-width row when the menu opens, so let the header grow
     (open-state only, so the closed bar keeps its compact 74/64px height) */
  #hd.nav-open .nav{height:auto;}
  /* mobile nav open state (driven by nav.js .nav-open on #hd) — IN-FLOW accordion panel.
     Must NOT be position:fixed: #hd carries a backdrop-filter (index.css:162), which makes
     the header the containing block for fixed descendants, collapsing the panel to the header
     height so only the first row shows. The panel wraps in-flow (order/flex-basis) and scrolls
     within the viewport instead. (Web mobile council 2026-06-28; Josh-approved.) */
  #hd.nav-open .links{display:flex;order:4;flex-basis:100%;flex-direction:column;align-items:stretch;gap:6px;
    margin:0;padding:18px 0 40px;max-height:calc(100vh - 96px);max-height:calc(100dvh - 96px);overflow-y:auto;
    -webkit-overflow-scrolling:touch;overscroll-behavior:contain;background:var(--paper);border-top:1px solid var(--line);}
  #hd.nav-open .links > a,#hd.nav-open .dd{padding:12px 4px;border-bottom:1px solid var(--line);}
  #hd.nav-open .dd{position:static;}
  #hd.nav-open .dd-t{width:100%;justify-content:space-between;font-size:17px;}
  #hd.nav-open .dd-m{position:static;transform:none;opacity:1;visibility:visible;pointer-events:auto;
    box-shadow:none;border:none;background:transparent;padding:6px 0 0;min-width:0;
    max-height:0;overflow:hidden;transition:max-height .3s var(--ease);}
  #hd.nav-open .dd.open .dd-m{max-height:420px;}
  #hd.nav-open .links > a{font-size:17px;}
  #hd.nav-open .themetoggle{align-self:flex-start;margin-top:8px;}
  #hd.nav-open .btn{margin-top:14px;justify-content:center;}
  body.nav-locked{overflow:hidden;}
}
@media (max-width:640px){
  .wrap{padding:0 22px;}
  body{font-size:16px;}
  .nav{height:64px;}
  .band{padding:68px 0;}
  .followgrid{grid-template-columns:1fr;}
  .hero-trust{gap:20px;}
  .float.f1{left:-2px;} .float.f2{right:-2px;}
  .tcard.integ h3{font-size:22px;}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;}
  html{scroll-behavior:auto;}
  .reveal{opacity:1;transform:none;transition:none;}
  .phone{transition:none;}
}
/* ---------- Ambient confetti (brand triangles) ---------- */
.orbs{position:fixed;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.conf{position:fixed;top:0;left:0;-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 87'%3E%3Cpath d='M50 8 L92 80 L8 80 Z' fill='white' stroke='white' stroke-width='13' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 87'%3E%3Cpath d='M50 8 L92 80 L8 80 Z' fill='white' stroke='white' stroke-width='13' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat;will-change:transform;transform:translateZ(0)}
.conf{opacity:.26!important}
html.theme-light .orbs{opacity:.72}
