
/* ─── Prototype body ─── */
html{scroll-behavior:smooth}
html,body{margin:0!important;padding:0!important;background:#F7F3EA;color:#1B140C;font-family:'Inter','Helvetica Neue',system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}

:root{
  --teal-700:#0E7490;
  --teal-600:#0891B2;
  --teal-800:#155E75;
  --teal-400:#22D3EE;
  --teal-100:#CFFAFE;

  --success:#15803D;
  --warning:#CA8A04;
  --error:#DC2626;
  --niva-red:#E63946;

  --font-sans:'Inter','Helvetica Neue',system-ui,-apple-system,sans-serif;
  --font-mono:'JetBrains Mono','SF Mono',ui-monospace,monospace;
  --font-display:'Inter','Helvetica Neue',system-ui,sans-serif;

  
  
  
  
}

*{box-sizing:border-box;margin:0;padding:0}

body{padding:48px 32px 120px}





















/* tile width matches content width — no zoom needed */
.tile-frame .site-section{
  width:1320px;
}





/* =================================================================
   WARM CANVAS — SITE COMPONENT STYLES
   ================================================================= */

.site-section{
  font-family:var(--font-sans);
  background:#F7F3EA;
  color:#1B140C;
  padding:56px 80px;
  position:relative;
  overflow:hidden;
  --paper:#F7F3EA;
  --ink:#1B140C;
  --n100:#F0EBE0;
  --n200:#E0DACC;
  --n400:#6B6256;
  --n600:#4A4338;
  --n800:#211C14;
}
.site-section.compact{padding:24px 80px}
.site-section.tall{padding:80px}
.site-section.hero-pad{padding:48px 80px 80px}

/* ---- NAV ---- */
.site-nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 0;
}
.brand{display:flex;align-items:center;gap:10px}






.nav-cta{
  background:var(--teal-700);
  color:#FAFAFA;
  border:none;
  padding:10px 20px;
  border-radius:999px;
  font-family:var(--font-sans);
  font-weight:500;
  font-size:13.5px;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:10px;
  white-space:nowrap;
}
.cta-glyph{display:inline-flex;align-items:center;gap:5px;margin-left:2px}





/* ---- HERO ---- */
.hero-row{
  display:grid;
  grid-template-columns:1.1fr 0.9fr;
  gap:64px;
  align-items:center;
  margin-top:0;
}
.hero-eyebrow{
  font-family:var(--font-mono);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.14em;
  color:var(--teal-700);
  margin-bottom:24px;
}
.hero-h1{
  font-family:var(--font-display);
  font-weight:700;
  font-size:72px;
  line-height:1.02;
  letter-spacing:-0.03em;
  color:var(--ink);
  margin-bottom:24px;
}
.hero-h1 em{font-style:italic;color:var(--teal-700);font-weight:700}
.hero-sub{
  font-size:19px;
  line-height:1.5;
  color:var(--n600);
  max-width:480px;
  margin-bottom:36px;
}
.hero-ctas{display:flex;align-items:center;gap:24px}
.cta-primary{
  background:var(--teal-700);
  color:#FAFAFA;
  border:none;
  padding:16px 28px;
  border-radius:999px;
  font-family:var(--font-sans);
  font-weight:500;
  font-size:14.5px;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:10px;
  white-space:nowrap;
}
.cta-primary.large{padding:20px 36px;font-size:16px}
.cta-secondary{
  background:transparent;
  border:none;
  color:var(--ink);
  font-family:var(--font-sans);
  font-weight:500;
  font-size:14px;
  cursor:pointer;
  text-decoration:underline;
  text-underline-offset:5px;
  text-decoration-thickness:1px;
  text-decoration-color:var(--n400);
}
.hero-trust{
  margin-top:48px;
  display:flex;
  align-items:center;
  gap:24px;
  font-family:var(--font-mono);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:var(--n400);
}

/* hero stat band (v6) — promoted outcome proof above the trust line */
.hero-stats{
  display:flex;
  align-items:flex-start;
  gap:40px;
  margin-top:36px;
  padding-top:32px;
  border-top:0.5px solid var(--n200);
}
.hero-stat .num{
  font-family:var(--font-display);
  font-weight:700;
  font-size:34px;
  line-height:1;
  letter-spacing:-0.025em;
  color:var(--ink);
  margin-bottom:6px;
}
.hero-stat .num em{font-style:italic;color:var(--teal-700);font-weight:700}
.hero-stat .lbl{
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--n400);
}
.hero-trust .niva{display:inline-flex;align-items:center;gap:8px;color:var(--n600)}
.hero-trust .niva-star{color:var(--niva-red);font-size:14px}

/* ---- HERO ORB DEVICE ---- */
.hero-device{
  display:flex;
  align-items:center;
  justify-content:center;
}
.phone{
  width:320px;
  height:640px;
  border-radius:38px;
  background:var(--paper);
  border:1px solid var(--n200);
  box-shadow:
    0 1px 0 rgba(0,0,0,0.04),
    0 30px 80px rgba(0,0,0,0.10),
    0 60px 140px rgba(0,0,0,0.05);
  padding:38px 24px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  position:relative;
}
.phone-header{
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--font-mono);font-size:9.5px;letter-spacing:0.08em;
  text-transform:uppercase;color:var(--n400);
}
.ask-eyebrow{
  font-family:var(--font-mono);
  font-size:10.5px;
  text-transform:uppercase;
  letter-spacing:0.14em;
  color:var(--n400);
  text-align:center;
  margin-top:36px;
}
.orb-wrap{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:18px 0;
}
.orb{
  position:relative;
  width:200px;
  height:200px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.orb.lg{width:240px;height:240px}
.orb.md{width:170px;height:170px}
.orb-r{
  position:absolute;
  border-radius:50%;
  border:1.5px solid var(--teal-700);
  background:transparent;
}
.orb-r.r1{inset:0;animation:orbPulse 2.2s ease-in-out infinite}
.orb-r.r2{inset:26px;animation:orbPulse 2.2s ease-in-out infinite 0.35s}
.orb-r.r3{inset:52px;animation:orbPulse 2.2s ease-in-out infinite 0.7s}
.orb-core{
  width:50px;
  height:50px;
  border-radius:50%;
  background:var(--teal-700);
  box-shadow:0 0 22px var(--teal-700),0 0 8px var(--teal-700);
  animation:orbGlow 2.2s ease-in-out infinite;
  position:relative;
  z-index:2;
}
.orb.lg .orb-core{width:60px;height:60px}
.orb.md .orb-core{width:40px;height:40px}
@keyframes orbPulse{
  0%,100%{opacity:0.25;transform:scale(0.95)}
  50%{opacity:1;transform:scale(1.12)}
}
@keyframes orbGlow{
  0%,100%{opacity:0.75;box-shadow:0 0 12px var(--teal-700),0 0 4px var(--teal-700)}
  50%{opacity:1;box-shadow:0 0 32px var(--teal-700),0 0 12px var(--teal-700)}
}
.ask-sub{
  text-align:center;
  font-style:italic;
  font-size:14px;
  line-height:1.45;
  color:var(--n600);
  padding:0 10px;
  margin-bottom:24px;
}
.phone-footer{
  display:flex;justify-content:center;
  font-family:var(--font-mono);font-size:9.5px;letter-spacing:0.08em;
  text-transform:uppercase;color:var(--n400);
}

/* ---- FEATURE SECTION ---- */
.feature-row{
  display:grid;
  grid-template-columns:0.95fr 1.05fr;
  gap:80px;
  align-items:center;
}
.feature-row.reverse{grid-template-columns:1.05fr 0.95fr}
.feature-row.reverse .feature-copy{order:2}
.feature-row.reverse .feature-visual{order:1}

.feature-eyebrow{
  font-family:var(--font-mono);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.14em;
  color:var(--teal-700);
  margin-bottom:20px;
}
.feature-h2{
  font-family:var(--font-display);
  font-weight:700;
  font-size:64px;
  line-height:0.98;
  letter-spacing:-0.032em;
  color:var(--ink);
  margin-bottom:22px;
}
.feature-h2 em{font-style:italic;color:var(--teal-700);font-weight:700}
.feature-sub{
  font-size:18px;
  line-height:1.5;
  color:var(--n600);
  max-width:460px;
}
.feature-visual{
  display:flex;
  justify-content:center;
  align-items:center;
  position:relative;
}

/* ---- PHONE SCREEN MOCK ---- */
.phone-screen{
  width:300px;
  height:600px;
  border-radius:34px;
  background:#F7F3EA;
  border:1px solid var(--n200);
  box-shadow:
    0 25px 60px rgba(0,0,0,0.12),
    0 60px 140px rgba(0,0,0,0.06);
  padding:28px 22px;
  display:flex;
  flex-direction:column;
  overflow:hidden;
  color:#1B140C;
}
.ps-header{
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--font-mono);font-size:9.5px;letter-spacing:0.08em;
  text-transform:uppercase;color:#6B6256;margin-bottom:18px;
}
.ps-eyebrow{
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.14em;
  text-transform:uppercase;color:#6B6256;margin-bottom:10px;
}
.ps-title{
  font-family:var(--font-display);font-weight:700;font-size:20px;
  letter-spacing:-0.012em;color:#1B140C;margin-bottom:20px;line-height:1.18;
}

/* LEARN SCREEN — lessons list */
.lesson-row{
  display:flex;align-items:center;gap:14px;
  padding:14px 0;
  border-bottom:0.5px solid #E0DACC;
}
.lesson-row:last-child{border-bottom:0}
.lesson-num{
  width:30px;height:30px;border-radius:50%;
  background:#F0EBE0;color:#6B6256;
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.lesson-num.done{background:#0E7490;color:#F7F3EA}
.lesson-num.active{background:#1B140C;color:#F7F3EA}
.lesson-meta{flex:1;min-width:0}
.lesson-title{
  font-family:var(--font-display);font-weight:600;font-size:14px;
  color:#1B140C;line-height:1.25;margin-bottom:3px;
}
.lesson-sub{
  font-family:var(--font-mono);font-size:9.5px;letter-spacing:0.06em;
  text-transform:uppercase;color:#6B6256;
}
.lesson-score{
  font-family:var(--font-display);font-weight:600;font-size:13px;
  color:#1B140C;
}
.lesson-score.muted{color:#6B6256}
.lesson-score.dash{color:#E0DACC}

.lang-badge-row{
  display:flex;flex-wrap:wrap;gap:5px;
  margin-top:auto;padding-top:14px;border-top:0.5px solid #E0DACC;
}
.lang-badge-row span{
  font-family:var(--font-mono);font-size:8.5px;letter-spacing:0.06em;
  text-transform:uppercase;background:#F0EBE0;color:#4A4338;
  padding:4px 8px;border-radius:999px;
}

/* PRACTICE SCREEN — fork-style: Pitch + Perform paired */
.practice-screen .ps-title{margin-bottom:18px}
.mode-card{
  background:#F0EBE0;
  border-radius:12px;
  padding:14px 16px;
  margin-bottom:10px;
  position:relative;
}
.mode-card.active{
  background:var(--teal-700);
  color:#F7F3EA;
}
.mode-card.active .mode-name,
.mode-card.active .mode-sub{color:#F7F3EA}
.mode-card.active .mode-score{color:#F7F3EA}
.mode-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.mode-name{
  font-family:var(--font-display);font-weight:600;font-size:14px;
  color:#1B140C;letter-spacing:-0.005em;
}
.mode-tag{
  font-family:var(--font-mono);font-size:8.5px;letter-spacing:0.08em;
  text-transform:uppercase;color:#6B6256;
}
.mode-card.active .mode-tag{color:#CFFAFE}
.mode-sub{
  font-size:11.5px;line-height:1.4;color:#4A4338;margin-bottom:8px;
}
.mode-score{
  font-family:var(--font-display);font-weight:700;font-size:18px;
  color:#1B140C;letter-spacing:-0.01em;
}
.mode-score-row{display:flex;justify-content:space-between;align-items:baseline}

/* CONVERSATION BUBBLE STRIP (Perform) */
.conv-strip{margin-top:8px;display:flex;flex-direction:column;gap:6px}
.bubble{
  font-size:10.5px;line-height:1.4;padding:7px 10px;border-radius:11px;
  max-width:80%;
}
.bubble.ai{background:#F7F3EA;color:#1B140C;align-self:flex-start;border-bottom-left-radius:4px;border:0.5px solid #E0DACC}
.bubble.you{background:#155E75;color:#F7F3EA;align-self:flex-end;border-bottom-right-radius:4px}
.bubble .label{
  font-family:var(--font-mono);font-size:8px;letter-spacing:0.08em;
  text-transform:uppercase;opacity:0.6;display:block;margin-bottom:2px;
}

/* ---- DASHBOARD VISUAL — cool canvas inside warm section ---- */
.dashboard-frame{
  background:#FAFAFA;
  border-radius:14px;
  border:1px solid #E2E8F0;
  padding:24px;
  width:560px;
  max-width:100%;
  box-shadow:
    0 25px 60px rgba(0,0,0,0.12),
    0 60px 140px rgba(0,0,0,0.06);
  color:#0A0A0A;
  font-family:var(--font-sans);
}
.dash-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.dash-title{
  font-family:var(--font-display);font-weight:600;font-size:15px;
  color:#0A0A0A;letter-spacing:-0.005em;
}
.dash-filter{
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.08em;
  text-transform:uppercase;color:#64748B;
}
.dash-stat-row{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
  margin-bottom:20px;
}
.dash-stat{
  background:#F1F5F9;border-radius:10px;padding:12px 14px;
}
.dash-stat .label{
  font-family:var(--font-mono);font-size:9px;letter-spacing:0.08em;
  text-transform:uppercase;color:#64748B;margin-bottom:6px;
}
.dash-stat .value{
  font-family:var(--font-display);font-weight:700;font-size:22px;
  color:#0A0A0A;letter-spacing:-0.02em;line-height:1;
}
.dash-stat .delta{
  font-family:var(--font-mono);font-size:9.5px;color:var(--success);
  margin-top:4px;
}
.dash-stat .delta.down{color:var(--error)}

/* Mini chart */
.dash-chart{
  background:#F1F5F9;border-radius:10px;padding:14px 16px;margin-bottom:20px;
  position:relative;height:120px;
}
.dash-chart .chart-title{
  font-family:var(--font-mono);font-size:9.5px;letter-spacing:0.08em;
  text-transform:uppercase;color:#64748B;margin-bottom:8px;
}
.dash-chart svg{display:block;width:100%;height:80px}

/* ---- 9-BOX PERFORMANCE MATRIX (v10) ---- */
.dash-matrix-wrap{
  background:#fff;border:1px solid #E2E8F0;border-radius:10px;
  padding:14px 16px;margin-bottom:20px;
}
.dash-matrix-head{
  display:flex;justify-content:space-between;align-items:baseline;margin-bottom:12px;
}
.dash-matrix-title{
  font-family:var(--font-mono);font-size:9.5px;letter-spacing:0.08em;
  text-transform:uppercase;color:#64748B;
}
.dash-matrix-total{
  font-family:var(--font-display);font-size:11px;font-weight:600;color:#475569;
}
.dash-matrix-grid{
  display:grid;
  grid-template-columns:42px repeat(3, 1fr);
  grid-template-rows:repeat(3, 60px) 22px;
  gap:4px;
}
.dash-matrix-y-label{
  font-family:var(--font-mono);font-size:8.5px;letter-spacing:0.04em;
  color:#94A3B8;
  display:flex;align-items:center;justify-content:center;
  text-align:center;line-height:1.1;
}
.dash-matrix-x-label{
  font-family:var(--font-mono);font-size:8.5px;letter-spacing:0.04em;
  color:#94A3B8;text-align:center;padding-top:6px;
}
.dash-matrix-axis-name{
  font-family:var(--font-mono);font-size:8.5px;letter-spacing:0.06em;
  text-transform:uppercase;color:#64748B;font-weight:600;
}
.dash-cell{
  background:#F1F5F9;border-radius:4px;padding:6px 8px;
  display:flex;flex-direction:column;justify-content:space-between;
}
.dash-cell.top{background:rgba(21,128,61,0.10)}
.dash-cell.top .count{color:#15803D}
.dash-cell.mid{background:rgba(202,138,4,0.10)}
.dash-cell.mid .count{color:#CA8A04}
.dash-cell.risk{background:rgba(220,38,38,0.10)}
.dash-cell.risk .count{color:#DC2626}
.dash-cell.star{background:#0E7490;color:#FAFAFA}
.dash-cell.star .count{color:#FAFAFA}
.dash-cell.star .label{color:#A5F3FC}
.dash-cell .count{
  font-family:var(--font-display);font-size:18px;font-weight:700;
  letter-spacing:-0.01em;line-height:1;color:#0A0A0A;
}
.dash-cell .label{
  font-family:var(--font-mono);font-size:8px;letter-spacing:0.03em;
  text-transform:uppercase;color:#475569;line-height:1.2;margin-top:4px;
}

/* Leaderboard */
.dash-board{
  display:flex;flex-direction:column;
}
.dash-board-head{
  font-family:var(--font-mono);font-size:9.5px;letter-spacing:0.08em;
  text-transform:uppercase;color:#64748B;margin-bottom:8px;
}
.dash-row{
  display:grid;grid-template-columns:24px 1fr 60px 40px;gap:12px;
  padding:8px 4px;border-bottom:0.5px solid #E2E8F0;
  font-size:12.5px;align-items:center;
}
.dash-row:last-child{border-bottom:0}
.dash-rank{
  font-family:var(--font-mono);font-size:11px;color:#64748B;font-weight:500;
}
.dash-name{font-family:var(--font-display);font-weight:500;font-size:12.5px;color:#0A0A0A}
.dash-name .role{font-family:var(--font-mono);font-size:9px;letter-spacing:0.06em;text-transform:uppercase;color:#64748B;margin-left:6px}
.dash-score{
  font-family:var(--font-display);font-weight:600;font-size:13px;color:#0A0A0A;text-align:right;
}
.dash-trend{
  font-family:var(--font-mono);font-size:10px;color:var(--success);text-align:right;
}
.dash-trend.flat{color:#64748B}
.dash-trend.down{color:var(--error)}
.dash-row.you{background:#CFFAFE;border-radius:6px;padding-left:8px;padding-right:8px;margin:0 -4px}

/* ---- FOOTER ---- */
.site-footer{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:24px 0;
  border-top:0.5px solid var(--n200);
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.04em;
  color:var(--n400);
  margin-top:80px;
}
.site-footer .left{display:flex;align-items:center;gap:16px}
.site-footer .right{display:flex;gap:28px}
.site-footer a{color:var(--n400);text-decoration:none}
.site-footer .copyright{text-transform:uppercase}
.footer-glyph{display:inline-flex;align-items:center;gap:6px}
.footer-glyph .bars{display:inline-flex;gap:2px}
.footer-glyph .bars span{width:2px;height:12px;background:var(--ink);border-radius:0.5px}
.footer-glyph .ring{width:12px;height:12px;border:1.3px solid var(--ink);border-radius:50%;position:relative}
.footer-glyph .ring::after{content:"";position:absolute;inset:2.8px;background:var(--ink);border-radius:50%}

/* ---- MINIMAL FOOTER (v15) — 3 legal links only ---- */
.footer-minimal{
  background:var(--paper);
  padding:36px 80px;
  display:flex;
  justify-content:center;
  align-items:center;
}
.footer-minimal-links{
  display:flex;
  gap:36px;
  align-items:center;
}
.footer-minimal-links a{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--n400);
  text-decoration:none;
  transition:color 0.15s;
}
.footer-minimal-links a:hover{color:var(--ink)}
.footer-minimal-sep{
  width:3px;
  height:3px;
  border-radius:50%;
  background:var(--n200);
}

/* ---- HERO AI COACH CONVERSATION (v7) ---- */
.hero-conv{
  flex:1;
  display:flex;
  flex-direction:column;
  gap:14px;
  padding:14px 4px 8px;
  overflow:hidden;
  justify-content:center;
}

.hc-mini-orb{
  width:48px;
  height:48px;
  border-radius:50%;
  margin:6px auto 14px;
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
}
.hc-mini-orb::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:50%;
  border:1.5px solid var(--teal-700);
  opacity:0.5;
  animation:hcMiniPulse 2.2s ease-in-out infinite;
}
.hc-mini-orb::after{
  content:"";
  position:absolute;
  inset:8px;
  border-radius:50%;
  border:1.5px solid var(--teal-700);
  opacity:0.7;
  animation:hcMiniPulse 2.2s ease-in-out infinite 0.4s;
}
.hc-mini-orb .core{
  width:18px;
  height:18px;
  border-radius:50%;
  background:var(--teal-700);
  box-shadow:0 0 12px var(--teal-700);
  animation:hcCoreGlow 2.2s ease-in-out infinite;
  position:relative;
  z-index:2;
}
@keyframes hcMiniPulse{
  0%,100%{opacity:0.3;transform:scale(0.92)}
  50%{opacity:1;transform:scale(1.08)}
}
@keyframes hcCoreGlow{
  0%,100%{opacity:0.8;box-shadow:0 0 10px var(--teal-700)}
  50%{opacity:1;box-shadow:0 0 22px var(--teal-700),0 0 6px var(--teal-700)}
}

/* Q&A pair containers — each fades in/out in sequence */
.hc-pair{
  display:none;
  flex-direction:column;
  gap:9px;
  opacity:0;
  animation:hcFadeCycle 9s linear infinite;
  animation-delay:0.4s;
}
.hc-pair.show{display:flex}
.hc-pair.pair-1{animation-delay:0.4s}
.hc-pair.pair-2{animation-delay:3.4s}
.hc-pair.pair-3{animation-delay:6.4s}

@keyframes hcFadeCycle{
  0%, 2%{opacity:0;transform:translateY(8px)}
  6%, 33%{opacity:1;transform:translateY(0)}
  37%, 100%{opacity:0;transform:translateY(-8px)}
}

/* ---- SECTION EYEBROWS — TWO-LINE STACKED (v9) ---- */
.sec-eyebrow{
  display:flex;
  flex-direction:column;
  gap:6px;
  margin-bottom:24px;
}
.sec-eyebrow .sec-eyebrow-top{
  font-family:var(--font-display);
  font-weight:700;
  font-size:22px;
  letter-spacing:-0.012em;
  text-transform:uppercase;
  color:var(--ink);
  line-height:1;
}
.sec-eyebrow .sec-eyebrow-sub{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--teal-700);
  line-height:1;
}
.sec-eyebrow.center{align-items:center;text-align:center}

/* ---- HERO ORB OPENING OVERLAY (v9) ---- */
.hc-orb-open{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  background:var(--paper);
  z-index:5;
  animation:hcOrbOpenFade 2s ease-in 1.5s forwards;
}
@keyframes hcOrbOpenFade{
  0%{opacity:1}
  60%{opacity:1}
  100%{opacity:0;visibility:hidden}
}
.hc-orb-open-title{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--n400);
  margin-bottom:40px;
}
.hc-orb-big{
  position:relative;
  width:160px;
  height:160px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.hc-orb-big .ring{
  position:absolute;
  border-radius:50%;
  border:1.5px solid var(--teal-700);
  background:transparent;
}
.hc-orb-big .ring.r1{inset:0;animation:hcOpenRing 2s ease-in-out infinite}
.hc-orb-big .ring.r2{inset:22px;animation:hcOpenRing 2s ease-in-out infinite 0.3s}
.hc-orb-big .ring.r3{inset:44px;animation:hcOpenRing 2s ease-in-out infinite 0.6s}
.hc-orb-big .core{
  width:42px;
  height:42px;
  border-radius:50%;
  background:var(--teal-700);
  box-shadow:0 0 22px var(--teal-700),0 0 6px var(--teal-700);
  animation:hcOpenGlow 2s ease-in-out infinite;
  position:relative;
  z-index:2;
}
@keyframes hcOpenRing{
  0%,100%{opacity:0.25;transform:scale(0.95)}
  50%{opacity:1;transform:scale(1.12)}
}
@keyframes hcOpenGlow{
  0%,100%{opacity:0.75;box-shadow:0 0 12px var(--teal-700),0 0 4px var(--teal-700)}
  50%{opacity:1;box-shadow:0 0 32px var(--teal-700),0 0 10px var(--teal-700)}
}

/* phone needs position:relative for overlay */
.hero-device .phone{
  position:relative;
}

.hc-q, .hc-a{
  border-radius:14px;
  padding:10px 13px;
  font-size:12px;
  line-height:1.4;
  max-width:88%;
}
.hc-q{
  background:#F0EBE0;
  color:#1B140C;
  align-self:flex-start;
  border-bottom-left-radius:4px;
}
.hc-a{
  background:var(--teal-700);
  color:var(--paper);
  align-self:flex-end;
  border-bottom-right-radius:4px;
}
.hc-q .meta, .hc-a .meta{
  font-family:var(--font-mono);
  font-size:8.5px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  opacity:0.65;
  display:flex;
  align-items:center;
  gap:5px;
  margin-bottom:3px;
}
.hc-q .meta{color:#4A4338}
.hc-a .meta{color:#CFFAFE}

/* voice/type icon mini */
.hc-mic{
  display:inline-flex;
  width:10px;
  height:10px;
  border-radius:50%;
  background:#DC2626;
  position:relative;
  animation:hcMicBlink 1.2s ease-in-out infinite;
}
@keyframes hcMicBlink{
  0%, 100%{opacity:0.5}
  50%{opacity:1}
}
.hc-keyboard{
  display:inline-flex;
  align-items:center;
  gap:2px;
}
.hc-keyboard span{
  width:3px;
  height:3px;
  border-radius:0.5px;
  background:currentColor;
}

.hc-input-bar{
  margin-top:auto;
  display:flex;
  align-items:center;
  gap:10px;
  background:#F0EBE0;
  border-radius:999px;
  padding:8px 12px 8px 16px;
}
.hc-input-placeholder{
  flex:1;
  font-size:11.5px;
  color:#6B6256;
  font-style:italic;
}
.hc-input-mic{
  width:30px;
  height:30px;
  border-radius:50%;
  background:var(--teal-700);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:#FAFAFA;
  font-size:14px;
}

.hc-toolbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:0 6px 0 6px;
  margin-bottom:8px;
}
.hc-toolbar .label{
  font-family:var(--font-mono);
  font-size:9.5px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--teal-700);
}
.hc-toolbar .status{
  font-family:var(--font-mono);
  font-size:9.5px;
  letter-spacing:0.06em;
  color:#6B6256;
  display:flex;
  align-items:center;
  gap:5px;
}
.hc-pulse-dot{
  width:6px;
  height:6px;
  border-radius:50%;
  background:#15803D;
  animation:hcDot 1.4s ease-in-out infinite;
}
@keyframes hcDot{
  0%, 100%{opacity:0.4}
  50%{opacity:1}
}

/* === HERO TILE 02 — LOCKED (Loveleen) === */
.hero-tagline{
  margin-top:36px;
  font-family:var(--font-mono);
  font-size:18px;
  letter-spacing:0.08em;
  color:var(--ink);
  font-weight:500;
}
.hero-tagline .x{
  color:var(--teal-700);
  margin:0 6px;
  font-weight:400;
}
.hero-tagline em{
  color:var(--teal-700);
  font-style:italic;
  font-weight:500;
}
.hero-device-intro{
  text-align:center;
  margin-bottom:18px;
  max-width:340px;
}
.hero-device-intro-eyebrow{
  font-family:var(--font-display);
  font-size:24px;
  font-weight:700;
  letter-spacing:-0.01em;
  color:var(--teal-700);
  margin-bottom:12px;
  line-height:1.15;
}
.hero-device-intro-eyebrow em{
  font-style:italic;
  font-weight:700;
}
.hero-device-intro-sub{
  font-size:15px;
  line-height:1.5;
  color:var(--n600);
}
.hero-conv-input{
  display:flex;
  align-items:center;
  justify-content:space-between;
  background:rgba(0,0,0,0.04);
  border-radius:999px;
  padding:10px 16px;
  margin:12px 16px 16px;
  font-size:12px;
  color:var(--n400);
}
.hero-conv-input-btn{
  width:24px;height:24px;border-radius:50%;
  background:var(--teal-700);
  display:flex;align-items:center;justify-content:center;
}
.hero-conv-input-btn .hc-pulse-dot{
  width:6px;height:6px;border-radius:50%;background:#fff;
}
.hero-device{
  display:flex;
  flex-direction:column;
  align-items:center;
}


.brand svg{
  height:32px;
  width:auto;
  display:block;
  color:var(--ink);
}


/* ───── Tile 02b: AI Xpert ───── */
.phone-02b{
  position:relative;
  width:380px;
  margin:0 auto;
  display:flex;
  flex-direction:column;
  min-height:680px;
}

/* Top bar: back / glyph / clock */
.x02b-topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:18px 22px 16px;
  border-bottom:1px solid rgba(0,0,0,0.05);
}
.x02b-topbar .x02b-icon-back,
.x02b-topbar .x02b-icon-clock{
  color:var(--ink);
  font-size:22px;
  line-height:1;
  display:inline-flex;
  align-items:center;
}
.x02b-glyph{
  display:inline-flex;
  align-items:center;
  gap:5px;
  color:var(--teal-700);
}
.x02b-glyph .bars{display:inline-flex;gap:2.5px}
.x02b-glyph .bars span{width:2.5px;height:14px;background:currentColor;border-radius:0.5px;display:block}
.x02b-glyph .ring{
  width:14px;height:14px;border:1.5px solid currentColor;border-radius:50%;
  position:relative;display:inline-block;
}
.x02b-glyph .ring::after{
  content:"";position:absolute;inset:3.5px;background:currentColor;border-radius:50%;
}

/* Eyebrow */
.x02b-eyebrow{
  font-family:var(--font-mono);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.16em;
  color:var(--teal-700);
  text-align:center;
  margin-top:36px;
  font-weight:600;
}

/* Orb */
.x02b-orb-wrap{
  display:flex;
  align-items:center;
  justify-content:center;
  margin:24px 0 36px;
}
.x02b-orb{width:180px; height:180px;}
.x02b-orb .orb-core{width:42px; height:42px;}
.x02b-orb .orb-r.r2{inset:28px}
.x02b-orb .orb-r.r3{inset:56px}

/* Greeting text */
.x02b-greet{
  font-family:var(--font-display);
  font-weight:700;
  font-size:22px;
  line-height:1.25;
  text-align:center;
  color:var(--ink);
  margin:0 24px 12px;
  letter-spacing:-0.01em;
}
.x02b-greet em{
  color:var(--teal-700);
  font-style:italic;
  font-weight:700;
}
.x02b-greet-sub{
  text-align:center;
  font-size:13.5px;
  line-height:1.5;
  color:var(--n600);
  padding:0 28px;
  margin-bottom:24px;
}

/* Input bar */
.x02b-input{
  margin-top:auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  background:rgba(0,0,0,0.04);
  border-radius:999px;
  padding:12px 18px;
  margin:0 16px 18px;
}
.x02b-input-text{
  font-size:13px;
  color:var(--n400);
}
.x02b-input-icons{
  display:inline-flex;
  align-items:center;
  gap:14px;
  color:var(--n500);
}

/* ───── Tile 03: Learn (v1) ───── */
.phone-03{
  width:340px;
  border-radius:38px;
  background:#F7F3EA;
  border:1px solid var(--n200);
  box-shadow:
    0 30px 70px rgba(0,0,0,0.13),
    0 70px 160px rgba(0,0,0,0.06);
  padding:22px 18px 26px;
  position:relative;
  overflow:hidden;
}

/* phone header */
.ph-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:4px 4px 18px;
}
.ph-logo{display:flex;align-items:center;color:#1B140C}
.ph-logo svg{width:62px;height:auto;display:block}
.ph-lang{
  display:flex;align-items:center;
  background:#FFFFFF;
  border:1px solid #E0DACC;
  border-radius:999px;
  padding:3px;
  gap:0;
  font-family:var(--font-sans);
  font-size:11px;font-weight:600;
}
.ph-lang .seg{
  padding:5px 11px;border-radius:999px;color:#6B6256;
}
.ph-lang .seg.active{background:#1B140C;color:#F7F3EA}
.ph-iiio{
  display:inline-flex;gap:2.5px;align-items:center;
}
.ph-iiio span{width:2.5px;height:14px;background:var(--teal-700);border-radius:0.5px}
.ph-back{
  width:20px;height:20px;color:#1B140C;opacity:0.5;
  display:flex;align-items:center;justify-content:center;
}
.ph-back svg{width:16px;height:16px}

/* breadcrumb / title */
.ph-chap-eyebrow{
  font-family:var(--font-mono);
  font-size:10px;letter-spacing:0.14em;
  text-transform:uppercase;color:#6B6256;
  padding:6px 4px 6px;
  margin-top:4px;
}
.ph-chap-title{
  font-family:var(--font-display);
  font-weight:700;
  font-size:24px;
  letter-spacing:-0.018em;
  color:#1B140C;
  padding:0 4px 22px;
  line-height:1.1;
}

/* lesson carousel */
.ph-carousel{
  position:relative;
  height:380px;
  overflow:hidden;
  margin:0 -18px;
}
.ph-carousel-track{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
}
.ph-card{
  background:#F7F3EA;
  border:1px solid #E0DACC;
  border-radius:14px;
  padding:14px;
  width:240px;
  flex-shrink:0;
  box-shadow:0 8px 20px rgba(0,0,0,0.05);
}
.ph-card-side{
  opacity:0.45;
  transform:scale(0.92);
  width:240px;
}
.ph-card-side.left{margin-right:-90px;z-index:1}
.ph-card-side.right{margin-left:-90px;z-index:1}
.ph-card-center{z-index:2}

.ph-card-eyebrow{
  font-family:var(--font-mono);
  font-size:9.5px;letter-spacing:0.14em;
  text-transform:uppercase;color:#6B6256;
  margin-bottom:10px;
}

/* video thumbnail with photo */
.ph-thumb{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  border-radius:8px;
  overflow:hidden;
  background:#1B140C;
  margin-bottom:14px;
}
.ph-thumb img{
  width:100%;height:100%;object-fit:cover;display:block;
  object-position:center 28%;
}
.ph-play{
  position:absolute;left:50%;top:50%;
  transform:translate(-50%,-50%);
  width:42px;height:42px;
  border-radius:50%;
  background:rgba(247,243,234,0.95);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 8px rgba(0,0,0,0.25);
}
.ph-play svg{width:14px;height:14px;color:#1B140C;margin-left:2px}
.ph-dur{
  position:absolute;bottom:8px;right:8px;
  background:rgba(0,0,0,0.62);
  color:#FAFAFA;
  font-family:var(--font-mono);
  font-size:10px;font-weight:600;
  letter-spacing:0.02em;
  padding:3px 7px;
  border-radius:4px;
}

.ph-card-title{
  font-family:var(--font-display);
  font-weight:700;
  font-size:16px;
  line-height:1.18;
  letter-spacing:-0.012em;
  color:#1B140C;
  margin-bottom:8px;
}
.ph-card-body{
  font-size:11.5px;
  line-height:1.45;
  color:#6B6256;
  margin-bottom:14px;
}
.ph-meta{
  display:flex;gap:18px;
  margin-bottom:14px;
}
.ph-meta .lbl{
  font-family:var(--font-mono);
  font-size:9px;letter-spacing:0.12em;
  text-transform:uppercase;color:#6B6256;
  display:block;margin-bottom:2px;
}
.ph-meta .val{
  font-size:12px;color:#1B140C;font-weight:500;
}
.ph-cta{
  display:block;
  background:var(--teal-700);
  color:#F7F3EA;
  border:none;
  padding:11px;
  width:100%;
  border-radius:999px;
  font-family:var(--font-sans);
  font-weight:500;
  font-size:13px;
  cursor:pointer;
  text-align:center;
}

.ph-swipe{
  font-family:var(--font-mono);
  font-size:9.5px;letter-spacing:0.14em;
  text-transform:uppercase;color:#6B6256;
  text-align:center;
  padding:16px 0 4px;
}

/* ━━━━━━ Tile 04 ━━━━━━ */
.phone-04{
  width:340px;
  border-radius:38px;
  background:#FFFFFF;
  border:1px solid var(--n200);
  box-shadow:
    0 30px 70px rgba(0,0,0,0.13),
    0 70px 160px rgba(0,0,0,0.06);
  padding:22px 18px 20px;
  position:relative;
  overflow:hidden;
}

/* Phone header */
.ph04-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:18px;
}
.ph04-back{
  display:flex;
  align-items:center;
  gap:6px;
  font-family:var(--font-sans);
  font-size:13px;
  color:var(--ink);
  font-weight:500;
}
.ph04-progress{
  display:flex;
  gap:4px;
}
.ph04-progress span{
  width:22px;
  height:3px;
  background:var(--n200);
  border-radius:2px;
}
.ph04-progress span.active{background:var(--teal-700)}

/* Eyebrow + title */
.ph04-eyebrow{
  font-family:var(--font-mono);
  font-size:10.5px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--n400);
  margin-bottom:8px;
  padding:0 4px;
}
.ph04-title{
  font-family:var(--font-display);
  font-weight:700;
  font-size:22px;
  line-height:1.15;
  color:var(--ink);
  margin-bottom:22px;
  padding:0 4px;
  letter-spacing:-0.01em;
}

/* Persona card (carousel center) */
.ph04-carousel{
  position:relative;
  display:flex;
  align-items:stretch;
  justify-content:center;
  margin:0 -10px 18px;
}
.ph04-card{
  background:var(--paper);
  border-radius:18px;
  border:1px solid var(--n200);
  overflow:hidden;
  width:100%;
  position:relative;
  z-index:2;
}
.ph04-card-side{
  position:absolute;
  top:24px;
  bottom:24px;
  width:60px;
  background:#EDE7D7;
  border:1px solid var(--n200);
  border-radius:18px;
  z-index:1;
}
.ph04-card-side.right{right:-30px}
.ph04-card-side.right .ph04-side-text{
  position:absolute;
  top:50%;
  left:8px;
  transform:translateY(-50%);
  font-family:var(--font-display);
  font-size:13px;
  font-weight:600;
  color:var(--n400);
  white-space:nowrap;
}

/* Photo block */
.ph04-photo{
  width:100%;
  aspect-ratio:1/1;
  background:#E0DACC;
  position:relative;
  overflow:hidden;
}
.ph04-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

/* Card content */
.ph04-card-body{
  padding:14px 16px 16px;
}
.ph04-card-eyebrow{
  font-family:var(--font-mono);
  font-size:9.5px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--n400);
  margin-bottom:6px;
}
.ph04-card-name{
  font-family:var(--font-display);
  font-weight:700;
  font-size:19px;
  color:var(--ink);
  margin-bottom:6px;
  letter-spacing:-0.005em;
}
.ph04-card-desc{
  font-family:var(--font-sans);
  font-size:12.5px;
  line-height:1.4;
  color:var(--n500);
  margin-bottom:12px;
}
.ph04-chips{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  margin-bottom:14px;
}
.ph04-chip{
  font-family:var(--font-mono);
  font-size:9.5px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--n500);
  padding:5px 10px;
  border:1px solid var(--n200);
  border-radius:20px;
  background:#FFFFFF;
}

/* Intensity + best */
.ph04-meta{
  display:flex;
  gap:22px;
  margin-bottom:14px;
}
.ph04-meta-col{flex:0 0 auto}
.ph04-meta-lbl{
  font-family:var(--font-mono);
  font-size:9.5px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--n400);
  margin-bottom:4px;
}
.ph04-bars{
  display:flex;
  gap:2px;
  align-items:flex-end;
  height:14px;
}
.ph04-bars span{
  width:4px;
  background:var(--n300);
  border-radius:1px;
}
.ph04-bars span:nth-child(1){height:5px;background:var(--teal-700)}
.ph04-bars span:nth-child(2){height:9px;background:var(--n300)}
.ph04-bars span:nth-child(3){height:13px;background:var(--n300)}
.ph04-meta-val{
  font-family:var(--font-display);
  font-weight:700;
  font-size:15px;
  color:var(--ink);
}

/* CTA */
.ph04-cta{
  width:100%;
  background:var(--teal-700);
  color:#fff;
  border:none;
  border-radius:30px;
  padding:13px 0;
  font-family:var(--font-sans);
  font-weight:600;
  font-size:14px;
  letter-spacing:-0.005em;
  cursor:pointer;
}

/* Footer */
.ph04-footer{
  text-align:center;
  font-family:var(--font-mono);
  font-size:9.5px;
  letter-spacing:0.18em;
  color:var(--n400);
  text-transform:uppercase;
  margin-top:14px;
}
.ph04-footer::before,
.ph04-footer::after{content:"—  ";color:var(--n300)}
.ph04-footer::after{content:"  —"}

/* ━━━━━━ Tile 05 ━━━━━━ */
/* ───── Phone — Shadow (dark canvas) ───── */
.phone-05{
  width:320px;
  border-radius:38px;
  background:#1A1410;
  border:1px solid #2A2218;
  box-shadow:
    0 30px 70px rgba(0,0,0,0.18),
    0 70px 160px rgba(0,0,0,0.10);
  padding:18px 14px 16px;
  position:relative;
  overflow:hidden;
  color:#F5F1E8;
  --d-ink:#F5F1E8;
  --d-muted:#8B8275;
  --d-card:#2A2118;
  --d-card-border:#3A3024;
}

/* Header bar */
.ph05-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:4px 8px;
  margin-bottom:14px;
}
.ph05-back{
  font-family:var(--font-sans);
  font-size:13px;
  color:var(--d-ink);
  font-weight:500;
}
.ph05-mode{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:#B0231C;
  color:#FFF;
  padding:5px 10px;
  border-radius:14px;
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:0.1em;
  font-weight:600;
}
.ph05-mode .timer{
  color:rgba(255,255,255,0.85);
  font-variant-numeric:tabular-nums;
  letter-spacing:0.05em;
}

/* Orb */
.ph05-orb-wrap{
  display:flex;
  flex-direction:column;
  align-items:center;
  margin:6px 0 18px;
}
.ph05-orb{
  position:relative;
  width:60px;
  height:60px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:10px;
}
.ph05-orb::before{
  content:"";
  position:absolute;
  inset:0;
  border:1px solid rgba(14,116,144,0.45);
  border-radius:50%;
}
.ph05-orb-core{
  width:18px;
  height:18px;
  background:var(--teal-600);
  border-radius:50%;
  box-shadow:
    0 0 18px var(--teal-600),
    0 0 6px var(--teal-600);
}
.ph05-orb-label{
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:0.06em;
  color:var(--d-muted);
}

/* Chat transcript */
.ph05-chat{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:0 2px;
  margin-bottom:14px;
}
.ph05-bubble{
  border-radius:14px;
  padding:10px 12px 11px;
  font-family:var(--font-sans);
  font-size:11.5px;
  line-height:1.45;
  max-width:88%;
}
.ph05-bubble-lbl{
  font-family:var(--font-mono);
  font-size:9px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  font-weight:600;
  margin-bottom:5px;
  opacity:0.7;
}
.ph05-bubble-body{color:var(--d-ink)}

/* AI bubble (cream/light) */
.ph05-bubble.ai{
  background:#3A3024;
  align-self:flex-start;
  border:1px solid #45382A;
}
.ph05-bubble.ai .ph05-bubble-lbl{color:#C9BEA6}

/* YOU bubble (teal) */
.ph05-bubble.you{
  background:var(--teal-700);
  align-self:flex-end;
  border:1px solid var(--teal-600);
}
.ph05-bubble.you .ph05-bubble-lbl{color:#A6E2EF;opacity:1}
.ph05-bubble.you .ph05-bubble-body{color:#fff}

/* AI speaking bubble (red, with wave) */
.ph05-bubble.ai-speaking{
  background:#5A1F1B;
  align-self:flex-start;
  border:1px solid #6E2A24;
}
.ph05-bubble.ai-speaking .ph05-bubble-lbl{color:#E0A8A2}
.ph05-bubble.ai-speaking .ph05-wave{
  display:inline-flex;
  align-items:flex-end;
  gap:2px;
  margin-top:7px;
  height:11px;
}
.ph05-bubble.ai-speaking .ph05-wave span{
  width:2px;
  background:#E89B92;
  border-radius:1px;
}
.ph05-bubble.ai-speaking .ph05-wave span:nth-child(1){height:5px}
.ph05-bubble.ai-speaking .ph05-wave span:nth-child(2){height:9px}
.ph05-bubble.ai-speaking .ph05-wave span:nth-child(3){height:4px}
.ph05-bubble.ai-speaking .ph05-wave span:nth-child(4){height:8px}
.ph05-bubble.ai-speaking .ph05-wave span:nth-child(5){height:6px}
.ph05-bubble.ai-speaking .ph05-wave span:nth-child(6){height:3px}

/* YOU live transcript (outlined dark teal) */
.ph05-bubble.you-live{
  background:rgba(14,116,144,0.18);
  border:1px solid rgba(14,116,144,0.55);
  align-self:flex-end;
}
.ph05-bubble.you-live .ph05-bubble-lbl{color:#7AC5D6;opacity:1}
.ph05-bubble.you-live .ph05-bubble-body{
  color:#C9E6EE;
  font-style:italic;
}

/* Footer recording bar */
.ph05-footer{
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px 6px 4px;
}
.ph05-mic{
  width:38px;
  height:38px;
  border-radius:50%;
  background:#B0231C;
  display:flex;
  align-items:center;
  justify-content:center;
  flex:0 0 38px;
  box-shadow:0 0 14px rgba(176,35,28,0.5);
}
.ph05-mic svg{width:14px;height:14px;fill:#fff}
.ph05-rec-label{
  flex:1;
  font-family:var(--font-sans);
  font-size:11px;
  color:var(--d-muted);
}
.ph05-end{
  background:#F5F1E8;
  color:#1B140C;
  font-family:var(--font-sans);
  font-weight:600;
  font-size:12px;
  padding:8px 16px;
  border-radius:18px;
  border:none;
}

/* ━━━━━━ Tile 06 ━━━━━━ */
/* ───── Phone — Perform report (warm canvas) ───── */
.phone-06{
  width:330px;
  border-radius:38px;
  background:#FAF6EC;
  border:1px solid var(--n200);
  box-shadow:
    0 30px 70px rgba(0,0,0,0.13),
    0 70px 160px rgba(0,0,0,0.06);
  padding:18px 16px 18px;
  position:relative;
  overflow:hidden;
}

/* Phone topbar */
.ph06-topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:14px;
  padding:0 2px;
}
.ph06-brand{
  display:inline-flex;
  align-items:center;
  gap:5px;
  font-family:var(--font-display);
  font-weight:700;
  font-size:11px;
  letter-spacing:0.06em;
  color:var(--ink);
}





.ph06-top-right{
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.ph06-lang{
  background:var(--ink);
  color:var(--paper);
  border-radius:14px;
  font-family:var(--font-mono);
  font-size:9.5px;
  font-weight:600;
  padding:4px 8px 4px 10px;
  display:inline-flex;
  align-items:center;
  gap:5px;
}
.ph06-lang .dot{width:5px;height:5px;background:var(--paper);border-radius:50%}
.ph06-bars-icon{display:inline-flex;gap:2px}
.ph06-bars-icon span{width:2.5px;height:13px;background:var(--teal-700);border-radius:0.5px}

/* Back */
.ph06-back{
  font-family:var(--font-sans);
  font-size:11.5px;
  color:var(--n400);
  margin-bottom:12px;
  padding:0 2px;
}

/* Session header */
.ph06-eyebrow{
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--teal-700);
  font-weight:700;
  margin-bottom:4px;
  padding:0 2px;
}
.ph06-session{
  font-family:var(--font-sans);
  font-size:11.5px;
  color:var(--n500);
  margin-bottom:14px;
  padding:0 2px;
}

/* Passed card */
.ph06-passed{
  background:#D9ECE9;
  border-radius:14px;
  padding:14px 14px 14px;
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:12px;
}
.ph06-score-ring{
  width:62px;
  height:62px;
  border-radius:50%;
  border:1.5px solid var(--teal-700);
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--font-display);
  font-weight:700;
  font-size:21px;
  color:var(--ink);
  flex:0 0 62px;
  background:#D9ECE9;
}
.ph06-passed-body{flex:1}
.ph06-passed-title{
  font-family:var(--font-display);
  font-weight:700;
  font-size:18px;
  color:var(--ink);
  margin-bottom:3px;
  letter-spacing:-0.01em;
}
.ph06-passed-sub{
  font-family:var(--font-sans);
  font-size:11.5px;
  line-height:1.4;
  color:var(--n500);
}

/* Listen back row */
.ph06-listen{
  background:#FFFFFF;
  border:1px solid var(--n200);
  border-radius:14px;
  padding:10px 12px;
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:8px;
}
.ph06-play{
  width:32px;
  height:32px;
  border-radius:50%;
  background:var(--teal-700);
  display:flex;
  align-items:center;
  justify-content:center;
  flex:0 0 32px;
}
.ph06-play svg{width:11px;height:11px;fill:#fff;margin-left:1px}
.ph06-listen-body{flex:1;min-width:0}
.ph06-listen-lbl{
  font-family:var(--font-mono);
  font-size:9px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--n400);
  margin-bottom:3px;
}
.ph06-waveform{
  display:flex;
  gap:1.5px;
  align-items:center;
  height:14px;
}
.ph06-waveform span{
  width:1.5px;
  background:var(--teal-700);
  border-radius:1px;
  opacity:0.7;
}
.ph06-listen-time{
  font-family:var(--font-mono);
  font-size:10px;
  color:var(--n400);
  flex:0 0 auto;
  font-variant-numeric:tabular-nums;
}

/* Transcript row */
.ph06-transcript{
  background:#FFFFFF;
  border:1px solid var(--n200);
  border-radius:14px;
  padding:10px 12px;
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:14px;
}
.ph06-doc-icon{
  width:22px;height:22px;
  background:#E5EDED;
  border-radius:6px;
  flex:0 0 22px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.ph06-doc-icon::after{
  content:"";
  width:10px;height:12px;
  background:var(--teal-700);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z'/></svg>") no-repeat center / contain;
  mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z'/></svg>") no-repeat center / contain;
}
.ph06-transcript-body{flex:1}
.ph06-transcript-title{
  font-family:var(--font-sans);
  font-size:12.5px;
  font-weight:600;
  color:var(--ink);
  margin-bottom:2px;
}
.ph06-transcript-sub{
  font-family:var(--font-sans);
  font-size:10.5px;
  color:var(--n400);
}
.ph06-chev{
  color:var(--n300);
  font-size:14px;
  flex:0 0 auto;
}

/* Score breakdown header */
.ph06-bd-eyebrow{
  font-family:var(--font-mono);
  font-size:9.5px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--n400);
  font-weight:600;
  margin:6px 2px 8px;
  padding-top:8px;
  border-top:0.5px solid var(--n200);
}

/* Component card */
.ph06-comp{
  background:#FFFFFF;
  border:1px solid var(--n200);
  border-radius:14px;
  padding:12px 13px 13px;
}
.ph06-comp-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:10px;
}
.ph06-comp-title{
  font-family:var(--font-display);
  font-weight:700;
  font-size:14px;
  color:var(--ink);
  letter-spacing:-0.005em;
}
.ph06-comp-score{
  background:#D9ECE9;
  color:var(--ink);
  font-family:var(--font-display);
  font-weight:700;
  font-size:14px;
  padding:5px 12px;
  border-radius:14px;
}
.ph06-comp-reason-lbl{
  font-family:var(--font-mono);
  font-size:9px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--n400);
  font-weight:600;
  margin-bottom:4px;
}
.ph06-comp-reason{
  font-family:var(--font-sans);
  font-size:11.5px;
  line-height:1.45;
  color:var(--n500);
  margin-bottom:10px;
}

/* Area of improvement strip */
.ph06-aoi{
  background:#FBE8E0;
  border-radius:10px;
  padding:9px 11px 10px;
  margin-bottom:10px;
}
.ph06-aoi-lbl{
  font-family:var(--font-mono);
  font-size:9px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:#A04018;
  font-weight:700;
  margin-bottom:4px;
}
.ph06-aoi-body{
  font-family:var(--font-sans);
  font-size:11px;
  line-height:1.4;
  color:#5C2710;
  display:flex;
  gap:6px;
  align-items:flex-start;
}
.ph06-aoi-body::before{
  content:"•";
  color:#A04018;
  font-weight:700;
  flex:0 0 auto;
}

/* View details button */
.ph06-view-details{
  display:inline-flex;
  align-items:center;
  gap:6px;
  background:transparent;
  border:1px solid var(--n300);
  color:var(--ink);
  font-family:var(--font-sans);
  font-size:11.5px;
  font-weight:500;
  padding:7px 14px;
  border-radius:20px;
  cursor:pointer;
}
.ph06-view-details::after{
  content:"→";
  color:var(--n400);
}

/* ━━━━━━ Tile 07 ━━━━━━ */
/* ───── Dashboard (cool canvas per locked two-canvas system) ───── */
.dash-07{
  width:100%;
  max-width:640px;
  background:#FAFAFA;
  border:1px solid #E5E7EB;
  border-radius:12px;
  padding:18px;
  box-shadow:
    0 20px 50px rgba(0,0,0,0.10),
    0 50px 120px rgba(0,0,0,0.05);
  --c-ink:#0A0A0A;
  --c-muted:#64748B;
  --c-line:#E5E7EB;
  --c-card:#FFFFFF;
  --c-bg-soft:#F1F5F9;
  color:var(--c-ink);
  font-family:var(--font-sans);
}

/* KPI strip header */
.dash07-strip-eyebrow{
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--c-muted);
  font-weight:600;
  margin-bottom:8px;
}

/* KPI cards row */
.dash07-kpi-row{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:8px;
  margin-bottom:18px;
}
.dash07-kpi{
  background:var(--c-card);
  border:1px solid var(--c-line);
  border-radius:8px;
  padding:11px 12px 12px;
}
.dash07-kpi-lbl{
  font-family:var(--font-mono);
  font-size:9px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--c-muted);
  font-weight:600;
  margin-bottom:5px;
}
.dash07-kpi-val{
  font-family:var(--font-display);
  font-weight:700;
  font-size:20px;
  color:var(--c-ink);
  letter-spacing:-0.01em;
  line-height:1.1;
}
.dash07-kpi-val .unit{
  font-size:13px;
  color:var(--c-muted);
  font-weight:600;
  margin-left:1px;
}
.dash07-kpi-sub{
  font-family:var(--font-sans);
  font-size:9.5px;
  color:var(--c-muted);
  margin-top:5px;
  line-height:1.3;
}
.dash07-chip{
  display:inline-block;
  font-family:var(--font-mono);
  font-size:8.5px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  font-weight:700;
  padding:2px 7px;
  border-radius:4px;
  margin-top:5px;
}
.dash07-chip.amber{background:#FEF3C7;color:#92400E}
.dash07-chip.red{background:#FEE2E2;color:#991B1B}

/* Matrix section header */
.dash07-matrix-eyebrow{
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--teal-700);
  font-weight:700;
  margin-bottom:8px;
}

/* Matrix card */
.dash07-matrix{
  background:var(--c-card);
  border:1px solid var(--c-line);
  border-radius:10px;
  padding:16px 16px 14px;
}
.dash07-matrix-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  margin-bottom:14px;
  gap:12px;
}
.dash07-matrix-title{
  font-family:var(--font-display);
  font-weight:700;
  font-size:14px;
  color:var(--c-ink);
  margin-bottom:2px;
  letter-spacing:-0.005em;
}
.dash07-matrix-sub{
  font-family:var(--font-sans);
  font-size:10.5px;
  color:var(--c-muted);
}
.dash07-filter{
  background:transparent;
  border:1px solid var(--c-line);
  font-family:var(--font-sans);
  font-size:10.5px;
  font-weight:500;
  color:var(--c-ink);
  padding:5px 10px 5px 12px;
  border-radius:14px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  cursor:pointer;
  flex:0 0 auto;
}
.dash07-filter::after{
  content:"▾";
  color:var(--c-muted);
  font-size:9px;
}

/* Matrix grid */
.dash07-grid{
  display:grid;
  grid-template-columns:90px 1fr 1fr 1fr;
  gap:6px;
}

/* Column headers */
.dash07-col{
  border-radius:6px;
  padding:7px 0;
  text-align:center;
  font-family:var(--font-mono);
  font-size:9.5px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  font-weight:700;
  color:#fff;
}
.dash07-col.green{background:#16A34A}
.dash07-col.amber{background:#D97706}
.dash07-col.red{background:#DC2626}
.dash07-col-spacer{}

/* Row labels */
.dash07-rowlbl{
  display:flex;
  align-items:center;
  font-family:var(--font-mono);
  font-size:9.5px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--c-ink);
  padding:0 4px;
}

/* Cells */
.dash07-cell{
  background:var(--c-card);
  border:1px solid var(--c-line);
  border-radius:6px;
  padding:8px 10px 9px;
  text-align:center;
  position:relative;
}
.dash07-cell.flag{
  border:1.5px solid #DC2626;
}
.dash07-cell-count{
  font-family:var(--font-display);
  font-weight:700;
  font-size:14px;
  color:var(--c-ink);
  line-height:1.1;
}
.dash07-cell-pct{
  font-family:var(--font-sans);
  font-size:9.5px;
  color:var(--c-muted);
  margin-top:2px;
}
.dash07-cell-rev{
  font-family:var(--font-display);
  font-weight:600;
  font-size:11.5px;
  color:var(--teal-700);
  margin-top:5px;
}
.dash07-cell-delta{
  font-family:var(--font-mono);
  font-size:8.5px;
  letter-spacing:0.06em;
  color:var(--c-muted);
  margin-top:2px;
}
.dash07-cell-delta.up{color:#16A34A}
.dash07-cell-delta.down{color:#DC2626}

/* ━━━━━━ Tile 08 ━━━━━━ */
/* Center the tile 08 section content */
.tile-frame > section:has(.lang08-grid){text-align:center;padding:64px 80px 72px}
.lang08-eyebrow{
  font-family:var(--font-mono);
  font-size:13px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  margin-bottom:18px;
  display:flex;
  flex-direction:column;
  gap:3px;
  align-items:center;
}
.lang08-eyebrow-top{font-weight:700;color:var(--ink);letter-spacing:0.16em}
.lang08-eyebrow-sub{color:var(--teal-700);font-weight:600;font-size:11px;letter-spacing:0.14em}

/* H2 */
.lang08-h2{
  font-family:var(--font-display);
  font-weight:700;
  font-size:54px;
  line-height:1.05;
  letter-spacing:-0.025em;
  color:var(--ink);
  margin:0 auto 16px;
  max-width:920px;
}
.lang08-h2 em{
  font-style:italic;
  color:var(--teal-700);
  font-weight:700;
}

/* Sub */
.lang08-sub{
  font-size:16px;
  line-height:1.55;
  color:var(--n500);
  max-width:580px;
  margin:0 auto 40px;
}

/* Language grid */
.lang08-grid{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:14px;
  max-width:880px;
  margin:0 auto;
}

/* Language chip */
.lang08-chip{
  background:var(--paper);
  border:1px solid var(--n200);
  border-radius:14px;
  padding:18px 22px 14px;
  min-width:120px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
  transition:all 0.15s ease;
}
.lang08-chip .native{
  font-family:var(--font-display);
  font-weight:600;
  font-size:22px;
  color:var(--ink);
  line-height:1.1;
  letter-spacing:-0.005em;
}
.lang08-chip .latin{
  font-family:var(--font-mono);
  font-size:9.5px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--n400);
  font-weight:600;
}

/* Selected state */
.lang08-chip.selected{
  background:var(--ink);
  border:1px solid var(--ink);
}
.lang08-chip.selected .native{
  color:var(--paper);
  font-family:var(--font-display);
  font-weight:600;
  font-style:italic;
}
.lang08-chip.selected .latin{
  color:#A89478;
}



/* ═══════════════════════ RESPONSIVE: TABLET (≤1024px) ═══════════════════════ */
@media (max-width: 1024px){
  .site-section{padding:48px 40px}
  .site-section.tall{padding:64px 40px}
  .feature-row{grid-template-columns:minmax(0,1fr);gap:48px}
  .feature-h2{font-size:38px}
  .hero-h1{font-size:52px}
  .hero-row{grid-template-columns:minmax(0,1fr);gap:36px}
  .lang08-h2{font-size:42px}
  .dash-07{max-width:560px;margin:0 auto}
}

/* ═══════════════════════ RESPONSIVE: MOBILE (≤768px) ═══════════════════════ */
@media (max-width: 768px){
  .hero-sub{max-width:100%;word-wrap:break-word;overflow-wrap:break-word}
  .feature-sub{max-width:100%}
  .lang08-sub{max-width:100%}
  .site-section{padding:40px 20px}
  .site-section.tall{padding:48px 20px}
  .site-section.hero-pad{padding:24px 20px 48px}
  .site-nav{padding:18px 0}
  .feature-row{grid-template-columns:minmax(0,1fr);gap:36px}
  .feature-h2{font-size:32px;line-height:1.1}
  .feature-sub{font-size:15px}
  .hero-h1{font-size:40px;line-height:1.05}
  .hero-sub{font-size:15px}

  /* Phones — center & cap width */
  .phone-04,.phone-05,.phone-06,.phone{margin:0 auto}

  /* Tile 02b AI Xpert */
  .x02b-row{grid-template-columns:minmax(0,1fr);gap:40px}
  .x02b-h2{font-size:32px}

  /* Tile 03 Learn — phone-sized layout */
  .ph-row{grid-template-columns:minmax(0,1fr);gap:36px}

  /* Tile 04 Pitch */
  .ph04-row{grid-template-columns:minmax(0,1fr);gap:36px}

  /* Tile 07 Dashboard — make it scroll horizontally if too wide */
  .dash-07{max-width:100%;font-size:11px;padding:14px}
  .dash07-kpi-row{grid-template-columns:repeat(2,1fr);gap:8px}
  .dash07-kpi-val{font-size:18px}
  .dash07-grid{grid-template-columns:64px 1fr 1fr 1fr;gap:4px;font-size:11px}
  .dash07-cell{padding:6px 4px}
  .dash07-cell-count{font-size:12px}
  .dash07-cell-pct{font-size:8.5px}
  .dash07-cell-rev{font-size:10px}
  .dash07-cell-delta{font-size:7.5px}
  .dash07-col{font-size:8.5px;padding:5px 0}
  .dash07-rowlbl{font-size:8.5px}

  /* Tile 08 Languages */
  .lang08-h2{font-size:32px;line-height:1.1}
  .lang08-grid{gap:10px;padding:0 8px}
  .lang08-chip{min-width:0;padding:14px 16px 11px}
  .lang08-chip .native{font-size:18px}
  .lang08-chip .latin{font-size:8.5px}

  /* Footer */
  .footer-minimal{padding:32px 20px}
  .footer-minimal-links{flex-wrap:wrap;gap:14px;font-size:12px;justify-content:center;text-align:center}

  /* Phone & device max-width constraint */
  .hero-device, .feature-visual{max-width:100%;overflow:hidden}
  .hero-device > *, .feature-visual > *{max-width:100%}
}

/* ═══════════════════════ Sticky nav ═══════════════════════ */
.proto-nav-wrap{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(247,243,234,0.92);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(27,20,12,0.06);
}





/* Section tone alternation for visual separation */
section.tone-shift{background:#EDE6D2}
@media (prefers-color-scheme: dark){}



/* Languages section centered (v20 spec) */
.lang08-section{text-align:center !important}
.lang08-section .lang08-eyebrow,
.lang08-section .lang08-h2,
.lang08-section .lang08-sub,
.lang08-section .lang08-grid{text-align:center}
.lang08-section .lang08-sub{margin-left:auto !important;margin-right:auto !important}


/* Footer minimal — v20 spec with visual separator */
.footer-minimal{
  background:#000000 !important;
  padding:36px 80px !important;
  display:flex;
  justify-content:center;
  align-items:center;
  border-top:none;
}
.footer-minimal-links a{color:rgba(255,255,255,0.55) !important}
.footer-minimal-links a:hover{color:#FFFFFF !important}
.footer-minimal-sep{background:rgba(255,255,255,0.25) !important}



/* Hero — compact for single-screen fit */
.hero-device .phone{
  width:280px !important;
  height:560px !important;
  padding:32px 20px !important;
  border-radius:34px !important;
}
.hero-device .phone .topbar,
.hero-device .phone .ph-topbar{margin-bottom:8px !important}
/* If chat/orb content has gaps, tighten them */
.hero-device .x02b-bubble{padding:10px 12px !important;font-size:11.5px !important}
.site-section.hero-pad{padding:16px 80px 48px !important}
@media (max-width: 1024px){
  .site-section.hero-pad{padding:32px 40px 48px !important}
}
@media (max-width: 768px){
  .hero-device .phone{width:260px !important;height:520px !important}
  .site-section.hero-pad{padding:24px 20px 40px !important}
}



/* ════════════ STORY-AWARE MOBILE COMPRESSION ════════════ */
@media (max-width: 768px){

  /* —— Fix: .feature-row.reverse collapse (was 2-column on mobile) —— */
  .feature-row.reverse{grid-template-columns:minmax(0,1fr) !important;gap:20px !important}
  .feature-row:not(.reverse){gap:20px !important}

  /* —— Nav compact stays compact —— */
  .site-section.compact{padding:0 20px !important}
  .proto-nav-wrap{padding:0 !important}
  
  /* —— Uniform mobile section rhythm —— */
  .site-section{padding:36px 20px !important}
  .site-section.tall{padding:36px 20px !important}
  .site-section.hero-pad{padding:16px 20px 40px !important}
  .site-section.tone-shift{padding:36px 20px !important}
  .lang08-section{padding:48px 20px !important}
  .footer-minimal{padding:32px 20px !important}

  /* —— Hero compression: smaller phone + tighter copy —— */
  .hero-h1{font-size:36px !important;line-height:1.05 !important;letter-spacing:-0.02em !important}
  .hero-sub{font-size:14.5px !important;line-height:1.55 !important;max-width:100% !important}
  .hero-tagline{font-size:15px !important;margin-top:24px !important;letter-spacing:0.05em !important;font-weight:600 !important}
  .hero-tagline .x{margin:0 4px !important;font-size:13px !important}
  .hero-tagline em{font-weight:600 !important;font-style:italic !important}
  .hero-device .phone{width:240px !important;height:480px !important;padding:24px 16px !important;border-radius:30px !important}
  .hero-device-intro-eyebrow,
  .hero-device > div:first-child{margin-bottom:14px !important}

  /* —— Phones: keep original sizes (shrinking width = taller height penalty) —— */
  /* Hero phone gets the only treatment because it's stacked WITH copy in same section */
  .hero-device .phone{width:300px !important;height:580px !important;padding:30px 20px !important;border-radius:34px !important}
  
  /* All other product phones keep original 320x640 */
  
  /* —— Learn carousel: clip to mobile width —— */

  
  /* —— Pitch CTA tap target —— */
  .ph04-cta{min-height:48px !important;padding:14px 24px !important}

  /* —— Feature copy tighten —— */
  .feature-h2{font-size:30px !important;line-height:1.1 !important;letter-spacing:-0.02em !important;margin-bottom:14px !important}
  .feature-sub{font-size:14.5px !important;line-height:1.55 !important;max-width:100% !important}
  .sec-eyebrow{margin-bottom:14px !important}
  .feature-copy{margin-bottom:0 !important}
  .feature-h2{margin-bottom:12px !important}
  .feature-sub{margin-bottom:0 !important}

  /* —— AI Xpert eyebrow + H2 (uses feature-h2 — already covered, but the .x02b-h2 might not exist) —— */

  /* —— Dashboard: bigger fonts + breathing —— */
  .dash-07{max-width:100% !important;padding:14px !important;border-radius:10px !important}
  .dash07-kpi-row{grid-template-columns:repeat(2,1fr) !important;gap:6px !important}
  .dash07-kpi{padding:10px !important}
  .dash07-kpi-val{font-size:18px !important}
  .dash07-grid{grid-template-columns:54px 1fr 1fr 1fr !important;gap:3px !important}
  .dash07-cell{padding:6px 3px !important}
  .dash07-cell-count{font-size:11px !important}
  .dash07-cell-pct{font-size:8px !important}
  .dash07-cell-rev{font-size:9.5px !important}
  .dash07-cell-delta{font-size:7px !important}
  .dash07-col{font-size:7.5px !important;padding:4px 0 !important;letter-spacing:0.06em !important}
  .dash07-rowlbl{font-size:7.5px !important}
  .dash07-matrix{padding:12px !important}
  .dash07-matrix-title{font-size:12.5px !important}
  .dash07-matrix-sub{font-size:9.5px !important}

  /* —— Languages tighten —— */
  .lang08-h2{font-size:30px !important;line-height:1.1 !important}
  .lang08-sub{font-size:14.5px !important;margin-bottom:28px !important}
  .lang08-grid{gap:8px !important}
  .lang08-chip{padding:12px 14px 10px !important;min-width:0 !important}
  .lang08-chip .native{font-size:17px !important}
  .lang08-chip .latin{font-size:8.5px !important}

  /* —— Tap targets (44px minimum) —— */
  .ph-cta,
  .ph05-end,
  .ph06-view-details,
  .dash07-filter{
    min-height:44px !important;
    padding-top:10px !important;
    padding-bottom:10px !important;
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
  }
  .footer-minimal-links a{padding:12px 6px !important;display:inline-block !important}
  .footer-minimal{flex-wrap:wrap !important}
  .footer-minimal-links{flex-wrap:wrap !important;gap:8px !important;justify-content:center !important}

}

/* ════════════ Very small screens ≤ 380px ════════════ */
@media (max-width: 380px){
  .hero-h1{font-size:32px !important}
  .feature-h2{font-size:26px !important}
  .lang08-h2{font-size:26px !important}
  .hero-device .phone{width:220px !important;height:440px !important}
}



/* ════════════ MOBILE READING ORDER FIX ════════════ */
/* Sections where HTML has visual before copy — flip to copy-first on mobile so context comes BEFORE proof. */
@media (max-width: 768px){
  #shadow + section .feature-copy,
  #dashboard + section .feature-copy,
  #learn + section .feature-copy{order:1}
  #shadow + section .feature-visual,
  #dashboard + section .feature-visual,
  #learn + section .feature-visual{order:2}
}



/* ═══════════════════════════════════════════════════════════════════════
   COMPREHENSIVE RESPONSIVE LAYER
   Adds: small-mobile polish, mid-tablet, large-desktop scaling, QHD/4K,
   landscape handling, image safety, and reduced-motion support.
   ═══════════════════════════════════════════════════════════════════════ */

/* ── Universal image safety: never overflow parent ── */
img{max-width:100%;height:auto;display:block}

/* ── Body padding adapts to viewport (fluid) ── */
@media (max-width: 1280px){
  body{padding:32px 24px 96px}
}
@media (max-width: 768px){
  body{padding:0 !important}
}

/* ═══════════════════════ EXTRA-SMALL MOBILE (≤480px) ═══════════════════════ */
@media (max-width: 480px){
  .site-section{padding:32px 16px !important}
  .site-section.tall{padding:32px 16px !important}
  .site-section.hero-pad{padding:16px 16px 32px !important}

  .hero-h1{font-size:34px !important;line-height:1.04 !important}
  .feature-h2{font-size:28px !important}
  .lang08-h2{font-size:28px !important}
  .hero-sub,.feature-sub,.lang08-sub{font-size:14px !important}

  /* Hero phone stays usable on small screens */
  .hero-device .phone{width:260px !important;height:520px !important;padding:24px 16px !important}

  /* Product phones scale down too */
  .phone-02b{width:100% !important;max-width:320px !important;min-height:580px !important;margin:0 auto !important}
  .phone-03,.phone-04,.phone-05,.phone-06{
    width:100% !important;
    max-width:320px !important;
    margin:0 auto !important;
  }

  /* Languages: keep 3 columns to avoid 1-tall lists */
  .lang08-grid{grid-template-columns:repeat(3,minmax(0,1fr)) !important;gap:8px !important}
  .lang08-chip{padding:10px 8px 8px !important}
  .lang08-chip .native{font-size:15px !important}
  .lang08-chip .latin{font-size:8px !important}

  /* Dashboard: condense further */
  .dash07-kpi-row{grid-template-columns:repeat(2,1fr) !important;gap:6px !important}
  .dash07-grid{grid-template-columns:48px 1fr 1fr 1fr !important}
  .dash07-cell-rev{font-size:9px !important}

  /* Footer: stack legal links */
  .footer-minimal-links{flex-direction:column !important;gap:10px !important}
  .footer-minimal-sep{display:none !important}
}

/* ═══════════════════════ MID-TABLET (769px – 1024px) ═══════════════════════ */
@media (min-width: 769px) and (max-width: 1024px){
  .site-section{padding:56px 48px}
  .site-section.tall{padding:72px 48px}

  /* Feature rows keep 2-col on tablet but tighter */
  .feature-row{grid-template-columns:1fr 1fr;gap:40px}
  .feature-row.reverse{grid-template-columns:1fr 1fr}

  .hero-row{grid-template-columns:1fr 1fr;gap:40px}
  .hero-h1{font-size:56px;line-height:1.04}
  .feature-h2{font-size:44px;line-height:1.04}
  .lang08-h2{font-size:44px}

  /* Phones scale down to fit two columns */
  .hero-device .phone{width:260px !important;height:520px !important}
  .phone-02b{width:320px !important}
  .phone-03,.phone-04,.phone-05,.phone-06{
    max-width:300px !important;
    margin:0 auto !important;
  }

  /* Dashboard cap */
  .dash-07{max-width:520px}

  /* Languages: 4-col on tablet */
  .lang08-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
}

/* ═══════════════════════ STANDARD DESKTOP (1025px – 1439px) ═══════════════════════ */
@media (min-width: 1025px) and (max-width: 1439px){
  .site-section{padding:64px 80px}
  .site-section.tall{padding:88px 80px}
  /* Constrain content to readable max-width and centre it */
  .site-section > .hero-row,
  .site-section > .feature-row,
  .site-section > .site-nav,
  .site-section.lang08-section,
  .site-section.footer-minimal{
    max-width:1280px;
    margin-left:auto;
    margin-right:auto;
  }
}

/* ═══════════════════════ LARGE DESKTOP (≥1440px) ═══════════════════════ */
@media (min-width: 1440px){
  .site-section{padding:80px 120px}
  .site-section.tall{padding:112px 120px}
  .site-section.hero-pad{padding:56px 120px 96px !important}

  /* Centred content rail */
  .site-section > .hero-row,
  .site-section > .feature-row,
  .site-section > .site-nav,
  .site-section.lang08-section,
  .site-section.footer-minimal{
    max-width:1440px;
    margin-left:auto;
    margin-right:auto;
  }

  /* Type scales up — display feels intentional on 27" screens */
  .hero-h1{font-size:84px;line-height:1.0;letter-spacing:-0.035em}
  .hero-sub{font-size:21px;max-width:540px}
  .feature-h2{font-size:72px;line-height:0.98}
  .feature-sub{font-size:19px;max-width:500px}
  .hero-tagline{font-size:20px;margin-top:44px}
  .lang08-h2{font-size:64px}
  .lang08-sub{font-size:18px;max-width:640px}

  /* Section eyebrows scale */
  .sec-eyebrow .sec-eyebrow-top{font-size:24px}

  /* Phones stay realistic device-sized — don't bloat */
  .hero-device .phone{width:320px !important;height:640px !important}

  /* Dashboard becomes slightly wider so the matrix breathes */
  .dash-07{max-width:640px}

  /* Languages chip rail centred */
  .lang08-grid{max-width:1100px;margin-left:auto;margin-right:auto}
}

/* ═══════════════════════ ULTRA-WIDE / QHD (≥1920px) ═══════════════════════ */
@media (min-width: 1920px){
  .site-section{padding:96px 160px}
  .site-section.tall{padding:144px 160px}
  .site-section.hero-pad{padding:80px 160px 120px !important}

  .site-section > .hero-row,
  .site-section > .feature-row,
  .site-section > .site-nav,
  .site-section.lang08-section,
  .site-section.footer-minimal{
    max-width:1600px;
  }

  .hero-h1{font-size:96px}
  .hero-sub{font-size:22px;max-width:580px}
  .feature-h2{font-size:80px}
  .feature-sub{font-size:20px;max-width:540px}
  .lang08-h2{font-size:72px}
  .lang08-sub{font-size:19px}

  .dash-07{max-width:720px}
}

/* ═══════════════════════ 4K / RETINA (≥2560px) ═══════════════════════ */
@media (min-width: 2560px){
  .site-section > .hero-row,
  .site-section > .feature-row,
  .site-section > .site-nav,
  .site-section.lang08-section,
  .site-section.footer-minimal{
    max-width:1800px;
  }
  .hero-h1{font-size:108px}
  .feature-h2{font-size:88px}
}

/* ═══════════════════════ LANDSCAPE PHONE / SHORT VIEWPORTS ═══════════════════════ */
@media (max-height: 600px) and (orientation: landscape){
  .hero-device .phone{height:auto !important;min-height:480px !important}
  .site-section.hero-pad{padding:16px 24px 32px !important}
  .hero-h1{font-size:40px !important}
}

/* ═══════════════════════ ACCESSIBILITY: REDUCED MOTION ═══════════════════════ */
@media (prefers-reduced-motion: reduce){
  *,
  *::before,
  *::after{
    animation-duration:0.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.001ms !important;
    scroll-behavior:auto !important;
  }
}

/* ═══════════════════════ DEVICE-INDEPENDENT GUARD RAILS ═══════════════════════ */
/* Prevent horizontal scroll at any viewport */
html,body{overflow-x:hidden;max-width:100vw}
.site-section{max-width:100vw;overflow-x:clip}

/* All flex / grid children should respect their column width */
.feature-row > *,
.hero-row > *{min-width:0}

/* Long, unbreakable words (URLs, technical terms) should wrap */
.hero-sub,.feature-sub,.lang08-sub,.ph-card-body{
  overflow-wrap:break-word;
  word-wrap:break-word;
}



/* ═══════════════════════════════════════════════════════════════════════
   LEGAL / POLICY PAGES (Privacy, Terms, Data Security)
   Single-column long-form prose using existing design tokens.
   ═══════════════════════════════════════════════════════════════════════ */
.legal-section{
  padding:64px 80px 96px;
}
.legal-wrap{
  max-width:820px;
  margin:0 auto;
}
.legal-back{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--n400);
  text-decoration:none;
  margin-bottom:28px;
}
.legal-back:hover{color:var(--teal-700)}
.legal-eyebrow{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--teal-700);
  margin-bottom:14px;
}
.legal-h1{
  font-family:var(--font-display);
  font-weight:700;
  font-size:56px;
  line-height:1.0;
  letter-spacing:-0.03em;
  color:var(--ink);
  margin-bottom:18px;
}
.legal-meta{
  font-family:var(--font-mono);
  font-size:12px;
  color:var(--n400);
  letter-spacing:0.04em;
  margin-bottom:14px;
}
.legal-entity{
  font-family:var(--font-display);
  font-weight:600;
  font-size:16px;
  color:var(--ink);
  margin-bottom:48px;
  padding-bottom:24px;
  border-bottom:0.5px solid var(--n200);
}
.legal-intro{
  font-size:17px;
  line-height:1.6;
  color:var(--n600);
  margin-bottom:14px;
}
.legal-intro:last-of-type{margin-bottom:32px}

.legal-section h2{
  font-family:var(--font-display);
  font-weight:700;
  font-size:28px;
  letter-spacing:-0.018em;
  color:var(--ink);
  margin-top:48px;
  margin-bottom:16px;
  line-height:1.15;
}
.legal-section h3{
  font-family:var(--font-display);
  font-weight:600;
  font-size:18px;
  letter-spacing:-0.005em;
  color:var(--ink);
  margin-top:28px;
  margin-bottom:10px;
}
.legal-section p{
  font-size:15.5px;
  line-height:1.65;
  color:var(--n600);
  margin-bottom:14px;
}
.legal-section p strong,
.legal-section li strong{
  color:var(--ink);
  font-weight:600;
}
.legal-section ul{
  list-style:none;
  padding:0;
  margin:0 0 18px;
}
.legal-section ul li{
  position:relative;
  padding:6px 0 6px 22px;
  font-size:15px;
  line-height:1.55;
  color:var(--n600);
}
.legal-section ul li::before{
  content:"";
  position:absolute;
  left:6px;
  top:16px;
  width:5px;
  height:5px;
  border-radius:50%;
  background:var(--teal-700);
}
.legal-section a{
  color:var(--teal-700);
  text-decoration:underline;
  text-underline-offset:3px;
  text-decoration-thickness:1px;
}
.legal-section a:hover{color:var(--teal-800)}
.legal-section .legal-callout{
  background:var(--n100);
  border-left:3px solid var(--teal-700);
  padding:14px 18px;
  border-radius:0 8px 8px 0;
  margin:16px 0 24px;
}
.legal-section .legal-callout p{margin-bottom:0;color:var(--ink);font-weight:500}
.legal-section .legal-address{
  font-style:normal;
  font-size:15px;
  line-height:1.55;
  color:var(--n600);
  margin-bottom:14px;
}
.legal-section .legal-address strong{color:var(--ink)}

/* Responsive: legal pages */
@media (max-width: 1024px){
  .legal-section{padding:48px 48px 72px}
  .legal-h1{font-size:48px}
}
@media (max-width: 768px){
  .legal-section{padding:36px 20px 56px}
  .legal-h1{font-size:36px}
  .legal-section h2{font-size:22px;margin-top:36px}
  .legal-section h3{font-size:16px}
  .legal-section p{font-size:15px}
  .legal-section ul li{font-size:14.5px}
  .legal-entity{margin-bottom:32px}
}
@media (min-width: 1440px){
  .legal-wrap{max-width:880px}
  .legal-h1{font-size:64px}
  .legal-section h2{font-size:32px}
}










