/* Kensora marketing site — shared stylesheet.
   Created by Claude — 2026-06-01. Colors per ADR 0003 (canonical Tri-Wedge palette).
   Reskinned 2026-06-18 to the redesigned homepage design language
   (Direction A warm editorial calm-luxury + Direction C product precision).
   Light = warm paper. Dark (default, no .theme-light) = deep warm ink.
   Plus Jakarta Sans only. WCAG AA in both modes.
   LOCKED, unchanged: .tri / .tri-* glyph masks, .orbs / .conf confetti. */

/* Fonts are loaded via <link rel="preconnect"> + stylesheet in each page <head>
   (faster first paint than an @import here). */

:root{
  /* Brand constants (locked) */
  --blue:#4D68CC;   /* Reflect — mental */
  --green:#008939;  /* Regulate — body */
  --red:#BC4437;    /* Relate — social */
  --neutral:#9AA1AC;/* Integrate — synthesis */

  --radius:18px;
  --maxw:1080px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --serif:"Plus Jakarta Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --sans:"Plus Jakarta Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;

  /* DARK is the default (no .theme-light) — deep warm ink, cinematic.
     Light values are set under html.theme-light below. */
  --paper:#14110D;
  --paper-raised:#1C1813;
  --paper-deep:#0E0C09;
  --tint:#19150F;
  --ink:#F3EDE2;
  --ink-soft:#C9BFAE;
  --ink-mute:#9A8F7C;
  --line:#2E2820;
  --line-strong:#3A3329;
  /* legacy alias — many components reference --card; map to the raised paper */
  --card:#1C1813;

  /* readable triad accents (text-safe per mode) + faint tints */
  --red-ink:#F0A99E;   --red-tint:#2A0D09;
  --green-ink:#97CEA0; --green-tint:#041D0A;
  --blue-ink:#A7BCF5;  --blue-tint:#0E152E;

  --shadow-sm:0 1px 2px rgba(0,0,0,.5);
  --shadow-md:0 12px 40px rgba(0,0,0,.5);
  --shadow-lg:0 40px 90px -30px rgba(0,0,0,.7);
  --film-bg:#0A0806;
}

/* Auto day/night theme. Inline JS adds .theme-light during daylight hours. */
html.theme-light{
  --paper:#F7F3EC;
  --paper-raised:#FDFBF7;
  --paper-deep:#EFE8DC;
  --tint:#F1EBE0;
  --ink:#211C16;
  --ink-soft:#4F473C;
  --ink-mute:#766C5D;
  --line:#E4DBCC;
  --line-strong:#D4C9B6;
  --card:#FDFBF7;

  --red-ink:#97271D;   --red-tint:#FFEEEB;
  --green-ink:#006A1E; --green-tint:#EAF8EC;
  --blue-ink:#354BA7;  --blue-tint:#EDF3FF;

  --shadow-sm:0 1px 2px rgba(33,28,22,.08);
  --shadow-md:0 10px 34px rgba(33,28,22,.10);
  --shadow-lg:0 40px 90px -34px rgba(33,28,22,.32);
  --film-bg:#16120D;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;transition:background .6s var(--ease),color .6s var(--ease)}

/* Floating ambient orbs (Reflect blue / Regulate green / Relate red), faint, drifting */
main{position:relative;z-index:1}
/* ---------- Ambient confetti (brand triangles) — LOCKED, do not restyle ---------- */
.orbs{position:fixed;inset:0;z-index:0;overflow:hidden;pointer-events:none}
/* seven faint floating triangles: 2 blue, 2 green, 2 red, 1 white(dark)/black(light) */
/* confetti: small rounded brand triangles, positioned + animated by orbs.js.
   Rounded via an SVG mask (stroke-linejoin:round) so one shape serves all 3 colors;
   no per-element blur filter — that was the scroll-jank culprit on fixed layers. */
.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)}
html.theme-light .orbs{opacity:.6}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}
.narrow{max-width:760px}
a{color:inherit}
h1,h2,h3,h4{font-family:var(--serif);font-weight:800;letter-spacing:-.02em;line-height:1.12;margin:0;color:var(--ink)}
p{margin:0}
img,svg{max-width:100%}

/* ---------- header / nav ---------- */
header{position:sticky;top:0;z-index:30;
  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)}
header.scrolled{border-bottom-color:var(--line);background:color-mix(in srgb, var(--paper) 92%, transparent)}
/* tri-color gradient seam under the nav */
header::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)}
header.scrolled::after{opacity:.9;animation:seamShift 9s linear infinite}
@keyframes seamShift{to{background-position:200% 0}}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;min-height:74px;flex-wrap:wrap;padding-top:10px;padding-bottom:10px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--serif);font-size:21px;font-weight:700;letter-spacing:-.01em;text-decoration:none;color:var(--ink)}
.brand .brandmark{width:30px;height:30px;display:block}
.links{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.links a{text-decoration:none;font-size:15px;font-weight:500;color:var(--ink-soft);transition:color .3s var(--ease)}
.links a:hover{color:var(--ink)}
.links a.active{color:var(--ink);font-weight:600}
/* mobile hamburger (hidden on desktop) */
.navtoggle{display:none;place-items:center;width:44px;height:44px;border-radius:11px;border:1px solid var(--line);background:transparent;color:var(--ink);cursor:pointer;padding:0;transition:border-color .3s var(--ease)}
.navtoggle:hover{border-color:var(--ink-mute)}
.navtoggle svg{width:22px;height:22px;display:block}
/* Product dropdown */
.dd{position:relative;display:inline-flex}
.dd-t{display:inline-flex;align-items:center;gap:5px;background:none;border:0;padding:0;margin:0;font-family:var(--sans);font-size:15px;font-weight:500;color:var(--ink-soft);cursor:pointer;transition:color .3s var(--ease)}
.dd-t:hover,.dd.open .dd-t,.dd-t.active,.dd:hover .dd-t{color:var(--ink)}
.dd-t.active{font-weight:600}
.dd-t .caret{width:15px;height:15px;transition:transform .3s var(--ease)}
.dd.open .dd-t .caret,.dd:hover .dd-t .caret{transform:rotate(180deg)}
.dd-m{position:absolute;top:calc(100% + 14px);left:0;min-width:220px;background:var(--paper-raised);border:1px solid var(--line);border-radius:16px;padding:10px;display:none;flex-direction:column;gap:2px;box-shadow:var(--shadow-md)}
.dd-m::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px}
.dd:hover .dd-m,.dd.open .dd-m{display:flex}
.dd-m a{padding:9px 13px;border-radius:10px;font-size:14.5px;font-weight:500;color:var(--ink-soft);white-space:nowrap;transition:background .2s var(--ease),color .2s var(--ease)}
.dd-m a:hover,.dd-m a.active{background:var(--tint);color:var(--ink)}
.dd-sep{height:1px;background:var(--line);margin:8px 6px}
.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;vertical-align:1px}
.dd-m a.dd-all{color:var(--ink);font-weight:600}
.dd-m a .tri{margin-right:10px;width:13px;height:13px;flex:0 0 auto}
.dd-m a{display:flex;align-items:center}
.nav-login{font-size:15px;font-weight:500;color:var(--ink-soft);text-decoration:none;transition:color .3s var(--ease)}
.nav-login:hover,.nav-login.active{color:var(--ink)}
/* Triad cross-link row (area pages) */
.tcross{display:flex;flex-wrap:wrap;gap:12px}
.tcross a,.tcross-cur{display:inline-flex;align-items:center;gap:9px;padding:11px 18px;border:1px solid var(--line);border-radius:999px;font-size:15px;font-weight:500;text-decoration:none;color:var(--ink-soft);background:var(--paper-raised);transition:color .25s var(--ease),border-color .25s var(--ease),box-shadow .25s var(--ease),transform .25s var(--ease)}
.tcross a:hover{color:var(--ink);border-color:var(--line-strong);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.tcross-cur{color:var(--ink);font-weight:600;background:var(--tint);border-color:var(--line-strong)}
.themetoggle{display:inline-grid;place-items:center;width:40px;height:40px;border-radius:50%;border:1px solid var(--line);background:transparent;color:var(--ink-soft);cursor:pointer;padding:0;transition:color .3s var(--ease),border-color .3s var(--ease)}
.themetoggle:hover{color:var(--ink);border-color:var(--ink-mute)}
.themetoggle svg{width:18px;height:18px;display:block}
.themetoggle .moon{display:none}
.themetoggle .sun{display:block}
html.theme-light .themetoggle .sun{display:block}
html.theme-light .themetoggle .moon{display:none}
html:not(.theme-light) .themetoggle .moon{display:block}
html:not(.theme-light) .themetoggle .sun{display:none}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--sans);font-weight:600;font-size:15px;line-height:1;cursor:pointer;padding:13px 24px;border-radius:999px;border:1px solid var(--ink);background:var(--ink);color:var(--paper-raised);text-decoration:none;box-shadow:var(--shadow-sm);white-space:nowrap;transition:transform .4s var(--ease),background .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease)}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn .arr{transition:transform .4s var(--ease)}
.btn:hover .arr{transform:translateX(3px)}
.btn.big{font-size:16px;padding:15px 28px}
.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)}
/* in dark mode the ink fill is light → keep label dark for contrast on the pill */
html:not(.theme-light) .btn{background:var(--ink);color:#14110D;border-color:var(--ink)}
html:not(.theme-light) .btn.ghost{background:transparent;color:var(--ink);border-color:var(--line-strong)}
html:not(.theme-light) .btn.ghost:hover{background:var(--paper-raised);border-color:var(--ink-mute)}
/* The nav CTA pill keeps its own label color — never the active-nav-link color. */
.links a.btn,.links a.btn.active{color:var(--paper-raised)}
html:not(.theme-light) .links a.btn,html:not(.theme-light) .links a.btn.active{color:#14110D}
.links a.btn.ghost{color:var(--ink)}
html.theme-light .links a.btn,html.theme-light .links a.btn.active{color:var(--paper-raised)}
html.theme-light .links a.btn.ghost{color:var(--ink)}

/* ---------- generic sections ---------- */
.band{padding:100px 0}
.band.tint{background:var(--tint);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
html.theme-light .band.tint{background:var(--tint)}
.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);margin-bottom:18px}
.pill .seed{width:7px;height:7px;border-radius:50%;background:conic-gradient(from 90deg,var(--red),var(--green),var(--blue),var(--red))}
/* eyebrow (label above headings) */
.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;margin-bottom:20px}
.eyebrow .seed{width:7px;height:7px;border-radius:50%;background:conic-gradient(from 90deg,var(--red),var(--green),var(--blue),var(--red))}
/* area-name colors: Reflect blue / Regulate green / Relate red / Integrate ink */
.t-reflect{color:var(--blue-ink)} .t-regulate{color:var(--green-ink)} .t-relate{color:var(--red-ink)} .t-integrate{color:var(--ink)}
.lead,.lede{font-size:clamp(18px,2.5vw,21px);line-height:1.6;color:var(--ink-soft)}
.prose p{font-size:18px;color:var(--ink-soft);line-height:1.65;margin-top:18px}
.prose p:first-child{margin-top:0}
.prose h2{font-size:clamp(28px,3.2vw,42px);line-height:1.1;letter-spacing:-.028em;margin-top:8px}
.prose h3{font-size:21px;margin-top:34px;color:var(--ink)}
.section-title{font-weight:800;font-size:clamp(30px,3.6vw,46px);line-height:1.08;letter-spacing:-.03em;max-width:720px;color:var(--ink)}
/* features.html supplemental labels (kept here so they pick up the warm palette) */
.fsub{font-size:12.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);opacity:.78;margin:22px 0 0}
.ftag{font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-mute);border:1px solid var(--line);border-radius:999px;padding:2px 7px;margin-left:7px;vertical-align:1px;white-space:nowrap}

/* ---------- hero (home) ---------- */
.hero{position:relative;overflow:hidden;padding:72px 0 64px}
.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{display:grid;grid-template-columns:1.02fr .98fr;gap:52px;align-items:center;position:relative;z-index:2}
.hero-copy{text-align:left}
.hero h1{font-weight:800;font-size:clamp(40px,6vw,72px);line-height:1.02;letter-spacing:-.035em;margin-bottom:24px}
.hero h1 .grad{background:linear-gradient(105deg,var(--red),var(--green) 52%,var(--blue));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero .lede{font-size:clamp(17.5px,2.4vw,19.5px);line-height:1.6;color:var(--ink-soft);margin:0 0 36px;max-width:600px}
.cta,.hero-actions{display:flex;align-items:center;gap:16px;justify-content:flex-start;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)}
.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}

/* eclipse photo + overlaid fold/unfold mark */
.heroart{position:relative;margin:0;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;box-shadow:var(--shadow-lg);border:1px solid var(--line)}
.heroart img{width:100%;height:100%;object-fit:cover;display:block}
/* hero holds a 16:9 film instead of the 4:3 photo */
.heroart.hasvideo{aspect-ratio:16/9;background:#000}
.heroart video{width:100%;height:100%;object-fit:cover;display:block}
/* Logo animation, centered on the photo. Canvas scrubs 120 alpha frames to scroll. */
.heromark,.heromark-poster{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:54%;height:auto;aspect-ratio:1/1;filter:drop-shadow(0 8px 24px rgba(0,0,0,.55))}
/* opacity-only fade — must NOT animate transform, or it overrides the centering translate */
.heromark{animation:heromarkin .9s ease both}
@keyframes heromarkin{from{opacity:0}to{opacity:1}}
.heromark-poster{display:none}            /* fallback only */
.no-js .heromark{display:none}
.no-js .heromark-poster{display:block}
@media (prefers-reduced-motion: reduce){.heromark{animation:none}}

@media (max-width:760px){
  .hero-grid{grid-template-columns:1fr;gap:30px;text-align:center}
  .hero-copy{text-align:center}
  .hero .lede{margin-left:auto;margin-right:auto}
  .cta,.hero-actions{justify-content:center}
  .hero-trust{justify-content:center}
  .heroart{max-width:480px;margin:0 auto;width:100%}
}

/* vertical (9:16) video frame — e.g. the 15s ad on the early-access page */
.vframe-tall{max-width:340px;margin:24px auto 0;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-lg);aspect-ratio:9/16;background:#000}
.vframe-tall video{width:100%;height:100%;display:block;object-fit:cover}

/* founder photo (about page) */
.founder-photo{margin:6px auto 30px;max-width:460px}
.founder-photo img{width:100%;height:auto;display:block;border-radius:var(--radius);border:1px solid var(--line);box-shadow:var(--shadow-md)}
.founder-photo figcaption{margin-top:10px;font-size:14px;color:var(--ink-mute);text-align:center}

/* homepage landscape breather band */
.photoband{padding:18px 0}
.pbframe{position:relative;margin:0;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-md);aspect-ratio:21/9;max-height:440px}
.pbframe img{width:100%;height:100%;object-fit:cover;display:block}
.pbframe figcaption{position:absolute;left:0;right:0;bottom:0;padding:54px 30px 22px;color:#fff;font-family:var(--serif);font-weight:700;font-size:clamp(16px,2.2vw,22px);letter-spacing:-.01em;background:linear-gradient(180deg,transparent,rgba(0,0,0,.6))}
@media (max-width:760px){.pbframe{aspect-ratio:4/3}.pbframe figcaption{font-size:17px;padding:40px 20px 18px}}

/* page hero (inner pages) */
.phero{padding:72px 0 8px;text-align:center}
.phero h1{font-weight:800;font-size:clamp(34px,5.4vw,58px);line-height:1.03;letter-spacing:-.035em;margin-bottom:18px}
.phero .lede{font-size:clamp(17px,2.3vw,20px);line-height:1.6;color:var(--ink-soft);max-width:660px;margin:0 auto}
.phero .pill,.phero .eyebrow{margin-bottom:20px}

/* ---------- hero mark (locked Tri-Wedge) ---------- */
.mark{width:104px;height:104px;margin:0 auto 26px;display:block;overflow:visible;animation:markin 1s ease both}
@keyframes markin{from{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:none}}
.markstatic{width:120px;height:120px;display:block;margin:0 auto}

/* ---------- pillar cards ---------- */
.pillars{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:42px}
.pcard{background:var(--paper-raised);border:1px solid var(--line);border-radius:22px;padding:30px 28px;position:relative;overflow:hidden;transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease)}
.pcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.pcard .tag{display:inline-flex;align-items:center;gap:9px;font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;margin-bottom:14px}
.dot{width:12px;height:12px;border-radius:50%;display:inline-block}
/* directional area triangles — rounded, matching the in-app glyphs (K116):
   Reflect ◀ left, Regulate ▶ right, Relate △ up, Integrate ▽ down. The rounded
   apex-up triangle (tri.svg) is masked with currentColor (inline data-URI so it works on file:// too);
   direction = rotation. LOCKED — do not restyle. */
.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)}
.pcard h3{font-size:22px;font-weight:800;letter-spacing:-.02em;margin-bottom:9px}
.pcard p{color:var(--ink-soft);font-size:15.5px;line-height:1.6}
.pcard .edge{position:absolute;left:0;top:0;bottom:0;width:4px}
.c-blue .edge{background:var(--blue)} .c-blue .dot{background:var(--blue)} .c-blue .tag{color:var(--blue-ink)}
.c-green .edge{background:var(--green)} .c-green .dot{background:var(--green)} .c-green .tag{color:var(--green-ink)}
.c-red .edge{background:var(--red)} .c-red .dot{background:var(--red)} .c-red .tag{color:var(--red-ink)}
.c-neutral .edge{background:var(--neutral)} .c-neutral .dot{background:var(--neutral)} .c-neutral .tag{color:var(--ink-mute)}
.c-blue:hover{border-color:color-mix(in srgb,var(--blue) 36%,var(--line));box-shadow:0 24px 50px -26px rgba(77,104,204,.4)}
.c-green:hover{border-color:color-mix(in srgb,var(--green) 36%,var(--line));box-shadow:0 24px 50px -26px rgba(0,137,57,.4)}
.c-red:hover{border-color:color-mix(in srgb,var(--red) 36%,var(--line));box-shadow:0 24px 50px -26px rgba(188,68,55,.4)}
.c-neutral:hover{border-color:var(--line-strong)}

/* ---------- triad detail rows ---------- */
.triadrow{display:grid;grid-template-columns:64px 1fr;gap:22px;align-items:start;padding:30px 0;border-top:1px solid var(--line)}
.triadrow .chip{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;background:var(--tint)}
.triadrow .chip span{width:20px;height:20px;border-radius:50%}
.triadrow h3{font-size:22px;font-weight:800;letter-spacing:-.02em;margin-bottom:6px}
.triadrow p{color:var(--ink-soft);font-size:16px;margin-top:8px;line-height:1.6}
.tagrow{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.tagrow span{font-size:13px;color:var(--ink-soft);background:var(--paper-raised);border:1px solid var(--line);border-radius:999px;padding:5px 12px}

/* ---------- feature blocks ---------- */
.fblock{padding:40px 0;border-top:1px solid var(--line)}
.fblock .tag{display:inline-flex;align-items:center;gap:9px;font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;margin-bottom:12px}
.fblock h3{font-size:clamp(22px,3vw,28px);font-weight:800;letter-spacing:-.02em;margin-bottom:10px}
.fblock .q{color:var(--ink-soft);font-size:16.5px;margin-top:14px;line-height:1.6}
.flist{list-style:none;padding:0;margin:18px 0 0;display:grid;grid-template-columns:repeat(2,1fr);gap:10px 22px}
.flist li{display:flex;gap:10px;font-size:15.5px;color:var(--ink-soft);line-height:1.55}
.flist li::before{content:"";flex:0 0 auto;width:8px;height:8px;border-radius:50%;background:currentColor;margin-top:9px;opacity:.5}

/* ---------- callout / quote ---------- */
.quote{font-family:var(--serif);font-weight:700;font-size:clamp(22px,3.4vw,30px);line-height:1.3;letter-spacing:-.02em;color:var(--ink);max-width:760px;margin:14px 0}
.callout{background:var(--paper-raised);border:1px solid var(--line);border-radius:var(--radius);padding:30px 28px;margin-top:24px;box-shadow:var(--shadow-sm)}
.callout p{font-size:17px;color:var(--ink-soft);margin-top:10px;line-height:1.6}

/* ---------- placeholder (for Josh to fill) ---------- */
.placeholder{border:1px dashed var(--line-strong);background:color-mix(in srgb,var(--neutral) 6%,transparent);border-radius:var(--radius);padding:22px 24px;color:var(--ink-soft);font-size:15.5px}
.placeholder p{margin-top:10px;font-size:15.5px}
.placeholder b{color:var(--ink)}
html.theme-light .placeholder{border-color:#c9b48a;background:#fdf8ee;color:#6b5a32}
html.theme-light .placeholder b{color:#7a6320}

/* draft / review banner (legal pages, pre-approval) */
.draftnote{background:var(--red-tint);border:1px solid color-mix(in srgb,var(--red) 30%,transparent);border-radius:var(--radius);padding:16px 20px;font-size:14.5px;color:var(--ink-soft);margin-bottom:8px}
.draftnote b{color:var(--red-ink)}

/* FAQ / definition rows */
.faqitem{border-top:1px solid var(--line);padding:24px 0}
.faqitem:first-of-type{border-top:none}
.faqitem h3{font-size:19px;font-weight:700;letter-spacing:-.01em;margin-bottom:6px;color:var(--ink)}
.faqitem p{color:var(--ink-soft);font-size:16.5px;margin-top:8px;line-height:1.65}
/* FAQ accordion-style (homepage + blog) */
.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);margin:0}
.faq h3:first-child{border-top:none;margin-top:6px}
.faq p{color:var(--ink-soft);font-size:16.5px;line-height:1.65;padding-bottom:8px;margin:0}
.faq a{color:var(--blue-ink);font-weight:600}
.faq a:hover{text-decoration:underline}

/* legal long-form: tighter prose, section anchors */
.legal h2{font-size:clamp(20px,2.6vw,26px);font-weight:800;letter-spacing:-.02em;margin-top:40px}
.legal h3{font-size:18px;margin-top:26px;color:var(--ink)}
.legal p,.legal li{font-size:16.5px;color:var(--ink-soft);margin-top:12px;line-height:1.65}
.legal ul{margin-top:12px;padding-left:22px}
.legal .updated{color:var(--ink-mute);font-size:14px;margin-top:8px}

/* ---------- privacy ---------- */
.privacy{display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center}
.privacy h2{font-size:clamp(28px,3.2vw,42px);font-weight:800;line-height:1.1;letter-spacing:-.028em;margin-bottom:18px}
.privacy p{color:var(--ink-soft);font-size:18px;margin-top:12px;line-height:1.65}
.plist{list-style:none;padding:0;margin:26px 0 0;display:grid;gap:14px}
.plist li{display:flex;gap:13px;align-items:flex-start;font-size:16px;color:var(--ink-soft);line-height:1.55}
.plist .check{flex:0 0 auto;width:24px;height:24px;border-radius:50%;background:var(--green-tint);color:var(--green);display:grid;place-items:center;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)}}

/* ---------- waitlist + feedback ---------- */
.signup{text-align:center;max-width:720px;margin:0 auto}
.signup h2{font-size:clamp(28px,3.2vw,44px);font-weight:800;letter-spacing:-.028em;line-height:1.08;margin-bottom:16px}
.signup p{color:var(--ink-soft);font-size:18px;margin-bottom:28px;line-height:1.6}
form{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
input[type=email]{font-family:var(--sans);font-size:15.5px;padding:14px 20px;border-radius:999px;border:1px solid var(--line-strong);background:var(--paper-raised);color:var(--ink);min-width:280px;outline:none;transition:border-color .25s var(--ease),box-shadow .25s var(--ease)}
input[type=email]::placeholder{color:var(--ink-mute)}
input[type=email]:focus{border-color:var(--blue);box-shadow:0 0 0 3px color-mix(in srgb,var(--blue) 18%,transparent)}
.note{font-size:14px;color:var(--ink-mute);margin-top:16px}
.ok{display:none;margin-top:18px;color:var(--green-ink);font-weight:600}
.ok.show{display:block}
.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 early-access band — present on every page ("visible throughout") */
.footjoin{display:flex;align-items:center;justify-content:space-between;gap:24px 48px;flex-wrap:wrap;padding:8px 0 48px;margin-bottom:36px;border-bottom:1px solid var(--line)}
.footjoin-copy{max-width:460px}
.footjoin .pill{margin-bottom:12px}
.footjoin h2{font-size:clamp(24px,2.6vw,34px);font-weight:800;letter-spacing:-.025em;line-height:1.1;margin-bottom:10px}
.footjoin p{color:var(--ink-soft);font-size:16px;margin:0;line-height:1.6}
.footform{flex:1 1 300px;justify-content:flex-start}
.footform input[type=email]{flex:1 1 auto;min-width:0}
.footform .ok{flex-basis:100%;margin-top:4px;text-align:left}
@media (max-width:760px){.footjoin{display:block}.footjoin-copy{margin-bottom:20px}}

/* ---------- footer ---------- */
footer{background:var(--paper-deep);border-top:1px solid var(--line);padding:48px 0;margin-top:24px}
.foot{display:flex;justify-content:space-between;align-items:flex-start;gap:36px;flex-wrap:wrap;color:var(--ink-mute);font-size:14px}
.foot .brand{font-size:19px;color:var(--ink);margin-bottom:8px}
.foot a{color:var(--ink-soft);text-decoration:none;transition:color .25s var(--ease)}
.foot a:hover{color:var(--ink)}
.footcol{display:grid;gap:9px}
.footcol a{font-size:14.5px}
.footcol strong{color:var(--ink);font-size:14px;font-weight:700;letter-spacing:.02em}
.social{display:flex;gap:12px;align-items:center;margin-top:10px;flex-wrap:wrap}
.social a{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:999px;border:1px solid var(--line);color:var(--ink-mute);transition:transform .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease)}
.social a:hover{color:var(--ink);border-color:var(--ink-mute);transform:translateY(-2px)}
.social svg{width:18px;height:18px;fill:currentColor;display:block}

/* ---------- follow band ---------- */
.followband{text-align:center}
.followband .fintro{max-width:560px;margin:0 auto 28px}
.followband .fintro p{color:var(--ink-soft);font-size:18px;line-height:1.6}
.fintro h2{font-size:clamp(28px,3vw,40px);font-weight:800;letter-spacing:-.025em;line-height:1.1;margin:0 0 14px;color:var(--ink)}
.followgrid{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;max-width:780px;margin:0 auto}
.fchip{display:inline-flex;align-items:center;gap:11px;padding:14px 20px;border-radius:16px;border:1px solid var(--line);background:var(--paper-raised);color:var(--ink);text-decoration:none;font-weight:600;font-size:15px;transition:transform .3s var(--ease),border-color .3s var(--ease),box-shadow .3s var(--ease)}
.fchip:hover{transform:translateY(-3px);border-color:var(--line-strong);box-shadow:var(--shadow-md)}
.fchip svg{width:20px;height:20px;fill:currentColor;display:block}
.fchip .handle{color:var(--ink-mute);font-weight:500;font-size:13px}
@media (max-width:520px){.fchip{padding:12px 16px}.fchip .handle{display:none}}

/* ---------- featured video (home) ---------- */
.videoband{text-align:center}
.videoband .vintro{max-width:660px;margin:0 auto 30px}
.vintro .lead{color:var(--ink-soft);font-size:18px;line-height:1.6;margin-top:14px}
.vframe{position:relative;max-width:920px;margin:0 auto;border-radius:20px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-lg);background:#000;aspect-ratio:16/9}
.vframe video{display:block;width:100%;height:100%;object-fit:cover}
.vcaption{font-size:14px;color:var(--ink-mute);margin-top:16px}

/* ---------- onboarding walkthrough ---------- */
.obgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px 26px;margin-top:44px}
.obcard{display:flex;flex-direction:column}
.obshot{position:relative;border-radius:20px;overflow:hidden;border:1px solid var(--line);background:var(--paper-raised);box-shadow:var(--shadow-md);aspect-ratio:768/1376}
.obshot img{display:block;width:100%;height:100%;object-fit:cover}
.obstep{position:absolute;top:12px;left:12px;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-size:13px;font-weight:700;color:#fff;background:rgba(8,9,11,.55);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.18)}
.obcard h3{font-size:19px;font-weight:800;letter-spacing:-.01em;margin:18px 0 6px}
.obcard p{color:var(--ink-soft);font-size:15px;line-height:1.55}
.obnote{max-width:680px;margin:40px auto 0;text-align:center;font-size:14px;color:var(--ink-mute)}

/* ---------- motion + responsive ---------- */
.rise{animation:rise .8s cubic-bezier(.2,.7,.2,1) both}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (max-width:900px){
  .obgrid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:760px){
  .pillars{grid-template-columns:1fr}
  .obgrid{grid-template-columns:repeat(2,1fr);gap:22px 16px}
  .privacy{grid-template-columns:1fr;gap:36px}
  .privacy .art{order:-1}
  .flist{grid-template-columns:1fr}
  .band{padding:68px 0}
  /* mobile nav: hamburger opens a full-height scrollable panel;
     top-level rows expand into sub-menus (Apple-style accordions) */
  .navtoggle{display:inline-grid}
  .links{display:none;order:4;flex-basis:100%;flex-direction:column;flex-wrap:nowrap;align-items:stretch;gap:0;padding:8px 0 32px;max-height:calc(100vh - 96px);max-height:calc(100dvh - 96px);overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;background:var(--paper)}
  header.nav-open .links{display:flex}
  .links>*{flex-shrink:0} /* children must overflow (scroll), not shrink to fit */
  header.nav-open{background:color-mix(in srgb,var(--paper) 97%,transparent)}
  body.nav-locked{overflow:hidden}
  body.nav-locked .sticky-cta{display:none}
  .dd{width:100%;flex-direction:column;align-items:stretch}
  .dd-t{font-size:17px;width:100%;justify-content:space-between;padding:14px 2px;border-bottom:1px solid var(--line)}
  .dd-t .caret{width:16px;height:16px}
  .dd:hover .dd-m,.dd .dd-m{display:none}
  .dd.open .dd-m{display:flex;position:static;border:0;border-radius:0;box-shadow:none;background:none;padding:2px 0 10px 14px;min-width:0}
  .dd-m::before{display:none}
  .dd-m a{font-size:16px;padding:11px 12px;white-space:normal}
  .links>a{font-size:17px;padding:14px 2px}
  .links>a:not(.btn){border-bottom:1px solid var(--line)}
  .links>.btn{margin-top:18px;padding:12px 22px;align-self:flex-start}
  .links>.themetoggle{margin-top:14px}
}
@media (max-width:640px){
  .wrap{padding:0 22px}
  body{font-size:16px}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important;scroll-behavior:auto}.reveal{opacity:1;transform:none;transition:none}}

/* ---------- coming-soon / status badge ---------- */
.soon{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute);border:1px solid var(--line);border-radius:999px;padding:6px 14px;background:var(--paper-raised)}
.soon::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--neutral)}
.soon.live{color:var(--green-ink)}
.soon.live::before{background:var(--green)}

/* visual placeholder for product imagery / concept renders */
.pvisual{display:grid;place-items:center;border:1px dashed var(--line-strong);border-radius:24px;background:radial-gradient(circle at 50% 0%,color-mix(in srgb,var(--neutral) 8%,transparent),transparent 70%);color:var(--ink-mute);font-size:14px;text-align:center;padding:24px}

/* ---------- product lineup (products.html) ---------- */
.lineup{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:40px}
.ptile{display:flex;flex-direction:column;align-items:center;text-align:center;padding:44px 30px 38px;border:1px solid var(--line);border-radius:24px;background:var(--paper-raised);box-shadow:var(--shadow-sm);transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease)}
.ptile:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--line-strong)}
.ptile h2{font-size:clamp(25px,3.2vw,32px);font-weight:800;letter-spacing:-.02em;margin-bottom:8px}
.ptile p{color:var(--ink-soft);font-size:16.5px;max-width:430px;margin:0 auto;line-height:1.6}
.ptile .pvisual{width:100%;max-width:360px;aspect-ratio:4/3;margin:4px auto 22px}
.ptile .pcta{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:24px}
.ptile .pcta a{font-size:15px}
@media (max-width:760px){.lineup{grid-template-columns:1fr}}

/* ---------- hardware concept page ---------- */
.hwhero{text-align:center;padding:70px 0 24px}
.hwhero h1{font-weight:800;font-size:clamp(34px,6vw,62px);line-height:1.02;letter-spacing:-.035em;margin-bottom:16px}
.hwhero .pvisual{max-width:620px;aspect-ratio:16/9;margin:32px auto 0}
.privacy .pvisual{aspect-ratio:4/3}

/* ---------- login / account (login.html) ---------- */
.authwrap{min-height:60vh;display:grid;place-items:center;padding:54px 0}
.authcard{width:100%;max-width:420px;border:1px solid var(--line);border-radius:24px;background:var(--paper-raised);padding:38px 32px;text-align:center;box-shadow:var(--shadow-md)}
.authcard .brandmark{width:46px;height:46px;margin:0 auto 14px;display:block}
.authcard h1{font-size:26px;font-weight:800;letter-spacing:-.02em;margin-bottom:6px}
.authcard .sub{color:var(--ink-soft);font-size:15.5px}
.authform{display:grid;gap:13px;text-align:left;margin-top:22px;opacity:.5;pointer-events:none}
.authform label{font-size:13px;color:var(--ink-mute);display:block;margin-bottom:5px}
.authform input{width:100%;padding:12px 14px;border-radius:12px;border:1px solid var(--line-strong);background:var(--paper);color:var(--ink);font-size:15px;font-family:var(--sans)}
.authbtn{width:100%;justify-content:center;opacity:.5;pointer-events:none}
.authsep{display:flex;align-items:center;gap:12px;color:var(--ink-mute);font-size:13px;margin:16px 0}
.authsep::before,.authsep::after{content:"";flex:1;height:1px;background:var(--line)}

/* ---------- accessibility: skip link + focus ---------- */
.skip{position:absolute;left:-9999px;top:0;z-index:100;background:var(--ink);color:var(--paper-raised);padding:12px 18px;border-radius:0 0 10px 0;font-weight:600;font-size:14px;text-decoration:none}
.skip:focus{left:0}
:focus-visible{outline:2px solid var(--blue);outline-offset:3px;border-radius:6px}
.dd-m a:focus-visible,.links a:focus-visible{outline-offset:-2px}

/* hide the offscreen logo defs holder */
.svgdefs{position:absolute;width:0;height:0;overflow:hidden}

/* ---------- sticky mobile CTA ---------- */
.sticky-cta{position:fixed;left:50%;bottom:18px;transform:translateX(-50%);z-index:40;opacity:0;visibility:hidden;transition:opacity .25s ease,visibility .25s ease;box-shadow:var(--shadow-md)}
.sticky-cta.show{opacity:1;visibility:visible}
@media (min-width:761px){.sticky-cta{display:none!important}}
@media (prefers-reduced-motion:reduce){.sticky-cta{transition:none}}

/* ---------- contact form (contact.html) ---------- */
.contactform{display:grid;gap:16px;max-width:560px;text-align:left}
.contactform .field{display:grid;gap:6px}
.contactform label{font-size:14px;color:var(--ink-soft)}
.contactform input,.contactform select,.contactform textarea{width:100%;padding:12px 16px;border-radius:14px;border:1px solid var(--line-strong);background:var(--paper-raised);color:var(--ink);font-size:15px;font-family:var(--sans);outline:none;transition:border-color .25s var(--ease),box-shadow .25s var(--ease)}
.contactform textarea{resize:vertical;min-height:130px;line-height:1.55}
.contactform input:focus,.contactform select:focus,.contactform textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px color-mix(in srgb,var(--blue) 18%,transparent)}
.contactform .btn{justify-self:start}

/* ---------- real imagery (web/img) ---------- */
.shot{display:block;width:100%;height:auto;border-radius:24px;border:1px solid var(--line);box-shadow:var(--shadow-md)}
.hwhero .shot{max-width:620px;margin:32px auto 0}
.area-banner{max-width:760px;margin:6px auto 0}
.ptile .shot{max-width:360px;margin:4px auto 22px;aspect-ratio:4/3;object-fit:cover}

/* ---------- blog hub + article (added 2026-06-16) ---------- */
.postlist{list-style:none;margin:0;padding:0;display:grid;gap:20px;grid-template-columns:1fr}
@media(min-width:760px){.postlist{grid-template-columns:1fr 1fr}}
.postcard{background:var(--paper-raised);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease)}
.postcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--line-strong)}
.postcard a{display:block;padding:28px 26px;text-decoration:none;color:inherit}
.postcard h2{font-size:21px;font-weight:800;letter-spacing:-.01em;line-height:1.25;margin:12px 0 10px}
.postcard p{color:var(--ink-soft);font-size:15.5px;margin:0;line-height:1.6}
.postcard .readmore{display:inline-block;margin-top:16px;font-weight:600;font-size:14.5px;color:var(--blue-ink)}
.article{max-width:720px;margin:0 auto}
.article .meta{color:var(--ink-mute);font-size:14px;margin:6px 0 0}
.article h2{font-size:25px;font-weight:800;letter-spacing:-.02em;margin:38px 0 12px}
.article h3{font-size:19px;margin:28px 0 8px}
.article p{font-size:17px;line-height:1.7;margin:0 0 18px;color:var(--ink)}
.article ul{font-size:17px;line-height:1.7;color:var(--ink);padding-left:22px;margin:0 0 18px}
.article li{margin-bottom:8px}
.article .note{font-size:14.5px;color:var(--ink-soft);border-left:3px solid var(--line-strong);padding:4px 0 4px 16px;margin:24px 0}
.article .endcta{margin-top:40px;padding-top:28px;border-top:1px solid var(--line)}
.crumbs{font-size:13.5px;color:var(--ink-mute);margin-bottom:8px}
.crumbs a{color:var(--ink-soft);text-decoration:none}
.crumbs a:hover{color:var(--ink)}
