/* =====================================================================
   Speak Easy Suite styles.css
   Editorial, gold-on-navy. Fraunces display + Source Sans 3 body,
   both self-hosted variable fonts. Mobile-first, WCAG AA+.
   ===================================================================== */

@font-face{
  font-family:"Fraunces";
  src:url("assets/fonts/fraunces-var.woff2") format("woff2");
  font-weight:100 900;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:"Source Sans 3";
  src:url("assets/fonts/source-sans-3-var.woff2") format("woff2");
  font-weight:200 900;
  font-style:normal;
  font-display:swap;
}

:root{
  --navy:#10141C;
  --navy-2:#0C1017;
  --panel:#171C26;
  --panel-2:#1E2530;
  --line:rgba(245,212,130,0.14);
  --line-soft:rgba(255,255,255,0.07);

  --gold:#F5D482;
  --gold-deep:#F6C177;
  --amber:#FF9800;
  --sage:#8FB339;
  --sage-deep:#6B8E23;

  --text:#F4F6EE;
  --muted:#BFC7CE;
  --muted-2:#9AA4AD;
  --ink:#161106;

  --display:"Fraunces", Georgia, "Times New Roman", serif;
  --body:"Source Sans 3", system-ui, sans-serif;

  --wrap:1180px;
  --gutter:clamp(20px, 5vw, 56px);
  --radius:18px;
  --radius-sm:12px;

  --t-fast:.18s ease;
  --t-med:.5s cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{ box-sizing:border-box; }

html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }

body{
  margin:0;
  font-family:var(--body);
  font-size:clamp(1.06rem, 0.98rem + 0.4vw, 1.22rem);
  line-height:1.62;
  font-weight:400;
  color:var(--text);
  background:var(--navy);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}

img{ max-width:100%; height:auto; display:block; }

h1,h2,h3,h4{
  font-family:var(--display);
  font-optical-sizing:auto;
  font-weight:600;
  line-height:1.04;
  letter-spacing:-0.01em;
  margin:0;
  text-wrap:balance;
}

p{ margin:0 0 1.1em; }
p:last-child{ margin-bottom:0; }

a{ color:var(--gold); text-decoration-thickness:1px; text-underline-offset:3px; }

.wrap{ width:100%; max-width:var(--wrap); margin-inline:auto; padding-inline:var(--gutter); }

.eyebrow{
  font-family:var(--body);
  font-size:.78rem;
  font-weight:700;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--sage);
  margin:0 0 .9rem;
}

.sr-only{
  position:absolute!important; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

.skip-link{
  position:absolute; left:12px; top:-60px; z-index:200;
  background:var(--gold); color:var(--ink); font-weight:700;
  padding:12px 18px; border-radius:10px; text-decoration:none;
  transition:top var(--t-fast);
}
.skip-link:focus{ top:12px; }

:focus-visible{
  outline:3px solid var(--gold);
  outline-offset:3px;
  border-radius:6px;
}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  min-height:48px; padding:13px 24px;
  font-family:var(--body); font-weight:700; font-size:1rem;
  border-radius:999px; text-decoration:none; cursor:pointer;
  border:1px solid transparent; transition:transform var(--t-fast), box-shadow var(--t-fast), background var(--t-fast);
}
.btn-primary{
  color:var(--ink);
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold-deep) 45%,var(--amber) 100%);
  box-shadow:0 10px 28px rgba(255,152,0,0.22);
}
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 16px 36px rgba(255,152,0,0.30); }
.btn-quiet{
  color:var(--gold);
  background:rgba(245,212,130,0.05);
  border-color:var(--line);
}
.btn-quiet:hover{ background:rgba(245,212,130,0.12); transform:translateY(-2px); }
.btn-small{ min-height:42px; padding:9px 18px; font-size:.92rem; }
.btn-lg{ min-height:56px; padding:16px 32px; font-size:1.08rem; }

/* Header */
.site-header{
  position:sticky; top:0; z-index:100;
  background:rgba(12,16,23,0.78);
  backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid var(--line-soft);
}
.header-inner{ display:flex; align-items:center; justify-content:space-between; gap:18px; padding-block:14px; }

.brand{ display:inline-flex; align-items:center; gap:12px; text-decoration:none; color:var(--text); }
.brand-mark{ width:44px; height:44px; border-radius:11px; box-shadow:0 4px 14px rgba(0,0,0,0.4); }
.brand-text{ display:flex; flex-direction:column; line-height:1.05; }
.brand-name{ font-family:var(--display); font-weight:600; font-size:1.18rem; letter-spacing:-0.01em; }
.brand-by{ font-size:.72rem; letter-spacing:0.14em; text-transform:uppercase; color:var(--muted-2); }

.site-nav{ display:flex; align-items:center; }
.nav-list{
  display:flex; align-items:center; gap:6px;
  list-style:none; margin:0; padding:0;
}
.nav-list a{
  display:inline-flex; align-items:center; min-height:44px; padding:8px 14px;
  color:var(--text); text-decoration:none; font-weight:600; font-size:.98rem;
  border-radius:10px; transition:background var(--t-fast), color var(--t-fast);
}
.nav-list a:hover{ background:rgba(245,212,130,0.08); color:var(--gold); }
.nav-cta a{ color:var(--ink); }

.nav-toggle{
  display:none; width:48px; height:48px; align-items:center; justify-content:center;
  background:transparent; border:1px solid var(--line); border-radius:12px; cursor:pointer;
}
.nav-toggle-bars, .nav-toggle-bars::before, .nav-toggle-bars::after{
  content:""; display:block; width:22px; height:2px; background:var(--gold); border-radius:2px;
  transition:transform var(--t-fast), opacity var(--t-fast);
}
.nav-toggle-bars{ position:relative; }
.nav-toggle-bars::before{ position:absolute; top:-7px; }
.nav-toggle-bars::after{ position:absolute; top:7px; }

@media (max-width:860px){
  .nav-toggle{ display:inline-flex; }
  .nav-list{
    position:absolute; right:var(--gutter); top:72px;
    flex-direction:column; align-items:stretch; gap:4px;
    background:var(--panel); border:1px solid var(--line);
    border-radius:16px; padding:10px; min-width:230px;
    box-shadow:0 24px 50px rgba(0,0,0,0.5);
    display:none;
  }
  .nav-list.open{ display:flex; }
  .nav-list a{ min-height:48px; }
  .nav-cta{ margin-top:4px; }
  .nav-cta a{ justify-content:center; background:linear-gradient(135deg,var(--gold),var(--amber)); }
  .nav-toggle[aria-expanded="true"] .nav-toggle-bars{ background:transparent; }
  .nav-toggle[aria-expanded="true"] .nav-toggle-bars::before{ transform:translateY(7px) rotate(45deg); }
  .nav-toggle[aria-expanded="true"] .nav-toggle-bars::after{ transform:translateY(-7px) rotate(-45deg); }
}

/* Hero */
.hero{ position:relative; padding-block:clamp(48px, 8vw, 104px) clamp(40px,6vw,80px); overflow:hidden; }
.hero-grid{
  display:grid; grid-template-columns:1fr; gap:clamp(36px,5vw,64px);
  align-items:center;
}
.hero-copy{ max-width:34rem; }

h1{ font-size:clamp(2.7rem, 1.8rem + 4.4vw, 5.2rem); font-weight:600; letter-spacing:-0.025em; }
h1 .hl{
  background:linear-gradient(120deg,var(--gold) 0%,var(--amber) 92%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  font-style:italic;
}
.lead{ margin-top:1.4rem; font-size:1.18rem; color:var(--muted); max-width:30rem; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:2rem; }

.hero-figure{ margin:0; }
.hero-figure figcaption{ margin-top:1.1rem; color:var(--muted); font-size:1rem; max-width:30rem; }
.hero-figure figcaption strong{ color:var(--gold); font-weight:700; }

.hero-glow{
  position:absolute; inset:auto -10% -40% 30%; height:560px; pointer-events:none; z-index:-1;
  background:radial-gradient(closest-side, rgba(255,152,0,0.16), rgba(246,193,119,0.06) 55%, transparent 75%);
  filter:blur(8px);
}

@media (min-width:900px){
  .hero-grid{ grid-template-columns:1.02fr 1.18fr; }
  .hero-copy{ padding-right:12px; }
}

/* Device frames */
.browser-frame{
  background:var(--panel); border:1px solid var(--line);
  border-radius:var(--radius); overflow:hidden;
  box-shadow:0 30px 70px rgba(0,0,0,0.55), 0 2px 0 rgba(255,255,255,0.04) inset;
  will-change:transform;
}
.browser-bar{
  display:flex; align-items:center; gap:8px;
  padding:11px 16px; background:rgba(255,255,255,0.035);
  border-bottom:1px solid var(--line-soft);
}
.browser-bar .dot{ width:11px; height:11px; border-radius:50%; background:rgba(255,255,255,0.18); }
.browser-bar .dot:nth-child(1){ background:#ff5f57; }
.browser-bar .dot:nth-child(2){ background:#febc2e; }
.browser-bar .dot:nth-child(3){ background:#28c840; }
.browser-title{
  margin-left:10px; font-size:.82rem; font-weight:600; letter-spacing:.02em; color:var(--muted-2);
}
.browser-frame .shot{ width:100%; display:block; }

.frame-soft{ box-shadow:0 18px 40px rgba(0,0,0,0.45); }

.phone-frame{
  margin:0; background:#05070b; border:1px solid var(--line);
  border-radius:30px; padding:10px; max-width:300px;
  box-shadow:0 24px 56px rgba(0,0,0,0.55);
  position:relative;
}
.phone-frame::before{
  content:""; position:absolute; top:18px; left:50%; transform:translateX(-50%);
  width:54px; height:5px; border-radius:3px; background:rgba(255,255,255,0.18); z-index:2;
}
.phone-frame .shot{ border-radius:22px; width:100%; }

/* Section scaffolding */
section{ position:relative; }
.story, .tools, .who, .adapts, .access{ padding-block:clamp(56px, 8vw, 116px); }

.section-head{ max-width:42rem; margin-bottom:clamp(40px,5vw,68px); }
.section-head h2, .who h2, .adapts h2, .story h2{ font-size:clamp(2rem, 1.4rem + 2.6vw, 3.3rem); }
.section-sub{ margin-top:1rem; color:var(--muted); font-size:1.12rem; }

/* Story */
.story{ border-top:1px solid var(--line-soft); background:linear-gradient(180deg, var(--navy) 0%, var(--navy-2) 100%); }
.story-grid{ display:grid; grid-template-columns:1fr; gap:clamp(24px,4vw,56px); }
.story-side h2{ font-size:clamp(2rem,1.4rem + 2.4vw,3rem); }
.story-body{ max-width:40rem; color:var(--muted); font-size:1.12rem; }
.story-body .story-mark{
  color:var(--text); font-family:var(--display); font-size:1.32rem; font-weight:500;
  line-height:1.4; border-left:3px solid var(--gold); padding-left:1.1rem; margin-top:1.6rem;
}
@media (min-width:860px){
  .story-grid{ grid-template-columns:0.8fr 1.2fr; align-items:start; }
  .story-side{ position:sticky; top:96px; }
}

/* Tools / spotlights */
.spotlight{
  display:grid; grid-template-columns:1fr; gap:clamp(24px,4vw,56px);
  align-items:center; margin-bottom:clamp(44px,6vw,88px);
}
.spotlight-figure{ margin:0; }
.spotlight-copy h3{ font-size:clamp(1.7rem,1.3rem + 1.6vw,2.5rem); color:var(--gold); margin-bottom:.7rem; }
.spotlight-copy p{ color:var(--muted); font-size:1.12rem; max-width:32rem; }
@media (min-width:880px){
  .spotlight{ grid-template-columns:1.25fr 0.95fr; gap:clamp(40px,5vw,72px); }
  .spotlight-flip .spotlight-figure{ order:2; }
  .spotlight-flip .spotlight-copy{ order:1; }
}

.gallery-head{
  font-size:clamp(1.3rem,1.1rem + 1vw,1.8rem); color:var(--text);
  margin:clamp(20px,3vw,40px) 0 clamp(26px,3vw,40px); font-weight:500;
}
.gallery{ display:grid; grid-template-columns:1fr; gap:clamp(28px,4vw,44px); }
@media (min-width:680px){ .gallery{ grid-template-columns:1fr 1fr; } }
@media (min-width:1040px){ .gallery{ grid-template-columns:repeat(3,1fr); } }

.tool{ display:flex; flex-direction:column; gap:18px; }
.tool .phone-frame{ max-width:230px; }
.tool-copy h4{ font-family:var(--display); font-weight:600; font-size:1.32rem; color:var(--gold); margin-bottom:.4rem; }
.tool-copy p{ color:var(--muted); font-size:1.02rem; }
@media (min-width:1040px){
  .tool .browser-frame, .tool .phone-frame{ align-self:flex-start; }
}

/* Who it is for */
.who{ border-top:1px solid var(--line-soft); }
.who-grid{ display:grid; grid-template-columns:1fr; gap:clamp(30px,4vw,56px); align-items:center; }
.who-copy{ max-width:38rem; }
.who-copy p{ color:var(--muted); font-size:1.12rem; }
.who-list{
  list-style:none; margin:0; padding:0;
  display:grid; grid-template-columns:1fr 1fr; gap:12px;
}
.who-list li{
  padding:16px 18px; border-radius:var(--radius-sm);
  background:linear-gradient(160deg, rgba(143,179,57,0.10), rgba(245,212,130,0.04));
  border:1px solid var(--line);
  font-weight:600; font-size:1rem; color:var(--text);
}
@media (min-width:920px){ .who-grid{ grid-template-columns:1.3fr 0.9fr; } }

/* How it adapts */
.adapts{ background:linear-gradient(180deg, var(--navy-2), var(--navy)); border-top:1px solid var(--line-soft); }
.adapts-inner{ max-width:62rem; }
.adapts-lead{ color:var(--muted); font-size:1.18rem; margin-top:1rem; max-width:40rem; }
.adapts-row{ display:grid; grid-template-columns:1fr; gap:24px; margin-top:clamp(34px,4vw,56px); }
.adapts-step{ background:var(--panel); border:1px solid var(--line); border-radius:var(--radius); padding:26px 24px; }
.step-num{
  display:inline-flex; align-items:center; justify-content:center;
  width:42px; height:42px; border-radius:12px; margin-bottom:14px;
  font-family:var(--display); font-weight:600; font-size:1.3rem; color:var(--ink);
  background:linear-gradient(135deg,var(--gold),var(--amber));
}
.adapts-step h3{ font-size:1.3rem; color:var(--text); margin-bottom:.5rem; }
.adapts-step p{ color:var(--muted); font-size:1.02rem; }
@media (min-width:820px){ .adapts-row{ grid-template-columns:repeat(3,1fr); } }

/* Mission moment */
.mission{
  padding-block:clamp(64px,9vw,128px);
  text-align:center;
  background:radial-gradient(120% 140% at 50% 0%, rgba(255,152,0,0.10), transparent 60%), var(--navy);
  border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
}
.mission-line{
  font-family:var(--display); font-optical-sizing:auto;
  font-weight:500; font-style:italic;
  font-size:clamp(2rem, 1.3rem + 3.6vw, 4rem);
  line-height:1.08; color:var(--gold);
  margin:0 auto; max-width:18ch;
}

/* Access */
.access-inner{ max-width:46rem; }
.access-inner h2{ font-size:clamp(2.1rem,1.5rem + 2.6vw,3.4rem); }
.access-inner > p{ color:var(--muted); font-size:1.16rem; margin-top:1rem; }
.access-actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:1.8rem; }
.access-note{ margin-top:1.4rem; color:var(--muted-2); font-size:.98rem; }

/* Footer */
.site-footer{ border-top:1px solid var(--line-soft); background:var(--navy-2); padding-block:clamp(40px,5vw,64px); }
.footer-grid{ display:grid; grid-template-columns:1fr; gap:30px; align-items:start; }
.footer-brand{ display:flex; align-items:center; gap:14px; }
.footer-brand img{ border-radius:10px; }
.footer-tag{ font-family:var(--display); font-style:italic; color:var(--muted); margin:0; font-size:1.05rem; }
.footer-nav{ display:flex; flex-wrap:wrap; gap:8px 22px; }
.footer-nav a{ color:var(--text); text-decoration:none; font-weight:600; }
.footer-nav a:hover{ color:var(--gold); }
.footer-contact{ display:flex; flex-direction:column; gap:6px; }
.footer-contact a{ color:var(--gold); text-decoration:none; }
.footer-contact a:hover{ text-decoration:underline; }
.footer-legal{ margin:8px 0 0; color:var(--muted-2); font-size:.9rem; }
@media (min-width:820px){
  .footer-grid{ grid-template-columns:1.2fr 1fr 1fr; }
  .footer-contact{ text-align:right; }
  .footer-nav{ justify-content:center; }
}

/* Motion */
.js .reveal{ opacity:0; transform:translateY(26px); transition:opacity var(--t-med), transform var(--t-med); }
.js .reveal.in{ opacity:1; transform:none; }

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