/* ==========================================================================
   ShipREKT — product design layer
   Built on the Simple Stack token system (see styles.css :root).
   Signature element: a live countdown scoreboard with urgency states.
   Vanilla CSS, no build step. Light + dark inherit from the base tokens.
   ========================================================================== */

/* ----------------------------------------------------------- ship tokens -- */
:root {
  --rekt: #ff3b6b;
  --rekt-2: #ff6b8e;
  --rekt-ink: #2a0410;
  --rekt-soft: rgba(255, 59, 107, 0.14);
  --rekt-line: rgba(255, 59, 107, 0.42);
  --rekt-glow: rgba(255, 59, 107, 0.55);

  --ship-green: #38e0a0;
  --ship-green-soft: rgba(56, 224, 160, 0.14);
  --ship-green-line: rgba(56, 224, 160, 0.4);

  --rarity-common: #9a97a6;
  --rarity-rare: #5cc8ff;
  --rarity-epic: #b98cff;
  --rarity-legendary: #ffc24d;

  --clock-face: rgba(255, 255, 255, 0.04);
  --clock-edge: rgba(255, 255, 255, 0.1);
}

:root[data-theme="light"] {
  --rekt: #e11d48;
  --rekt-2: #f43f5e;
  --rekt-ink: #fff5f7;
  --rekt-soft: rgba(225, 29, 72, 0.08);
  --rekt-line: rgba(225, 29, 72, 0.26);
  --rekt-glow: rgba(225, 29, 72, 0.28);

  --ship-green: #0fa472;
  --ship-green-soft: rgba(15, 164, 114, 0.1);
  --ship-green-line: rgba(15, 164, 114, 0.28);

  --rarity-common: #7a7580;
  --rarity-rare: #1f7fb8;
  --rarity-epic: #7c4fe0;
  --rarity-legendary: #b5790a;

  --clock-face: rgba(20, 16, 14, 0.03);
  --clock-edge: rgba(20, 16, 14, 0.1);
}

/* --------------------------------------------------------------- helpers -- */
.ship-wrap {
  width: min(var(--container), 100% - 40px);
  margin-inline: auto;
  margin-block-end: clamp(52px, 7vw, 100px);
}

/* Roomier section rhythm for ship .content pages (base .content gap is tighter,
   and is shared with login/admin so we don't touch it directly). */
main.ship-page { gap: clamp(30px, 3.5vw, 52px); }

.ship-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px;
  color: var(--accent-text);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.ship-kicker::before {
  content: "";
  width: 18px;
  height: 2px;
  border-radius: 2px;
  background: var(--accent);
}
.ship-kicker.is-rekt {
  color: var(--rekt-2);
}
.ship-kicker.is-rekt::before {
  background: var(--rekt);
}
.ship-kicker.is-clean {
  color: var(--ship-green);
}
.ship-kicker.is-clean::before {
  background: var(--ship-green);
}

.ship-section-head {
  max-width: 760px;
  margin-bottom: clamp(20px, 3vw, 34px);
}
.ship-section-head h2 {
  font-size: var(--step-4);
  line-height: 1;
}
.ship-section-head p {
  margin-top: 12px;
  color: var(--text-muted);
  font-size: 1.05rem;
}
.ship-section-head.center {
  margin-inline: auto;
  text-align: center;
}
.ship-section-head.center .ship-kicker::before {
  display: none;
}

.section-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 4px;
  color: var(--accent-text);
  font-weight: 700;
}
.section-link svg {
  width: 16px;
  height: 16px;
  transition: transform 0.2s var(--ease);
}
.section-link:hover svg {
  transform: translateX(3px);
}

.headline-rekt {
  position: relative;
  color: var(--rekt);
  -webkit-text-stroke: 0;
}

/* word stamped like a rubber REKT stamp */
.rekt-stamp {
  display: inline-block;
  margin: 0 0.14em;
  padding: 0.04em 0.26em;
  border: 0.08em solid var(--rekt);
  border-radius: 0.12em;
  color: var(--rekt);
  transform: rotate(-3deg);
  line-height: 0.95;
  white-space: nowrap;
  box-shadow: 0 0 0 0.06em var(--rekt-soft);
}

/* "Ship" — the lighter half of the ShipREKT wordmark. Green (the ship/shipped
   colour) with a soft marker underline + glow: a quiet counterpart to the bold
   outlined REKT box. Keeps both brand words emphasised in the long tagline, and
   (unlike a filled tag) lets following punctuation sit flush. */
.ship-stamp {
  position: relative;
  color: var(--ship-green);
  white-space: nowrap;
  text-shadow: 0 0 24px color-mix(in srgb, var(--ship-green) 26%, transparent);
}
.ship-stamp::after {
  content: "";
  position: absolute;
  left: 0.03em;
  right: 0.03em;
  bottom: 0.01em;
  height: 0.1em;
  border-radius: 0.08em;
  background: var(--ship-green);
  opacity: 0.6;
}

/* compact nav/footer wordmark: "Ship" in the heading colour + red "Rekt" */
.wm-rekt { color: var(--rekt); }

/* larger call-to-action button (base .button lives in styles.css) */
.button-lg {
  padding: 14px 26px;
  font-size: 1.02rem;
  font-weight: 700;
  border-radius: var(--radius-sm);
}

/* generic ship card primitive */
.ship-card {
  position: relative;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow: var(--shadow);
  overflow: clip;
}

.ship-grid {
  display: grid;
  gap: var(--gap);
}

/* ============================================================ the clock === */
/* full scoreboard: <div class="clock is-chill" data-clock data-countdown="N"> */
.clock {
  --c: var(--accent-text);
  --c-soft: var(--accent-soft);
  --c-line: var(--accent-line);
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: stretch;
  gap: 8px;
  width: 100%;
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}

.clock-cell {
  display: grid;
  gap: 6px;
  justify-items: center;
  min-width: 0;
  padding: 14px 6px 10px;
  border: 1px solid var(--c-line);
  border-radius: 14px;
  background:
    linear-gradient(180deg, var(--clock-edge), transparent 42%),
    var(--c-soft),
    var(--clock-face);
  box-shadow: inset 0 1px 0 var(--clock-edge);
}

.clock-num {
  font-size: clamp(1.7rem, 1rem + 2.2vw, 2.7rem);
  font-weight: 700;
  line-height: 0.9;
  letter-spacing: -0.02em;
  color: var(--c);
  font-variant-numeric: tabular-nums;
  text-shadow: 0 0 22px color-mix(in srgb, var(--c) 35%, transparent);
}

.clock-unit {
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--text-faint);
}

.clock-colon {
  display: grid;
  align-content: center;
  font-size: 2rem;
  font-weight: 700;
  color: var(--c);
  opacity: 0.55;
}

/* sizes */
.clock-lg .clock-cell { min-width: 0; padding: 18px 8px 12px; border-radius: 18px; }
.clock-lg .clock-num { font-size: clamp(2.5rem, 1rem + 4vw, 4.2rem); }
.clock-lg .clock-colon { font-size: 2.6rem; }

.clock-sm .clock-cell { min-width: 0; padding: 9px 6px 7px; border-radius: 11px; }
.clock-sm .clock-num { font-size: 1.7rem; }
.clock-sm .clock-unit { font-size: 0.5rem; }
.clock-sm .clock-colon { font-size: 1.2rem; }

/* urgency states (toggled by JS) */
.clock.is-chill { --c: var(--accent-text); --c-soft: var(--accent-soft); --c-line: var(--accent-line); }
.clock.is-warning { --c: var(--warn); --c-soft: var(--warn-soft); --c-line: color-mix(in srgb, var(--warn) 36%, transparent); }
.clock.is-danger { --c: var(--rekt-2); --c-soft: var(--rekt-soft); --c-line: var(--rekt-line); }
.clock.is-danger .clock-cell { animation: clock-pulse 1.1s var(--ease) infinite; }
.clock.is-rekt { --c: var(--rekt); --c-soft: var(--rekt-soft); --c-line: var(--rekt-line); }
.clock.is-rekt .clock-cell { opacity: 0.55; filter: saturate(0.7); }

/* compact label pill: <span class="cd-pill" data-countdown-label data-countdown="N"> */
.cd-pill {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 6px 12px;
  border: 1px solid var(--accent-line);
  border-radius: 999px;
  background: var(--accent-soft);
  color: var(--accent-text);
  font-family: var(--font-mono);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  white-space: nowrap;
}
.cd-pill::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: currentColor;
  box-shadow: 0 0 0 3px color-mix(in srgb, currentColor 22%, transparent);
}
.cd-pill.is-warning { border-color: color-mix(in srgb, var(--warn) 40%, transparent); background: var(--warn-soft); color: var(--warn); }
.cd-pill.is-danger { border-color: var(--rekt-line); background: var(--rekt-soft); color: var(--rekt-2); }
.cd-pill.is-danger::before { animation: blink 1s steps(2, start) infinite; }
.cd-pill.is-rekt { border-color: var(--rekt-line); background: var(--rekt-soft); color: var(--rekt); }

@keyframes clock-pulse {
  0%, 100% { box-shadow: inset 0 1px 0 var(--clock-edge), 0 0 0 0 var(--rekt-glow); }
  50% { box-shadow: inset 0 1px 0 var(--clock-edge), 0 0 0 5px transparent; }
}
@keyframes blink { 50% { opacity: 0.25; } }

/* ============================================================ stat tiles === */
.ship-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--gap);
}

.ship-stat {
  position: relative;
  display: grid;
  gap: 4px;
  padding: 20px 20px 18px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  overflow: clip;
}
.ship-stat::after {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  background: var(--accent);
  opacity: 0.85;
}
.ship-stat .stat-emoji {
  font-size: 1.05rem;
  line-height: 1;
}
.ship-stat .stat-label {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text-muted);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.ship-stat .stat-value {
  font-family: var(--font-display);
  font-size: clamp(2.2rem, 1.6rem + 2vw, 3rem);
  line-height: 1;
  letter-spacing: -0.02em;
}
.ship-stat .stat-sub {
  color: var(--text-faint);
  font-size: 0.84rem;
}
.ship-stat.is-streak::after { background: linear-gradient(90deg, var(--accent), var(--accent-2)); }
.ship-stat.is-streak .stat-value { color: var(--accent-text); }
.ship-stat.is-shipped::after { background: var(--ship-green); }
.ship-stat.is-shipped .stat-value { color: var(--ship-green); }
.ship-stat.is-rekt::after { background: var(--rekt); }
.ship-stat.is-rekt .stat-value { color: var(--rekt-2); }

/* =============================================================== badges ==== */
.badge-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 12px;
}

.badge-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 16px;
  border: 1px solid var(--rar, var(--border));
  border-radius: var(--radius-sm);
  background:
    radial-gradient(120% 120% at 0 0, color-mix(in srgb, var(--rar, var(--accent)) 12%, transparent), transparent 60%),
    var(--surface-inset);
}
.badge-card .badge-emoji {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 12px;
  background: color-mix(in srgb, var(--rar, var(--accent)) 16%, var(--surface));
  border: 1px solid color-mix(in srgb, var(--rar, var(--accent)) 34%, transparent);
  font-size: 1.35rem;
  line-height: 1;
}
.badge-card .badge-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1rem;
  line-height: 1.2;
  letter-spacing: -0.01em;
}
.badge-card .badge-body {
  margin-top: -2px;
  color: var(--text-muted);
  font-size: 0.82rem;
  line-height: 1.45;
}

/* small chip variant for cards/rows */
.badge-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 9px 4px 6px;
  border: 1px solid var(--rar, var(--border));
  border-radius: 999px;
  background: color-mix(in srgb, var(--rar, var(--accent)) 10%, var(--surface-inset));
  font-size: 0.78rem;
  font-weight: 600;
}
.badge-chip .e { font-size: 0.95rem; }

/* rarity colour assignment */
.rarity-common { --rar: var(--rarity-common); }
.rarity-rare { --rar: var(--rarity-rare); }
.rarity-epic { --rar: var(--rarity-epic); }
.rarity-legendary { --rar: var(--rarity-legendary); }
.rarity-legendary.badge-card {
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--rarity-legendary) 22%, transparent), transparent 55%),
    var(--surface-inset);
  box-shadow: 0 0 24px -8px color-mix(in srgb, var(--rarity-legendary) 50%, transparent);
}

.rarity-tag {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--rar, var(--text-faint));
}

/* =========================================================== skill cloud == */
.skill-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.skill-cloud span {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border: 1px solid var(--border-2);
  border-radius: 999px;
  background: var(--surface-inset);
  color: var(--text);
  font-size: 0.84rem;
  font-weight: 600;
}

/* ============================================================ nav brand ==== */
.logo-badge {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 10px;
  background: linear-gradient(140deg, var(--accent), var(--accent-2));
  color: var(--accent-ink);
  box-shadow: 0 6px 18px -6px var(--accent-glow);
}
.logo-badge svg { width: 20px; height: 20px; display: block; }

/* ============================================================== hero ====== */
.ship-home { padding-top: 0; }

.hero {
  position: relative;
  overflow: clip;
  border-bottom: 1px solid var(--border);
  /* Pull up under the floating nav; hero-inner adds the only top padding so the
     gap below the nav stays consistent (overrides the base template .hero). */
  margin: calc(var(--nav-flow-h) * -1) 0 clamp(40px, 6vw, 84px);
  padding: 0;
}
.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}
/* perspective grid floor */
.hero-bg::before {
  content: "";
  position: absolute;
  inset: 38% -20% -30% -20%;
  background-image:
    linear-gradient(var(--accent-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--accent-line) 1px, transparent 1px);
  background-size: 54px 54px;
  transform: perspective(520px) rotateX(62deg);
  transform-origin: top center;
  opacity: 0.28;
  mask-image: linear-gradient(to bottom, transparent, #000 38%, transparent 92%);
}
/* ember glows */
.hero-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(680px 420px at 78% 8%, color-mix(in srgb, var(--accent) 30%, transparent), transparent 60%),
    radial-gradient(560px 380px at 12% 78%, var(--rekt-soft), transparent 62%);
}

.hero-inner {
  position: relative;
  z-index: 1;
  width: min(var(--container), 100% - 40px);
  margin-inline: auto;
  padding: calc(var(--nav-flow-h) + clamp(28px, 4vw, 60px)) 0 clamp(40px, 6vw, 76px);
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(300px, 0.85fr);
  gap: clamp(28px, 5vw, 64px);
  align-items: center;
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 13px;
  border: 1px solid var(--border-2);
  border-radius: 999px;
  background: var(--surface-glass);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: 0.74rem;
  font-weight: 600;
}
.hero-badge .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--ship-green);
  box-shadow: 0 0 0 3px var(--ship-green-soft);
  animation: blink 1.6s var(--ease) infinite;
}

.hero h1 {
  margin: 20px 0 0;
  font-family: var(--font-display);
  font-size: clamp(2.8rem, 1.4rem + 7.4vw, 6.6rem);
  line-height: 1.05;
  letter-spacing: -0.03em;
  font-weight: 700;
}
.hero h1 .rekt-stamp { margin: 0 0.08em; }

.hero-sub {
  max-width: 600px;
  margin-top: 26px;
  color: var(--text-muted);
  font-size: clamp(1.05rem, 1rem + 0.4vw, 1.28rem);
  line-height: 1.55;
}
.hero-sub strong { color: var(--text); }

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 30px;
}

.hero-trust {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  margin-top: 26px;
  color: var(--text-faint);
  font-size: 0.86rem;
}
.hero-trust span { display: inline-flex; align-items: center; gap: 7px; }
.hero-trust svg { width: 15px; height: 15px; color: var(--ship-green); }

/* hero clock console card */
.hero-console {
  position: relative;
  display: grid;
  gap: 18px;
  padding: clamp(22px, 2.4vw, 30px);
  border: 1px solid var(--border-2);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(160deg, color-mix(in srgb, var(--accent) 8%, var(--surface)), var(--surface)),
    var(--surface);
  box-shadow: var(--shadow-lg);
  /* Size the clock cells to the card width (cqw) so the 4 cells always stay on
     one row — big on the wide stacked card, smaller on the narrow desktop rail. */
  container-type: inline-size;
}
.hero-console .console-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border);
}
.hero-console .console-dots { display: inline-flex; gap: 6px; }
.hero-console .console-dots i { width: 10px; height: 10px; border-radius: 50%; background: var(--border-2); }
.hero-console .console-dots i:first-child { background: var(--rekt); }
.hero-console .console-dots i:nth-child(2) { background: var(--warn); }
.hero-console .console-dots i:nth-child(3) { background: var(--ship-green); }
.hero-console .console-tag { font-family: var(--font-mono); font-size: 0.72rem; color: var(--text-faint); }
.hero-console .console-clock { display: grid; justify-items: center; gap: 4px; text-align: center; }
/* Always 4 cells in a single row, sized to the console width (never 2x2). */
.hero-console .console-clock .clock { grid-template-columns: repeat(4, minmax(0, 1fr)); gap: clamp(6px, 1.6cqw, 10px); width: 100%; max-width: none; }
.hero-console .console-clock .clock-cell { padding: clamp(12px, 3cqw, 18px) 4px clamp(9px, 2.2cqw, 12px); border-radius: 14px; }
.hero-console .console-clock .clock-num { font-size: clamp(1.5rem, 12cqw, 3.1rem); }
.hero-console .console-clock .clock-unit { font-size: clamp(0.46rem, 1.7cqw, 0.6rem); letter-spacing: 0.12em; }
.hero-console .console-caption { color: var(--text-muted); font-size: 0.9rem; }
.hero-console .console-foot {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  text-align: center;
}
.hero-console .console-foot div {
  padding: 10px 6px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--surface-inset);
}
.hero-console .console-foot strong { display: block; font-family: var(--font-display); font-size: 1.5rem; line-height: 1; }
.hero-console .console-foot span { font-size: 0.68rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-faint); }

/* =========================================================== marquee band = */
.ship-marquee {
  border-block: 1px solid var(--border);
  background: var(--surface-inset);
  overflow: clip;
  margin-bottom: clamp(40px, 6vw, 84px);
}
.ship-marquee .track {
  display: flex;
  gap: 40px;
  padding: 14px 0;
  white-space: nowrap;
  animation: marquee 30s linear infinite; /* ~52px/s, matched to getsimplestack.com */
  font-family: var(--font-mono);
  font-size: 0.85rem;
  color: var(--text-muted);
}
.ship-marquee .track span { display: inline-flex; align-items: center; gap: 10px; }
.ship-marquee .track b { color: var(--accent-text); }
@keyframes marquee { to { transform: translateX(-50%); } }

/* ============================================================== rules ===== */
.rules-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap);
}
.rule {
  position: relative;
  padding: clamp(22px, 2.4vw, 30px);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
}
.rule .rule-step {
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  margin-bottom: 18px;
  border-radius: 13px;
  background: var(--accent-soft);
  border: 1px solid var(--accent-line);
  color: var(--accent-text);
  font-family: var(--font-mono);
  font-size: 1.2rem;
  font-weight: 700;
}
.rule h3 { font-size: 1.3rem; margin-bottom: 8px; }
.rule p { color: var(--text-muted); }
.rule.is-rekt .rule-step { background: var(--rekt-soft); border-color: var(--rekt-line); color: var(--rekt-2); }

/* =========================================================== home split === */
.home-split {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(290px, 0.8fr);
  gap: var(--gap);
  align-items: start;
}

/* =============================================== home 3-column board ======= */
.home-board {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--gap);
  align-items: stretch;
}
.board-col {
  display: flex;
  flex-direction: column;
  padding: clamp(18px, 2vw, 26px);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow: var(--shadow);
}
.board-col > .ship-kicker { margin-bottom: 6px; }
.board-col > h3 {
  margin-bottom: 16px;
  font-size: 1.5rem;
  letter-spacing: -0.01em;
}
.board-list {
  display: grid;
  gap: 8px;
  margin-bottom: 14px;
}
.board-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 11px;
  align-items: center;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--surface-inset);
  transition: border-color 0.18s var(--ease), transform 0.15s var(--ease);
}
a.board-row:hover { border-color: var(--accent-line); transform: translateY(-1px); }
.board-row .mono-avatar { width: 36px; height: 36px; font-size: 0.85rem; border-radius: 10px; }
.board-row .br-rank {
  width: 26px;
  text-align: center;
  font-family: var(--font-display);
  font-weight: 700;
  color: var(--text-faint);
}
.board-row .br-main { min-width: 0; display: grid; gap: 1px; }
.board-row .br-title {
  font-weight: 600;
  font-size: 0.94rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.board-row .br-sub {
  color: var(--text-muted);
  font-size: 0.78rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.board-row .br-trail {
  font-family: var(--font-mono);
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--text-faint);
  white-space: nowrap;
}
.board-row.is-streak .br-trail { color: var(--accent-text); }
.board-row.is-rekt .br-trail { color: var(--rekt-2); }
.board-col .section-link { margin-top: auto; }
.board-col .ship-empty { margin-bottom: 14px; }

/* =============================================== kudos / like button ======= */
.like-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 11px;
  border: 1px solid var(--border-2);
  border-radius: 999px;
  background: var(--surface-inset);
  color: var(--text-muted);
  font: inherit;
  font-size: 0.82rem;
  font-weight: 700;
  cursor: pointer;
  transition: border-color 0.15s var(--ease), color 0.15s var(--ease), background 0.15s var(--ease);
}
.like-btn:hover { border-color: var(--accent-line); color: var(--text); }
.like-btn .like-ico { font-size: 0.95rem; line-height: 1; transition: transform 0.15s var(--ease); }
.like-btn.is-liked {
  border-color: var(--accent-line);
  background: var(--accent-soft);
  color: var(--accent-text);
}
.like-btn.is-liked .like-ico { transform: scale(1.15); }
.feed-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; justify-content: flex-end; }

/* =============================================== "sound familiar" truths === */
.truths-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.truth {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 13px;
  align-items: start;
  padding: 17px 19px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
}
.truth .t-emoji { font-size: 1.5rem; line-height: 1.1; }
.truth p { color: var(--text-muted); }
.truth strong { color: var(--text); font-weight: 600; }

.center-note {
  max-width: 760px;
  margin: clamp(20px, 3vw, 34px) auto 0;
  text-align: center;
  color: var(--text);
  font-size: clamp(1.05rem, 1rem + 0.4vw, 1.22rem);
  line-height: 1.5;
}

@media (max-width: 900px) {
  .home-board { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .truths-grid { grid-template-columns: 1fr; }
}

/* ==================================================== legal pages ========= */
.legal-body h2 { margin-top: 30px; font-size: 1.3rem; letter-spacing: -0.01em; }
.legal-body h2:first-child { margin-top: 0; }
.legal-body p { margin-top: 10px; max-width: 780px; color: var(--text-muted); }
.legal-body strong { color: var(--text); }
.legal-body a { color: var(--accent-text); font-weight: 600; }
.legal-body ul { margin: 12px 0 0; padding-left: 20px; display: grid; gap: 8px; max-width: 780px; }
.legal-body li { color: var(--text-muted); line-height: 1.5; }
.legal-note {
  margin-top: 30px;
  padding-top: 18px;
  border-top: 1px solid var(--border);
  color: var(--text-faint);
  font-size: 0.85rem;
  font-style: italic;
}

/* ============================================== Simple Stack promo band === */
.ss-promo {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: clamp(20px, 4vw, 56px);
  align-items: center;
  padding: clamp(26px, 3.5vw, 46px);
  border: 1px solid var(--border-2);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(130% 150% at 100% 0, var(--accent-soft), transparent 62%),
    color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow: var(--shadow);
  overflow: clip;
}
.ss-promo h2 {
  margin-top: 6px;
  font-size: clamp(1.5rem, 1.1rem + 1.6vw, 2.1rem);
}
.ss-promo p {
  margin-top: 12px;
  max-width: 640px;
  color: var(--text-muted);
}
.ss-promo-cta {
  display: grid;
  gap: 12px;
  justify-items: start;
  align-content: center;
  white-space: nowrap;
}
.ss-price {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
  font-family: var(--font-display);
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1;
  color: var(--accent-text);
}
.ss-price small {
  font-family: var(--font-mono);
  font-size: 0.66rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-faint);
}
.ss-fine {
  color: var(--text-faint);
  font-family: var(--font-mono);
  font-size: 0.78rem;
}

@media (max-width: 760px) {
  .ss-promo { grid-template-columns: 1fr; }
  .ss-promo-cta { justify-items: stretch; }
  .ss-promo-cta .button { width: 100%; }
}

/* ====================================================== activity feed ===== */
.feed {
  display: grid;
  gap: 12px;
}
.feed-item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  padding: 16px 18px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  transition: border-color 0.2s var(--ease), transform 0.2s var(--ease);
}
.feed-item:hover { border-color: var(--border-2); transform: translateY(-1px); }
.feed-icon {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 12px;
  background: var(--ship-green-soft);
  border: 1px solid var(--ship-green-line);
  font-size: 1.2rem;
}
.feed-item.is-rekt .feed-icon { background: var(--rekt-soft); border-color: var(--rekt-line); }
.feed-body { min-width: 0; }
.feed-body .feed-title { font-family: var(--font-display); font-size: 1.15rem; font-weight: 600; }
.feed-body .feed-title a:hover { color: var(--accent-text); }
.feed-body .feed-meta { margin-top: 3px; color: var(--text-muted); font-size: 0.88rem; }
.feed-body .feed-meta a { color: var(--text); font-weight: 600; }
.feed-body .feed-meta a:hover { color: var(--accent-text); }
.feed-body .feed-desc { margin-top: 6px; color: var(--text-faint); font-size: 0.9rem; }
.feed-side { display: grid; gap: 6px; justify-items: end; text-align: right; white-space: nowrap; }
.feed-time { color: var(--text-faint); font-family: var(--font-mono); font-size: 0.76rem; }

/* mini profile list (home aside) */
.mini-list { display: grid; gap: 10px; }
.mini-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--surface-inset);
  transition: border-color 0.2s var(--ease);
}
.mini-row:hover { border-color: var(--accent-line); }
.mini-row .mono-avatar { width: 38px; height: 38px; font-size: 0.95rem; }
.mini-row strong { font-weight: 600; }
.mini-row .mini-meta { color: var(--text-muted); font-size: 0.82rem; }

/* ============================================== monogram avatar (shared) == */
.mono-avatar {
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  flex: none;
  border-radius: 13px;
  background: linear-gradient(140deg, color-mix(in srgb, var(--accent) 30%, var(--surface-3)), var(--surface-3));
  border: 1px solid var(--border-2);
  color: var(--text);
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: -0.02em;
  text-transform: uppercase;
}
.mono-avatar.xl { width: 84px; height: 84px; border-radius: 22px; font-size: 2.2rem; }

/* ============================================================ leaderboard = */
.lb-tabs {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 5px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--surface-inset);
}
.lb-tabs a {
  padding: 8px 16px;
  border-radius: 999px;
  color: var(--text-muted);
  font-weight: 600;
  font-size: 0.9rem;
  transition: background 0.18s var(--ease), color 0.18s var(--ease);
}
.lb-tabs a:hover { color: var(--text); }
.lb-tabs a.is-active { background: var(--accent); color: var(--accent-ink); }

.lb {
  display: grid;
  gap: 8px;
}
.lb-row {
  display: grid;
  grid-template-columns: 54px auto minmax(0, 1fr) repeat(3, minmax(64px, auto)) minmax(120px, auto);
  gap: 16px;
  align-items: center;
  padding: 14px 18px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  transition: border-color 0.2s var(--ease), transform 0.15s var(--ease);
}
.lb-row:hover { border-color: var(--border-2); transform: translateY(-1px); }
.lb-rank {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--text-faint);
  text-align: center;
}
.lb-row.top-1, .lb-row.top-2, .lb-row.top-3 { border-color: var(--medal-line, var(--border-2)); }
.lb-row.top-1 { --medal: var(--rarity-legendary); --medal-line: color-mix(in srgb, var(--rarity-legendary) 45%, transparent); }
.lb-row.top-2 { --medal: #c8d0dd; --medal-line: rgba(200,208,221,0.4); }
.lb-row.top-3 { --medal: #d8965a; --medal-line: rgba(216,150,90,0.4); }
.lb-row.top-1 .lb-rank, .lb-row.top-2 .lb-rank, .lb-row.top-3 .lb-rank { color: var(--medal); }
.lb-id { display: grid; gap: 1px; min-width: 0; }
.lb-id .lb-name { font-family: var(--font-display); font-weight: 600; font-size: 1.08rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.lb-id .lb-handle { color: var(--text-faint); font-size: 0.8rem; }
.lb-metric { display: grid; gap: 1px; justify-items: center; text-align: center; }
.lb-metric strong { font-family: var(--font-display); font-size: 1.35rem; line-height: 1; }
.lb-metric span { font-size: 0.66rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-faint); }
.lb-metric.is-streak strong { color: var(--accent-text); }
.lb-metric.is-shipped strong { color: var(--ship-green); }
.lb-metric.is-rekt strong { color: var(--rekt-2); }
.lb-clock { justify-self: end; }

/* ============================================================ profile grid  */
.profile-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--gap);
}
.profile-card {
  display: grid;
  gap: 14px;
  padding: clamp(20px, 2.2vw, 26px);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow: var(--shadow);
  transition: border-color 0.2s var(--ease), transform 0.2s var(--ease), box-shadow 0.2s var(--ease);
}
.profile-card:hover { border-color: var(--accent-line); transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.profile-card .pc-top { display: flex; align-items: center; gap: 12px; }
.profile-card .pc-name { font-family: var(--font-display); font-size: 1.25rem; font-weight: 600; }
.profile-card .pc-handle { color: var(--text-faint); font-size: 0.82rem; font-family: var(--font-mono); }
.profile-card .pc-headline { color: var(--text-muted); font-size: 0.92rem; min-height: 2.6em; }
.profile-card .pc-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.pc-stats .pc-stat { display: grid; gap: 1px; padding: 9px; border: 1px solid var(--border); border-radius: 11px; background: var(--surface-inset); text-align: center; }
.pc-stats .pc-stat strong { font-family: var(--font-display); font-size: 1.25rem; line-height: 1; }
.pc-stats .pc-stat span { font-size: 0.64rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-faint); }
.pc-stats .pc-stat.s strong { color: var(--accent-text); }
.pc-stats .pc-stat.p strong { color: var(--ship-green); }
.pc-stats .pc-stat.r strong { color: var(--rekt-2); }
.profile-card .pc-foot { display: flex; align-items: center; justify-content: space-between; gap: 10px; }

/* ============================================================ wall of rekt  */
.rekt-hero {
  position: relative;
  padding: clamp(30px, 5vw, 56px);
  border: 1px solid var(--rekt-line);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(120% 140% at 80% 0, var(--rekt-soft), transparent 60%),
    color-mix(in srgb, var(--surface) 90%, transparent);
  overflow: clip;
}
.rekt-hero h1 { font-size: var(--step-5); }
.rekt-hero h1 .rekt-stamp { font-size: 0.92em; }
.rekt-hero p { max-width: 640px; margin-top: 14px; color: var(--text-muted); font-size: 1.06rem; }

.rekt-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: var(--gap);
}
.rekt-card {
  position: relative;
  display: grid;
  gap: 10px;
  padding: 22px;
  border: 1px solid var(--rekt-line);
  border-radius: var(--radius);
  background:
    radial-gradient(120% 120% at 100% 0, var(--rekt-soft), transparent 55%),
    color-mix(in srgb, var(--surface) 92%, transparent);
  overflow: clip;
}
.rekt-card .rekt-count {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  font-family: var(--font-display);
}
.rekt-card .rekt-count b { font-size: 2.6rem; line-height: 1; color: var(--rekt); }
.rekt-card .rekt-count span { color: var(--text-faint); font-size: 0.8rem; letter-spacing: 0.06em; text-transform: uppercase; }
.rekt-card .rc-top { display: flex; align-items: center; gap: 12px; }
.rekt-card .rc-name { font-family: var(--font-display); font-weight: 600; font-size: 1.1rem; }
.rekt-card .rekt-quip { color: var(--text-muted); font-size: 0.9rem; font-style: italic; }
.rekt-card .rc-foot { display: flex; align-items: center; justify-content: space-between; gap: 8px; color: var(--text-faint); font-size: 0.78rem; }
.rekt-skull { position: absolute; top: 14px; right: 16px; font-size: 1.3rem; opacity: 0.5; }

/* ============================================================ pricing ===== */
.price-hero { width: 100%; max-width: 820px; margin-inline: auto; text-align: center; padding-top: clamp(20px, 4vw, 44px); }
.price-hero h1 { font-size: var(--step-5); }
.price-hero h1 .accent { color: var(--accent-text); }
.price-hero p { margin-top: 16px; color: var(--text-muted); font-size: 1.1rem; }

.price-card {
  position: relative;
  width: 100%;
  max-width: 580px;
  margin: clamp(26px, 4vw, 44px) auto 0;
  display: grid;
  gap: 22px;
  padding: clamp(28px, 4vw, 44px);
  border: 1px solid var(--accent-line);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(120% 120% at 50% 0, var(--accent-soft), transparent 60%),
    color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow: var(--shadow-lg);
  overflow: clip;
  text-align: center;
}
.price-card .price-tag { display: grid; gap: 4px; justify-items: center; }
.price-card .price-amount { font-family: var(--font-display); font-size: clamp(3.4rem, 2.4rem + 4vw, 5rem); line-height: 0.9; letter-spacing: -0.03em; }
.price-card .price-period { color: var(--text-muted); font-family: var(--font-mono); font-size: 0.9rem; }
.price-card .price-list { display: grid; gap: 12px; text-align: left; padding: 0; margin: 0; }
.price-card .price-list li { display: grid; grid-template-columns: auto 1fr; gap: 12px; align-items: start; list-style: none; }
.price-card .price-list svg { width: 20px; height: 20px; color: var(--ship-green); margin-top: 2px; }
.price-card .price-cta { display: grid; gap: 10px; }
.price-card .price-fine { color: var(--text-faint); font-size: 0.82rem; }

.price-faq { width: 100%; max-width: 820px; margin: clamp(44px, 6vw, 76px) auto 0; display: grid; gap: 12px; }
.price-faq details {
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--surface-inset);
  padding: 16px 18px;
}
.price-faq summary { cursor: pointer; font-weight: 600; font-family: var(--font-display); font-size: 1.05rem; }
.price-faq summary::-webkit-details-marker { display: none; }
.price-faq p { margin-top: 10px; color: var(--text-muted); }

/* ============================================================ dashboard === */
.dash { padding-top: clamp(20px, 3vw, 36px); display: grid; gap: clamp(30px, 3.5vw, 52px); }

.dash-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.85fr);
  gap: var(--gap);
  align-items: stretch;
}
.dash-clockcard {
  position: relative;
  display: grid;
  gap: 16px;
  align-content: center;
  padding: clamp(24px, 3vw, 38px);
  border: 1px solid var(--border-2);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(120% 120% at 80% 0, var(--accent-soft), transparent 55%),
    color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow: var(--shadow);
  text-align: center;
  justify-items: center;
}
.dash-clockcard.is-rekt { border-color: var(--rekt-line); background: radial-gradient(120% 120% at 80% 0, var(--rekt-soft), transparent 55%), color-mix(in srgb, var(--surface) 92%, transparent); }
.dash-clockcard .deadline { color: var(--text-faint); font-family: var(--font-mono); font-size: 0.82rem; }

.dash-side {
  display: grid;
  gap: var(--gap);
}
.dash-shipcard {
  display: grid;
  gap: 14px;
  align-content: start;
  padding: clamp(22px, 2.6vw, 30px);
  border: 1px solid var(--ship-green-line);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(120% 120% at 100% 0, var(--ship-green-soft), transparent 55%),
    color-mix(in srgb, var(--surface) 92%, transparent);
}
.dash-shipcard h2 { font-size: 1.5rem; }
.dash-shipcard p { color: var(--text-muted); font-size: 0.92rem; }

.dash-nudge {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  align-items: start;
  padding: 14px 16px;
  border: 1px solid var(--border);
  border-left: 3px solid var(--accent);
  border-radius: var(--radius-sm);
  background: var(--surface-inset);
}
.dash-nudge.suggest { border-left-color: var(--warn); }
.dash-nudge .nudge-emoji { font-size: 1.2rem; }
.dash-nudge p { color: var(--text-muted); font-size: 0.92rem; }
.dash-nudge strong { color: var(--text); }

.dash-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--gap);
  align-items: start;
}

.panel-head { margin-bottom: 16px; }
.panel-head h2 { font-size: 1.5rem; }
.panel-head p { margin-top: 6px; color: var(--text-muted); font-size: 0.9rem; }
.panel-head .public-url { font-family: var(--font-mono); font-size: 0.82rem; }
.panel-head .public-url a { color: var(--accent-text); }

/* ====================================================== public profile ==== */
.pp-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 380px);
  gap: var(--gap);
  align-items: stretch;
  margin-bottom: var(--gap);
}
.pp-head { display: grid; gap: 16px; align-content: center; padding: clamp(24px, 3vw, 40px); border: 1px solid var(--border); border-radius: var(--radius-lg); background: color-mix(in srgb, var(--surface) 92%, transparent); }
.pp-idline { display: flex; align-items: center; gap: 16px; }
.pp-head h1 { font-size: clamp(2.2rem, 1.6rem + 3vw, 3.4rem); }
.pp-head .pp-headline { color: var(--text-muted); font-size: 1.08rem; }
.pp-socials { display: flex; flex-wrap: wrap; gap: 10px; }
.pp-socials a {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 14px; border: 1px solid var(--border-2); border-radius: 999px;
  background: var(--surface-inset); color: var(--text-muted); font-weight: 600; font-size: 0.86rem;
}
.pp-socials a:hover { color: var(--accent-text); border-color: var(--accent-line); }
.pp-socials svg { width: 15px; height: 15px; }
.pp-follow-row { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }
.pp-followcounts { display: flex; gap: 18px; color: var(--text-muted); font-size: 0.9rem; }
.pp-followcounts b { color: var(--text); font-family: var(--font-display); }

.pp-columns { display: grid; grid-template-columns: minmax(0, 1.3fr) minmax(0, 0.7fr); gap: var(--gap); align-items: start; }

.product-list { display: grid; gap: 12px; }
.product-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  padding: 16px 18px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  transition: border-color 0.2s var(--ease);
}
.product-row:hover { border-color: var(--border-2); }
.product-row.is-removed { opacity: 0.6; border-style: dashed; border-color: var(--rekt-line); }
.pr-removed { color: var(--rekt-2); font-weight: 700; }
.product-row .pr-num { font-family: var(--font-mono); color: var(--text-faint); font-size: 0.9rem; width: 28px; text-align: center; }
.product-row .pr-body { min-width: 0; }
.product-row .pr-title { font-family: var(--font-display); font-size: 1.15rem; font-weight: 600; }
.product-row .pr-title a:hover { color: var(--accent-text); }
.product-row .pr-desc { margin-top: 3px; color: var(--text-muted); font-size: 0.9rem; }
.product-row .pr-meta { margin-top: 6px; color: var(--text-faint); font-family: var(--font-mono); font-size: 0.76rem; display: flex; flex-wrap: wrap; gap: 6px 14px; }
.product-row .pr-actions { display: flex; gap: 8px; align-items: center; }

/* ============================================================== forms ===== */
.ship-form { display: grid; gap: 14px; }
.ship-form .field { display: grid; gap: 6px; }
.ship-form label, .ship-form .field > span.label { color: var(--text); font-weight: 600; font-size: 0.92rem; }
.ship-form .hint { color: var(--text-faint); font-size: 0.8rem; }
.ship-form-row { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.ship-form input,
.ship-form select,
.ship-form textarea {
  width: 100%;
  min-height: 46px;
  border: 1px solid var(--border-2);
  border-radius: var(--radius-sm);
  background: var(--surface-inset);
  color: var(--text);
  font: inherit;
  padding: 11px 13px;
  transition: border-color 0.16s var(--ease), box-shadow 0.16s var(--ease);
}
.ship-form input:focus,
.ship-form select:focus,
.ship-form textarea:focus {
  outline: none;
  border-color: var(--accent-line);
  box-shadow: 0 0 0 3px var(--accent-soft);
}
.ship-form textarea { resize: vertical; min-height: 92px; }

/* segmented timer picker */
.timer-pick { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.timer-pick label {
  position: relative;
  display: grid;
  gap: 2px;
  padding: 12px;
  border: 1px solid var(--border-2);
  border-radius: var(--radius-sm);
  background: var(--surface-inset);
  text-align: center;
  cursor: pointer;
  transition: border-color 0.16s var(--ease), background 0.16s var(--ease);
}
.timer-pick input { position: absolute; opacity: 0; pointer-events: none; }
.timer-pick label strong { font-family: var(--font-display); font-size: 1.5rem; }
.timer-pick label span { font-size: 0.72rem; color: var(--text-faint); }
.timer-pick label:hover { border-color: var(--accent-line); }
.timer-pick input:checked + .tp-face { color: var(--accent-text); }
.timer-pick label:has(input:checked) { border-color: var(--accent); background: var(--accent-soft); }
.timer-pick label:has(input:checked) strong { color: var(--accent-text); }
.tp-tag {
  position: absolute;
  top: 6px;
  right: 7px;
  padding: 1px 6px;
  border-radius: 999px;
  border: 1px solid var(--ship-green-line);
  background: var(--ship-green-soft);
  color: var(--ship-green);
  font-family: var(--font-mono);
  font-size: 0.5rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* inline form feedback */
.form-msg { display: none; padding: 10px 14px; border-radius: var(--radius-sm); font-size: 0.9rem; font-weight: 600; }
.form-msg.is-shown { display: block; }
.form-msg.ok { background: var(--ship-green-soft); border: 1px solid var(--ship-green-line); color: var(--ship-green); }
.form-msg.err { background: var(--rekt-soft); border: 1px solid var(--rekt-line); color: var(--rekt-2); }

/* ============================================================ paywall ===== */
.paywall {
  display: grid;
  gap: 12px;
  padding: clamp(22px, 3vw, 34px);
  border: 1px solid var(--warn-soft);
  border-left: 4px solid var(--warn);
  border-radius: var(--radius);
  background:
    radial-gradient(120% 120% at 100% 0, var(--warn-soft), transparent 55%),
    color-mix(in srgb, var(--surface) 92%, transparent);
}
.paywall h1 { font-size: clamp(1.6rem, 1.2rem + 2vw, 2.4rem); }
.paywall p { max-width: 680px; color: var(--text-muted); }

/* ============================================================== modal ===== */
.report-options { display: grid; gap: 8px; margin: 6px 0 4px; }
.report-options label {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 14px;
  border: 1px solid var(--border-2);
  border-radius: var(--radius-sm);
  background: var(--surface-inset);
  cursor: pointer;
  font-weight: 600;
  font-size: 0.92rem;
  transition: border-color 0.16s var(--ease);
}
.report-options label:hover { border-color: var(--accent-line); }
.report-options label:has(input:checked) { border-color: var(--rekt-line); background: var(--rekt-soft); }
.report-options input { accent-color: var(--rekt); }

.modal-card .field { display: grid; gap: 6px; margin-top: 6px; text-align: left; }
.modal-card textarea {
  width: 100%; min-height: 80px; resize: vertical;
  border: 1px solid var(--border-2); border-radius: var(--radius-sm);
  background: var(--surface-inset); color: var(--text); font: inherit; padding: 10px 12px;
}

/* ====================================================== ship celebration == */
.ship-toast {
  position: fixed;
  left: 50%;
  bottom: 28px;
  transform: translateX(-50%) translateY(140%);
  z-index: 120;
  display: grid;
  gap: 8px;
  width: min(420px, calc(100% - 32px));
  padding: 18px 20px;
  border: 1px solid var(--ship-green-line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 96%, transparent);
  box-shadow: var(--shadow-lg);
  transition: transform 0.4s var(--ease-out);
}
.ship-toast.is-shown { transform: translateX(-50%) translateY(0); }
.ship-toast .toast-top { display: flex; align-items: center; gap: 10px; font-family: var(--font-display); font-size: 1.2rem; font-weight: 700; color: var(--ship-green); }
.ship-toast .toast-badges { display: flex; flex-wrap: wrap; gap: 8px; }

/* confetti bits */
.confetti { position: fixed; inset: 0; z-index: 119; pointer-events: none; overflow: clip; }
.confetti i {
  position: absolute;
  top: -12px;
  width: 9px;
  height: 14px;
  border-radius: 2px;
  opacity: 0.9;
  animation: confetti-fall linear forwards;
}
@keyframes confetti-fall {
  to { transform: translateY(105vh) rotate(720deg); opacity: 0.2; }
}

/* ============================================================ empty ====== */
.ship-empty {
  display: grid;
  gap: 6px;
  justify-items: start;
  padding: clamp(22px, 3vw, 34px);
  border: 1px dashed var(--border-2);
  border-radius: var(--radius);
  background: var(--surface-inset);
}
.ship-empty.center { justify-items: center; text-align: center; }
.ship-empty .e { font-size: 1.6rem; }
.ship-empty strong { font-family: var(--font-display); font-size: 1.15rem; }
.ship-empty span { color: var(--text-muted); }

/* ============================================================ responsive == */
@media (max-width: 1040px) {
  .hero-inner { grid-template-columns: 1fr; gap: clamp(28px, 5vw, 40px); }
  /* Stacked: center the whole copy column, console below it. The base template
     caps .hero-copy at 620px (styles.css) — lift it so centering has room. */
  .hero-copy { max-width: none; text-align: center; }
  .hero-actions { justify-content: center; }
  .hero-trust { justify-content: center; }
  .hero-sub { max-width: 620px; margin-inline: auto; }
  /* Keep "Ship, or get REKT" on a single line, scaled to fit the viewport.
     Headline width ≈ 8.25 × font-size (the rotated REKT stamp adds width), so
     10vw keeps a safe margin down to ~320px; capped at 5.5rem on big tablets. */
  .hero h1 { white-space: nowrap; font-size: clamp(2rem, 10vw, 5.5rem); }
  .hero-console { max-width: 560px; margin-inline: auto; width: 100%; }
  .lb-row { grid-template-columns: 44px auto minmax(0, 1fr) repeat(2, minmax(56px, auto)) minmax(110px, auto); }
  .lb-row .lb-metric.hide-md { display: none; }
}

@media (max-width: 900px) {
  .ship-stats { grid-template-columns: repeat(2, 1fr); }
  .rules-grid { grid-template-columns: 1fr; }
  .home-split { grid-template-columns: 1fr; }
  .dash-hero { grid-template-columns: 1fr; }
  .dash-grid { grid-template-columns: 1fr; }
  .pp-hero { grid-template-columns: 1fr; }
  .pp-columns { grid-template-columns: 1fr; }
}

@media (max-width: 620px) {
  .clock-lg .clock-num { font-size: clamp(2rem, 7vw, 3rem); }
  .clock-lg .clock-cell { min-width: 0; }
  .ship-stats { grid-template-columns: 1fr 1fr; }
  .ship-form-row { grid-template-columns: 1fr; }
  .lb-row {
    grid-template-columns: 38px 1fr auto;
    grid-template-areas: "rank id clock" "rank metrics metrics";
    row-gap: 10px;
  }
  .lb-rank { grid-area: rank; }
  .lb-id { grid-area: id; }
  .lb-clock { grid-area: clock; }
  .lb-metric { display: none; }
  .feed-item { grid-template-columns: auto minmax(0, 1fr); }
  .feed-side { grid-column: 2; justify-items: start; text-align: left; }
  .hero-actions .button { width: 100%; }
}

/* ============================================================ motion ===== */
@media (prefers-reduced-motion: reduce) {
  .clock.is-danger .clock-cell,
  .cd-pill.is-danger::before,
  .hero-badge .dot,
  .ship-marquee .track,
  .confetti i { animation: none; }
  .ship-toast { transition: none; }
}
