/* ============================================================
   ScoreBox Racing Dashboard — styles
   Palette: deep racing turf green + winners' gold accent
   ============================================================ */

:root {
  /* Type scale */
  --text-xs: clamp(0.75rem, 0.7rem + 0.25vw, 0.8125rem);
  --text-sm: clamp(0.8125rem, 0.78rem + 0.25vw, 0.9375rem);
  --text-base: clamp(0.9375rem, 0.9rem + 0.25vw, 1.0625rem);
  --text-lg: clamp(1.0625rem, 1rem + 0.5vw, 1.3125rem);
  --text-xl: clamp(1.4rem, 1.1rem + 1.1vw, 2rem);

  /* Spacing */
  --space-1: 0.25rem;  --space-2: 0.5rem;  --space-3: 0.75rem;
  --space-4: 1rem;     --space-5: 1.25rem; --space-6: 1.5rem;
  --space-8: 2rem;     --space-10: 2.5rem; --space-12: 3rem;
  --space-16: 4rem;

  --radius-sm: 0.4rem; --radius-md: 0.6rem; --radius-lg: 0.9rem;
  --radius-xl: 1.25rem; --radius-full: 9999px;

  --transition: 180ms cubic-bezier(0.16, 1, 0.3, 1);

  --content-wide: 1180px;

  --font-display: 'Clash Display', 'Satoshi', system-ui, sans-serif;
  --font-body: 'Satoshi', system-ui, -apple-system, sans-serif;
}

/* ---------- DARK (default) ---------- */
[data-theme="dark"] {
  --bg: #0a1f19;
  --surface: #0f2a22;
  --surface-2: #143329;
  --surface-3: #1a3d32;
  --border: #224a3c;
  --divider: #1a3a2f;

  --text: #eaf3ee;
  --text-muted: #9bb4a8;
  --text-faint: #6a857a;
  --text-inverse: #0a1f19;

  --gold: #e8b647;
  --gold-soft: #f0cf85;
  --gold-bg: #2e2511;

  --green: #3fb27f;
  --green-bg: #14302440;
  --red: #e0697a;
  --red-bg: #3a1c2240;
  --blue: #5aa6d6;

  --shadow-sm: 0 1px 2px rgba(0,0,0,.35);
  --shadow-md: 0 6px 18px rgba(0,0,0,.4);
  --shadow-lg: 0 16px 44px rgba(0,0,0,.5);
  --gate-overlay: radial-gradient(circle at 30% 20%, #143329 0%, #07140f 70%);
}

/* ---------- LIGHT ---------- */
[data-theme="light"] {
  --bg: #f3f6f3;
  --surface: #ffffff;
  --surface-2: #f6f9f6;
  --surface-3: #eef3ef;
  --border: #d8e2da;
  --divider: #e4ebe5;

  --text: #122019;
  --text-muted: #5a6f64;
  --text-faint: #94a89c;
  --text-inverse: #ffffff;

  --gold: #b8851a;
  --gold-soft: #9a6f12;
  --gold-bg: #f6edd4;

  --green: #2e8a5b;
  --green-bg: #e2f1e8;
  --red: #c43d56;
  --red-bg: #f8e4e8;
  --blue: #2f72a8;

  --shadow-sm: 0 1px 2px rgba(18,32,25,.06);
  --shadow-md: 0 6px 18px rgba(18,32,25,.09);
  --shadow-lg: 0 16px 44px rgba(18,32,25,.13);
  --gate-overlay: radial-gradient(circle at 30% 20%, #dfeae2 0%, #c7d7cc 70%);
}

/* ---------- base ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; scroll-behavior: smooth; }
body {
  min-height: 100dvh;
  line-height: 1.55;
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--text);
  background: var(--bg);
}
img, svg { display: block; max-width: 100%; }
button { cursor: pointer; background: none; border: none; font: inherit; color: inherit; }
input { font: inherit; color: inherit; }
a { color: var(--gold); text-decoration: none; }
a:hover { text-decoration: underline; }
h1,h2,h3,h4 { line-height: 1.15; font-family: var(--font-display); font-weight: 600; }
:focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; border-radius: var(--radius-sm); }

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

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}

/* ============ PASSWORD GATE ============ */
.gate {
  position: fixed; inset: 0; z-index: 50;
  display: grid; place-items: center;
  padding: var(--space-6);
  background: color-mix(in srgb, var(--bg) 55%, transparent);
  backdrop-filter: blur(6px);
}
.gate[hidden] { display: none; }
#app[hidden], #home[hidden] { display: none; }
.gate__card {
  width: 100%; max-width: 380px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: var(--space-10) var(--space-8) var(--space-8);
  text-align: center;
  box-shadow: var(--shadow-lg);
}
.gate__logo {
  width: 56px; height: 56px; margin: 0 auto var(--space-5);
  border-radius: var(--radius-md);
  background:
    linear-gradient(135deg, var(--gold) 0%, var(--gold-soft) 100%);
  position: relative;
}
.gate__logo::before, .gate__logo::after {
  content: ""; position: absolute; width: 18px; height: 18px; border-radius: 4px;
  background: var(--surface);
}
.gate__logo::before { top: 11px; left: 11px; }
.gate__logo::after  { bottom: 11px; right: 11px; }
.gate__title { font-size: var(--text-xl); letter-spacing: -0.02em; }
.gate__subtitle { color: var(--text-muted); font-size: var(--text-sm); margin-top: var(--space-1); }
.gate__form { display: flex; flex-direction: column; gap: var(--space-3); margin-top: var(--space-6); }
.gate__input {
  width: 100%; padding: var(--space-3) var(--space-4);
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: var(--radius-md); font-size: var(--text-base);
  transition: border-color var(--transition), box-shadow var(--transition);
}
.gate__input:focus { outline: none; border-color: var(--gold); box-shadow: 0 0 0 3px var(--gold-bg); }
.gate__btn { width: 100%; }
.gate__error { color: var(--red); font-size: var(--text-sm); margin-top: var(--space-3); }
.gate__note { color: var(--text-faint); font-size: var(--text-xs); margin-top: var(--space-6); line-height: 1.5; }

/* ============ BUTTONS ============ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  border-radius: var(--radius-md); font-weight: 700; font-size: var(--text-sm);
  transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
}
.btn--primary { background: var(--gold); color: var(--text-inverse); }
.btn--primary:hover { background: var(--gold-soft); transform: translateY(-1px); text-decoration: none; }
.btn--primary:active { transform: translateY(0); }

.icon-btn {
  display: grid; place-items: center; width: 38px; height: 38px;
  border-radius: var(--radius-md); border: 1px solid var(--border);
  color: var(--text-muted); transition: color var(--transition), border-color var(--transition), background var(--transition);
}
.icon-btn:hover { color: var(--text); border-color: var(--gold); }

/* ============ TOPBAR ============ */
.topbar {
  position: sticky; top: 0; z-index: 20;
  background: color-mix(in srgb, var(--bg) 88%, transparent);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--divider);
}
.topbar__inner {
  max-width: var(--content-wide); margin: 0 auto;
  padding: var(--space-3) var(--space-5);
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-4);
}
.brand { display: flex; align-items: center; gap: var(--space-3); color: var(--text); }
.brand:hover { text-decoration: none; }
.brand__mark {
  width: 30px; height: 30px; border-radius: var(--radius-sm);
  background: linear-gradient(135deg, var(--gold), var(--gold-soft));
  position: relative; flex-shrink: 0;
}
.brand__mark::before, .brand__mark::after {
  content: ""; position: absolute; width: 10px; height: 10px; border-radius: 3px; background: var(--bg);
}
.brand__mark::before { top: 6px; left: 6px; }
.brand__mark::after  { bottom: 6px; right: 6px; }
.brand__name { font-family: var(--font-display); font-weight: 700; font-size: var(--text-lg); letter-spacing: -0.02em; }
.topbar__actions { display: flex; align-items: center; gap: var(--space-3); }

.toggle {
  display: inline-flex; padding: 3px; gap: 3px;
  background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--radius-full);
}
.toggle__btn {
  padding: var(--space-2) var(--space-4); border-radius: var(--radius-full);
  font-size: var(--text-sm); font-weight: 700; color: var(--text-muted);
  transition: color var(--transition), background var(--transition);
}
.toggle__btn[aria-selected="true"] { background: var(--gold); color: var(--text-inverse); }

/* ============ LAYOUT ============ */
.container { max-width: var(--content-wide); margin: 0 auto; padding: var(--space-8) var(--space-5) var(--space-16); }

/* meeting header */
.meeting-head { margin-bottom: var(--space-8); }
.meeting-head__kicker {
  font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--gold);
}
.meeting-head__title { font-size: var(--text-xl); letter-spacing: -0.02em; margin-top: var(--space-2); }
.meeting-head__sub { color: var(--text-muted); font-size: var(--text-sm); margin-top: var(--space-2); display:flex; flex-wrap:wrap; gap: var(--space-2) var(--space-4); }
.meeting-head__sub span { display: inline-flex; align-items: center; gap: 6px; }
.dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold); }

/* headline cards */
.headline { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: var(--space-5); margin-bottom: var(--space-10); }
.hcard {
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg);
  padding: var(--space-6); box-shadow: var(--shadow-sm); position: relative; overflow: hidden;
}
.hcard::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--gold), transparent);
}
.hcard__label { font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-faint); }
.hcard__horse { font-family: var(--font-display); font-weight: 700; font-size: var(--text-lg); margin-top: var(--space-2); letter-spacing: -0.01em; }
.hcard__meta { font-size: var(--text-sm); color: var(--text-muted); margin-top: var(--space-1); }
.hcard__foot { display: flex; align-items: center; gap: var(--space-3); margin-top: var(--space-4); flex-wrap: wrap; }
.hcard__odds { font-family: var(--font-display); font-weight: 700; font-size: var(--text-lg); color: var(--gold); }

/* race cards */
.races { display: flex; flex-direction: column; gap: var(--space-6); }
.race {
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm); overflow: hidden;
}
.race__head {
  display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-4);
  padding: var(--space-5) var(--space-6); border-bottom: 1px solid var(--divider);
  background: var(--surface-2); cursor: pointer;
}
.race__head:hover { background: var(--surface-3); }
.race__time { font-family: var(--font-display); font-weight: 700; font-size: var(--text-lg); color: var(--gold); min-width: 64px; }
.race__titlewrap { flex: 1; }
.race__name { font-family: var(--font-display); font-weight: 600; font-size: var(--text-base); }
.race__sub { font-size: var(--text-xs); color: var(--text-muted); margin-top: 3px; display: flex; flex-wrap: wrap; gap: var(--space-1) var(--space-3); }
.race__chev { color: var(--text-faint); transition: transform var(--transition); flex-shrink: 0; margin-top: 3px; }
.race[data-open="true"] .race__chev { transform: rotate(180deg); }

.race__body { padding: var(--space-5) var(--space-6) var(--space-6); }
.race[data-open="false"] .race__body { display: none; }

/* pick rows inside race */
.pick {
  display: flex; align-items: center; gap: var(--space-4);
  padding: var(--space-4); border: 1px solid var(--border); border-radius: var(--radius-md);
  margin-bottom: var(--space-3); background: var(--surface-2);
}
.pick--win { border-left: 3px solid var(--gold); }
.pick--ew  { border-left: 3px solid var(--blue); }
.pick__rank {
  width: 30px; height: 30px; flex-shrink: 0; display: grid; place-items: center;
  border-radius: var(--radius-full); background: var(--surface-3);
  font-weight: 700; font-size: var(--text-sm); color: var(--text-muted);
}
.pick__main { flex: 1; min-width: 0; }
.pick__horse { font-weight: 700; font-size: var(--text-base); }
.pick__conn { font-size: var(--text-xs); color: var(--text-muted); margin-top: 2px; }
.pick__stats { display: flex; align-items: center; gap: var(--space-4); flex-shrink: 0; flex-wrap: wrap; justify-content: flex-end; }
.stat { text-align: right; }
.stat__val { font-family: var(--font-display); font-weight: 700; font-size: var(--text-base); }
.stat__lab { font-size: 0.65rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-faint); }
.stat__val--odds { color: var(--gold); }

/* reasons */
.reasons { margin-top: var(--space-3); padding-left: var(--space-4); }
.reasons li { font-size: var(--text-sm); color: var(--text-muted); margin-bottom: 4px; }

/* badges */
.badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 10px; border-radius: var(--radius-full);
  font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.02em;
}
.badge--high  { background: var(--green-bg); color: var(--green); }
.badge--medium{ background: var(--gold-bg); color: var(--gold); }
.badge--low   { background: var(--surface-3); color: var(--text-muted); }
.badge--ew    { background: var(--surface-3); color: var(--blue); }
.badge--value { background: var(--gold-bg); color: var(--gold); }

/* section subhead inside race */
.subhead {
  font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--text-faint); margin: var(--space-5) 0 var(--space-3);
}
.subhead:first-child { margin-top: 0; }

/* full ranking table */
.rank-table { width: 100%; border-collapse: collapse; font-size: var(--text-sm); }
.rank-table th {
  text-align: left; font-size: var(--text-xs); font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.06em; color: var(--text-faint); padding: var(--space-2) var(--space-3);
  border-bottom: 1px solid var(--border);
}
.rank-table th.num, .rank-table td.num { text-align: right; }
.rank-table td { padding: var(--space-2) var(--space-3); border-bottom: 1px solid var(--divider); vertical-align: middle; }
.rank-table tr:last-child td { border-bottom: none; }
.rank-table tr.is-top td { background: var(--gold-bg); }
.rank-table .rt-horse { font-weight: 700; }
.rank-table .rt-conn { color: var(--text-muted); font-size: var(--text-xs); }
.rt-odds { color: var(--gold); font-weight: 700; }

/* states */
.state { text-align: center; padding: var(--space-16) var(--space-4); color: var(--text-muted); }
.state__title { font-family: var(--font-display); font-size: var(--text-lg); color: var(--text); margin-bottom: var(--space-2); }

/* footer */
.footer { margin-top: var(--space-12); padding-top: var(--space-6); border-top: 1px solid var(--divider); }
.footer__disclaimer { font-size: var(--text-xs); color: var(--text-faint); line-height: 1.6; max-width: 70ch; }
.footer__meta { font-size: var(--text-xs); color: var(--text-faint); margin-top: var(--space-3); }

@media (max-width: 560px) {
  .pick { flex-wrap: wrap; }
  .pick__stats { width: 100%; justify-content: flex-start; gap: var(--space-5); margin-top: var(--space-1); }
  .stat { text-align: left; }
  .race__head { padding: var(--space-4); }
  .race__body { padding: var(--space-4); }
  .rank-table .col-hide { display: none; }
  .topbar .brand__name { display: none; }
}

/* ============================================================
   PUBLIC HOMEPAGE
   ============================================================ */
.home { min-height: 100dvh; display: flex; flex-direction: column; }

/* --- home nav --- */
.home-nav {
  position: sticky; top: 0; z-index: 20;
  background: color-mix(in srgb, var(--bg) 88%, transparent);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--divider);
}
.home-nav__inner {
  max-width: var(--content-wide); margin: 0 auto;
  padding: var(--space-3) var(--space-5);
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-4);
}
.home-nav__actions { display: flex; align-items: center; gap: var(--space-3); }

/* --- buttons (extend) --- */
.btn--lg { padding: var(--space-4) var(--space-6); font-size: var(--text-base); }
.btn--ghost {
  background: transparent; color: var(--text);
  border: 1px solid var(--border);
}
.btn--ghost:hover { border-color: var(--gold); color: var(--gold); text-decoration: none; transform: translateY(-1px); }

/* --- hero --- */
.hero {
  position: relative; overflow: hidden;
  padding: clamp(3rem, 7vw, 6rem) var(--space-5) clamp(2.5rem, 5vw, 4rem);
}
.hero::before {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(60% 80% at 75% 10%, color-mix(in srgb, var(--gold) 16%, transparent) 0%, transparent 60%),
    radial-gradient(50% 60% at 10% 90%, color-mix(in srgb, var(--green) 14%, transparent) 0%, transparent 60%);
}
.hero__inner { position: relative; z-index: 1; max-width: 760px; margin: 0 auto; text-align: center; }
.hero__kicker {
  display: inline-block; font-size: var(--text-xs); font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--gold);
  padding: 6px 14px; border: 1px solid color-mix(in srgb, var(--gold) 40%, transparent);
  border-radius: var(--radius-full); margin-bottom: var(--space-5);
}
.hero__title {
  font-size: clamp(2.2rem, 1.4rem + 4vw, 4.2rem); line-height: 1.04;
  letter-spacing: -0.03em; font-weight: 700;
}
.hero__lede {
  margin: var(--space-5) auto 0; max-width: 600px;
  font-size: var(--text-lg); color: var(--text-muted); line-height: 1.6;
}
.hero__cta { display: flex; gap: var(--space-3); justify-content: center; flex-wrap: wrap; margin-top: var(--space-8); }
.hero__age { margin-top: var(--space-6); font-size: var(--text-xs); color: var(--text-faint); letter-spacing: 0.02em; }

/* --- verticals --- */
.verticals { padding: var(--space-4) var(--space-5) var(--space-12); }
.vert-grid {
  max-width: var(--content-wide); margin: 0 auto;
  display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: var(--space-5);
}
.vert {
  position: relative; background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: var(--space-8) var(--space-6) var(--space-6);
  box-shadow: var(--shadow-sm);
}
.vert--live { border-color: color-mix(in srgb, var(--gold) 45%, var(--border)); }
.vert--soon { opacity: 0.96; }
.vert__badge {
  position: absolute; top: var(--space-5); right: var(--space-5);
  font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--text-faint); padding: 4px 10px; border: 1px solid var(--border); border-radius: var(--radius-full);
}
.vert__badge--live {
  color: var(--text-inverse); background: var(--gold); border-color: var(--gold);
}
.vert__icon {
  width: 52px; height: 52px; display: grid; place-items: center;
  border-radius: var(--radius-md); margin-bottom: var(--space-4);
  background: var(--green-bg); color: var(--green);
}
.vert--live .vert__icon { background: var(--gold-bg); color: var(--gold); }
.vert__title { font-size: var(--text-lg); letter-spacing: -0.01em; }
.vert__desc { margin-top: var(--space-2); color: var(--text-muted); font-size: var(--text-sm); }

/* --- section heads --- */
.section-kicker { font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gold); }
.section-title { font-size: var(--text-xl); letter-spacing: -0.02em; margin-top: var(--space-2); }

/* --- how it works --- */
.how { padding: var(--space-12) var(--space-5); border-top: 1px solid var(--divider); }
.how__inner { max-width: var(--content-wide); margin: 0 auto; text-align: center; }
.how-steps {
  margin-top: var(--space-8); display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: var(--space-6); text-align: left;
}
.how-step {
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: var(--space-6);
}
.how-step__num { font-family: var(--font-display); font-weight: 700; font-size: var(--text-xl); color: var(--gold); }
.how-step__title { margin-top: var(--space-3); font-size: var(--text-lg); }
.how-step__desc { margin-top: var(--space-2); color: var(--text-muted); font-size: var(--text-sm); }

/* --- responsible gambling --- */
.responsible { padding: var(--space-12) var(--space-5); border-top: 1px solid var(--divider); background: var(--surface); }
.responsible__inner { max-width: 820px; margin: 0 auto; }
.responsible__head { display: flex; align-items: center; gap: var(--space-4); }
.responsible__age {
  flex-shrink: 0; display: grid; place-items: center; width: 48px; height: 48px;
  border-radius: var(--radius-md); background: var(--gold); color: var(--text-inverse);
  font-family: var(--font-display); font-weight: 700; font-size: var(--text-lg);
}
.responsible__title { font-size: var(--text-xl); letter-spacing: -0.02em; }
.responsible__lede { margin-top: var(--space-5); color: var(--text-muted); font-size: var(--text-base); line-height: 1.65; }
.responsible__points {
  margin: var(--space-5) 0 0; padding-left: 0; list-style: none; display: flex; flex-direction: column; gap: var(--space-3);
}
.responsible__points li {
  position: relative; padding-left: var(--space-6); color: var(--text); font-size: var(--text-sm);
}
.responsible__points li::before {
  content: ""; position: absolute; left: 0; top: 0.5em; width: 8px; height: 8px;
  border-radius: 2px; background: var(--gold);
}
.responsible__resources {
  margin-top: var(--space-8); padding-top: var(--space-6); border-top: 1px solid var(--divider);
  display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-3) var(--space-5);
}
.rg-link { font-weight: 700; font-size: var(--text-sm); }
.rg-helpline { color: var(--text-faint); font-size: var(--text-xs); width: 100%; }

/* --- home footer --- */
.home-footer { margin-top: auto; padding: var(--space-8) var(--space-5); border-top: 1px solid var(--divider); }
.home-footer__inner {
  max-width: var(--content-wide); margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-5); flex-wrap: wrap;
}
.home-footer__brand {
  display: flex; align-items: center; gap: var(--space-3);
  font-family: var(--font-display); font-weight: 700; font-size: var(--text-base);
}
.brand__mark--sm { width: 24px; height: 24px; }
.brand__mark--sm::before, .brand__mark--sm::after { width: 8px; height: 8px; }
.brand__mark--sm::before { top: 5px; left: 5px; }
.brand__mark--sm::after { bottom: 5px; right: 5px; }
.home-footer__legal { color: var(--text-faint); font-size: var(--text-xs); line-height: 1.6; max-width: 560px; }

/* --- gate close button --- */
.gate__card { position: relative; }
.gate__close {
  position: absolute; top: var(--space-4); right: var(--space-4);
  width: 34px; height: 34px; display: grid; place-items: center;
  border-radius: var(--radius-md); color: var(--text-faint);
  transition: color var(--transition), background var(--transition);
}
.gate__close:hover { color: var(--text); background: var(--surface-2); }

@media (max-width: 640px) {
  .home-nav .brand__name { display: none; }
  .responsible__resources { gap: var(--space-3); }
}
