/* --- self-contained design tokens (ported from mewayz.com design system) --- */
@font-face {
  font-family: "Airstrike";
  src: url("/assets/fonts/airstrike.ttf") format("truetype");
  font-weight: 400 900;
  font-style: normal;
  font-display: block;
}
@import url("https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap");
:root {
  --ink: #0A0A0A;
  --ink-soft: #1A1A1A;
  --paper: #FAFAFA;
  --paper-warm: #F0EDE4;
  --paper-cream: #E8E2D3;
  --mute: #6B6B6B;
  --mute-soft: #9B9B9B;
  --line: rgba(10, 10, 10, 0.12);
  --line-strong: rgba(10, 10, 10, 0.32);
  --accent: #4F46E5;
  --accent-warm: #FF5C1F;
  --accent-cool: #1F6FFF;
  --font-display: "Airstrike", "Space Grotesk", system-ui, sans-serif;
  --font-sans: "Space Grotesk", system-ui, -apple-system, sans-serif;
  --font-mono: "JetBrains Mono", "SF Mono", "Menlo", monospace;
}

/* ============================================================
   MOGUL — game stylesheet. Built on Mewayz tokens.css
   (ink / paper / indigo, Airstrike + Space Grotesk + JetBrains).
   ============================================================ */

:root {
  --green: #22C55E;
  --green-deep: #15803D;
  --warm: #FF5C1F;
  --hud-h: 64px;
}

html, body { margin: 0; background: var(--paper-cream, #E8E2D3); }
#root { min-height: 100vh; }
.app { min-height: 100vh; display: flex; flex-direction: column; background:
  radial-gradient(1200px 600px at 80% -10%, rgba(79,70,229,0.10), transparent 60%),
  var(--paper-cream, #E8E2D3); }

.mono { font-family: var(--font-mono); font-variant-numeric: tabular-nums; }
.mono-tag { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--mute); white-space: nowrap; }

/* ---------------- generic button ---------------- */
.g-btn {
  font-family: var(--font-sans); font-weight: 600; font-size: 14px;
  display: inline-flex; align-items: center; justify-content: center; gap: 7px;
  padding: 11px 16px; border-radius: 999px; border: 1px solid var(--ink);
  background: var(--ink); color: var(--paper); cursor: pointer; white-space: nowrap;
  transition: transform 120ms var(--ease-out, ease), background 120ms, opacity 120ms, box-shadow 120ms;
}
.g-btn:hover { transform: translateY(-1px); box-shadow: 0 8px 20px -8px rgba(10,10,10,0.5); }
.g-btn:active { transform: translateY(0) scale(0.98); }
.g-btn.sm { padding: 8px 13px; font-size: 13px; }
.g-btn.full { width: 100%; }
.g-btn.off { opacity: 0.32; cursor: not-allowed; background: var(--mute); border-color: transparent; box-shadow: none; transform: none; }
.g-btn.pitch { background: var(--accent); border-color: var(--accent); }
.g-btn.pitch:hover { background: #3f37c9; }
.buy-btn { background: var(--accent); border-color: var(--accent); }
.buy-btn:hover { background: #3f37c9; }

/* ---------------- HUD ---------------- */
.hud {
  position: sticky; top: 0; z-index: 40;
  background: var(--ink); color: var(--paper);
  display: flex; align-items: center; gap: 20px;
  padding: 0 22px; height: var(--hud-h);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.hud-brand { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.hud-mark {
  width: 34px; height: 34px; border-radius: 9px; flex-shrink: 0;
  background: var(--accent); display: grid; place-items: center;
  font-family: var(--font-display); font-style: italic; font-size: 20px; color: #fff;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.2);
}
.hud-titles { line-height: 1; }
.hud-game { font-family: var(--font-display); font-style: italic; font-size: 21px; letter-spacing: -0.01em; text-transform: uppercase; }
.hud-co { display: flex; align-items: center; gap: 6px; margin-top: 3px; font-family: var(--font-mono); font-size: 11px; color: rgba(255,255,255,0.55); cursor: text; }
.hud-co input { background: transparent; border: none; color: rgba(255,255,255,0.85); font-family: var(--font-mono); font-size: 11px; width: 150px; padding: 0; outline: none; border-bottom: 1px dashed rgba(255,255,255,0.25); }

.hud-stats { display: flex; align-items: center; gap: 8px; margin-left: auto; overflow: hidden; }
.hchip { display: flex; flex-direction: column; gap: 1px; padding: 5px 13px; border-radius: 11px; background: rgba(255,255,255,0.05); min-width: 0; }
.hchip .l { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255,255,255,0.5); }
.hchip .v { font-family: var(--font-display); font-style: italic; font-size: 19px; letter-spacing: -0.01em; line-height: 1; }
.hchip.cash .v { color: var(--green); }
.hchip.cash.neg .v { color: var(--warm); }
.hchip.rank { background: var(--accent); }
.hchip.rank .l { color: rgba(255,255,255,0.7); }
.hchip.rank .v { font-size: 16px; font-style: normal; font-weight: 700; font-family: var(--font-sans); }

.hud-time { display: flex; align-items: center; gap: 6px; flex-shrink: 0; padding-left: 14px; border-left: 1px solid rgba(255,255,255,0.1); }
.hud-date { font-family: var(--font-mono); font-size: 12px; color: rgba(255,255,255,0.7); width: 58px; }
.t-btn { width: 32px; height: 32px; border-radius: 9px; border: 1px solid rgba(255,255,255,0.14); background: rgba(255,255,255,0.05); color: var(--paper); display: grid; place-items: center; cursor: pointer; transition: background 120ms; }
.t-btn:hover { background: rgba(255,255,255,0.14); }
.t-btn.on { background: var(--paper); color: var(--ink); border-color: var(--paper); }
.spd { font-family: var(--font-mono); font-size: 12px; font-weight: 700; }

/* ---------------- tabs ---------------- */
.tabs { position: sticky; top: var(--hud-h); z-index: 35; display: flex; gap: 4px; padding: 10px 22px; background: rgba(232,226,211,0.9); backdrop-filter: blur(12px); border-bottom: 1px solid var(--line); overflow-x: auto; }
.tab { display: inline-flex; align-items: center; gap: 8px; padding: 9px 16px; border-radius: 999px; border: 1px solid transparent; background: transparent; color: var(--ink); font-family: var(--font-sans); font-weight: 600; font-size: 14px; cursor: pointer; opacity: 0.6; transition: opacity 130ms, color 130ms; white-space: nowrap; }
.tab:hover { opacity: 1; background: rgba(10,10,10,0.05); }
.tab.on { opacity: 1; background: var(--ink); color: var(--paper); }

/* ---------------- stage / layout ---------------- */
.stage { flex: 1; overflow-y: auto; padding: 28px 22px 80px; }
.panel { max-width: 1240px; margin: 0 auto; }
.panel-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 24px; margin-bottom: 24px; flex-wrap: wrap; }
.panel-title { font-family: var(--font-display); font-style: italic; font-size: 46px; line-height: 0.95; letter-spacing: -0.02em; margin: 0 0 10px; }
.panel-sub { font-family: var(--font-sans); font-size: 15px; line-height: 1.5; color: var(--mute); max-width: 620px; margin: 0; }
.panel-sub b { color: var(--ink); }

/* ---------------- stat grid (dashboard) ---------------- */
.grid-stats { display: grid; grid-template-columns: repeat(6, 1fr); gap: 12px; margin-bottom: 20px; }
.stat { background: var(--paper); border: 1px solid var(--line); border-radius: 16px; padding: 16px 18px; }
.stat-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--mute); margin-bottom: 8px; }
.stat-value { font-family: var(--font-display); font-style: italic; font-size: 30px; line-height: 1; letter-spacing: -0.02em; }
.stat-sub { font-family: var(--font-mono); font-size: 11px; color: var(--mute); margin-top: 7px; }
.stat.hero { background: var(--ink); color: var(--paper); }
.stat.hero .stat-label, .stat.hero .stat-sub { color: rgba(255,255,255,0.55); }
.stat.good .stat-value { color: var(--green-deep); }
.stat.bad .stat-value { color: var(--warm); }
.stat.rank { background: var(--accent); color: #fff; }
.stat.rank .stat-label, .stat.rank .stat-sub { color: rgba(255,255,255,0.72); }
.stat.rank .stat-value { font-style: normal; font-family: var(--font-sans); font-weight: 700; font-size: 25px; }

/* ---------------- cards ---------------- */
.card { background: var(--paper); border: 1px solid var(--line); border-radius: 18px; padding: 22px; }
.card-h { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 16px; }
.card-h h3 { font-family: var(--font-sans); font-weight: 700; font-size: 18px; margin: 0; letter-spacing: -0.01em; }
.dash-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }

.flow { display: flex; flex-direction: column; }
.flow-row { display: flex; justify-content: space-between; align-items: center; padding: 11px 0; border-bottom: 1px solid var(--line); font-size: 14px; }
.flow-row .mono { font-size: 13px; }
.flow-row.good span:last-child { color: var(--green-deep); }
.flow-row.cost span:last-child { color: var(--warm); }
.flow-row.total { border-bottom: none; margin-top: 4px; padding-top: 14px; font-weight: 700; font-size: 16px; }
.flow-row.total .mono { font-size: 16px; font-weight: 700; }

.rank-block { margin-top: 18px; padding-top: 18px; border-top: 1px dashed var(--line); }
.rank-row { display: flex; justify-content: space-between; margin-bottom: 8px; }
.rank-hint { font-size: 12.5px; color: var(--mute); margin-top: 9px; line-height: 1.45; }
.rank-hint b { color: var(--accent); }

.bar { height: 8px; border-radius: 999px; background: rgba(10,10,10,0.08); overflow: hidden; }
.bar-fill { height: 100%; border-radius: 999px; transition: width 350ms var(--ease-out, ease); }

/* log */
.log { display: flex; flex-direction: column; gap: 2px; max-height: 320px; overflow-y: auto; }
.log-row { display: flex; align-items: center; gap: 10px; padding: 8px 4px; border-bottom: 1px solid rgba(10,10,10,0.05); font-size: 13.5px; }
.log-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--mute); flex-shrink: 0; }
.log-row.good .log-dot { background: var(--green); }
.log-row.bad .log-dot { background: var(--warm); }
.log-t { flex: 1; line-height: 1.35; }
.log-m { color: var(--mute); font-size: 10px; flex-shrink: 0; }

/* plan ladder */
.plan-card { }
.plan-ladder { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; }
.plan-tier { border: 1px solid var(--line); border-radius: 14px; padding: 16px; display: flex; flex-direction: column; gap: 6px; background: var(--paper); position: relative; }
.plan-tier.current { border-color: var(--accent); box-shadow: 0 0 0 2px rgba(79,70,229,0.18); }
.plan-tier.locked { opacity: 0.62; }
.plan-name { font-family: var(--font-sans); font-weight: 700; font-size: 15px; }
.plan-share { font-family: var(--font-display); font-style: italic; font-size: 38px; line-height: 0.9; letter-spacing: -0.02em; color: var(--accent); }
.plan-meta { font-size: 11px; color: var(--mute); }
.plan-blurb { font-size: 12px; color: var(--mute); line-height: 1.4; flex: 1; margin-bottom: 4px; }
.plan-badge { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; text-align: center; padding: 8px; border-radius: 999px; }
.plan-badge.cur { background: rgba(79,70,229,0.12); color: var(--accent); }
.plan-badge.lock { background: rgba(10,10,10,0.05); color: var(--mute); }

/* ---------------- clients ---------------- */
.cap-meter { min-width: 220px; }
.cap-num { font-family: var(--font-display); font-style: italic; font-size: 34px; letter-spacing: -0.02em; margin: 4px 0 8px; }
.cap-num span { color: var(--mute); font-size: 22px; }
.seg-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.seg-card { background: var(--paper); border: 1px solid var(--line); border-radius: 16px; padding: 18px; display: flex; flex-direction: column; gap: 12px; transition: box-shadow 200ms, border-color 200ms, transform 120ms; }
.seg-card.locked { opacity: 0.66; }
.seg-card.flash-win { border-color: var(--green); box-shadow: 0 0 0 2px rgba(34,197,94,0.3); }
.seg-card.flash-lose { border-color: var(--warm); box-shadow: 0 0 0 2px rgba(255,92,31,0.25); }
.seg-top { display: flex; justify-content: space-between; gap: 12px; }
.seg-name { font-family: var(--font-sans); font-weight: 700; font-size: 16px; }
.seg-desc { font-size: 12.5px; color: var(--mute); line-height: 1.4; margin-top: 4px; }
.seg-count { font-family: var(--font-display); font-style: italic; font-size: 30px; line-height: 0.85; text-align: right; }
.seg-count span { display: block; font-family: var(--font-mono); font-style: normal; font-size: 9px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--mute); }
.seg-nums { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; padding: 12px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.seg-val { font-family: var(--font-display); font-style: italic; font-size: 22px; letter-spacing: -0.02em; }
.seg-val span { font-family: var(--font-mono); font-style: normal; font-size: 11px; color: var(--mute); margin-left: 2px; }
.seg-val.good { color: var(--green-deep); }
.seg-chance { display: flex; justify-content: space-between; align-items: center; }
.seg-lock { display: flex; align-items: center; gap: 8px; font-size: 12.5px; color: var(--mute); padding: 8px 0; }
.seg-lock b { color: var(--ink); }

/* ---------------- buy grids (team/upgrades) ---------------- */
.team-summary, .life-hero-stats { display: flex; gap: 22px; }
.team-summary > div { text-align: right; }
.ts-num { font-family: var(--font-display); font-style: italic; font-size: 26px; letter-spacing: -0.02em; margin-top: 3px; }
.ts-num span { font-family: var(--font-mono); font-style: normal; font-size: 11px; color: var(--mute); margin-left: 1px; }
.buy-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.buy-card { background: var(--paper); border: 1px solid var(--line); border-radius: 16px; padding: 18px; display: flex; flex-direction: column; gap: 14px; }
.buy-ico { width: 46px; height: 46px; border-radius: 12px; background: rgba(79,70,229,0.1); color: var(--accent); display: grid; place-items: center; }
.buy-body { flex: 1; }
.buy-h { display: flex; align-items: center; justify-content: space-between; }
.buy-h h4 { margin: 0; font-family: var(--font-sans); font-weight: 700; font-size: 16px; }
.owned-pill { background: var(--ink); color: var(--paper); font-size: 12px; padding: 2px 10px; border-radius: 999px; }
.buy-desc { font-size: 13px; color: var(--mute); line-height: 1.45; margin: 8px 0; }
.buy-meta { font-size: 11px; color: var(--mute); }
.dots { display: flex; gap: 4px; }
.dots i { width: 8px; height: 8px; border-radius: 50%; background: rgba(10,10,10,0.14); }
.dots i.on { background: var(--accent); }

/* ---------------- lifestyle ---------------- */
.life-hero { display: flex; justify-content: space-between; align-items: flex-end; gap: 24px; flex-wrap: wrap; background: var(--ink); color: var(--paper); border-radius: 20px; padding: 28px 30px; margin-bottom: 22px;
  background-image: radial-gradient(600px 300px at 90% 10%, rgba(79,70,229,0.35), transparent 60%); }
.life-hero .mono-tag { color: rgba(255,255,255,0.55); }
.life-hero-title { font-family: var(--font-display); font-style: italic; font-size: 44px; line-height: 0.95; letter-spacing: -0.02em; margin: 8px 0 10px; }
.life-hero .panel-sub { color: rgba(255,255,255,0.72); }
.life-hero .panel-sub b { color: #fff; }
.life-hero-stats > div { text-align: right; }
.lh-num { font-family: var(--font-display); font-style: italic; font-size: 28px; letter-spacing: -0.02em; margin-top: 3px; }

.sub-nav { display: flex; gap: 8px; margin-bottom: 14px; flex-wrap: wrap; }
.sub-tab { display: inline-flex; align-items: center; gap: 9px; padding: 10px 16px; border-radius: 12px; border: 1px solid var(--line); background: var(--paper); color: var(--ink); font-family: var(--font-sans); font-weight: 600; font-size: 14px; cursor: pointer; opacity: 0.7; transition: opacity 130ms, color 130ms; }
.sub-tab:hover { opacity: 1; }
.sub-tab.on { opacity: 1; background: var(--accent); color: #fff; border-color: var(--accent); }
.sub-count { background: rgba(10,10,10,0.07); padding: 1px 8px; border-radius: 999px; font-size: 11px; }
.sub-tab.on .sub-count { background: rgba(255,255,255,0.2); color: #fff; }
.sub-blurb { font-size: 14px; color: var(--mute); margin: 0 0 18px; }

.life-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.life-card { background: var(--paper); border: 1px solid var(--line); border-radius: 16px; overflow: hidden; display: flex; flex-direction: column; transition: transform 140ms var(--ease-out, ease), box-shadow 140ms; }
.life-card:hover { transform: translateY(-3px); box-shadow: 0 16px 34px -16px rgba(10,10,10,0.35); }
.life-card.locked { opacity: 0.72; }
.life-card.owned { border-color: var(--green); }

.tile-img { position: relative; aspect-ratio: 16/10; overflow: hidden; background: linear-gradient(140deg, var(--accent) 0%, #241a5e 100%); }
.tile-glyph { position: absolute; inset: 0; display: grid; place-items: center; color: rgba(255,255,255,0.85); }
.tile-img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0; transition: opacity 400ms; filter: grayscale(1) contrast(1.05) brightness(1.04); mix-blend-mode: luminosity; }
.tile-img img.on { opacity: 0.92; }
.tile-grain { position: absolute; inset: 0; background-image: radial-gradient(rgba(255,255,255,0.16) 0.6px, transparent 0.6px); background-size: 7px 7px; opacity: 0.4; pointer-events: none; }
.tile-img.owned::after { content: "✓"; position: absolute; top: 8px; right: 9px; width: 22px; height: 22px; border-radius: 50%; background: var(--green); color: #fff; font-size: 13px; font-weight: 700; display: grid; place-items: center; box-shadow: 0 2px 8px rgba(0,0,0,0.3); }

.life-body { padding: 14px 15px 8px; flex: 1; }
.life-h { display: flex; justify-content: space-between; align-items: flex-start; gap: 8px; }
.life-h h4 { margin: 0; font-family: var(--font-sans); font-weight: 700; font-size: 15px; line-height: 1.2; }
.life-pts { font-family: var(--font-display); font-style: italic; font-size: 22px; color: var(--accent); line-height: 0.8; flex-shrink: 0; }
.life-pts span { font-family: var(--font-mono); font-style: normal; font-size: 9px; color: var(--mute); display: block; text-align: right; letter-spacing: 0.1em; }
.life-note { font-size: 12.5px; color: var(--mute); line-height: 1.4; margin: 8px 0 10px; }
.life-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.tag { display: inline-flex; align-items: center; gap: 4px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.04em; padding: 3px 8px; border-radius: 999px; }
.tag.perk { background: rgba(34,197,94,0.12); color: var(--green-deep); }
.tag.cost { background: rgba(255,92,31,0.1); color: var(--warm); }
.life-foot { padding: 12px 15px 15px; }
.life-owned { display: flex; align-items: center; gap: 7px; color: var(--green-deep); font-weight: 600; font-size: 13.5px; }
.life-lock { display: flex; align-items: center; gap: 7px; color: var(--mute); font-size: 12px; }

/* ---------------- toasts ---------------- */
.toasts { position: fixed; right: 18px; bottom: 18px; z-index: 60; display: flex; flex-direction: column; gap: 10px; pointer-events: none; }
.toast { background: var(--ink); color: var(--paper); padding: 12px 16px; border-radius: 13px; font-size: 13.5px; max-width: 320px; box-shadow: 0 18px 40px -14px rgba(10,10,10,0.6); display: flex; align-items: center; gap: 10px; animation: toastIn 280ms var(--ease-out, ease); border-left: 3px solid var(--mute); }
.toast.good { border-left-color: var(--green); }
.toast.bad { border-left-color: var(--warm); }
@keyframes toastIn { from { opacity: 0; transform: translateX(20px); } to { opacity: 1; transform: none; } }

/* ---------------- intro modal ---------------- */
.scrim { position: fixed; inset: 0; z-index: 80; background: rgba(10,10,10,0.7); backdrop-filter: blur(6px); display: grid; place-items: center; padding: 20px; }
.intro { background: var(--paper); border-radius: 22px; max-width: 560px; padding: 40px; box-shadow: var(--shadow-xl, 0 32px 64px -12px rgba(0,0,0,0.4)); }
.intro h1 { font-family: var(--font-display); font-style: italic; font-size: 56px; line-height: 0.9; letter-spacing: -0.02em; margin: 0 0 8px; }
.intro h1 .accent { color: var(--accent); }
.intro .lead { font-size: 16px; color: var(--mute); line-height: 1.55; margin: 0 0 22px; }
.intro ol { margin: 0 0 26px; padding-left: 18px; }
.intro li { font-size: 14px; line-height: 1.5; margin-bottom: 9px; }
.intro li b { color: var(--ink); }
.intro .field { margin-bottom: 22px; }
.intro .field label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--mute); display: block; margin-bottom: 8px; }
.intro .field input { width: 100%; padding: 13px 16px; border-radius: 12px; border: 1px solid var(--line); font-family: var(--font-sans); font-size: 16px; background: var(--paper); }
.intro .field input:focus { outline: 2px solid var(--accent); border-color: var(--accent); }

.menu-pop { position: absolute; top: 56px; right: 12px; background: var(--paper); border: 1px solid var(--line); border-radius: 14px; padding: 8px; box-shadow: 0 18px 40px -14px rgba(10,10,10,0.4); z-index: 50; min-width: 180px; }
.menu-pop button { display: flex; width: 100%; align-items: center; gap: 10px; padding: 10px 12px; border: none; background: transparent; font-family: var(--font-sans); font-size: 14px; color: var(--ink); cursor: pointer; border-radius: 9px; text-align: left; }
.menu-pop button:hover { background: rgba(10,10,10,0.05); }
.menu-pop button.danger { color: var(--warm); }

/* ---------------- net worth trend ---------------- */
.nw-trend { margin-bottom: 16px; }
.trend-row { display: flex; align-items: center; gap: 24px; }
.trend-meta { flex-shrink: 0; }
.trend-now { font-family: var(--font-display); font-style: italic; font-size: 40px; line-height: 0.9; letter-spacing: -0.02em; }
.trend-delta { font-family: var(--font-mono); font-size: 12px; margin-top: 8px; }
.trend-delta.up { color: var(--green-deep); }
.trend-delta.down { color: var(--warm); }
.trend-chart { flex: 1; min-width: 0; }
.spark { width: 100%; height: 64px; display: block; }
.spark-empty { padding: 22px 0; }

/* ---------------- achievements ---------------- */
.ach-prog { min-width: 220px; text-align: right; }
.ach-prog-num { font-family: var(--font-display); font-style: italic; font-size: 38px; letter-spacing: -0.02em; margin: 4px 0 10px; }
.ach-prog-num span { color: var(--mute); font-size: 22px; }
.ach-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.ach-card { display: flex; gap: 14px; align-items: flex-start; background: var(--paper); border: 1px solid var(--line); border-radius: 14px; padding: 16px; opacity: 0.66; transition: opacity 150ms, border-color 150ms, box-shadow 150ms; }
.ach-card.got { opacity: 1; border-color: rgba(79,70,229,0.4); box-shadow: 0 0 0 1px rgba(79,70,229,0.12); }
.ach-ico { width: 42px; height: 42px; flex-shrink: 0; border-radius: 11px; display: grid; place-items: center; background: rgba(10,10,10,0.05); color: var(--mute); }
.ach-card.got .ach-ico { background: var(--accent); color: #fff; }
.ach-body { flex: 1; min-width: 0; }
.ach-h { display: flex; align-items: center; gap: 8px; }
.ach-h h4 { margin: 0; font-family: var(--font-sans); font-weight: 700; font-size: 15px; }
.ach-check { width: 18px; height: 18px; border-radius: 50%; background: var(--green); color: #fff; display: grid; place-items: center; flex-shrink: 0; }
.ach-desc { font-size: 12.5px; color: var(--mute); line-height: 1.4; margin: 5px 0 8px; }
.tag.mut { background: rgba(10,10,10,0.05); color: var(--mute); }

/* ---------------- offer card ---------------- */
.g-btn.ghost { background: transparent; color: var(--ink); border-color: var(--line); }
.g-btn.ghost:hover { background: rgba(10,10,10,0.05); box-shadow: none; }
.offer-card { position: fixed; left: 18px; bottom: 18px; z-index: 60; width: 320px; background: var(--paper); border: 1px solid var(--line); border-radius: 16px; padding: 18px; box-shadow: 0 24px 50px -16px rgba(10,10,10,0.45); animation: offerIn 320ms var(--ease-out, ease); border-top: 3px solid var(--accent); }
.offer-card.urgent { border-top-color: var(--warm); }
.offer-h { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.offer-card.urgent .offer-h .mono-tag { color: var(--warm); }
.offer-exp { font-size: 11px; color: var(--mute); }
.offer-card h4 { margin: 0 0 6px; font-family: var(--font-sans); font-weight: 700; font-size: 17px; }
.offer-card p { margin: 0 0 14px; font-size: 13px; color: var(--mute); line-height: 1.45; }
.offer-actions { display: flex; gap: 8px; }
.offer-actions .g-btn { flex: 1; }
@keyframes offerIn { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }

/* ---------------- victory ---------------- */
.intro.victory { text-align: left; }
.vic-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin: 4px 0 26px; padding: 20px; background: var(--ink); border-radius: 16px; }
.vic-stats .mono-tag { color: rgba(255,255,255,0.55); }
.vic-n { font-family: var(--font-display); font-style: italic; font-size: 26px; color: var(--paper); letter-spacing: -0.02em; margin-top: 4px; }

/* ---------------- leaderboard ---------------- */
.lb-rankbox { min-width: 200px; text-align: right; }
.lb-rank-num { font-family: var(--font-display); font-style: italic; font-size: 40px; letter-spacing: -0.02em; margin-top: 4px; }
.lb-rank-num span { color: var(--mute); font-size: 22px; }
.lb-list { display: flex; flex-direction: column; gap: 6px; }
.lb-row { display: flex; align-items: center; gap: 14px; background: var(--paper); border: 1px solid var(--line); border-radius: 13px; padding: 12px 16px; transition: box-shadow 150ms; }
.lb-row.you { border-color: var(--accent); box-shadow: 0 0 0 2px rgba(79,70,229,0.16); background: rgba(79,70,229,0.04); }
.lb-pos { width: 28px; text-align: center; font-size: 14px; font-weight: 700; color: var(--mute); flex-shrink: 0; }
.lb-row.you .lb-pos { color: var(--accent); }
.lb-mono { width: 36px; height: 36px; border-radius: 50%; display: grid; place-items: center; font-family: var(--font-sans); font-weight: 700; font-size: 15px; flex-shrink: 0; }
.lb-name { font-family: var(--font-sans); font-weight: 600; font-size: 15px; width: 210px; flex-shrink: 0; display: flex; align-items: center; gap: 8px; }
.lb-youtag { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.12em; background: var(--accent); color: #fff; padding: 2px 6px; border-radius: 5px; }
.lb-bar { flex: 1; height: 8px; border-radius: 999px; background: rgba(10,10,10,0.06); overflow: hidden; min-width: 60px; }
.lb-bar-fill { height: 100%; border-radius: 999px; }
.lb-nw { width: 90px; text-align: right; font-size: 14px; font-weight: 600; flex-shrink: 0; }

/* ---------------- sync modal ---------------- */
.intro.sync { max-width: 600px; max-height: 92vh; overflow-y: auto; }
.sync-sec { margin-bottom: 20px; }
.sync-sec label { display: block; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--mute); margin-bottom: 8px; }
.sync-code { width: 100%; box-sizing: border-box; min-height: 70px; resize: vertical; padding: 12px 14px; border-radius: 12px; border: 1px solid var(--line); font-family: var(--font-mono); font-size: 12px; line-height: 1.5; color: var(--ink); background: var(--paper-warm); word-break: break-all; }
.sync-code:focus { outline: 2px solid var(--accent); border-color: var(--accent); }
.sync-actions { display: flex; align-items: center; gap: 10px; margin-top: 10px; flex-wrap: wrap; }
.sync-msg { font-size: 13px; color: var(--mute); }

/* ---------------- lifestyle enhancements ---------------- */
.life-hero { align-items: flex-start; }
.life-hero-main { flex: 1; min-width: 280px; }
.life-hero-side { display: flex; gap: 22px; flex-shrink: 0; }
.life-hero-side > div { text-align: right; }
.life-perks { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 16px; }
.perk-chip { display: flex; flex-direction: column; gap: 2px; padding: 8px 14px; border-radius: 11px; background: rgba(255,255,255,0.06); }
.perk-chip .mono-tag { color: rgba(255,255,255,0.5); }
.perk-chip b { font-family: var(--font-display); font-style: italic; font-size: 20px; letter-spacing: -0.01em; color: #fff; }
.perk-chip.warn b { color: #FF9B6B; }

/* per-category tile theming */
.tile-img.cat-garage { background: linear-gradient(140deg, #1F6FFF 0%, #0c2a6b 100%); }
.tile-img.cat-luxury { background: linear-gradient(140deg, #FF5C1F 0%, #5e1d06 100%); }
.tile-img.cat-family { background: linear-gradient(140deg, #22C55E 0%, #0b3f23 100%); }
.tile-img.cat-holdings { background: linear-gradient(140deg, #3a2f7a 0%, #0A0A0A 100%); }

/* flagship */
.life-card { position: relative; }
.flag-ribbon { position: absolute; top: 12px; left: 12px; z-index: 3; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; padding: 4px 9px; border-radius: 6px; background: var(--accent-warm); color: #fff; box-shadow: 0 4px 12px rgba(0,0,0,0.3); }
.life-card.flagship { border-color: rgba(255,92,31,0.4); }

/* save up */
.save-up { width: 100%; }
.save-row { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 8px; }
.save-amt { font-size: 11px; color: var(--mute); }

/* sub-tab completed */
.sub-tab.done { border-color: var(--green); color: var(--green-deep); }
.sub-tab.done .sub-count { background: var(--green); color: #fff; display: inline-grid; place-items: center; min-width: 20px; height: 18px; }
.sub-tab.on.done { background: var(--green); color: #fff; border-color: var(--green); }
.sub-tab.on.done .sub-count { background: rgba(255,255,255,0.25); }

/* set complete banner */
.set-banner { display: flex; align-items: center; gap: 10px; background: rgba(34,197,94,0.1); border: 1px solid rgba(34,197,94,0.3); color: var(--green-deep); border-radius: 12px; padding: 12px 18px; font-size: 14px; margin-bottom: 18px; }
.set-banner b { color: var(--green-deep); }

/* ---------------- owned-reveal (overlay lifts when owned) ---------------- */
.tile-overlay { position: absolute; inset: 0; pointer-events: none; transition: opacity 400ms var(--ease-out, ease); background: linear-gradient(180deg, rgba(10,10,10,0.05) 0%, rgba(10,10,10,0.42) 100%); }
.tile-img.owned .tile-overlay { opacity: 0; }
.tile-img img.on { opacity: 0.68; }
.tile-img.owned img.on { opacity: 1; filter: none; mix-blend-mode: normal; }
.tile-img.owned.has-photo .tile-glyph { opacity: 0; transition: opacity 400ms; }
.tile-img.owned .tile-grain { opacity: 0.18; }

/* ---------------- races ---------------- */
.races { background: var(--paper); border: 1px solid var(--line); border-radius: 18px; padding: 20px; margin-bottom: 18px; }
.races-h { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 14px; }
.races-h h3 { margin: 0; font-family: var(--font-sans); font-weight: 700; font-size: 18px; }
.race-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.race-card { border: 1px solid var(--line); border-radius: 14px; padding: 14px; display: flex; flex-direction: column; gap: 10px; transition: box-shadow 200ms, border-color 200ms; }
.race-card.win { border-color: var(--green); box-shadow: 0 0 0 2px rgba(34,197,94,0.3); }
.race-card.lose { border-color: var(--warm); box-shadow: 0 0 0 2px rgba(255,92,31,0.25); }
.race-top { display: flex; gap: 10px; }
.race-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(31,111,255,0.12); color: var(--accent-cool); display: grid; place-items: center; flex-shrink: 0; }
.race-name { font-family: var(--font-sans); font-weight: 700; font-size: 14px; line-height: 1.2; }
.race-desc { font-size: 11.5px; color: var(--mute); margin-top: 2px; }
.race-meta { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; padding: 10px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.race-meta b { font-family: var(--font-display); font-style: italic; font-size: 17px; letter-spacing: -0.01em; display: block; margin-top: 2px; }
.race-meta b.good { color: var(--green-deep); }
.race-entrant { font-size: 11px; color: var(--mute); }
.race-lock { display: flex; align-items: center; gap: 7px; font-size: 12px; color: var(--mute); padding: 6px 0; }

/* ---------------- rent toggle ---------------- */
.rent-btn { width: 100%; display: flex; align-items: center; justify-content: center; gap: 7px; padding: 10px 14px; border-radius: 999px; border: 1px solid var(--line); background: var(--paper); color: var(--ink); font-family: var(--font-sans); font-weight: 600; font-size: 13px; cursor: pointer; transition: background 130ms, border-color 130ms, color 130ms; }
.rent-btn:hover { background: rgba(10,10,10,0.04); }
.rent-btn.on { background: rgba(34,197,94,0.12); border-color: var(--green); color: var(--green-deep); }

/* ---------------- businesses ---------------- */
.biz-total { text-align: right; min-width: 180px; }
.biz-total-num { font-family: var(--font-display); font-style: italic; font-size: 34px; letter-spacing: -0.02em; margin-top: 4px; color: var(--green-deep); }
.biz-total-num span { color: var(--mute); font-size: 18px; }
.biz-card.biz-locked-card { opacity: 0.64; }
.biz-stats { display: flex; justify-content: space-between; align-items: center; margin-top: 8px; font-size: 13px; }
.biz-rev { color: var(--green-deep); font-weight: 700; }
.biz-lockmsg { display: flex; align-items: center; gap: 7px; font-size: 12px; color: var(--mute); margin-top: 8px; }
.biz-lockmsg b { color: var(--ink); }
.biz-add { font-size: 11px; opacity: 0.82; margin-left: 4px; font-weight: 500; }

/* ---------------- responsive ---------------- */
@media (max-width: 1100px) {
  .grid-stats { grid-template-columns: repeat(3, 1fr); }
  .plan-ladder { grid-template-columns: repeat(3, 1fr); }
  .seg-grid, .buy-grid { grid-template-columns: repeat(2, 1fr); }
  .ach-grid { grid-template-columns: repeat(2, 1fr); }
  .race-grid { grid-template-columns: repeat(2, 1fr); }
  .life-grid { grid-template-columns: repeat(3, 1fr); }
  .hud-stats .hchip.nw, .hud-stats .hchip.mrr { display: none; }
}
@media (max-width: 820px) {
  .dash-cols { grid-template-columns: 1fr; }
  .life-grid { grid-template-columns: repeat(2, 1fr); }
  .plan-ladder { grid-template-columns: repeat(2, 1fr); }
  .panel-title { font-size: 36px; }
  .hud-game { font-size: 18px; }
  .hud-co { display: none; }
  .hud-stats .hchip.clients { display: none; }
}
@media (max-width: 560px) {
  .grid-stats { grid-template-columns: repeat(2, 1fr); }
  .seg-grid, .buy-grid, .life-grid, .plan-ladder { grid-template-columns: 1fr; }
  .ach-grid { grid-template-columns: 1fr; }
  .race-grid { grid-template-columns: 1fr; }
  .trend-row { flex-direction: column; align-items: flex-start; gap: 12px; }
  .trend-chart { width: 100%; }
  .offer-card { left: 12px; right: 12px; width: auto; }
  .vic-stats { grid-template-columns: repeat(2, 1fr); }
  .lb-name { width: 130px; }
  .lb-bar { display: none; }
  .hud-stats .hchip.rep { display: none; }
  .stage { padding: 20px 14px 70px; }
  .tabs { padding: 8px 14px; }
}
