:root{
  --surface: #0E0E13;
  --surface-dim: #0A0A0E;
  --surface-bright: #3A3A4D;
  --surface-container-lowest: #07070A;
  --surface-container-low: #14141D;
  --surface-container: #1B1B26;
  --surface-container-high: #242430;
  --surface-container-highest: #2D2D3B;
  --on-surface: #F3F2F8;
  --on-surface-variant: #9C9CB2;
  --outline-variant: rgba(255,255,255,0.08);
  --primary: #A368FF;
  --primary-container: #4B2A8C;
  --secondary: #F5A623;
  --secondary-container: #5C4419;
  --danger: #FF8A8A;
  --gradient-flow: linear-gradient(120deg, #FFC56B 0%, #F5A623 28%, #C77DFF 64%, #A368FF 100%);

  --font-display: 'Manrope', sans-serif;
  --font-body: 'Inter', sans-serif;

  --radius-md: 0.75rem;
  --radius-lg: 1.25rem;
  --radius-xl: 1.5rem;
  --radius-full: 999px;

  --container-w: 1180px;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior: smooth; }
html,body{ background: var(--surface); color: var(--on-surface); }
body{
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img{ display:block; max-width:100%; }
ul{ list-style:none; }
a{ color: inherit; text-decoration: none; }
button{ font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }

:focus-visible{
  outline: 2px solid var(--secondary);
  outline-offset: 3px;
  border-radius: 4px;
}

.visually-hidden{
  position:absolute !important;
  left:-9999px !important;
  width:1px; height:1px;
  overflow:hidden;
}

/* Skip link */
.skip-link{
  position:absolute;
  left: 1rem; top: -3rem;
  background: var(--surface-container-high);
  color: var(--on-surface);
  padding: 0.6rem 1rem;
  border-radius: var(--radius-md);
  font-size: 0.85rem;
  font-weight: 600;
  z-index: 1000;
  transition: top 0.2s ease;
}
.skip-link:focus{ top: 1rem; }

/* ---------- Layout helpers ---------- */
.wrap{
  position:relative;
  z-index: 1;
  max-width: var(--container-w);
  margin: 0 auto;
  padding: 0 1.5rem;
}
.section{
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  padding: 7rem 0;
  overflow: hidden;
}
.eyebrow{
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--secondary);
  margin-bottom: 1.5rem;
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
}
.eyebrow::before{
  content:'';
  display:block;
  width: 1.5rem;
  height: 1px;
  background: var(--secondary);
  opacity: 0.6;
}
.headline{
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(2.6rem, 6vw, 4.6rem);
  line-height: 1.04;
  letter-spacing: -0.02em;
  margin-bottom: 1.5rem;
}
.headline em{
  font-style: normal;
  background: var(--gradient-flow);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}
.lede{
  font-size: clamp(1rem, 1.2vw, 1.15rem);
  color: var(--on-surface-variant);
  max-width: 38ch;
  line-height: 1.75;
  margin-bottom: 2.25rem;
}
.ghost-rule{
  border: none;
  border-top: 1px solid var(--outline-variant);
  margin: 2rem 0;
}

/* ---------- Buttons ---------- */
.actions{ display:flex; flex-wrap:wrap; gap: 0.9rem; align-items:center; }
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:0.5rem;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.95rem;
  padding: 0.95rem 1.9rem;
  border-radius: var(--radius-full);
  transition: transform 0.25s ease, box-shadow 0.25s ease, opacity 0.25s ease, background 0.25s ease;
  white-space: nowrap;
}
.btn--primary{
  background: var(--gradient-flow);
  color: #1B1325;
  box-shadow: 0 12px 30px -12px rgba(163,104,255,0.55);
}
.btn--primary:hover{ transform: translateY(-2px); box-shadow: 0 16px 36px -12px rgba(163,104,255,0.7); }
.btn--ghost{
  background: var(--surface-container-high);
  color: var(--on-surface);
  box-shadow: inset 1px 1px 0 rgba(255,255,255,0.05), inset -1px -1px 0 rgba(0,0,0,0.35);
}
.btn--ghost:hover{ background: var(--surface-container-highest); }
.btn--text{
  color: var(--on-surface-variant);
  padding: 0.95rem 0.5rem;
}
.btn--text:hover{ color: var(--on-surface); }
.btn--text svg{ transition: transform 0.25s ease; }
.btn--text:hover svg{ transform: translateY(3px); }
.btn--full{ width:100%; }
.btn[disabled]{ opacity:0.55; cursor:not-allowed; transform:none !important; }

/* ---------- Loader ---------- */
.loader{
  position: fixed;
  inset: 0;
  z-index: 999;
  background: var(--surface);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap: 1.4rem;
  transition: opacity 0.7s ease, visibility 0.7s ease;
}
.loader.is-hidden{ opacity:0; visibility:hidden; pointer-events:none; }
.loader-mark{
  width: 84px; height: 84px;
  border-radius: 22px;
  background: var(--surface-container-low);
  display:flex; align-items:center; justify-content:center;
  box-shadow: 0 0 60px 10px rgba(245,166,35,0.18);
  animation: pulseGlow 2.2s ease-in-out infinite;
}
.loader-mark svg{ width: 42px; height: 42px; }
.loader-word{
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 2.1rem;
  background: var(--gradient-flow);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}
.loader-tagline{
  font-size: 0.7rem;
  letter-spacing: 0.34em;
  color: var(--on-surface-variant);
  text-transform: uppercase;
}
.loader-bar{
  width: 160px; height: 2px;
  background: var(--surface-container-high);
  border-radius: var(--radius-full);
  overflow: hidden;
  margin-top: 1rem;
}
.loader-bar-fill{
  height: 100%;
  width: 0%;
  background: var(--gradient-flow);
  animation: fillBar 1.7s cubic-bezier(.4,0,.2,1) forwards;
}
.loader-status{
  font-size: 0.65rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--on-surface-variant);
  opacity: 0.7;
}
@keyframes pulseGlow{
  0%, 100%{ box-shadow: 0 0 40px 6px rgba(245,166,35,0.14); }
  50%{ box-shadow: 0 0 70px 14px rgba(163,104,255,0.22); }
}
@keyframes fillBar{ to{ width: 100%; } }

/* ---------- Nav ---------- */
.nav{
  position: fixed;
  top: 0; left:0; right:0;
  z-index: 100;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 1.25rem 1.5rem;
  transition: background 0.4s ease, backdrop-filter 0.4s ease, box-shadow 0.4s ease;
}
.nav.is-scrolled{
  background: rgba(14,14,19,0.6);
  backdrop-filter: blur(18px);
  box-shadow: 0 1px 0 var(--outline-variant);
}
.nav-brand{
  display:flex; align-items:center; gap:0.6rem;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.15rem;
}
.nav-brand svg{ width:26px; height:26px; }
.nav-brand span{
  background: var(--gradient-flow);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}
.nav .btn{ padding: 0.7rem 1.4rem; font-size: 0.85rem; }

/* ---------- Section navigation (labeled, replaces dots) ---------- */
.section-nav{
  position: fixed;
  right: 1.25rem;
  top: 50%;
  transform: translateY(-50%);
  z-index: 90;
  display:flex;
  flex-direction:column;
  gap: 0.2rem;
  padding: 0.6rem;
  border-radius: var(--radius-lg);
  background: rgba(20,20,29,0.5);
  backdrop-filter: blur(14px);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.06), 0 16px 40px -18px rgba(0,0,0,0.6);
}
.section-nav__item{
  display:flex; align-items:center; gap:0.6rem;
  padding: 0.4rem 0.7rem;
  border-radius: var(--radius-md);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--on-surface-variant);
  transition: color 0.25s ease, background 0.25s ease;
  white-space: nowrap;
}
.section-nav__item:hover{ color: var(--on-surface); background: rgba(255,255,255,0.05); }
.section-nav__dot{
  width:7px; height:7px; border-radius:50%;
  background: var(--surface-container-high);
  box-shadow: inset 0 0 0 1px var(--outline-variant);
  flex-shrink:0;
  transition: background 0.3s ease, box-shadow 0.3s ease, transform 0.3s ease;
}
.section-nav__item.is-active{ color: var(--on-surface); }
.section-nav__item.is-active .section-nav__dot{
  background: var(--gradient-flow);
  box-shadow: none;
  transform: scale(1.25);
}
@media (max-width: 1240px){
  .section-nav{ display:none; }
}

/* ---------- Reveal animation ---------- */
.reveal{
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.9s cubic-bezier(.16,1,.3,1), transform 0.9s cubic-bezier(.16,1,.3,1);
}
.reveal.is-visible{ opacity:1; transform: translateY(0); }
.reveal-delay-1{ transition-delay: 0.08s; }
.reveal-delay-2{ transition-delay: 0.16s; }
.reveal-delay-3{ transition-delay: 0.24s; }

/* ---------- Ambient glow orbs ---------- */
.glow{
  position:absolute;
  border-radius: 50%;
  filter: blur(110px);
  pointer-events:none;
  mix-blend-mode: screen;
  opacity: 0.28;
}
.glow--gold{ background: #F5A623; }
.glow--purple{ background: #7C3AED; }
@keyframes drift{
  0%{ transform: translate(0,0) scale(1); }
  50%{ transform: translate(30px,-40px) scale(1.08); }
  100%{ transform: translate(0,0) scale(1); }
}
.glow{ animation: drift 26s ease-in-out infinite; }

/* ---------- Sparkles (Aceternity) ---------- */
.sparkles-wrap{
  position:absolute;
  inset:0;
  pointer-events:none;
}
.sparkles-wrap canvas{ display:block; }

/* ---------- Split layout ---------- */
.split{
  display:grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 4rem;
  align-items:center;
  width:100%;
}
.split--reverse{ grid-template-columns: 1fr 1.05fr; }
.split--reverse .text{ order:2; }
.split--reverse .visual{ order:1; }
@media (max-width: 900px){
  .split, .split--reverse{ grid-template-columns: 1fr; gap: 3rem; text-align:left; }
  .split .text, .split--reverse .text{ order:1; }
  .split .visual, .split--reverse .visual{ order:2; }
}

/* ---------- Phone frame ---------- */
.visual{ position:relative; display:flex; justify-content:center; }
.phone{
  position:relative;
  width: min(280px, 78vw);
  aspect-ratio: 520 / 1127;
  border-radius: 2.4rem;
  background: var(--surface-container-lowest);
  box-shadow:
    0 30px 80px -28px rgba(0,0,0,0.7),
    inset 0 0 0 1px rgba(255,255,255,0.05);
  overflow:hidden;
  z-index: 2;
}
.phone img{ width:100%; height:100%; object-fit:cover; object-position: top; }
.phone--stack-back{
  position:absolute;
  width: min(240px, 66vw);
  top: 6%;
  right: -6%;
  transform: rotate(7deg);
  opacity: 0.55;
  z-index: 1;
  filter: saturate(0.85);
}
.phone--stack-front{
  transform: rotate(-4deg);
}
@media (max-width: 900px){
  .phone--stack-back{ display:none; }
  .phone--stack-front{ transform:none; }
}

/* Floating glass chip */
.chip{
  position:absolute;
  display:flex;
  flex-direction:column;
  gap: 0.2rem;
  padding: 0.85rem 1.1rem;
  border-radius: var(--radius-lg);
  background: rgba(28,28,38,0.55);
  backdrop-filter: blur(18px);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.07), 0 16px 40px -18px rgba(0,0,0,0.6);
  z-index: 3;
  max-width: 200px;
}
.chip-label{
  font-size: 0.65rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--secondary);
  font-weight: 600;
}
.chip-title{ font-weight: 700; font-size: 0.95rem; }
.chip-meta{ font-size: 0.78rem; color: var(--on-surface-variant); }

/* ---------- Hero ---------- */
.section--hero{ padding-top: 9rem; }
.hero-phone-wrap{ position:relative; display:flex; justify-content:center; }
.tele-phone{
  position:relative;
  width: min(280px, 78vw);
  aspect-ratio: 9/19.5;
  border-radius: 2.8rem;
  background: var(--surface-container-low);
  padding: 0.5rem;
  box-shadow:
    0 40px 90px -28px rgba(0,0,0,0.8),
    0 0 0 1px rgba(255,255,255,0.06),
    0 0 70px -10px rgba(163,104,255,0.35);
  z-index:2;
}
.tele-island{
  position:absolute;
  top: 22px; left:50%;
  transform: translateX(-50%);
  width: 80px; height: 22px;
  background:#000;
  border-radius: 14px;
  z-index: 5;
  box-shadow: 0 0 0 1px rgba(255,255,255,0.08);
}
.tele-screen{
  position:absolute; inset: 0.5rem;
  border-radius: 2.35rem;
  display:flex; align-items:center; justify-content:center;
  padding: 0 1.5rem;
  overflow:hidden;
  background:
    radial-gradient(circle at 50% 35%, rgba(163,104,255,0.12), transparent 60%),
    #000;
}
.tele-lines{
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.05rem;
  line-height: 1.8;
  text-align:center;
  color: #fff;
  animation: scrollText 28s linear infinite;
}
.tele-lines p{ margin-bottom: 1.7em; }
.tele-lines .word{ transition: color 0.35s ease, text-shadow 0.35s ease; }
.tele-lines .word.active{
  color: var(--secondary);
  text-shadow: 0 0 18px rgba(245,166,35,0.55);
}
@keyframes scrollText{
  from{ transform: translateY(8%); }
  to{ transform: translateY(-58%); }
}
.pip-cam{
  position:absolute;
  top: 46px; right: 16px;
  width: 64px; height: 86px;
  border-radius: 1rem;
  background: linear-gradient(150deg, rgba(245,166,35,0.28), rgba(163,104,255,0.32));
  backdrop-filter: blur(8px);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.18), 0 10px 24px -12px rgba(0,0,0,0.6);
  z-index: 6;
  display:flex; align-items:center; justify-content:center;
}
.pip-cam svg{ width:22px; height:22px; opacity:0.85; }
.tele-fade-top, .tele-fade-bottom{
  position:absolute; left:0; right:0; height: 22%;
  pointer-events:none; z-index:4;
}
.tele-fade-top{ top:0; background: linear-gradient(to bottom, #000 10%, transparent); }
.tele-fade-bottom{ bottom:0; background: linear-gradient(to top, #000 10%, transparent); }
.speed-chip{
  position:absolute;
  bottom: -22px; left: 50%;
  transform: translateX(-50%);
  z-index: 7;
  display:flex; align-items:center; gap:0.6rem;
  padding: 0.6rem 1.1rem;
  background: rgba(28,28,38,0.65);
  backdrop-filter: blur(18px);
  border-radius: var(--radius-full);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.08), 0 16px 40px -16px rgba(0,0,0,0.7);
  font-size: 0.78rem;
  white-space:nowrap;
}
.speed-chip .dotline{
  width: 60px; height: 3px; border-radius: 2px;
  background: var(--surface-container-high);
  position:relative; overflow:hidden;
}
.speed-chip .dotline::after{
  content:''; position:absolute; inset:0;
  width:60%; background: var(--gradient-flow);
  border-radius:2px;
}

/* ---------- Trust strip ---------- */
.trust-strip{
  display:flex;
  flex-wrap:wrap;
  gap: 1.5rem;
  margin-top: 0.5rem;
}
.trust-strip li{
  display:flex; align-items:center; gap:0.55rem;
  font-size: 0.85rem;
  color: var(--on-surface-variant);
}
.trust-strip li svg{
  width:18px; height:18px;
  color: var(--secondary);
  flex-shrink:0;
}

/* ---------- Pricing ---------- */
.period-toggle{
  display:inline-flex;
  gap: 0.25rem;
  padding: 0.3rem;
  background: var(--surface-container);
  border-radius: var(--radius-full);
  margin-bottom: 1.75rem;
  box-shadow: inset 1px 1px 0 rgba(255,255,255,0.04), inset -1px -1px 0 rgba(0,0,0,0.3);
}
.period-btn{
  display:flex; align-items:center; gap:0.5rem;
  padding: 0.55rem 1.3rem;
  border-radius: var(--radius-full);
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--on-surface-variant);
  transition: background 0.25s ease, color 0.25s ease;
}
.period-btn.is-active{
  background: var(--surface-container-high);
  color: var(--on-surface);
  box-shadow: inset 1px 1px 0 rgba(255,255,255,0.06);
}
.save-pill{
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  padding: 0.15rem 0.5rem;
  border-radius: var(--radius-full);
  background: var(--gradient-flow);
  color: #1B1325;
}
.pricing{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  max-width: 720px;
}
@media (max-width: 760px){
  .pricing{ grid-template-columns: 1fr; }
}
.price-card{
  background: var(--surface-container);
  border-radius: var(--radius-xl);
  padding: 2rem;
  display:flex;
  flex-direction:column;
  gap: 1.5rem;
}
.price-card--pro{
  background: var(--surface-container-high);
  box-shadow: 0 0 0 1.5px rgba(163,104,255,0.4), 0 24px 60px -28px rgba(163,104,255,0.45);
  position:relative;
}
.price-card-badge{
  position:absolute;
  top: -0.75rem; right: 1.5rem;
  background: var(--gradient-flow);
  color: #1B1325;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0.35rem 0.85rem;
  border-radius: var(--radius-full);
}
.price-card h3{
  font-family: var(--font-display);
  font-size: 1.35rem;
  font-weight: 700;
}
.price-row{ display:flex; align-items:baseline; gap:0.35rem; margin-top: -0.75rem; flex-wrap:wrap; }
.price-row .amount{ font-family: var(--font-display); font-weight: 800; font-size: 2.1rem; }
.price-row .period{ color: var(--on-surface-variant); font-size: 0.85rem; }
.billed-note{
  font-size: 0.78rem;
  color: var(--on-surface-variant);
  margin-top: -1.25rem;
  min-height: 1.1em;
}
.checklist{ display:flex; flex-direction:column; gap: 0.85rem; flex:1; }
.checklist li{
  display:flex; align-items:flex-start; gap:0.7rem;
  font-size: 0.92rem; color: var(--on-surface);
}
.checklist li svg{ flex-shrink:0; margin-top:0.15rem; width:16px; height:16px; color: var(--secondary); }
.price-card--pro .checklist li svg{ color: var(--primary); }
.fine-print{
  font-size: 0.78rem;
  color: var(--on-surface-variant);
  max-width: 720px;
  margin-top: 1.5rem;
  line-height: 1.7;
}
.fine-print a{
  color: var(--on-surface-variant);
  text-decoration: underline;
  text-decoration-color: var(--outline-variant);
  text-underline-offset: 2px;
}
.fine-print a:hover{ color: var(--on-surface); }

/* ---------- Final CTA ---------- */
.section--final{
  background: radial-gradient(circle at 30% 20%, rgba(245,166,35,0.20), transparent 55%),
              radial-gradient(circle at 75% 80%, rgba(163,104,255,0.28), transparent 55%),
              var(--surface-dim);
  text-align:center;
  flex-direction:column;
  justify-content:center;
  gap: 1rem;
}
.section--final .wrap{ display:flex; flex-direction:column; align-items:center; }
.section--final .lede{ text-align:center; }

/* ---------- Footer ---------- */
footer{
  background: var(--surface-container-lowest);
  padding: 3rem 0;
}
.footer-row{
  display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:1.5rem;
}
.footer-links{ display:flex; gap:1.75rem; flex-wrap:wrap; }
.footer-links a{ color: var(--on-surface-variant); font-size:0.85rem; transition: color 0.2s ease; }
.footer-links a:hover{ color: var(--on-surface); }
.footer-copy{ font-size: 0.8rem; color: var(--on-surface-variant); }
.footer-bottom{
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--outline-variant);
  display:flex; flex-wrap:wrap; gap:1rem; justify-content:space-between; align-items:center;
}
.footer-credit{ font-size: 0.75rem; color: var(--on-surface-variant); }
.footer-credit a{ color: var(--on-surface-variant); text-decoration: underline; text-decoration-color: var(--outline-variant); text-underline-offset:2px; }
.footer-credit a:hover{ color: var(--on-surface); }

/* ---------- Section-specific tints ---------- */
.tint-low{ background: var(--surface-container-low); }
.tint-base{ background: var(--surface); }

/* ================= Sub-pages (Privacy / Terms / Contact) ================= */
.page-hero{
  padding: 9rem 0 2.5rem;
  position:relative;
  overflow:hidden;
}
.page-hero h1{
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(2.2rem, 5vw, 3.4rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin-bottom: 0.85rem;
}
.page-meta{ color: var(--on-surface-variant); font-size: 0.85rem; }
.page-lede{
  color: var(--on-surface-variant);
  max-width: 56ch;
  line-height: 1.75;
  margin-top: 1rem;
}

.legal{ padding: 1rem 0 6rem; }
.legal .wrap{ max-width: 760px; }
.legal h2{
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.45rem;
  letter-spacing: -0.01em;
  margin: 2.5rem 0 1rem;
}
.legal h2:first-of-type{ margin-top: 0; }
.legal h3{
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.05rem;
  margin: 1.5rem 0 0.75rem;
}
.legal p{ color: var(--on-surface-variant); margin-bottom: 1rem; }
.legal strong{ color: var(--on-surface); }
.legal a{ color: var(--primary); text-decoration: underline; text-decoration-color: rgba(163,104,255,0.35); text-underline-offset: 2px; }
.legal a:hover{ text-decoration-color: var(--primary); }
.legal ul, .legal ol{ margin: 0 0 1.25rem 0; display:flex; flex-direction:column; gap: 0.6rem; color: var(--on-surface-variant); }
.legal ul{ padding-left: 0; }
.legal ul li{ position:relative; padding-left: 1.4rem; }
.legal ul li::before{
  content:''; position:absolute; left:0; top:0.65em;
  width: 0.5rem; height: 2px; border-radius: 2px;
  background: var(--gradient-flow);
}
.legal ol{ padding-left: 1.4rem; }
.legal .callout{
  background: var(--surface-container-low);
  border-radius: var(--radius-lg);
  padding: 1.25rem 1.5rem;
  margin: 1.5rem 0;
  color: var(--on-surface-variant);
  font-size: 0.92rem;
}
.legal .callout strong{ color: var(--on-surface); }
.toc{
  background: var(--surface-container-low);
  border-radius: var(--radius-lg);
  padding: 1.5rem 1.75rem;
  margin-bottom: 2.5rem;
}
.toc p{ margin:0 0 0.75rem; font-size:0.75rem; letter-spacing:0.18em; text-transform:uppercase; color: var(--secondary); font-weight:600; }
.toc ol{ margin:0; padding-left: 1.25rem; display:flex; flex-direction:column; gap:0.4rem; color: var(--on-surface-variant); font-size:0.92rem; }
.toc a{ color: var(--on-surface-variant); }
.toc a:hover{ color: var(--on-surface); }

/* ---------- Contact page ---------- */
.contact{ padding: 1rem 0 6rem; }
.contact-grid{
  display:grid;
  grid-template-columns: 1fr 1.15fr;
  gap: 3rem;
  align-items:start;
}
@media (max-width: 900px){
  .contact-grid{ grid-template-columns: 1fr; }
}
.contact-card{
  background: var(--surface-container);
  border-radius: var(--radius-xl);
  padding: 2rem;
}
.contact-card h2{
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.25rem;
  margin-bottom: 0.5rem;
}
.contact-card p{ color: var(--on-surface-variant); font-size:0.92rem; line-height:1.7; }
.contact-list{ display:flex; flex-direction:column; gap: 1.25rem; margin-top: 1.5rem; }
.contact-list a{ color: var(--on-surface); font-weight:600; font-size:0.95rem; }
.contact-list a:hover{ color: var(--secondary); }
.contact-label{
  display:block; font-size:0.7rem; letter-spacing:0.2em; text-transform:uppercase;
  color: var(--secondary); margin-bottom:0.25rem; font-weight:600;
}

.form-card{
  background: var(--surface-container);
  border-radius: var(--radius-xl);
  padding: 2rem;
}
.form-field{ display:flex; flex-direction:column; gap:0.5rem; margin-bottom:1.25rem; }
.form-field label{ font-size:0.85rem; font-weight:600; color: var(--on-surface); }
.form-field input, .form-field select, .form-field textarea{
  background: var(--surface-container-low);
  border-radius: var(--radius-md);
  padding: 0.85rem 1rem;
  color: var(--on-surface);
  font-family: var(--font-body);
  font-size: 0.95rem;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.05);
  transition: box-shadow 0.2s ease;
  width: 100%;
}
.form-field select{
  appearance:none;
  cursor:pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239C9CB2' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  padding-right: 2.5rem;
}
.form-field input:focus, .form-field select:focus, .form-field textarea:focus{
  box-shadow: inset 0 0 0 1.5px var(--primary);
}
.form-field textarea{ min-height: 140px; resize: vertical; }
.form-row{ display:grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 560px){ .form-row{ grid-template-columns: 1fr; } }
.form-note{ font-size: 0.78rem; color: var(--on-surface-variant); margin: -0.5rem 0 1.25rem; }
.form-status{
  display:none;
  padding: 0.85rem 1rem;
  border-radius: var(--radius-md);
  font-size: 0.9rem;
  margin-bottom: 1.25rem;
}
.form-status.is-success{ display:block; background: rgba(245,166,35,0.12); color: var(--secondary); }
.form-status.is-error{ display:block; background: rgba(255,138,138,0.12); color: var(--danger); }

/* ---------- Responsive type tweaks ---------- */
@media (max-width: 600px){
  .section{ padding: 5.5rem 0; min-height: auto; }
  .headline{ font-size: clamp(2.2rem, 9vw, 3rem); }
  .lede{ max-width: 100%; }
  .nav .btn{ padding: 0.6rem 1.1rem; font-size: 0.8rem; }
  .page-hero{ padding-top: 7.5rem; }
}

@media (prefers-reduced-motion: reduce){
  *{ animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; scroll-behavior:auto !important; }
  .tele-lines{ animation: none; transform: translateY(-20%); }
}
