/* =============================================================
   GenApps — design system
   Distilled from inspiration deck: deep navy base, light-blue
   accent panels, rounded-bold wordmark (Nunito) + clean sans (Inter).
   ============================================================= */

:root {
  /* navy palette — mined from deck */
  --navy-900: #0E3460;
  --navy-800: #12426F;  /* deck hero bg */
  --navy-700: #1B568B;
  --navy-500: #2F7AB9;  /* mid accent */
  --sky-200:  #B7CEE3;  /* deck light panel */
  --sky-100:  #D6E4F0;
  --sky-050:  #EAF1F7;

  /* neutrals — warm-cool whites */
  --paper:    #F7F6F2;
  --paper-2:  #EFEDE6;
  --ink-900:  #0F1822;
  --ink-700:  #2A3644;
  --ink-500:  #5A6675;
  --ink-300:  #9AA4B2;
  --line:     #E3DFD6;

  /* accent (tweakable) */
  --accent:      var(--navy-800);
  --accent-soft: var(--sky-200);

  /* product brand colours — one per product */
  --vocado:        #4A7C4A;  /* forest green — sampled from vocado.pro app icon */
  --vocado-soft:   #EAF1E5;
  --vocado-deep:   #2E4F2E;
  --textchecker:   #7C3AED;  /* purple for the next product */
  --textchecker-soft: #EDE5FE;

  /* type */
  --f-display: "Nunito", ui-rounded, system-ui, sans-serif;
  --f-body:    "Inter", ui-sans-serif, system-ui, sans-serif;

  /* scale */
  --sp-1:  4px;
  --sp-2:  8px;
  --sp-3: 12px;
  --sp-4: 16px;
  --sp-5: 24px;
  --sp-6: 32px;
  --sp-7: 48px;
  --sp-8: 72px;
  --sp-9: 112px;

  --maxw: 1240px;
}

/* ---------- theme: Light with Dark Hero (default) ---------- */
body[data-theme="light-dark-hero"] {
  --bg:          var(--paper);
  --bg-alt:      #fff;
  --fg:          var(--ink-900);
  --fg-soft:     var(--ink-700);
  --fg-mute:     var(--ink-500);
  --rule:        var(--line);

  --hero-bg:     var(--navy-800);
  --hero-fg:     #ffffff;
  --hero-soft:   #B7CEE3;

  --panel-bg:    var(--sky-100);
  --panel-fg:    var(--navy-900);
  --panel-soft:  var(--navy-700);

  --accent:      var(--navy-800);
  --accent-soft: var(--sky-200);
}

/* ---------- theme: Full Dark ---------- */
body[data-theme="dark"] {
  --bg:       var(--navy-900);
  --bg-alt:   #0B2A4B;
  --fg:       #F3F6FA;
  --fg-soft:  #C9D7E6;
  --fg-mute:  #8AA0B8;
  --rule:     rgba(255,255,255,.10);

  --hero-bg:     var(--navy-900);
  --hero-fg:     #ffffff;
  --hero-soft:   #9EB8D1;

  --panel-bg:    #0B2A4B;
  --panel-fg:    #F3F6FA;
  --panel-soft:  #9EB8D1;

  --accent:      #8FB6DE;
  --accent-soft: #1B568B;
}

/* ---------- theme: Clean Light ---------- */
body[data-theme="light"] {
  --bg:       #FBFAF6;
  --bg-alt:   #ffffff;
  --fg:       var(--navy-900);
  --fg-soft:  #324A67;
  --fg-mute:  #6A7A8E;
  --rule:     #E3DFD6;

  --hero-bg:     #FBFAF6;
  --hero-fg:     var(--navy-900);
  --hero-soft:   #6A7A8E;

  --panel-bg:    #EEF3F8;
  --panel-fg:    var(--navy-900);
  --panel-soft:  var(--navy-700);

  --accent:      var(--navy-800);
  --accent-soft: #CFDDEC;
}

/* ---------- accent override ---------- */
body[data-accent="steel"] { --accent: #365A7A; --accent-soft: #C8D7E3; }
body[data-accent="ink"]   { --accent: #1B2430; --accent-soft: #D5D9DE; }

/* ==================== RESET & BASE ==================== */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--bg);
  color: var(--fg);
  font-family: var(--f-body);
  font-size: 17px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }

::selection { background: var(--accent); color: #fff; }

/* ==================== NAV ==================== */
.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: color-mix(in srgb, var(--bg) 82%, transparent);
  backdrop-filter: saturate(1.4) blur(10px);
  -webkit-backdrop-filter: saturate(1.4) blur(10px);
  border-bottom: 1px solid var(--rule);
}
.nav__inner {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 14px var(--sp-6);
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--sp-5);
  align-items: center;
}
.nav__brand { text-decoration: none; }
.brand-mark {
  font-family: var(--f-display);
  font-weight: 900;
  font-size: 22px;
  letter-spacing: -0.02em;
  color: var(--fg);
}
.nav__links {
  display: flex; gap: var(--sp-6);
  justify-content: center;
}
.nav__links a {
  text-decoration: none;
  color: var(--fg-soft);
  font-weight: 500;
  font-size: 14.5px;
  padding: 6px 0;
  border-bottom: 1.5px solid transparent;
  transition: border-color .2s, color .2s;
}
.nav__links a:hover { color: var(--fg); border-bottom-color: var(--accent); }

.nav__lang {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--f-body); font-size: 13px; font-weight: 600;
  color: var(--fg-mute);
}
.nav__lang button {
  padding: 4px 8px;
  border-radius: 6px;
  color: var(--fg-mute);
  letter-spacing: 0.06em;
}
.nav__lang button.is-on { color: var(--fg); background: var(--accent-soft); }

@media (max-width: 760px) {
  .nav__links { display: none; }
  .nav__inner { grid-template-columns: auto 1fr; }
}

/* ==================== HERO ==================== */
.hero {
  background: var(--hero-bg);
  color: var(--hero-fg);
  padding: var(--sp-9) var(--sp-6) var(--sp-8);
  position: relative;
  overflow: hidden;
}
.hero__inner {
  max-width: var(--maxw);
  margin: 0 auto;
}
.hero__word {
  font-family: var(--f-display);
  font-weight: 900;
  /* big & confident, matches deck wordmark */
  font-size: clamp(72px, 13vw, 200px);
  line-height: 0.92;
  letter-spacing: -0.035em;
  margin: 0;
  color: var(--hero-fg);
}
.hero__tagline {
  font-family: var(--f-display);
  font-weight: 700;
  font-size: clamp(22px, 3vw, 32px);
  color: var(--hero-soft);
  margin: var(--sp-5) 0 var(--sp-5);
  letter-spacing: -0.01em;
}
.hero__lede {
  max-width: 62ch;
  font-size: clamp(17px, 1.4vw, 19px);
  line-height: 1.55;
  color: color-mix(in srgb, var(--hero-fg) 85%, transparent);
  margin: 0 0 var(--sp-6);
}
.hero__scroll {
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--hero-soft);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-decoration: none;
  padding: 6px 2px;
  border-bottom: 1px solid color-mix(in srgb, var(--hero-soft) 40%, transparent);
  transition: color .2s, border-color .2s, transform .2s;
}
.hero__scroll:hover {
  color: var(--hero-fg);
  border-bottom-color: currentColor;
}
.hero__scroll svg { transition: transform .2s; }
.hero__scroll:hover svg { transform: translateY(2px); }

/* ==================== SECTION LAYOUT ==================== */
.section { padding: 168px var(--sp-6); }
@media (max-width: 760px) { .section { padding: 96px var(--sp-6); } }
.section--light   { background: var(--bg); }
.section--panel   { background: var(--bg-alt); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.section--contact { background: var(--bg); border-top: 1px solid var(--rule); }
.section--dark    {
  background: var(--navy-900);
  color: #F3F6FA;
  border-top: 1px solid rgba(255,255,255,.04);
  border-bottom: 1px solid rgba(255,255,255,.04);
}

body[data-theme="dark"] .section--panel { background: #0B2A4B; }

.section__grid {
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: var(--sp-8);
  align-items: start;
}
@media (max-width: 900px) {
  .section__grid { grid-template-columns: 1fr; gap: var(--sp-6); }
}
.section__head { position: sticky; top: 80px; }
@media (max-width: 900px) { .section__head { position: static; } }
.section__head h2 {
  font-family: var(--f-display);
  font-weight: 900;
  font-size: clamp(40px, 5vw, 64px);
  line-height: 0.95;
  letter-spacing: -0.025em;
  margin: 0 0 var(--sp-4);
  color: var(--fg);
}
.section__kicker {
  margin: 0;
  color: var(--fg-mute);
  font-size: 15.5px;
  max-width: 32ch;
}
.section__body { max-width: 62ch; }
.section__body p {
  margin: 0 0 var(--sp-5);
  color: var(--fg-soft);
  font-size: 17.5px;
  line-height: 1.65;
  text-wrap: pretty;
}
.lede {
  font-family: var(--f-display);
  font-weight: 800;
  font-size: clamp(22px, 2.2vw, 28px) !important;
  line-height: 1.25 !important;
  letter-spacing: -0.015em;
  color: var(--fg) !important;
}

/* ==================== PHILOSOPHY (dark feature) ==================== */
.phil {
  max-width: var(--maxw);
  margin: 0 auto;
}
.phil__title {
  font-family: var(--f-display);
  font-weight: 900;
  font-size: clamp(40px, 5vw, 64px);
  line-height: 0.95;
  letter-spacing: -0.025em;
  margin: 0 0 var(--sp-5);
  color: #ffffff;
}
.phil__lede {
  max-width: 64ch;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: clamp(20px, 2vw, 26px);
  line-height: 1.35;
  letter-spacing: -0.01em;
  color: #D6E4F0;
  margin: 0 0 var(--sp-8);
}
.phil-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 18px;
  overflow: hidden;
}
.phil-cell {
  background: var(--navy-900);
  padding: var(--sp-6) var(--sp-5);
  display: flex; flex-direction: column; gap: 10px;
  min-height: 160px;
  transition: background .2s;
}
.phil-cell:hover { background: #0B2A4B; }
.phil-label {
  font-family: var(--f-body);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #8FB6DE;
}
.phil-value {
  font-family: var(--f-display);
  font-weight: 800;
  font-size: clamp(18px, 1.5vw, 22px);
  line-height: 1.3;
  letter-spacing: -0.01em;
  color: #F3F6FA;
}
@media (max-width: 760px) {
  .phil-grid { grid-template-columns: 1fr; }
  .phil-cell { min-height: 0; }
}

/* ==================== PROJECT CARDS ==================== */
.cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--sp-5);
}

.card {
  position: relative;
  background: var(--bg);
  border: 1px solid var(--rule);
  border-radius: 20px;
  padding: var(--sp-6);
  display: flex; flex-direction: column;
  min-height: 260px;
  transition: transform .2s, border-color .2s, box-shadow .2s, background .2s;
}
body[data-theme="dark"] .card { background: var(--navy-900); }

.card__top {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: var(--sp-6);
}
.card__logo {
  width: 56px; height: 56px;
  border-radius: 14px;
  display: grid; place-items: center;
  font-family: var(--f-display);
  font-weight: 900;
  font-size: 24px;
  overflow: hidden;
  flex-shrink: 0;
}
.card__logo img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Vocado icon — the PNG already carries its own dark-green tile, so the
   wrapper is transparent. We just add a soft drop-shadow so the icon
   "lifts" off the card surface in both variants. */
.card__logo--vocado {
  background: transparent;
  box-shadow: 0 6px 16px -8px color-mix(in srgb, var(--vocado-deep) 55%, transparent);
}

/* Coming-soon tile — solid purple "app icon placeholder" with white glyph,
   mirroring how the Vocado PNG sits as a self-contained app tile. */
.card__logo--soon {
  background: linear-gradient(140deg, var(--textchecker), #5B2FB7);
  color: #fff;
  box-shadow: 0 6px 16px -8px color-mix(in srgb, var(--textchecker) 55%, transparent);
}

.card__status {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 12px; font-weight: 600;
  color: var(--fg-mute);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}
.status-dot { width: 8px; height: 8px; border-radius: 50%; }
.status-dot--vocado {
  background: var(--vocado);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--vocado) 22%, transparent);
}
.status-dot--soon {
  background: var(--textchecker);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--textchecker) 18%, transparent);
}

.card__name {
  font-family: var(--f-display);
  font-weight: 900;
  font-size: 34px;
  letter-spacing: -0.02em;
  margin: 0 0 6px;
  color: var(--fg);
}
.card__name--soon { color: var(--textchecker); }
.card__tag {
  margin: 0 0 var(--sp-6);
  color: var(--fg-soft);
  font-size: 16px;
  line-height: 1.45;
}
.card__foot { margin-top: auto; }
.card__link {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--accent);
  font-weight: 600;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  padding-bottom: 2px;
}
.card__link:hover { border-bottom-color: currentColor; }
.card__link--muted { color: var(--fg-mute); cursor: default; }
.card__link--vocado { color: var(--vocado-deep); }

/* Vocado card — full Vocado-green wash. The card itself feels like Vocado. */
.card--vocado {
  background: var(--vocado-soft);
  border-color: color-mix(in srgb, var(--vocado) 30%, transparent);
}
.card--vocado .card__name,
.card--vocado .card__tag,
.card--vocado .card__status {
  color: var(--vocado-deep);
}
.card--vocado:hover {
  transform: translateY(-2px);
  background: color-mix(in srgb, var(--vocado) 18%, var(--vocado-soft));
  box-shadow: 0 12px 30px -16px color-mix(in srgb, var(--vocado-deep) 50%, transparent);
}

/* Coming-soon card — full purple wash to match the Vocado branded treatment. */
.card--soon {
  background: var(--textchecker-soft);
  border-color: color-mix(in srgb, var(--textchecker) 30%, transparent);
}
.card--soon .card__tag,
.card--soon .card__status {
  color: color-mix(in srgb, var(--textchecker) 80%, var(--ink-900));
}

/* ==================== ABOUT ==================== */
.about__lede {
  font-family: var(--f-display);
  font-weight: 700;
  font-size: clamp(20px, 2vw, 26px);
  line-height: 1.35;
  color: var(--fg) !important;
  letter-spacing: -0.01em;
  margin-bottom: var(--sp-5) !important;
}
.quote {
  margin: var(--sp-6) 0 0;
  padding-left: var(--sp-4);
  border-left: 3px solid var(--rule);
}
.quote__text {
  margin: 0;
  font-style: italic;
  font-size: clamp(18px, 1.6vw, 22px);
  line-height: 1.45;
  color: var(--fg);
}
.quote__cite {
  margin-top: var(--sp-3);
  display: flex; flex-direction: column; gap: 2px;
}
.quote__name {
  font-family: var(--f-display);
  font-weight: 800;
  font-size: 18px;
  color: var(--fg);
}
.quote__role { color: var(--fg-mute); font-size: 14px; }

/* ==================== CONTACT ==================== */
.contact-list {
  margin: 0; padding: 0;
  border-top: 1px solid var(--rule);
}
.contact-list > div {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: var(--sp-5);
  padding: var(--sp-4) 0;
  border-bottom: 1px solid var(--rule);
  align-items: baseline;
}
.contact-list dt {
  font-size: 12px; font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fg-mute);
}
.contact-list dd {
  margin: 0;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 17px;
  color: var(--fg);
}
.contact-list a {
  color: var(--accent);
  text-decoration: none;
  border-bottom: 1px solid color-mix(in srgb, var(--accent) 40%, transparent);
  padding-bottom: 1px;
}
.contact-list a:hover { border-bottom-color: var(--accent); }
.contact-list__soon {
  color: var(--fg-mute) !important;
  font-weight: 500 !important;
  font-style: italic;
}
@media (max-width: 600px) {
  .contact-list > div { grid-template-columns: 1fr; gap: 2px; }
}

/* ==================== FOOTER ==================== */
.foot {
  background: var(--navy-900);
  color: #E5EDF5;
  padding: var(--sp-7) var(--sp-6);
}
body[data-theme="light"] .foot { background: var(--navy-900); }
.foot__inner {
  max-width: var(--maxw);
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--sp-6);
  flex-wrap: wrap;
}
.foot__brand {
  font-family: var(--f-display);
  font-weight: 900;
  font-size: 22px;
  letter-spacing: -0.02em;
  color: #fff;
  margin-bottom: var(--sp-2);
}
.foot__meta {
  color: #9EB8D1;
  font-size: 13.5px;
  display: flex; gap: 10px; flex-wrap: wrap;
}
.foot__links {
  display: flex; gap: var(--sp-5);
  align-items: center;
}
.foot__links a {
  color: #C9D7E6;
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
  border-bottom: 1px solid transparent;
  padding-bottom: 2px;
}
.foot__links a:hover { color: #fff; border-bottom-color: currentColor; }

/* ==================== COOKIE CONSENT BANNER ==================== */
.consent {
  position: fixed;
  left: 16px; right: 16px; bottom: 16px;
  z-index: 200;
  max-width: var(--maxw);
  margin: 0 auto;
  background: var(--ink-900);
  color: #F3F6FA;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 24px 60px -24px rgba(0,0,0,.6), 0 8px 20px -12px rgba(0,0,0,.4);
  padding: var(--sp-5) var(--sp-6);
  font-family: var(--f-body);
}
.consent__inner {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--sp-5);
  align-items: center;
}
.consent__text {
  margin: 0;
  font-size: 14.5px;
  line-height: 1.5;
  color: #E5EDF5;
  max-width: 60ch;
}
.consent__actions {
  display: flex; gap: var(--sp-3);
  flex-shrink: 0;
}
.consent__btn {
  padding: 10px 18px;
  border-radius: 999px;
  font-weight: 600;
  font-size: 14px;
  font-family: var(--f-body);
  cursor: pointer;
  transition: background .2s, color .2s, border-color .2s;
  white-space: nowrap;
}
.consent__btn--primary {
  background: #ffffff;
  color: var(--ink-900);
  border: 1px solid #ffffff;
}
.consent__btn--primary:hover { background: #DDE5EE; border-color: #DDE5EE; }
.consent__btn--ghost {
  background: transparent;
  color: #E5EDF5;
  border: 1px solid rgba(255,255,255,.35);
}
.consent__btn--ghost:hover { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.55); }
.consent__more {
  grid-column: 1 / -1;
  margin: 8px 0 0;
  font-size: 12.5px;
  color: #9EB8D1;
}
.consent__more a {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.consent__more a:hover { color: #fff; }

@media (max-width: 700px) {
  .consent { padding: var(--sp-4) var(--sp-5); }
  .consent__inner { grid-template-columns: 1fr; gap: var(--sp-4); }
  .consent__actions { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
  .consent__btn { padding: 11px 14px; }
}

/* ==================== TWEAKS PANEL ==================== */
.tweaks {
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 100;
  width: 280px;
  background: #fff;
  color: var(--ink-900);
  border: 1px solid var(--line);
  border-radius: 14px;
  box-shadow: 0 20px 50px -20px rgba(10,30,60,.35);
  font-family: var(--f-body);
  overflow: hidden;
}
.tweaks__head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 14px;
  border-bottom: 1px solid var(--line);
  background: var(--sky-050);
}
.tweaks__head strong { font-family: var(--f-display); font-weight: 800; font-size: 14px; }
#tweaks-close {
  font-size: 20px; line-height: 1;
  width: 26px; height: 26px;
  border-radius: 6px;
  color: var(--ink-500);
}
#tweaks-close:hover { background: rgba(0,0,0,.05); }
.tweaks__row { padding: 10px 14px; border-bottom: 1px solid var(--line); }
.tweaks__row:last-child { border-bottom: 0; }
.tweaks__label {
  display: block;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-500);
  margin-bottom: 8px;
}
.tweaks__seg {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
  background: var(--paper-2);
  border-radius: 8px;
  padding: 4px;
}
.tweaks__seg button {
  padding: 7px 8px;
  border-radius: 6px;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--ink-500);
  white-space: nowrap;
}
.tweaks__seg button[aria-checked="true"] {
  background: #fff;
  color: var(--navy-900);
  box-shadow: 0 1px 2px rgba(0,0,0,.06), 0 1px 0 rgba(0,0,0,.04);
}

/* ==================== LEGAL PAGES ==================== */
.legal {
  max-width: 780px;
  margin: 0 auto;
  padding: var(--sp-9) var(--sp-6);
}
.legal__crumbs {
  font-size: 13px;
  color: var(--fg-mute);
  margin-bottom: var(--sp-6);
}
.legal__crumbs a {
  color: var(--accent);
  text-decoration: none;
  border-bottom: 1px solid color-mix(in srgb, var(--accent) 40%, transparent);
}
.legal h1 {
  font-family: var(--f-display);
  font-weight: 900;
  font-size: clamp(40px, 5vw, 64px);
  line-height: 0.95;
  letter-spacing: -0.025em;
  margin: 0 0 var(--sp-6);
  color: var(--fg);
}
.legal h2 {
  font-family: var(--f-display);
  font-weight: 800;
  font-size: 22px;
  letter-spacing: -0.01em;
  margin: var(--sp-7) 0 var(--sp-3);
  color: var(--fg);
}
.legal h3 {
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 17px;
  margin: var(--sp-5) 0 var(--sp-2);
  color: var(--fg);
}
.legal p, .legal li {
  color: var(--fg-soft);
  font-size: 16px;
  line-height: 1.65;
}
.legal a { color: var(--accent); }
.legal ul { padding-left: 20px; }
.legal__meta {
  margin-top: var(--sp-8);
  padding-top: var(--sp-5);
  border-top: 1px solid var(--rule);
  font-size: 13.5px;
  color: var(--fg-mute);
}
.legal__table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--sp-4) 0 var(--sp-5);
  border-top: 1px solid var(--rule);
}
.legal__table th, .legal__table td {
  padding: 10px 0;
  text-align: left;
  vertical-align: top;
  border-bottom: 1px solid var(--rule);
  font-size: 15px;
}
.legal__table th {
  width: 38%;
  font-weight: 600;
  color: var(--fg-mute);
  font-size: 13px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.legal__table td { color: var(--fg); font-family: var(--f-body); }
