@import url("https://fonts.googleapis.com/css2?family=Hanken+Grotesk:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;700&display=swap");

/* ============================================================================
   Arawase — shared design system (buildless)
   Apple-grade, "sectioned": clean off-white body + cinematic near-black bands.
   One file, linked from every page. Defines:
     1. Design tokens (light surfaces) + legacy aliases (--panel/--accent/…)
     2. Base element styles (body, headings, buttons, inputs, tables)
     3. Legacy component classes (.wrap/.card/.btn/.nav/.stage/…) so app pages
        migrate by swapping their inline <style> for one <link> — JS untouched.
     4. New .aw-* components for the marketing/landing rebuild.
     5. A .aw-dark scope that inverts tokens for the cinematic bands.
   ========================================================================== */

:root{
  /* — Surfaces (light primary, Apple off-white) — */
  --bg:#fbfbfd;
  --surface:#ffffff;
  --surface-2:#f5f5f7;
  --ink:#1d1d1f;
  --ink-2:#515154;
  --muted:#86868b;
  --line:rgba(0,0,0,.09);
  --line-2:rgba(0,0,0,.15);

  /* — Cinematic dark band — */
  --d-bg:#08080a;
  --d-surface:#141416;
  --d-surface-2:#1e1e22;
  --d-ink:#f5f5f7;
  --d-ink-2:#a1a1a6;
  --d-line:rgba(255,255,255,.12);
  --d-line-2:rgba(255,255,255,.18);

  /* — Brand accent (the single brand tie) — */
  --accent:#c8962a;          /* refined gold — fills/borders/accents on light */
  --accent-bright:#ffb000;   /* original gold — dark bands + the ◇ mark */
  --accent-soft:rgba(200,150,42,.12);
  --link:#9a7012;            /* AA-readable gold for prose links on white */

  /* — Semantic — */
  --ok:#1a7f55; --ok-bright:#46d99a;
  --bad:#c0362c; --bad-bright:#ff5d56;
  --warn:#9a6b00;

  /* — Type — */
  --sans:'Hanken Grotesk',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,monospace;

  /* — Fluid type scale — */
  --fs-display:clamp(44px,7.4vw,92px);
  --fs-h1:clamp(32px,4.6vw,56px);
  --fs-h2:clamp(26px,3.3vw,40px);
  --fs-h3:20px;
  --fs-lede:clamp(18px,2.1vw,23px);
  --fs-body:17px;

  /* — Spacing (8pt) — */
  --s1:8px; --s2:16px; --s3:24px; --s4:40px; --s5:64px; --s6:96px; --s7:136px;

  /* — Radius — */
  --r-sm:10px; --r-md:16px; --r-lg:22px; --r-xl:30px; --r-pill:999px;

  /* — Elevation (soft, low-contrast) — */
  --shadow-1:0 1px 2px rgba(0,0,0,.04), 0 6px 16px rgba(0,0,0,.05);
  --shadow-2:0 10px 34px rgba(0,0,0,.09);
  --shadow-3:0 24px 70px rgba(0,0,0,.14);

  /* — Motion — */
  --ease:cubic-bezier(.4,0,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --dur:.5s; --dur-fast:.22s;

  --maxw:1160px;

  /* — Legacy aliases (so existing inline var(--panel)/var(--mono)/… resolve) — */
  --panel:var(--surface);
  --panel-2:var(--surface-2);
}

*{box-sizing:border-box}
html,body{margin:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:var(--fs-body);
  line-height:1.55;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:var(--link);text-decoration:none;font-weight:500}
a:hover{text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
img{max-width:100%}
::selection{background:rgba(200,150,42,.22)}

/* Headings — sans, tight, confident.
   Base sizes are APP-page scale (page titles / section headers). Marketing pages
   use the larger .aw-display / .aw-h1 / .aw-h2 classes explicitly. */
h1,h2,h3,h4{font-weight:700;letter-spacing:-.015em;line-height:1.15;color:var(--ink);margin:0}
h1{font-size:27px;font-weight:800;letter-spacing:-.02em;margin:0 0 4px}
h2{font-size:18px;margin:0 0 6px}
h3{font-size:16px}

/* Focus ring (Phase-5 a11y) */
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}

/* ============================================================================
   2 + 3. BASE ELEMENTS & LEGACY COMPONENT CLASSES
   These reproduce — and elevate — the classes the app pages already use, so a
   page can drop its inline <style> and just <link> this file.
   ========================================================================== */

/* Layout container */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

/* Header / nav (legacy header.top + .brand + .nav) */
header.top{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:18px 0;margin-bottom:var(--s4);
  border-bottom:1px solid var(--line);
}
.brand{font-family:var(--mono);font-weight:700;letter-spacing:.02em;font-size:17px;color:var(--ink)}
.brand b{color:var(--accent)}
.brand small{display:block;font-family:var(--sans);font-weight:500;color:var(--muted);
  letter-spacing:.14em;text-transform:uppercase;font-size:10px;margin-top:6px}
.nav{font-family:var(--sans);font-size:14px;font-weight:500;display:flex;gap:22px;align-items:center}
.nav a{color:var(--ink-2)}
.nav a:hover{color:var(--ink);text-decoration:none}
.nav a.cta{
  font-weight:600;color:#1a1305;background:var(--accent);border:0;
  padding:9px 16px;border-radius:var(--r-pill);box-shadow:var(--shadow-1);
  transition:transform var(--dur-fast) var(--ease),box-shadow var(--dur-fast) var(--ease);
}
.nav a.cta:hover{transform:translateY(-1px);box-shadow:var(--shadow-2);color:#1a1305}

/* Sub / intro / hint / muted text */
.sub{font-family:var(--sans);font-size:14px;color:var(--muted);margin-bottom:22px}
.intro{font-family:var(--sans);font-size:15.5px;color:var(--ink-2);line-height:1.65;margin:0 0 22px}
.hint{font-family:var(--sans);font-size:12px;color:var(--muted);line-height:1.6;margin-top:8px}
.empty{font-family:var(--sans);font-size:14px;color:var(--muted)}
p.desc{font-size:14.5px;color:var(--ink-2);line-height:1.65;margin:0 0 16px}

/* Buttons — pill, sans, soft depth */
button,.btn{
  font-family:var(--sans);font-weight:600;font-size:14px;letter-spacing:0;
  cursor:pointer;border-radius:var(--r-pill);
  border:1px solid var(--line-2);background:var(--surface);color:var(--ink);
  padding:10px 18px;text-decoration:none;display:inline-flex;align-items:center;
  justify-content:center;gap:8px;white-space:nowrap;
  transition:transform var(--dur-fast) var(--ease),box-shadow var(--dur-fast) var(--ease),
    border-color var(--dur-fast) var(--ease),background var(--dur-fast) var(--ease);
}
button:hover,.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-1);border-color:var(--line-2)}
button:disabled,.btn:disabled{opacity:.45;cursor:default;transform:none;box-shadow:none}
button.pri,.btn.pri,button.save{background:var(--accent);color:#1a1305;border-color:transparent;box-shadow:var(--shadow-1)}
button.pri:hover,.btn.pri:hover,button.save:hover{box-shadow:var(--shadow-2);color:#1a1305}
button.ghost,.btn.ghost{background:transparent;color:var(--ink-2);border-color:var(--line-2);font-weight:500}
button.ghost:hover{color:var(--ink);background:var(--surface-2)}

/* Form fields */
input,textarea,select{
  width:100%;background:var(--surface);border:1px solid var(--line-2);color:var(--ink);
  font-family:var(--sans);font-size:14px;padding:12px 14px;border-radius:var(--r-sm);outline:none;
  transition:border-color var(--dur-fast) var(--ease),box-shadow var(--dur-fast) var(--ease);
}
input::placeholder,textarea::placeholder{color:var(--muted)}
input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
input[type=range]{padding:0;background:none;border:0;box-shadow:none;accent-color:var(--accent)}
input[type=color]{width:46px;height:34px;padding:2px;cursor:pointer}
input[type=checkbox]{width:auto;accent-color:var(--accent)}
label{display:block;font-family:var(--sans);font-size:12px;color:var(--ink-2);font-weight:500;
  margin:14px 0 6px;letter-spacing:0}

/* Cards / panels — soft elevation, not hard hairline boxes */
.card,.panel{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--shadow-1);
}
.card{padding:22px;display:flex;flex-direction:column;overflow:hidden}
.panel{padding:20px}
.card.current{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft),var(--shadow-2)}

/* Grids */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}

/* Notes / status text */
.note,.formnote{font-family:var(--sans);font-size:12.5px;margin-top:12px;min-height:16px;color:var(--muted)}
.note.ok,.formnote.ok{color:var(--ok)}
.note.bad,.formnote.bad{color:var(--bad)}
.err{font-family:var(--sans);font-size:12.5px;color:var(--bad);line-height:1.55}

/* Video stage (kept black inner frame) */
.stage{
  position:relative;width:100%;aspect-ratio:9/16;background:#000;overflow:hidden;
  border-radius:var(--r-md);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
}
.stage video{width:100%;height:100%;object-fit:cover;display:block}
.ph{font-family:var(--sans);font-size:12px;color:#9a9aa2;text-align:center;padding:14px}

/* Render-card meta (dashboard) */
.meta{padding:14px 15px;display:flex;flex-direction:column;gap:9px}
.nm{font-family:var(--sans);font-weight:600;font-size:14px;word-break:break-word;color:var(--ink)}
.st{font-family:var(--sans);font-size:12px;display:inline-flex;align-items:center;gap:6px}
.dot{width:7px;height:7px;border-radius:50%;display:inline-block}
.s-completed{color:var(--ok)} .s-completed .dot{background:var(--ok)}
.s-failed{color:var(--bad)} .s-failed .dot{background:var(--bad)}
.s-queued,.s-rendering,.s-probing,.s-enriching,.s-generating,.s-running{color:var(--warn)}
.s-queued .dot,.s-rendering .dot,.s-probing .dot,.s-enriching .dot,.s-generating .dot,.s-running .dot{
  background:var(--warn);animation:pulse 1s infinite}
@keyframes pulse{50%{opacity:.35}}
.bar{height:5px;background:var(--surface-2);border-radius:3px;overflow:hidden}
.bar > i{display:block;height:100%;background:var(--accent);width:0;transition:width .4s var(--ease)}

/* Tables (settings/admin) */
table{width:100%;border-collapse:collapse;font-size:14px;margin-top:8px}
th,td{text-align:left;padding:11px 10px;border-bottom:1px solid var(--line)}
th{font-family:var(--mono);font-size:10.5px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;font-weight:500}
td.mono,.mono{font-family:var(--mono);font-size:12px}
.scroll{overflow-x:auto}
.link{font-family:var(--mono);font-size:11.5px;color:var(--accent);word-break:break-all}

/* Mono code blocks (kept mono — technical metadata) */
pre{white-space:pre-wrap;font-family:var(--mono);font-size:11px;color:var(--ink-2);
  max-height:200px;overflow:auto;margin:8px 0 0}
pre.cfg{background:#0d0d11;color:#e8e8ef;border:1px solid var(--line);border-radius:var(--r-md);
  padding:16px;line-height:1.6;font-size:11.5px;max-height:none}
details summary{font-family:var(--sans);font-size:11.5px;color:var(--muted);cursor:pointer}
code{font-family:var(--mono);font-size:.92em}

/* Badges / pills / chips (mono metadata) */
.badge{font-family:var(--mono);font-size:9.5px;padding:3px 8px;border-radius:var(--r-pill);
  border:1px solid var(--line-2);color:var(--muted);letter-spacing:.02em}
.badge.adm{color:var(--accent);border-color:rgba(200,150,42,.45)}
.badge.inv{color:var(--ok);border-color:rgba(26,127,85,.4)}
.pill{display:inline-block;font-family:var(--mono);font-size:10px;padding:2px 8px;border-radius:var(--r-pill);
  border:1px solid var(--line-2);color:var(--muted);margin-right:4px}
.pill.rot,.pill.aw{color:var(--accent);border-color:rgba(200,150,42,.4)}

/* ---- enrich page specifics ---- */
.caps{display:flex;flex-wrap:wrap;gap:7px;margin:4px 0 2px}
.cap{font-family:var(--mono);font-size:10px;padding:4px 9px;border-radius:var(--r-pill);
  border:1px solid var(--line-2);color:var(--muted)}
.cap.on{color:var(--ok);border-color:rgba(26,127,85,.4);background:rgba(26,127,85,.06)}
.cap.off{color:var(--bad);border-color:rgba(192,54,44,.35)}
.assets{display:flex;flex-direction:column;gap:7px;margin-top:6px;max-height:200px;overflow:auto}
.arow{display:flex;align-items:center;gap:9px;font-family:var(--sans);font-size:12.5px;background:var(--surface-2);
  border:1px solid var(--line);border-radius:var(--r-sm);padding:8px 10px}
.arow .nm{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}
.arow .kind{color:var(--muted);font-family:var(--mono);font-size:11px}
.steps{font-family:var(--sans);font-size:12.5px;line-height:1.7;color:var(--ink-2);margin-top:10px}
.steps .done{color:var(--ok)} .steps .now{color:var(--accent)} .steps .fail{color:var(--bad)}
.gen{font-family:var(--mono);font-size:10.5px;color:var(--muted);margin-top:10px}
.gen b{color:var(--ink)}
.upload{border:1.5px dashed var(--line-2);border-radius:var(--r-md);padding:16px;text-align:center;
  font-family:var(--sans);font-size:12.5px;color:var(--muted);cursor:pointer;margin-top:6px;
  transition:border-color var(--dur-fast) var(--ease),background var(--dur-fast) var(--ease)}
.upload:hover{border-color:var(--accent);background:var(--accent-soft)}

/* ---- billing specifics ---- */
.banner{font-family:var(--sans);font-size:13px;padding:13px 16px;border-radius:var(--r-md);
  margin-bottom:20px;border:1px solid var(--line-2);background:var(--surface)}
.banner.ok{color:var(--ok);border-color:rgba(26,127,85,.4);background:rgba(26,127,85,.06)}
.banner.info{color:var(--ink-2)}
.pname{font-family:var(--sans);font-size:17px;font-weight:700}
.pname .badge{font-size:9.5px;color:#1a1305;background:var(--accent);border:0;padding:3px 8px;margin-left:8px;vertical-align:middle}
.feat{font-size:14px;color:var(--ink-2);line-height:1.8;flex:1}
.feat b{color:var(--ink);font-weight:600}
.manage{margin-top:24px;font-family:var(--sans);font-size:13px}

/* ---- brandkit specifics ---- */
.layout{display:grid;grid-template-columns:1fr 320px;gap:32px}
.field{margin-bottom:18px}
.toggle{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-size:14px;font-weight:500}
.preview{position:sticky;top:20px}
.canvas{position:relative;width:100%;aspect-ratio:9/16;border-radius:var(--r-md);overflow:hidden;
  border:1px solid var(--line);background:linear-gradient(135deg,#2a2d22,#14160f);box-shadow:var(--shadow-2)}
.canvas .logo{position:absolute;max-width:50%;max-height:24%}
.canvas .handle{position:absolute;font-family:var(--mono);font-weight:700;font-size:13px;
  background:rgba(0,0,0,.35);color:#fff;padding:4px 8px;border-radius:5px;white-space:nowrap}
.plabel{font-family:var(--sans);font-size:11.5px;color:var(--muted);text-align:center;margin-top:10px}

/* ---- settings specifics ---- */
.reveal{margin-top:16px;background:var(--accent-soft);border:1px solid var(--accent);border-radius:var(--r-md);
  padding:16px;display:none}
.reveal.show{display:block}
.reveal code{font-family:var(--mono);font-size:12px;color:var(--accent);word-break:break-all;display:block;margin:6px 0 10px}
.reveal .warn{font-family:var(--sans);font-size:11.5px;color:var(--bad)}
.copybox{display:flex;gap:8px;align-items:center;margin-top:10px}

/* ---- admin specifics ---- */
.stats{display:flex;gap:14px;flex-wrap:wrap;margin:20px 0 6px}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);
  padding:16px 20px;min-width:120px;box-shadow:var(--shadow-1)}
.stat .n{font-size:28px;font-weight:800;letter-spacing:-.02em}
.stat .l{font-family:var(--mono);font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-top:4px}

/* ---- social specifics ---- */
.plat,.acct{display:flex;align-items:center;gap:13px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-md);padding:15px;box-shadow:var(--shadow-1)}
.acct{margin-bottom:10px}
.plat .icon,.acct .icon{font-size:22px;width:28px;text-align:center}
.plat .label,.acct .pl{font-family:var(--sans);font-weight:600;font-size:14px;flex:1}
.plat .gate{font-family:var(--mono);font-size:10px;color:var(--muted)}
.acct .info{flex:1}
.acct .handle{font-family:var(--mono);font-size:11px;color:var(--muted)}

/* ---- index (templates catalog) specifics ---- */
.card[href]{cursor:pointer;color:var(--ink);transition:transform var(--dur-fast) var(--ease),box-shadow var(--dur-fast) var(--ease)}
.card[href]:hover{transform:translateY(-3px);box-shadow:var(--shadow-2)}
.scenebadge{position:absolute;top:8px;right:8px;z-index:9;font-family:var(--mono);font-size:10px;
  background:rgba(0,0,0,.6);color:#fff;padding:3px 8px;border-radius:var(--r-pill);letter-spacing:.03em}
.sect{font-family:var(--sans);font-weight:700;font-size:18px;letter-spacing:-.01em;margin:34px 0 16px;
  padding-bottom:10px;border-bottom:1px solid var(--line);display:flex;align-items:baseline;gap:10px}
.sect b{color:var(--accent)}
.sect small{color:var(--muted);font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-family:var(--mono)}

/* ============================================================================
   5. DARK SCOPE — invert tokens for cinematic bands & auth pages.
   Apply .aw-dark to <body> (auth) or .aw-band-dark to a <section>.
   ========================================================================== */
.aw-dark,.aw-band-dark{
  --bg:var(--d-bg); --surface:var(--d-surface); --surface-2:var(--d-surface-2);
  --panel:var(--d-surface); --panel-2:var(--d-surface-2);
  --ink:var(--d-ink); --ink-2:var(--d-ink-2); --muted:var(--d-ink-2);
  --line:var(--d-line); --line-2:var(--d-line-2);
  --accent:var(--accent-bright); --accent-soft:rgba(255,176,0,.14);
  --link:var(--accent-bright);
  --shadow-1:0 1px 2px rgba(0,0,0,.4), 0 8px 24px rgba(0,0,0,.45);
  --shadow-2:0 18px 50px rgba(0,0,0,.55);
  --shadow-3:0 30px 80px rgba(0,0,0,.6);
}
.aw-dark{background:var(--d-bg);color:var(--d-ink)}
.aw-band-dark{background:var(--d-bg);color:var(--d-ink)}
.aw-dark .brand b,.aw-band-dark .brand b{color:var(--accent-bright)}

/* ============================================================================
   4. .aw-* MARKETING COMPONENTS (landing / auth bespoke)
   ========================================================================== */

.aw-section{padding:var(--s7) 0;position:relative}
.aw-section--tight{padding:var(--s5) 0}
.aw-band-dark.aw-section{overflow:hidden}

.aw-eyebrow{
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent);font-weight:500;margin-bottom:20px;display:block;
}
.aw-kicker{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent);font-weight:500;margin-bottom:14px;display:block}
.aw-display{font-size:var(--fs-display);font-weight:800;letter-spacing:-.03em;line-height:1.02;margin:0}
.aw-display .hl{color:var(--accent)}
.aw-h1{font-size:var(--fs-h1);font-weight:800;letter-spacing:-.025em;line-height:1.05}
.aw-h2{font-size:var(--fs-h2);font-weight:800;letter-spacing:-.02em;line-height:1.08}
.aw-lede{font-size:var(--fs-lede);line-height:1.45;color:var(--ink-2);font-weight:400}
.aw-band-dark .aw-lede{color:var(--d-ink-2)}
.aw-measure{max-width:60ch}
.aw-center{text-align:center}
.aw-center .aw-lede{margin-left:auto;margin-right:auto}

/* Marketing nav (transparent over the dark hero) */
.aw-nav{
  position:sticky;top:0;z-index:60;display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:16px 0;backdrop-filter:saturate(180%) blur(14px);
  background:rgba(8,8,10,.6);border-bottom:1px solid rgba(255,255,255,.08);
}
.aw-nav .brand{color:#f5f5f7}
.aw-nav .brand b{color:var(--accent-bright)}
.aw-nav__links{display:flex;gap:24px;align-items:center;font-size:14px;font-weight:500}
.aw-nav__links a{color:#c7c7cf}
.aw-nav__links a:hover{color:#fff;text-decoration:none}
.aw-nav__links a.cta{color:#1a1305;background:var(--accent-bright);padding:9px 16px;border-radius:var(--r-pill);font-weight:600}
.aw-nav__links a.cta:hover{transform:translateY(-1px);color:#1a1305}

/* Primary marketing buttons */
.aw-btn{font-family:var(--sans);font-weight:600;font-size:15px;cursor:pointer;border-radius:var(--r-pill);
  padding:14px 28px;display:inline-flex;align-items:center;justify-content:center;gap:9px;border:1px solid transparent;
  transition:transform var(--dur-fast) var(--ease),box-shadow var(--dur-fast) var(--ease)}
.aw-btn--accent{background:var(--accent-bright);color:#1a1305;box-shadow:var(--shadow-1)}
.aw-btn--accent:hover{transform:translateY(-1px);box-shadow:var(--shadow-2);color:#1a1305;text-decoration:none}
.aw-btn--ink{background:var(--ink);color:#fff}
.aw-btn--ink:hover{transform:translateY(-1px);box-shadow:var(--shadow-2);color:#fff;text-decoration:none}
.aw-btn--ghost{background:transparent;border-color:currentColor}

/* Hero */
.aw-hero{position:relative;text-align:center;padding:clamp(56px,9vw,110px) 0 clamp(40px,7vw,80px)}
.aw-hero__glow{position:absolute;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(820px 480px at 50% -4%, rgba(255,176,0,.28), transparent 60%),
    radial-gradient(620px 540px at 82% 26%, rgba(255,150,0,.12), transparent 58%),
    radial-gradient(620px 540px at 16% 40%, rgba(255,176,0,.07), transparent 60%);}
.aw-hero > *{position:relative;z-index:1}
.aw-hero .aw-display{max-width:16ch;margin:0 auto}
.aw-hero .aw-lede{max-width:54ch;margin:22px auto 0}

/* Floating sample-video trio */
.aw-trio{display:flex;gap:clamp(12px,2.4vw,28px);justify-content:center;align-items:center;
  margin:clamp(40px,6vw,72px) auto 0;max-width:760px;perspective:1600px}
.aw-trio__card{position:relative;flex:0 0 auto;width:30%;border-radius:18px;overflow:hidden;
  background:#000;box-shadow:var(--shadow-3);border:1px solid rgba(255,255,255,.1)}
.aw-trio__card video{width:100%;aspect-ratio:9/16;object-fit:cover;display:block}
.aw-trio__card.side{width:25%;opacity:.82;transform:translateY(14px) scale(.96)}
.aw-trio__card.side.left{transform:translateY(14px) rotateY(8deg) scale(.96)}
.aw-trio__card.side.right{transform:translateY(14px) rotateY(-8deg) scale(.96)}
.aw-trio__card.center{width:34%;z-index:2}
.aw-trio__verdict{position:absolute;top:9px;left:9px;z-index:3;font-family:var(--mono);font-size:9px;
  background:rgba(0,0,0,.62);color:var(--ok-bright);border:1px solid rgba(70,217,154,.4);
  padding:3px 7px;border-radius:var(--r-pill);letter-spacing:.02em}
@media(max-width:640px){.aw-trio__card.side{display:none}.aw-trio__card.center{width:64%}}

/* Email signup form (legacy .signup kept) */
.signup{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;max-width:480px;margin:26px auto 0}
.signup input{flex:1 1 260px;width:auto;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.18);
  color:#fff;font-size:15px;padding:14px 18px;border-radius:var(--r-pill)}
.aw-band-dark .signup input::placeholder{color:#8a8a92}
.signup input:focus{border-color:var(--accent-bright);box-shadow:0 0 0 4px rgba(255,176,0,.16)}
.signup button{background:var(--accent-bright);color:#1a1305;border:0;font-weight:600;font-size:15px;
  padding:14px 26px;border-radius:var(--r-pill);box-shadow:var(--shadow-1)}
/* light-section signup variant */
.aw-section:not(.aw-band-dark) .signup input{background:var(--surface);border-color:var(--line-2);color:var(--ink)}
.aw-section:not(.aw-band-dark) .signup input::placeholder{color:var(--muted)}

/* Scroll cue */
.aw-scrollcue{margin-top:48px;font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--d-ink-2);animation:awbob 2.4s var(--ease) infinite}
@keyframes awbob{50%{transform:translateY(6px);opacity:.6}}

/* 3-beat narrative strip */
.aw-beats{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,4vw,56px);margin-top:var(--s4)}
.aw-beat__n{font-family:var(--mono);font-size:12px;color:var(--accent);margin-bottom:14px;letter-spacing:.1em}
.aw-beat h3{font-size:21px;margin-bottom:10px}
.aw-beat p{color:var(--ink-2);font-size:15px;line-height:1.6;margin:0}
@media(max-width:760px){.aw-beats{grid-template-columns:1fr;gap:32px}}

/* How-it-works numbered rows */
.aw-steps{margin-top:var(--s4);display:flex;flex-direction:column}
.aw-step{display:grid;grid-template-columns:88px 1fr;gap:28px;align-items:start;
  padding:34px 0;border-top:1px solid var(--line)}
.aw-step__n{font-family:var(--mono);font-size:42px;font-weight:700;color:var(--accent);
  letter-spacing:-.04em;line-height:1;opacity:.5}
.aw-step h3{font-size:23px;margin-bottom:10px}
.aw-step p{color:var(--ink-2);font-size:16px;line-height:1.65;margin:0;max-width:60ch}
@media(max-width:640px){.aw-step{grid-template-columns:1fr;gap:8px}.aw-step__n{font-size:30px}}

/* Sample showcase gallery (legacy .gallery/.gcard/.verdict/.gmeta kept) */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:22px;margin-top:var(--s4)}
.gcard{background:var(--d-surface);border:1px solid rgba(255,255,255,.08);border-radius:var(--r-md);
  overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-2)}
.gcard .stage{border:0;border-radius:0;border-bottom:1px solid rgba(255,255,255,.08)}
.verdict{position:absolute;top:9px;left:9px;z-index:9;font-family:var(--mono);font-size:9px;
  background:rgba(0,0,0,.66);color:var(--ok-bright);border:1px solid rgba(70,217,154,.4);
  padding:3px 7px;border-radius:var(--r-pill);letter-spacing:.02em}
.gmeta{padding:14px 15px}
.gmeta .nm{font-family:var(--sans);font-weight:600;font-size:14px;color:#f5f5f7}
.gmeta .gsub{font-size:12.5px;color:var(--d-ink-2);margin-top:6px;line-height:1.5}

/* Differentiation pillars */
.pillars{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px;margin-top:var(--s4)}
.pillar{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px;box-shadow:var(--shadow-1)}
.pillar .ic{font-size:30px;color:var(--accent);margin-bottom:16px;line-height:1}
.pillar h3{font-size:19px;margin-bottom:10px}
.pillar p{font-size:14.5px;color:var(--ink-2);margin:0;line-height:1.65}

/* Pricing teaser */
.teaser{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);padding:clamp(36px,5vw,60px);
  text-align:center;box-shadow:var(--shadow-2);max-width:760px;margin:0 auto}
.teaser h2{margin-bottom:12px}
.teaser p{color:var(--ink-2);max-width:50ch;margin:0 auto 8px;font-size:15.5px}

/* FAQ */
.faq{margin-top:var(--s3);max-width:780px}
.faq details{border-top:1px solid var(--line);padding:22px 2px}
.faq details:last-child{border-bottom:1px solid var(--line)}
.faq summary{font-weight:600;font-size:17px;cursor:pointer;list-style:none;display:flex;
  justify-content:space-between;align-items:center;gap:16px;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--accent);font-family:var(--mono);font-size:22px;font-weight:400}
.faq details[open] summary::after{content:"−"}
.faq p{color:var(--ink-2);font-size:15px;margin:14px 0 0;max-width:66ch;line-height:1.65}

/* Footer */
.aw-footer{border-top:1px solid var(--line);padding:34px 0 56px;margin-top:var(--s4);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}
.aw-footer .meta{font-family:var(--mono);font-size:11.5px;color:var(--muted);padding:0}

/* Auth card */
.aw-auth{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative}
.aw-auth__glow{position:fixed;inset:0;pointer-events:none;z-index:0;
  background:radial-gradient(800px 520px at 50% -10%,rgba(255,176,0,.16),transparent 62%)}
.aw-card-auth{position:relative;z-index:1;width:100%;max-width:420px;background:var(--d-surface);
  border:1px solid rgba(255,255,255,.1);border-radius:var(--r-lg);padding:38px;box-shadow:var(--shadow-3)}
.aw-card-auth .brand{font-size:18px;margin-bottom:8px}
.aw-card-auth h1{font-size:26px;margin:16px 0 6px}
.aw-card-auth .sub{margin-bottom:6px}
.aw-card-auth label{margin-top:16px}
.aw-card-auth form button[type=submit]{width:100%;margin-top:24px;
  background:var(--accent-bright);color:#1a1305;border:0;box-shadow:var(--shadow-1)}
.gbtn{display:none;width:100%;margin-top:14px;background:#fff;color:#1d1d1f;
  border:1px solid rgba(0,0,0,.12);font-weight:600}
.gbtn:hover{background:#f0f0f2;border-color:rgba(0,0,0,.2)}
.gbtn svg{width:18px;height:18px;flex:none}
.divider{display:none;align-items:center;gap:12px;margin:20px 0 4px;color:var(--muted);
  font-family:var(--mono);font-size:11px;letter-spacing:.08em}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--d-line-2)}
.alt{font-family:var(--sans);font-size:13px;color:var(--muted);margin-top:22px;text-align:center}

/* ============================================================================
   Scroll-reveal (driven by arawase.js AW.reveal())
   ========================================================================== */
.aw-reveal{opacity:0;transform:translateY(26px);
  transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.aw-reveal.in{opacity:1;transform:none}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  .aw-reveal{opacity:1;transform:none}
}

/* ============================================================================
   Responsive
   ========================================================================== */
@media(max-width:820px){
  .layout{grid-template-columns:1fr}
  .grid2{grid-template-columns:1fr}
}
@media(max-width:640px){
  .wrap{padding:0 20px}
  .aw-section{padding:var(--s5) 0}
  .nav,.aw-nav__links{gap:14px;font-size:13px}
  .nav a:not(.cta){display:none}
  .aw-nav__links a:not(.cta){display:none}
  header.top{flex-wrap:wrap}
}
