/* === GYMROM v2 — CYBERPUNK / FUTURISTIC === */

:root {
  /* base palette */
  --bg-0: #020617;
  --bg-1: #0a0e2e;
  --bg-2: #0f1638;
  --ink: #e7f6ff;
  --ink-dim: #8b9bcf;
  --ink-mute: #5a6a9b;

  /* neon accents (overridden by theme) */
  --neon-1: #00f0ff;     /* cyan */
  --neon-2: #ff2fb0;     /* magenta */
  --neon-3: #a3ff12;     /* acid green */
  --neon-glow-1: 0 0 8px rgba(0,240,255,0.55), 0 0 24px rgba(0,240,255,0.25);
  --neon-glow-2: 0 0 8px rgba(255,47,176,0.55), 0 0 24px rgba(255,47,176,0.25);

  --panel: rgba(10,16,46,0.55);
  --panel-strong: rgba(10,16,46,0.85);
  --border: rgba(0,240,255,0.25);
  --border-strong: rgba(0,240,255,0.5);

  --good: #00ff8a;
  --warn: #ffd54a;
  --danger: #ff3a5c;
}

/* Themes */
.theme-cyber    { --neon-1: #00f0ff; --neon-2: #ff2fb0; }
.theme-plasma   { --neon-1: #ff2fb0; --neon-2: #fff200; }
.theme-matrix   { --neon-1: #00ff8a; --neon-2: #aaff00; }
.theme-inferno  { --neon-1: #ff5a3c; --neon-2: #ffd54a; }
.theme-arctic   { --neon-1: #62e2ff; --neon-2: #5879ff; }
.theme-gold     { --neon-1: #ffd54a; --neon-2: #ff8a00; }
.theme-galaxy   { --neon-1: #b266ff; --neon-2: #ff66c4; }
.theme-toxic    { --neon-1: #a3ff12; --neon-2: #00ff8a; }
.theme-vapor    { --neon-1: #ff6ad5; --neon-2: #94d0ff; }
.theme-blood    { --neon-1: #ff003c; --neon-2: #7a0019; }
.theme-quantum  { --neon-1: #00ffff; --neon-2: #a3ff12; }
.theme-godmode  { --neon-1: #fff200; --neon-2: #ff2fb0; }

/* Backgrounds */
.bg-grid     { background: radial-gradient(ellipse at top, var(--bg-1), var(--bg-0)); }
.bg-void     { background: #000; }
.bg-matrix   { background: linear-gradient(180deg,#001500,#003322); }
.bg-sunset   { background: linear-gradient(180deg,#0d1330,#ff5e62 70%,#ffa64f); }
.bg-ocean    { background: linear-gradient(180deg,#001f3f,#006d77); }
.bg-nebula   { background: radial-gradient(ellipse at center,#3a1078,#070218); }
.bg-hologram { background: linear-gradient(135deg,#022,#055), linear-gradient(45deg, #00f0ff44, #ff2fb044); background-blend-mode: screen; }
.bg-glitch   { background: linear-gradient(135deg,#1a0010,#000018); }
.bg-aurora   { background: linear-gradient(135deg,#0a0030,#001a3a,#0a0030); }
.bg-mars     { background: linear-gradient(180deg,#3d0d00,#ff5a3c 60%,#1a0500); }
.bg-singular { background: radial-gradient(ellipse at center,#fff 0%,#00f0ff 5%,#000 30%); }
.bg-godrays  { background: linear-gradient(180deg,#000,#1a1500 40%,#000); }

* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0;
  font-family: 'Heebo', system-ui, -apple-system, sans-serif;
  color: var(--ink);
  min-height: 100vh;
  overflow-x: hidden;
  -webkit-tap-highlight-color: transparent;
}
body {
  padding-bottom: 60px;
  position: relative;
  background-attachment: fixed;
}

/* ======= BG layers ======= */
.bg-grid-floor {
  position: fixed; inset: 0; z-index: -3; pointer-events: none;
  perspective: 600px;
  perspective-origin: 50% 0%;
  overflow: hidden;
}
.bg-grid-floor::before {
  content: ''; position: absolute;
  bottom: -20%; left: -20%; right: -20%; height: 80vh;
  background:
    linear-gradient(transparent 0%, var(--neon-1) 100%) bottom/100% 1px no-repeat,
    repeating-linear-gradient(90deg, transparent 0 39px, rgba(0,240,255,0.18) 39px 40px),
    repeating-linear-gradient(0deg, transparent 0 39px, rgba(0,240,255,0.18) 39px 40px);
  transform: rotateX(60deg);
  animation: gridmove 8s linear infinite;
  mask-image: linear-gradient(transparent 30%, black 100%);
  opacity: 0.55;
}
@keyframes gridmove {
  from { background-position-y: 0, 0, 0; }
  to   { background-position-y: 0, 40px, 40px; }
}

.bg-stars {
  position: fixed; inset: 0; z-index: -2; pointer-events: none;
  background-image:
    radial-gradient(1px 1px at 25px 5px,#fff,transparent),
    radial-gradient(1px 1px at 50px 25px,#fff,transparent),
    radial-gradient(1.5px 1.5px at 125px 20px,#fff,transparent),
    radial-gradient(1px 1px at 50px 75px,#fff,transparent),
    radial-gradient(2px 2px at 15px 125px,#fff,transparent),
    radial-gradient(2px 2px at 110px 80px,#fff,transparent),
    radial-gradient(2px 2px at 250px 150px,#fff,transparent),
    radial-gradient(1px 1px at 200px 50px,var(--neon-1),transparent),
    radial-gradient(1px 1px at 320px 200px,var(--neon-2),transparent);
  background-size: 350px 220px;
  opacity: 0.35;
  animation: twinkle 6s ease-in-out infinite;
}
@keyframes twinkle { 0%,100%{opacity:.3} 50%{opacity:.55} }

.bg-scanlines {
  position: fixed; inset: 0; z-index: -1; pointer-events: none;
  background-image: repeating-linear-gradient(0deg, rgba(0,0,0,0.18) 0 2px, transparent 2px 4px);
  mix-blend-mode: multiply;
  opacity: 0.4;
  animation: flicker 0.15s steps(2) infinite;
}
@keyframes flicker { 0%{opacity:.38} 100%{opacity:.42} }

.bg-glow {
  position: fixed; inset: 0; z-index: -1; pointer-events: none;
  background:
    radial-gradient(800px circle at 10% 0%, color-mix(in srgb, var(--neon-2) 22%, transparent), transparent 60%),
    radial-gradient(700px circle at 90% 100%, color-mix(in srgb, var(--neon-1) 22%, transparent), transparent 60%);
  animation: glowshift 10s ease-in-out infinite alternate;
}
@keyframes glowshift {
  from { transform: translate(0,0); }
  to   { transform: translate(-30px, 20px); }
}

/* ======= HUD ======= */
.hud {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 18px; padding-top: max(14px, env(safe-area-inset-top));
  position: relative; z-index: 10;
}
.logo-group { display: flex; align-items: center; gap: 12px; }
.logo-mark {
  width: 44px; height: 44px;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--neon-1), var(--neon-2));
  color: #000;
  font-size: 22px;
  clip-path: polygon(15% 0, 100% 0, 100% 70%, 85% 100%, 0 100%, 0 30%);
  box-shadow: 0 0 16px var(--neon-1);
  position: relative;
}
.logo-mark::after {
  content: ''; position: absolute; inset: 2px;
  background: var(--bg-0);
  clip-path: inherit;
  z-index: -1;
}
.logo-name {
  font-family: 'Orbitron', sans-serif;
  font-weight: 900;
  font-size: 22px;
  letter-spacing: 3px;
  background: linear-gradient(90deg, var(--neon-1), var(--neon-2));
  -webkit-background-clip: text; background-clip: text; color: transparent;
  text-shadow: 0 0 18px color-mix(in srgb, var(--neon-1) 30%, transparent);
}
.logo-sub {
  font-family: 'Share Tech Mono', monospace;
  font-size: 11px; color: var(--ink-dim);
  letter-spacing: 2px;
}
.logo-sub .dot { color: var(--neon-1); animation: blink 1s steps(2) infinite; }
@keyframes blink { 0%,49%{opacity:1} 50%,100%{opacity:0} }

.hud-right { display: flex; gap: 8px; }
.stat-chip {
  display: flex; align-items: center; gap: 6px;
  background: var(--panel-strong);
  border: 1px solid var(--border-strong);
  padding: 6px 12px;
  font-family: 'Share Tech Mono', monospace;
  clip-path: polygon(10px 0, 100% 0, calc(100% - 10px) 100%, 0 100%);
  box-shadow: var(--neon-glow-1);
  position: relative;
}
.stat-chip.streak {
  border-color: var(--neon-2);
  box-shadow: var(--neon-glow-2);
}
.stat-icon { font-size: 14px; color: var(--neon-1); }
.stat-chip.streak .stat-icon { color: var(--neon-2); }
.stat-num { font-weight: 700; font-size: 16px; min-width: 18px; text-align: center; }
.stat-lbl { font-size: 10px; color: var(--ink-dim); letter-spacing: 1px; }

/* level bar */
.level-bar-wrap { padding: 0 18px; margin-top: 4px; }
.level-bar {
  display: flex; align-items: center; gap: 12px;
  background: var(--panel);
  border: 1px solid var(--border);
  padding: 8px 12px;
  position: relative;
  clip-path: polygon(8px 0, 100% 0, calc(100% - 8px) 100%, 0 100%);
}
.level-info { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
.level-tag {
  font-family: 'Share Tech Mono', monospace;
  font-size: 10px; color: var(--ink-dim); letter-spacing: 1px;
}
.level-num {
  font-family: 'Orbitron', sans-serif; font-weight: 900;
  font-size: 18px; color: var(--neon-1);
  text-shadow: 0 0 10px var(--neon-1);
}
.level-name {
  font-family: 'Rajdhani', sans-serif; font-weight: 700;
  font-size: 13px; color: var(--neon-2); letter-spacing: 2px;
}
.level-progress {
  flex: 1; height: 14px;
  background: rgba(0,0,0,0.45);
  border: 1px solid var(--border);
  position: relative;
  overflow: hidden;
}
.level-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--neon-1), var(--neon-2));
  box-shadow: 0 0 14px var(--neon-1);
  transition: width 0.6s ease;
  position: relative;
}
.level-fill::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.4), transparent);
  animation: shine 2s linear infinite;
}
@keyframes shine { from{transform:translateX(-100%)} to{transform:translateX(100%)} }
.level-text {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Share Tech Mono', monospace; font-size: 10px;
  color: #fff; text-shadow: 0 0 4px #000;
  letter-spacing: 1px;
}

/* ======= TABS ======= */
nav.tabs {
  display: flex; gap: 4px;
  padding: 12px 16px 4px;
  overflow-x: auto;
  scrollbar-width: none;
  position: sticky; top: 0; z-index: 5;
  backdrop-filter: blur(8px);
}
nav.tabs::-webkit-scrollbar { display: none; }
.tab {
  flex: 1 0 auto;
  background: var(--panel);
  color: var(--ink-dim);
  border: 1px solid var(--border);
  padding: 10px 14px;
  cursor: pointer;
  font-family: 'Rajdhani', sans-serif;
  font-weight: 600; font-size: 14px;
  letter-spacing: 1.5px;
  display: flex; align-items: center; gap: 6px;
  white-space: nowrap;
  transition: all 0.2s;
  clip-path: polygon(8px 0, 100% 0, calc(100% - 8px) 100%, 0 100%);
  position: relative;
}
.tab .tab-icon { color: var(--neon-1); font-size: 16px; }
.tab.active {
  color: #000;
  background: linear-gradient(135deg, var(--neon-1), var(--neon-2));
  border-color: transparent;
  box-shadow: 0 0 18px var(--neon-1);
}
.tab.active .tab-icon { color: #000; }

main { padding: 16px; max-width: 760px; margin: 0 auto; }

.tab-content { display: none; animation: fadeIn 0.3s ease; }
.tab-content.active { display: block; }
@keyframes fadeIn {
  0%   { opacity: 0; transform: translateY(8px); filter: blur(4px); }
  100% { opacity: 1; transform: translateY(0); filter: blur(0); }
}

/* ======= PANELS ======= */
.panel {
  position: relative;
  background: var(--panel);
  border: 1px solid var(--border);
  backdrop-filter: blur(10px);
  padding: 16px;
}
.panel-corner {
  position: absolute;
  width: 14px; height: 14px;
  border-color: var(--neon-1);
}
.panel-corner.tl { top: 0; right: 0; border-top: 2px solid; border-right: 2px solid; }
.panel-corner.tr { top: 0; left: 0;  border-top: 2px solid; border-left: 2px solid; }
.panel-corner.bl { bottom: 0; right: 0; border-bottom: 2px solid; border-right: 2px solid; }
.panel-corner.br { bottom: 0; left: 0;  border-bottom: 2px solid; border-left: 2px solid; }

/* ======= HERO ======= */
.hero-panel {
  display: grid; grid-template-columns: 1fr 140px;
  gap: 12px;
  margin-bottom: 14px;
  position: relative;
  background: var(--panel-strong);
  border: 1px solid var(--border);
  padding: 18px;
  overflow: hidden;
}
.hero-panel::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--neon-1) 12%, transparent), transparent);
  animation: scan 4s linear infinite;
}
@keyframes scan { 0%{transform:translateX(-100%)} 100%{transform:translateX(100%)} }
.hero-status {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: 'Share Tech Mono', monospace;
  font-size: 11px; color: var(--neon-3); letter-spacing: 2px;
  margin-bottom: 8px;
}
.status-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--neon-3);
  box-shadow: 0 0 8px var(--neon-3);
  animation: pulse 1.5s ease-in-out infinite;
}
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.4} }
.hero-day {
  font-family: 'Orbitron', sans-serif;
  font-weight: 900; font-size: 30px;
  background: linear-gradient(90deg, var(--neon-1), var(--neon-2));
  -webkit-background-clip: text; background-clip: text; color: transparent;
  letter-spacing: 1px;
}
.hero-date {
  font-family: 'Share Tech Mono', monospace;
  color: var(--ink-dim); font-size: 12px; letter-spacing: 1px;
  margin-top: 2px;
}
.hero-mascot { display: flex; align-items: center; justify-content: center; }
.mascot-svg {
  width: 130px; height: 130px;
  filter: drop-shadow(0 0 10px var(--neon-1));
}
.mascot-svg .arm-l, .mascot-svg .arm-r {
  transform-origin: 100px 80px;
  animation: arm-pump 1.6s ease-in-out infinite;
}
.mascot-svg .arm-r { animation-delay: -0.8s; }
@keyframes arm-pump {
  0%,100% { transform: rotate(0deg); }
  50%     { transform: rotate(-25deg); }
}
.mascot-svg .leg-l, .mascot-svg .leg-r {
  transform-origin: 100px 115px;
  animation: leg-bounce 1.6s ease-in-out infinite;
}
.mascot-svg .leg-r { animation-delay: -0.8s; }
@keyframes leg-bounce {
  0%,100% { transform: rotate(0deg); }
  50%     { transform: rotate(-8deg) translateY(-4px); }
}
.mascot-scan {
  animation: mscan 2.5s linear infinite;
}
@keyframes mscan {
  0% { transform: translateY(0); opacity: 0.2; }
  50% { opacity: 0.7; }
  100% { transform: translateY(190px); opacity: 0; }
}

/* ======= WORKOUT CARD ======= */
.workout-card { padding: 18px; }
.workout-card h2 {
  margin: 0;
  font-family: 'Orbitron', sans-serif;
  font-size: 20px; letter-spacing: 1px;
  color: var(--neon-1);
  text-shadow: 0 0 8px color-mix(in srgb, var(--neon-1) 50%, transparent);
}
.workout-meta {
  font-family: 'Share Tech Mono', monospace;
  color: var(--ink-dim); font-size: 11px; letter-spacing: 1px;
  margin: 4px 0 12px;
  display: flex; gap: 12px;
}
.workout-meta .timer-display { color: var(--neon-3); }

.exercise-list { display: flex; flex-direction: column; gap: 8px; }
.exercise-row {
  display: flex; align-items: center; gap: 12px;
  background: rgba(0,0,0,0.3);
  border: 1px solid rgba(0,240,255,0.18);
  border-right: 3px solid var(--neon-1);
  padding: 12px 14px;
  cursor: pointer; user-select: none;
  transition: all 0.2s;
  position: relative;
}
.exercise-row:hover { border-color: var(--neon-1); transform: translateX(-2px); }
.exercise-row.done {
  border-right-color: var(--good);
  background: rgba(0,255,138,0.08);
}
.exercise-row.done .ex-name { text-decoration: line-through; opacity: 0.6; }
.exercise-row .check {
  width: 28px; height: 28px;
  border: 2px solid var(--border-strong);
  display: flex; align-items: center; justify-content: center;
  font-size: 16px;
  flex-shrink: 0;
  background: rgba(0,0,0,0.4);
  clip-path: polygon(20% 0, 100% 0, 100% 80%, 80% 100%, 0 100%, 0 20%);
}
.exercise-row.done .check {
  background: var(--good); border-color: transparent; color: #000;
  box-shadow: 0 0 10px var(--good);
}
.ex-info { flex: 1; min-width: 0; }
.ex-emoji { font-size: 20px; margin-left: 8px; }
.ex-name { font-weight: 700; font-size: 15px; }
.ex-meta {
  font-family: 'Share Tech Mono', monospace;
  color: var(--ink-dim); font-size: 12px;
}
.ex-rest-btn {
  background: transparent; border: 1px solid var(--border);
  color: var(--neon-1);
  padding: 4px 8px;
  font-size: 12px; cursor: pointer;
  font-family: 'Share Tech Mono', monospace;
}
.ex-rest-btn:hover { background: var(--neon-1); color: #000; }

.complete-bar {
  margin-top: 14px; height: 6px;
  background: rgba(0,0,0,0.5);
  border: 1px solid var(--border);
  overflow: hidden;
}
.complete-bar .fill {
  height: 100%;
  background: linear-gradient(90deg, var(--neon-1), var(--neon-2));
  box-shadow: 0 0 10px var(--neon-1);
  transition: width 0.4s;
}

/* ======= BUTTONS ======= */
.btn {
  border: 1px solid var(--border-strong);
  background: var(--panel);
  color: var(--ink);
  padding: 12px 18px;
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700; font-size: 14px;
  letter-spacing: 2px;
  cursor: pointer;
  position: relative;
  transition: all 0.15s;
  clip-path: polygon(8px 0, 100% 0, calc(100% - 8px) 100%, 0 100%);
}
.btn:hover { border-color: var(--neon-1); color: var(--neon-1); }
.btn:active { transform: scale(0.97); }
.btn:disabled { opacity: 0.4; cursor: not-allowed; }
.btn-primary {
  background: linear-gradient(135deg, var(--neon-1), var(--neon-2));
  color: #000; border-color: transparent;
  box-shadow: 0 0 18px var(--neon-1);
}
.btn-primary:hover { color: #000; filter: brightness(1.1); }
.btn-success {
  background: linear-gradient(135deg, var(--good), #00cc6a);
  color: #000; border-color: transparent;
  box-shadow: 0 0 14px var(--good);
}
.btn-danger {
  border-color: var(--danger); color: var(--danger);
}
.btn-danger:hover { background: var(--danger); color: #fff; }
.btn-block { width: 100%; margin-top: 12px; }
.btn-sm { padding: 8px 14px; font-size: 12px; }
.btn-ghost { background: transparent; }

.btn-mini {
  background: var(--panel);
  border: 1px solid var(--border-strong);
  color: var(--neon-1);
  padding: 8px 12px;
  font-family: 'Share Tech Mono', monospace;
  font-size: 12px;
  cursor: pointer;
  letter-spacing: 1px;
}
.btn-mini:hover { background: var(--neon-1); color: #000; }
.btn-mini.cancel { border-color: var(--danger); color: var(--danger); }

/* ======= SECTIONS ======= */
.section-head {
  display: flex; justify-content: space-between; align-items: center;
  margin: 8px 0 12px;
}
.section-head h2 {
  margin: 0;
  font-family: 'Orbitron', sans-serif;
  font-size: 22px; letter-spacing: 2px;
  color: var(--ink);
}
.section-head h2 .hl { color: var(--neon-1); text-shadow: 0 0 8px var(--neon-1); }
.balance {
  font-family: 'Share Tech Mono', monospace;
  font-size: 14px; color: var(--neon-1);
  letter-spacing: 1px;
}
.hint {
  color: var(--ink-dim); font-size: 13px;
  margin: 0 0 14px;
  font-family: 'Share Tech Mono', monospace;
  letter-spacing: 0.5px;
}
.sub-h {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 600; letter-spacing: 2px;
  margin: 24px 0 10px;
  color: var(--neon-2);
}

/* ======= PLAN editor ======= */
.plan-day {
  background: var(--panel);
  border: 1px solid var(--border);
  border-right: 3px solid var(--neon-1);
  padding: 14px;
  margin-bottom: 10px;
  position: relative;
}
.plan-day.disabled { opacity: 0.45; border-right-color: var(--ink-mute); }
.plan-day.disabled .ex-edit-list, .plan-day.disabled .add-ex-btn,
.plan-day.disabled .day-name-input { pointer-events: none; opacity: 0.5; }
.plan-day-head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 10px;
  gap: 8px;
}
.plan-day-head h3 {
  margin: 0;
  font-family: 'Rajdhani', sans-serif;
  font-size: 17px; letter-spacing: 2px;
  color: var(--neon-1);
}
.plan-day.disabled .plan-day-head h3 { color: var(--ink-mute); }

.toggle {
  position: relative; width: 50px; height: 26px;
  background: rgba(0,0,0,0.5);
  border: 1px solid var(--border);
  cursor: pointer;
  transition: all 0.2s;
  clip-path: polygon(8px 0, 100% 0, calc(100% - 8px) 100%, 0 100%);
}
.toggle::after {
  content: ''; position: absolute;
  top: 2px; right: 2px;
  width: 20px; height: 20px;
  background: var(--ink-mute);
  transition: all 0.2s;
}
.toggle.on {
  background: linear-gradient(135deg, var(--neon-1), var(--neon-2));
  box-shadow: 0 0 12px var(--neon-1);
}
.toggle.on::after {
  transform: translateX(-22px);
  background: #000;
}

.day-name-input {
  background: rgba(0,0,0,0.4);
  border: 1px solid var(--border);
  color: var(--ink);
  padding: 8px 10px;
  font-family: inherit; font-size: 14px;
  width: 100%;
  margin-bottom: 8px;
}
.day-name-input:focus { outline: none; border-color: var(--neon-1); box-shadow: 0 0 8px var(--neon-1); }

.ex-edit-list { display: flex; flex-direction: column; gap: 6px; margin-bottom: 8px; }
.ex-edit-row {
  display: grid;
  grid-template-columns: 1fr 64px 64px 36px;
  gap: 6px; align-items: center;
}
.ex-edit-row .ex-pick-btn {
  background: rgba(0,0,0,0.4);
  border: 1px solid var(--border);
  color: var(--ink);
  padding: 8px 10px;
  font-family: inherit; font-size: 13px;
  cursor: pointer;
  text-align: right;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ex-edit-row .ex-pick-btn:hover { border-color: var(--neon-1); }
.ex-edit-row input[type="number"] {
  background: rgba(0,0,0,0.4);
  border: 1px solid var(--border);
  color: var(--ink);
  padding: 8px;
  font-family: 'Share Tech Mono', monospace;
  font-size: 13px;
  text-align: center;
  width: 100%;
}
.ex-edit-row input[type="number"]:focus { outline: none; border-color: var(--neon-1); }
.ex-edit-row .rm-btn {
  background: transparent;
  border: 1px solid var(--danger);
  color: var(--danger);
  width: 36px; height: 34px;
  cursor: pointer; font-size: 14px;
}
.ex-edit-row .rm-btn:hover { background: var(--danger); color: #fff; }

.add-ex-btn {
  background: transparent;
  border: 1px dashed var(--border-strong);
  color: var(--neon-1);
  padding: 8px;
  width: 100%;
  font-family: 'Share Tech Mono', monospace;
  font-size: 12px;
  cursor: pointer;
  letter-spacing: 1px;
}
.add-ex-btn:hover { border-style: solid; box-shadow: 0 0 10px var(--neon-1); }

/* ======= SHOP ======= */
.shop-tabs {
  display: flex; gap: 6px; margin-bottom: 14px;
}
.shop-tab {
  flex: 1;
  background: var(--panel);
  border: 1px solid var(--border);
  color: var(--ink-dim);
  padding: 8px;
  cursor: pointer;
  font-family: 'Rajdhani', sans-serif;
  font-weight: 600; font-size: 13px;
  letter-spacing: 1px;
  clip-path: polygon(8px 0, 100% 0, calc(100% - 8px) 100%, 0 100%);
}
.shop-tab.active {
  background: linear-gradient(135deg, var(--neon-1), var(--neon-2));
  color: #000;
  box-shadow: 0 0 12px var(--neon-1);
}
.shop-section-content { display: none; }
.shop-section-content.active { display: block; }

.grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 10px;
}
.shop-item {
  background: var(--panel);
  border: 1px solid var(--border);
  padding: 12px;
  cursor: pointer;
  position: relative;
  transition: all 0.2s;
}
.shop-item:hover { border-color: var(--neon-1); transform: translateY(-2px); box-shadow: 0 0 14px var(--neon-1); }
.shop-item.owned { border-color: var(--good); }
.shop-item.active-item {
  border-color: var(--neon-1);
  box-shadow: 0 0 16px var(--neon-1);
}
.shop-item.locked { opacity: 0.55; cursor: not-allowed; }
.shop-item.locked:hover { transform: none; box-shadow: none; }

.shop-item .preview {
  height: 60px; margin-bottom: 8px;
  border: 1px solid rgba(255,255,255,0.1);
  position: relative;
  overflow: hidden;
}
.shop-item .preview.avatar-preview {
  display: flex; align-items: center; justify-content: center;
  font-size: 36px;
  background: linear-gradient(135deg, var(--neon-1), var(--neon-2));
}
.shop-item .name {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700; font-size: 13px;
  letter-spacing: 1.5px;
  color: var(--neon-1);
}
.shop-item .heb-name {
  font-size: 12px; color: var(--ink-dim);
  margin-bottom: 6px;
}
.shop-item .price {
  display: flex; justify-content: space-between; align-items: center;
  font-family: 'Share Tech Mono', monospace;
  font-size: 12px; margin-top: 6px;
}
.shop-item .price .cost { color: var(--warn); font-weight: 700; }
.shop-item .badge {
  position: absolute; top: 6px; left: 6px;
  background: var(--good); color: #000;
  padding: 2px 8px;
  font-family: 'Share Tech Mono', monospace;
  font-size: 10px; font-weight: 700;
  letter-spacing: 1px;
}
.shop-item .badge.active { background: var(--neon-1); }
.shop-item .badge.lock { background: var(--ink-mute); color: #000; }

/* ======= ACHIEVEMENTS ======= */
.ach-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 10px;
}
.ach-card {
  background: var(--panel);
  border: 1px solid var(--border);
  padding: 14px;
  text-align: center;
  position: relative;
  transition: all 0.2s;
}
.ach-card.unlocked {
  border-color: var(--neon-1);
  box-shadow: 0 0 14px color-mix(in srgb, var(--neon-1) 30%, transparent);
}
.ach-card.locked { opacity: 0.4; }
.ach-icon { font-size: 36px; margin-bottom: 6px; filter: grayscale(0); }
.ach-card.locked .ach-icon { filter: grayscale(1); }
.ach-name { font-family: 'Rajdhani', sans-serif; font-weight: 700; font-size: 14px; letter-spacing: 1px; color: var(--neon-1); }
.ach-card.locked .ach-name { color: var(--ink-mute); }
.ach-desc { font-size: 11px; color: var(--ink-dim); margin-top: 4px; }
.ach-reward { font-family: 'Share Tech Mono', monospace; font-size: 11px; color: var(--warn); margin-top: 6px; }

/* ======= STATS ======= */
.big-stats {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px;
  margin-bottom: 16px;
}
.big-stat { padding: 14px; text-align: center; }
.big-stat .num {
  font-family: 'Orbitron', sans-serif; font-weight: 900;
  font-size: 28px;
  background: linear-gradient(90deg, var(--neon-1), var(--neon-2));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.big-stat .lbl {
  font-family: 'Share Tech Mono', monospace;
  color: var(--ink-dim); font-size: 11px; letter-spacing: 1.5px;
  margin-top: 2px;
}

.weeks-chart {
  padding: 16px;
  display: flex; gap: 6px; align-items: flex-end;
  height: 160px;
  overflow-x: auto;
}
.week-bar-wrap {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; gap: 4px; min-width: 28px;
  height: 100%;
}
.week-bar {
  width: 100%; flex: 1;
  display: flex; flex-direction: column-reverse;
  align-items: stretch;
  position: relative;
}
.week-bar .bar-fill {
  background: linear-gradient(180deg, var(--neon-2), var(--neon-1));
  box-shadow: 0 0 10px var(--neon-1);
  width: 100%;
  border-bottom: 2px solid var(--neon-1);
  animation: bar-rise 0.6s ease;
  transform-origin: bottom;
}
@keyframes bar-rise { from {transform: scaleY(0)} to {transform: scaleY(1)} }
.week-label {
  font-family: 'Share Tech Mono', monospace;
  font-size: 10px; color: var(--ink-dim);
}

#calendar {
  display: grid; grid-template-columns: repeat(7, 1fr);
  gap: 4px; padding: 14px;
}
.cal-head {
  text-align: center;
  font-family: 'Share Tech Mono', monospace;
  font-size: 11px; color: var(--neon-1); padding: 4px 0;
  letter-spacing: 1px;
}
.cal-cell {
  aspect-ratio: 1;
  display: flex; align-items: center; justify-content: center;
  background: rgba(0,0,0,0.3);
  font-family: 'Share Tech Mono', monospace; font-size: 12px;
  border: 1px solid transparent;
  position: relative;
}
.cal-cell.empty { background: transparent; }
.cal-cell.done {
  background: linear-gradient(135deg, var(--neon-1), var(--neon-2));
  color: #000; font-weight: 700;
  box-shadow: 0 0 8px var(--neon-1);
}
.cal-cell.today {
  border-color: var(--neon-1);
  box-shadow: 0 0 8px var(--neon-1);
}
.cal-cell.planned:not(.done) {
  border-style: dashed; border-color: var(--neon-2); color: var(--neon-2);
}

.settings { padding: 14px; }
.setting-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 0;
  border-bottom: 1px solid var(--border);
  font-family: 'Rajdhani', sans-serif;
  font-weight: 600; letter-spacing: 1px;
}
.setting-row:last-of-type { border-bottom: none; }
.setting-row input[type="checkbox"] {
  width: 24px; height: 24px;
  accent-color: var(--neon-1);
  cursor: pointer;
}

/* ======= REST TIMER ======= */
.rest-timer {
  margin-top: 14px;
  padding: 16px;
  text-align: center;
}
.rest-label {
  font-family: 'Share Tech Mono', monospace;
  font-size: 11px; color: var(--neon-2);
  letter-spacing: 2px;
}
.rest-display {
  font-family: 'Orbitron', sans-serif;
  font-size: 56px; font-weight: 900;
  background: linear-gradient(90deg, var(--neon-1), var(--neon-2));
  -webkit-background-clip: text; background-clip: text; color: transparent;
  text-shadow: 0 0 30px var(--neon-1);
  letter-spacing: 4px;
  margin: 8px 0;
  animation: pulse-num 1s ease-in-out infinite;
}
@keyframes pulse-num { 0%,100%{filter:brightness(1)} 50%{filter:brightness(1.3)} }
.rest-buttons {
  display: flex; justify-content: center; gap: 6px; flex-wrap: wrap;
}

/* ======= MODAL ======= */
.modal {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.85);
  backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  z-index: 200; padding: 20px;
  animation: fadeIn 0.15s ease;
}
.modal.hidden { display: none; }
.modal-card {
  max-width: 380px; width: 100%;
  padding: 24px;
}
.modal-card h3 {
  font-family: 'Orbitron', sans-serif;
  font-size: 18px; letter-spacing: 2px;
  color: var(--neon-1);
  margin: 0 0 12px;
}
.modal-actions {
  display: flex; gap: 8px; margin-top: 18px; justify-content: flex-end;
}

.ex-picker-card { max-width: 480px; max-height: 80vh; display: flex; flex-direction: column; }
.ex-search {
  background: rgba(0,0,0,0.4);
  border: 1px solid var(--border-strong);
  color: var(--ink);
  padding: 10px;
  width: 100%;
  font-family: inherit;
  margin-bottom: 10px;
}
.ex-search:focus { outline: none; border-color: var(--neon-1); box-shadow: 0 0 10px var(--neon-1); }
.ex-cats {
  display: flex; gap: 4px; margin-bottom: 10px;
  overflow-x: auto;
  scrollbar-width: thin;
}
.ex-cats::-webkit-scrollbar { height: 4px; }
.ex-cat {
  background: var(--panel);
  border: 1px solid var(--border);
  color: var(--ink-dim);
  padding: 6px 10px;
  font-size: 12px;
  cursor: pointer;
  white-space: nowrap;
  font-family: inherit;
}
.ex-cat.active { background: linear-gradient(135deg, var(--neon-1), var(--neon-2)); color: #000; border-color: transparent; }
.ex-list {
  flex: 1; overflow-y: auto;
  display: flex; flex-direction: column; gap: 4px;
  scrollbar-width: thin;
  padding: 4px;
}
.ex-pick-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px;
  background: rgba(0,0,0,0.3);
  border: 1px solid var(--border);
  cursor: pointer;
}
.ex-pick-row:hover { border-color: var(--neon-1); background: rgba(0,240,255,0.08); }
.ex-pick-row .ex-pick-emoji { font-size: 22px; }
.ex-pick-row .ex-pick-name { flex: 1; font-weight: 600; }
.ex-pick-row .ex-pick-meta { font-family: 'Share Tech Mono', monospace; font-size: 12px; color: var(--ink-dim); }

/* ======= TOAST ======= */
.toast {
  position: fixed; bottom: 30px; left: 50%; transform: translateX(-50%);
  background: var(--panel-strong);
  border: 1px solid var(--neon-1);
  color: var(--neon-1);
  padding: 12px 20px;
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700; letter-spacing: 1.5px;
  box-shadow: 0 0 20px var(--neon-1);
  z-index: 100;
  clip-path: polygon(10px 0, 100% 0, calc(100% - 10px) 100%, 0 100%);
  animation: toastIn 0.25s ease;
}
.toast.hidden { display: none; }
@keyframes toastIn { from {transform: translate(-50%, 30px); opacity: 0} to {transform: translate(-50%, 0); opacity: 1} }

/* ======= LEVEL UP overlay ======= */
.levelup {
  position: fixed; inset: 0; z-index: 300;
  background: radial-gradient(circle at center, rgba(0,240,255,0.2), rgba(0,0,0,0.95));
  display: flex; align-items: center; justify-content: center;
  animation: lvlIn 0.3s ease;
}
.levelup.hidden { display: none; }
@keyframes lvlIn { from {opacity: 0} to {opacity: 1} }
.levelup-inner {
  text-align: center;
  animation: lvlPop 0.6s cubic-bezier(.5,1.6,.5,1);
}
@keyframes lvlPop { 0%{transform:scale(0.3)} 60%{transform:scale(1.1)} 100%{transform:scale(1)} }
.levelup-glitch {
  font-family: 'Orbitron', sans-serif;
  font-weight: 900; font-size: 42px;
  letter-spacing: 6px;
  background: linear-gradient(90deg, var(--neon-1), var(--neon-2));
  -webkit-background-clip: text; background-clip: text; color: transparent;
  position: relative;
  text-shadow: 0 0 30px var(--neon-1);
  animation: glitch 0.5s linear infinite;
}
.levelup-glitch::before, .levelup-glitch::after {
  content: attr(data-text);
  position: absolute; inset: 0;
  background: inherit;
  -webkit-background-clip: text; background-clip: text;
}
.levelup-glitch::before { color: var(--neon-2); transform: translate(2px, 0); mix-blend-mode: screen; opacity: 0.7; animation: glitch1 0.4s steps(2) infinite; }
.levelup-glitch::after  { color: var(--neon-1); transform: translate(-2px, 0); mix-blend-mode: screen; opacity: 0.7; animation: glitch2 0.4s steps(2) infinite; }
@keyframes glitch1 { 0%,100%{transform: translate(2px,0)} 50%{transform: translate(-3px,1px)} }
@keyframes glitch2 { 0%,100%{transform: translate(-2px,0)} 50%{transform: translate(3px,-1px)} }
@keyframes glitch { 0%,100%{filter: hue-rotate(0)} 50%{filter: hue-rotate(20deg)} }
.levelup-num {
  font-family: 'Orbitron', sans-serif;
  font-size: 110px; font-weight: 900;
  color: var(--neon-1);
  text-shadow: 0 0 40px var(--neon-1);
  margin: 10px 0;
}
.levelup-name {
  font-family: 'Rajdhani', sans-serif;
  font-size: 24px; letter-spacing: 6px;
  color: var(--neon-2);
}
.levelup-sub {
  font-family: 'Share Tech Mono', monospace;
  font-size: 12px; color: var(--ink-dim);
  margin-top: 10px; letter-spacing: 2px;
}

/* ======= ACHIEVEMENT POP ======= */
.ach-pop {
  position: fixed; top: 80px; left: 50%; transform: translateX(-50%);
  z-index: 250;
  animation: achIn 0.4s ease;
}
.ach-pop.hidden { display: none; }
@keyframes achIn { from {transform: translate(-50%, -100%); opacity: 0} to {transform: translate(-50%, 0); opacity: 1} }
.ach-pop-inner {
  background: var(--panel-strong);
  border: 1px solid var(--neon-1);
  padding: 18px 24px;
  text-align: center;
  min-width: 280px;
  box-shadow: 0 0 30px var(--neon-1);
}
.ach-pop-tag {
  font-family: 'Share Tech Mono', monospace;
  font-size: 11px; letter-spacing: 2px;
  color: var(--neon-2);
}
.ach-pop-icon { font-size: 48px; margin: 6px 0; }
.ach-pop-name {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700; font-size: 18px;
  letter-spacing: 2px; color: var(--neon-1);
}
.ach-pop-desc { color: var(--ink-dim); font-size: 12px; }
.ach-pop-reward {
  font-family: 'Share Tech Mono', monospace;
  color: var(--warn); margin-top: 8px;
  letter-spacing: 1px;
}

/* ======= confetti ======= */
.spark {
  position: fixed;
  pointer-events: none;
  z-index: 150;
  width: 4px; height: 4px;
  border-radius: 50%;
  box-shadow: 0 0 8px currentColor;
  animation: sparkfly 1.5s ease-out forwards;
}
@keyframes sparkfly {
  to { transform: translate(var(--dx), var(--dy)) scale(0); opacity: 0; }
}

.hidden { display: none !important; }

/* ======= MOBILE ======= */
@media (max-width: 480px) {
  .hero-panel { grid-template-columns: 1fr 100px; }
  .mascot-svg { width: 90px; height: 90px; }
  .hero-day { font-size: 24px; }
  .logo-name { font-size: 18px; letter-spacing: 2px; }
  .stat-num { font-size: 14px; }
  nav.tabs .tab-text { display: none; }
  nav.tabs .tab { padding: 10px 14px; }
  nav.tabs .tab-icon { font-size: 18px; }
  nav.tabs .tab.active .tab-text { display: inline; }
  .levelup-num { font-size: 80px; }
  .levelup-glitch { font-size: 32px; letter-spacing: 4px; }
}
