/* ── VARIABLES ── */
:root {
  --bg:      #000000;
  --surface: #0a0a0a;
  --card:    #111111;
  --card2:   rgba(255,255,255,0.03);
  --border:  rgba(255,255,255,0.07);
  --accent:  #ff4500;
  --accent2: #ff8c00;
  --accent3: #ff2d55;
  --glow:    rgba(255,69,0,0.3);
  --glow2:   rgba(255,140,0,0.2);
  --text:    #ffffff;
  --muted:   #3a3a3a;
  --muted2:  #888888;
  --skeleton-base:  #161616;
  --skeleton-shine: #222222;
}
[data-theme="light"] {
  --bg:#f5f5f5; --surface:#ffffff; --card:#ffffff; --card2:rgba(0,0,0,0.03);
  --border:rgba(0,0,0,0.08); --text:#111111; --muted:#d0d0d0; --muted2:#666666;
  --skeleton-base:#e8e8e8; --skeleton-shine:#f5f5f5;
}

/* ── BASE ── */
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{
  min-height:100vh;
  background:var(--bg);
  color:var(--text);
  font-family:'Inter',system-ui,sans-serif;
  overflow-x:hidden;
  transition:background .3s,color .3s;
}
::-webkit-scrollbar{width:0;}

/* ── MESH GRADIENT BG ── */
.mesh-bg {
  position:fixed; inset:0; z-index:0; pointer-events:none;
  overflow:hidden;
}
.mesh-bg::before {
  content:'';
  position:absolute;
  width:600px; height:600px;
  top:-200px; right:-200px;
  background: radial-gradient(circle, rgba(255,69,0,0.12) 0%, transparent 70%);
  animation: meshMove1 8s ease-in-out infinite alternate;
}
.mesh-bg::after {
  content:'';
  position:absolute;
  width:400px; height:400px;
  bottom:-100px; left:-100px;
  background: radial-gradient(circle, rgba(255,140,0,0.08) 0%, transparent 70%);
  animation: meshMove2 10s ease-in-out infinite alternate;
}
.mesh-blob {
  position:absolute;
  width:300px; height:300px;
  top:40%; left:50%;
  transform:translate(-50%,-50%);
  background: radial-gradient(circle, rgba(255,45,85,0.06) 0%, transparent 70%);
  animation: meshMove3 12s ease-in-out infinite alternate;
}
@keyframes meshMove1 {
  0%   { transform: translate(0,0) scale(1); }
  100% { transform: translate(-80px,60px) scale(1.2); }
}
@keyframes meshMove2 {
  0%   { transform: translate(0,0) scale(1); }
  100% { transform: translate(60px,-80px) scale(1.15); }
}
@keyframes meshMove3 {
  0%   { transform: translate(-50%,-50%) scale(1); opacity:0.6; }
  100% { transform: translate(-30%,-60%) scale(1.3); opacity:1; }
}

/* ── HEADER ── */
.header {
  position:sticky; top:0; z-index:100;
  background: rgba(0,0,0,0.75);
  backdrop-filter: blur(32px);
  -webkit-backdrop-filter: blur(32px);
  border-bottom: 1px solid rgba(255,69,0,0.15);
  padding: 14px 20px;
  display:flex; align-items:center; justify-content:space-between;
}
[data-theme="light"] .header { background:rgba(245,245,245,0.85); border-bottom-color:rgba(255,69,0,0.2); }
.header-left{display:flex;align-items:center;gap:12px;}
.avatar {
  width:40px; height:40px; border-radius:14px;
  background: linear-gradient(135deg, #ff4500, #ff8c00);
  display:flex; align-items:center; justify-content:center;
  font-size:15px; font-weight:800; color:#fff;
  box-shadow: 0 0 20px rgba(255,69,0,0.5), 0 0 40px rgba(255,69,0,0.2);
}
.header-name { font-size:16px; font-weight:700; color:var(--text); }
.header-sub  { font-size:11px; color:var(--muted2); margin-top:1px; }
.header-right { display:flex; align-items:center; gap:8px; }
.theme-btn {
  width:32px; height:32px; border-radius:10px;
  border:1px solid var(--border); background:var(--card);
  font-size:16px; display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all .2s;
}
.theme-btn:active { transform:scale(0.88); }
#lang-btn { color:#ff8c00 !important; font-size:12px; font-weight:700; }
.header-badge {
  padding:5px 12px; border-radius:20px; font-size:11px; font-weight:700;
  background: linear-gradient(135deg, rgba(255,69,0,0.15), rgba(255,140,0,0.15));
  color: var(--accent2);
  border: 1px solid rgba(255,140,0,0.3);
  letter-spacing: 0.5px;
}

/* ── STATS ── */
.stats-row { display:flex; gap:10px; padding:16px 16px 0; }
.stat-card {
  flex:1; background:var(--card); border:1px solid var(--border);
  border-radius:18px; padding:14px 12px;
  position:relative; overflow:hidden;
  transition:transform .15s,background .3s;
  animation:slideUp .4s ease both;
}
.stat-card:nth-child(1){animation-delay:.05s;}
.stat-card:nth-child(2){animation-delay:.10s;}
.stat-card:nth-child(3){animation-delay:.15s;}
.stat-card:active{transform:scale(0.96);}
.stat-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:var(--accent-color,var(--accent));
  box-shadow:0 0 16px var(--glow-color,var(--glow));
}
.stat-card::after {
  content:''; position:absolute; top:0; right:0;
  width:60px; height:60px;
  background:radial-gradient(circle, var(--glow-color,var(--glow)) 0%, transparent 70%);
  pointer-events:none;
}
.stat-value { font-size:24px; font-weight:800; color:var(--text); line-height:1; margin-top:2px; }
.stat-label { font-size:9px; color:var(--muted2); text-transform:uppercase; letter-spacing:.8px; margin-top:5px; }
.stat-sub   { font-size:10px; margin-top:3px; color:var(--accent-color,var(--accent)); font-weight:600; }

/* ── SKELETON STATS ── */
.skeleton-stat {
  flex:1; background:var(--card); border:1px solid var(--border);
  border-radius:18px; padding:14px 12px;
}

/* ── TABS ── */
.tabs { display:flex; padding:16px 16px 0; gap:4px; }
.tab {
  flex:1; padding:10px 0; font-size:12px; font-weight:600;
  color:var(--muted2); background:none; border:none; cursor:pointer;
  border-bottom:2px solid transparent; transition:all .2s;
  display:flex; flex-direction:column; align-items:center; gap:4px;
}
.tab.active { color:var(--accent); border-bottom-color:var(--accent); }
.tab:active { opacity:.7; }
.tab-icon { font-size:18px; }

/* ── CONTENT ── */
.content { padding:16px; padding-bottom:30px; position:relative; z-index:1; }
.page { display:none; }
.page.active { display:block; animation:slideUp .3s ease both; }

/* ── SECTION TITLE ── */
.section-title {
  font-size:22px; font-weight:800; margin-bottom:4px;
  background: linear-gradient(135deg, #fff 30%, var(--accent2));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.section-sub { font-size:12px; color:var(--muted2); margin-bottom:16px; }

/* ── GLASS CARD ── */
.chart-card {
  background: rgba(17,17,17,0.8);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border:1px solid rgba(255,69,0,0.15);
  border-radius:20px; padding:16px; margin-bottom:14px;
  position:relative; overflow:hidden;
  animation:slideUp .4s ease .1s both;
}
.chart-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background: linear-gradient(90deg, transparent, rgba(255,69,0,0.5), transparent);
}
.chart-label {
  font-size:11px; color:var(--muted2); text-transform:uppercase;
  letter-spacing:.8px; margin-bottom:12px; font-weight:600;
}
.chart-wrap { position:relative; height:130px; }

/* ── WORKOUT CARDS ── */
.workout-card {
  background: rgba(17,17,17,0.9);
  backdrop-filter: blur(12px);
  border:1px solid var(--border);
  border-radius:16px; padding:14px 16px;
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:10px; transition:transform .15s,background .15s;
  position:relative; overflow:hidden;
  animation:slideUp .4s ease both;
}
.workout-card:active { transform:scale(0.98); }
.workout-card::before {
  content:''; position:absolute; left:0; top:0; bottom:0; width:3px;
  background: linear-gradient(180deg, var(--accent), var(--accent2), transparent);
  border-radius:3px 0 0 3px;
}
.wc-left { display:flex; align-items:center; gap:12px; }
.wc-date-box {
  width:42px; height:42px; border-radius:12px;
  background: rgba(255,69,0,0.1);
  border:1px solid rgba(255,69,0,0.25);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
}
.wc-day  { font-size:9px; color:var(--accent2); font-weight:700; text-transform:uppercase; }
.wc-num  { font-size:16px; font-weight:800; color:var(--text); line-height:1; }
.wc-title { font-size:14px; font-weight:600; color:var(--text); }
.wc-sub   { font-size:11px; color:var(--muted2); margin-top:2px; }
.wc-right { text-align:right; }
.wc-volume {
  font-size:16px; font-weight:800;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.wc-kg { font-size:9px; color:var(--muted2); text-transform:uppercase; letter-spacing:.8px; }

/* ── SKELETON ── */
.skeleton-card {
  background:var(--card); border:1px solid var(--border);
  border-radius:16px; padding:14px 16px; margin-bottom:10px;
  display:flex; align-items:center; gap:12px;
}
.skeleton-box {
  border-radius:12px; flex-shrink:0;
  background:linear-gradient(90deg,var(--skeleton-base) 25%,var(--skeleton-shine) 50%,var(--skeleton-base) 75%);
  background-size:200% 100%; animation:shimmer 1.4s infinite;
}
.skeleton-lines { flex:1; display:flex; flex-direction:column; gap:8px; }
.skeleton-line {
  border-radius:6px; height:12px;
  background:linear-gradient(90deg,var(--skeleton-base) 25%,var(--skeleton-shine) 50%,var(--skeleton-base) 75%);
  background-size:200% 100%; animation:shimmer 1.4s infinite;
}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}

/* ── MUSCLES ── */
.muscle-card {
  background:rgba(17,17,17,0.9);
  backdrop-filter:blur(12px);
  border:1px solid var(--border);
  border-radius:16px; padding:14px 16px; margin-bottom:10px;
  animation:slideUp .4s ease both; transition:background .3s;
}
.muscle-card:active { transform:scale(0.98); }
.muscle-header { display:flex; justify-content:space-between; align-items:baseline; margin-bottom:10px; }
.muscle-name  { font-size:14px; font-weight:600; color:var(--text); }
.muscle-vol   { font-size:14px; font-weight:700; }
.muscle-bar-bg {
  height:5px; border-radius:6px;
  background:rgba(255,255,255,0.06); overflow:hidden;
}
[data-theme="light"] .muscle-bar-bg { background:rgba(0,0,0,0.08); }
.muscle-bar-fill {
  height:100%; border-radius:6px;
  transition:width 1s cubic-bezier(.4,0,.2,1);
}
.muscle-pct { font-size:10px; color:var(--muted2); margin-top:5px; }
.group-header { display:flex; align-items:center; gap:10px; padding:16px 4px 8px; }
.group-icon  { font-size:18px; }
.group-title {
  font-size:12px; font-weight:700; color:var(--muted2);
  text-transform:uppercase; letter-spacing:1px; flex:1;
}
.group-total { font-size:13px; font-weight:700; color:var(--text); }

/* ── PROGRESS ── */
.ex-selector {
  display:flex; flex-wrap:wrap; gap:8px; margin-bottom:16px;
  max-height:130px; overflow-y:auto; padding:2px;
}
.ex-btn {
  padding:7px 14px; border-radius:20px; font-size:12px; font-weight:500;
  border:1px solid var(--border); background:var(--card);
  color:var(--muted2); cursor:pointer; transition:all .15s;
  font-family:'Inter',sans-serif;
}
.ex-btn.active {
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  color:#fff; border-color:var(--accent);
  box-shadow:0 0 16px var(--glow);
}
.ex-btn:active { transform:scale(0.93); }
.mini-stats { display:flex; gap:10px; margin-top:14px; }
.mini-stat {
  flex:1; background:var(--card); border:1px solid var(--border);
  border-radius:14px; padding:12px; text-align:center; transition:background .3s;
}
.mini-stat-val   { font-size:15px; font-weight:700; }
.mini-stat-label { font-size:9px; color:var(--muted2); text-transform:uppercase; letter-spacing:.8px; margin-top:4px; }
.diff-badge { padding:3px 10px; border-radius:20px; font-size:11px; font-weight:600; }
.diff-pos { background:rgba(52,199,89,0.15); color:#34c759; }
.diff-neg { background:rgba(255,69,0,0.15); color:var(--accent); }

/* ── TODAY / PLAN ── */
.today-card {
  background:rgba(17,17,17,0.9);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,69,0,0.2);
  border-radius:20px; padding:20px; margin-bottom:14px;
  position:relative; overflow:hidden;
  animation:slideUp .4s ease both;
}
.today-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background: linear-gradient(90deg, var(--accent), var(--accent2), var(--accent3));
  box-shadow:0 0 20px var(--glow);
}
.today-card.rest::before { background:linear-gradient(90deg,#444,#666); box-shadow:none; }
.today-card.done::before { background:linear-gradient(90deg,#34c759,#30d158); box-shadow:0 0 16px rgba(52,199,89,0.3); }
.today-header { display:flex; align-items:center; gap:14px; margin-bottom:16px; }
.today-emoji  { font-size:36px; line-height:1; }
.today-title  { font-size:20px; font-weight:800; color:var(--text); }
.today-subtitle { font-size:12px; color:var(--muted2); margin-top:3px; }
.today-exercises { display:flex; flex-direction:column; gap:8px; }
.today-ex {
  display:flex; align-items:flex-start;
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.05);
  border-radius:12px; padding:10px 14px;
  animation:slideUp .3s ease both;
  transition:background .2s;
}
.today-ex:active { background:rgba(255,69,0,0.05); }
.today-ex-num {
  width:24px; height:24px; border-radius:8px;
  background:rgba(255,69,0,0.12);
  color:var(--accent);
  font-size:11px; font-weight:700;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
}
.today-ex.done-ex .today-ex-num { background:rgba(52,199,89,0.12); color:#34c759; }
.today-ex-body { flex:1; margin:0 10px; }
.today-ex-top  { display:flex; align-items:baseline; justify-content:space-between; gap:8px; }
.today-ex-name { font-size:13px; font-weight:600; color:var(--text); }
.today-ex-target { font-size:11px; color:var(--muted2); white-space:nowrap; }
.today-ex-hint { display:flex; align-items:center; gap:8px; margin-top:5px; flex-wrap:wrap; }
.ex-last  { font-size:11px; color:var(--muted2); }
.ex-first { font-size:11px; color:var(--accent2); font-weight:600; }
.ex-diff  { font-size:11px; font-weight:700; padding:2px 8px; border-radius:8px; }
.ex-diff.up   { background:rgba(52,199,89,0.12); color:#34c759; }
.ex-diff.down { background:rgba(255,69,0,0.12);  color:var(--accent); }
.ex-diff.same { background:rgba(136,136,136,0.12); color:var(--muted2); }
.today-done-banner {
  display:flex; align-items:center; gap:12px;
  background:rgba(52,199,89,0.06);
  border:1px solid rgba(52,199,89,0.2);
  border-radius:14px; padding:14px 16px; margin-bottom:14px;
}
.today-done-icon  { font-size:28px; }
.today-done-title { font-size:14px; font-weight:700; color:#34c759; }
.today-done-sub   { font-size:12px; color:var(--muted2); margin-top:2px; }
.today-rest-banner {
  display:flex; flex-direction:column; align-items:center;
  padding:32px 20px; text-align:center;
}
.today-rest-icon  { font-size:56px; margin-bottom:16px; }
.today-rest-title { font-size:18px; font-weight:800; color:var(--text); margin-bottom:6px; }
.today-rest-sub   { font-size:13px; color:var(--muted2); line-height:1.5; }

/* ── WEEK COMPARE ── */
.week-compare-card {
  background:rgba(17,17,17,0.9);
  backdrop-filter:blur(20px);
  border:1px solid rgba(255,69,0,0.15);
  border-radius:20px; padding:16px; margin-bottom:14px;
  animation:slideUp .4s ease both;
}
.wc-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.wc-header-title {
  font-size:11px; color:var(--muted2); text-transform:uppercase;
  letter-spacing:.8px; font-weight:600;
}
.wc-cols { display:flex; gap:10px; margin-bottom:14px; }
.wc-col {
  flex:1; background:rgba(255,255,255,0.03);
  border:1px solid var(--border);
  border-radius:14px; padding:12px; position:relative; overflow:hidden;
}
.wc-col.current {
  border-color:rgba(255,69,0,0.3);
  background:rgba(255,69,0,0.06);
}
.wc-col-label { font-size:10px; color:var(--muted2); text-transform:uppercase; letter-spacing:.6px; margin-bottom:8px; }
.wc-col-vol   { font-size:20px; font-weight:800; color:var(--text); line-height:1; }
.wc-col-vol span { font-size:11px; font-weight:500; color:var(--muted2); margin-left:3px; }
.wc-col-days  { font-size:12px; color:var(--muted2); margin-top:5px; }
.wc-col.current .wc-col-vol {
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.wc-col-badge {
  position:absolute; top:10px; right:10px;
  font-size:10px; font-weight:700; padding:2px 8px; border-radius:10px;
}
.wc-badge-up   { background:rgba(52,199,89,0.15); color:#34c759; }
.wc-badge-down { background:rgba(255,69,0,0.15);  color:var(--accent); }
.wc-badge-same { background:rgba(136,136,136,0.15); color:var(--muted2); }
.wc-bars { display:flex; align-items:flex-end; gap:6px; height:50px; }
.wc-bar-wrap  { flex:1; display:flex; flex-direction:column; align-items:center; gap:4px; height:100%; }
.wc-bar-bg    { width:100%; flex:1; border-radius:6px; background:rgba(255,255,255,0.04); position:relative; overflow:hidden; display:flex; align-items:flex-end; }
.wc-bar-fill  { width:100%; border-radius:6px; transition:height .8s cubic-bezier(.4,0,.2,1); }
.wc-bar-label { font-size:9px; color:var(--muted2); }

/* ── SHARE ── */
.share-btn {
  width:100%; padding:14px; border-radius:16px; border:none; cursor:pointer;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:#fff; font-size:15px; font-weight:700;
  font-family:'Inter',sans-serif;
  box-shadow:0 0 24px var(--glow), 0 4px 16px rgba(255,69,0,0.3);
  transition:all .2s; margin-bottom:14px;
  display:flex; align-items:center; justify-content:center; gap:8px;
  position:relative; overflow:hidden;
}
.share-btn::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,0.15),transparent);
  pointer-events:none;
}
.share-btn:active { transform:scale(0.97); }
#share-canvas-wrap { display:none; border-radius:20px; overflow:hidden; margin-bottom:14px; box-shadow:0 0 40px var(--glow); }
#share-canvas { width:100%; display:block; border-radius:20px; }
.share-actions { display:none; gap:10px; margin-bottom:14px; }
.share-action-btn {
  flex:1; padding:12px; border-radius:14px;
  border:1px solid rgba(255,69,0,0.25);
  background:rgba(255,69,0,0.06);
  color:var(--accent2); font-size:13px; font-weight:600;
  font-family:'Inter',sans-serif; cursor:pointer; transition:all .2s;
  display:flex; align-items:center; justify-content:center; gap:6px;
}
.share-action-btn:active { transform:scale(0.96); }
.share-action-btn:disabled { opacity:.5; cursor:not-allowed; transform:none; }
.share-stories-btn {
  background:linear-gradient(135deg,rgba(255,45,85,0.18),rgba(255,140,0,0.12));
  border-color:rgba(255,45,85,0.4); color:#ff2d55;
}
.share-send-btn {
  background:rgba(255,255,255,0.04);
  border-color:rgba(255,255,255,0.12); color:var(--muted2);
}
.share-social {
  display:none; gap:10px; margin-bottom:10px;
}
.share-social-btn {
  flex:1; padding:11px; border-radius:14px; border:none; cursor:pointer;
  font-size:13px; font-weight:700; font-family:'Inter',sans-serif;
  display:flex; align-items:center; justify-content:center; gap:8px;
  transition:all .2s;
}
.share-social-btn:active { transform:scale(0.96); }
.share-instagram-btn {
  background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);
  color:#fff;
}
.share-tiktok-btn {
  background:#010101; color:#fff;
  border:1px solid rgba(255,255,255,0.15);
}

/* ── ONBOARDING ── */
.onboarding {
  position:fixed; inset:0; z-index:999;
  background:#000;
  display:none; flex-direction:column;
  align-items:center; justify-content:center; padding:32px 24px;
}
.onboarding::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 50% 0%, rgba(255,69,0,0.15) 0%, transparent 60%);
  pointer-events:none;
}
.onboarding-inner { width:100%; max-width:360px; display:flex; flex-direction:column; align-items:center; position:relative; z-index:1; }
.ob-icon  { font-size:80px; margin-bottom:24px; animation:slideUp .4s ease both; }
.ob-title { font-size:26px; font-weight:800; color:var(--text); text-align:center; margin-bottom:12px; }
.ob-text  { font-size:15px; color:var(--muted2); text-align:center; line-height:1.6; }
.onboarding-dots { display:flex; gap:8px; margin:32px 0; }
.onboarding-dot { width:8px; height:8px; border-radius:4px; background:var(--border); transition:all .3s; }
.onboarding-dot.active { width:24px; background:linear-gradient(90deg,var(--accent),var(--accent2)); }
.onboarding-btn {
  width:100%; padding:16px; border-radius:16px; border:none; cursor:pointer;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:#fff; font-size:16px; font-weight:700;
  font-family:'Inter',sans-serif;
  box-shadow:0 0 24px var(--glow);
  transition:all .2s; position:relative; overflow:hidden;
}
.onboarding-btn::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,0.15),transparent);
  pointer-events:none;
}
.onboarding-btn:active { transform:scale(0.97); }
.onboarding-skip { margin-top:16px; font-size:13px; color:var(--muted2); background:none; border:none; cursor:pointer; font-family:'Inter',sans-serif; }

/* ── LOADER / EMPTY ── */
.loader { display:flex; justify-content:center; align-items:center; padding:40px; }
.spinner {
  width:32px; height:32px; border-radius:50%;
  border:2px solid var(--border); border-top-color:var(--accent);
  animation:spin .8s linear infinite;
}
.empty { display:flex; flex-direction:column; align-items:center; padding:48px 20px; color:var(--muted2); text-align:center; }
.empty-icon  { font-size:48px; margin-bottom:16px; }
.empty-title { font-size:15px; font-weight:600; color:var(--muted2); margin-bottom:6px; }
.empty-sub   { font-size:12px; }

/* ── TODAY EX HINT ── */
.today-ex { align-items:flex-start; }

/* ── ANIMATIONS ── */
@keyframes slideUp { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:translateY(0)} }
@keyframes spin    { to{transform:rotate(360deg)} }

/* ── RADAR CARD ── */
#radar-card { background:rgba(17,17,17,0.9); backdrop-filter:blur(20px); border-color:rgba(255,69,0,0.15); }

/* ── HEATMAP ── */
.heatmap-card {
  background:rgba(17,17,17,0.9); backdrop-filter:blur(20px);
  border-radius:16px; border:1px solid rgba(255,45,85,0.2);
  padding:14px; margin-bottom:12px;
  box-shadow:0 4px 24px rgba(0,0,0,0.4);
}
.heatmap-card-top {
  display:flex; align-items:center; justify-content:space-between; margin-bottom:12px;
}
.heatmap-card-label { font-size:14px; font-weight:600; color:var(--text); }
.hm-toggle {
  display:flex; border-radius:8px; overflow:hidden; border:1px solid var(--border);
}
.hm-btn {
  padding:5px 14px; border:none; background:transparent; color:var(--muted2);
  cursor:pointer; font-size:12px; font-weight:500; font-family:'Inter',sans-serif;
  transition:all .2s;
}
.hm-btn.hm-active { background:var(--accent3); color:#fff; }
.heatmap-body { display:flex; flex-direction:column; gap:12px; }
.hm-silhouettes { display:flex; gap:8px; justify-content:center; }
.hm-svg-col { display:flex; flex-direction:column; align-items:center; gap:4px; flex:1; }
.hm-view-label {
  font-size:10px; color:var(--muted2); text-transform:uppercase;
  letter-spacing:.05em; font-weight:600;
}
.hm-svg { width:100%; max-width:160px; height:auto; filter:drop-shadow(0 2px 8px rgba(0,0,0,0.6)); }
.hm-legend-col {
  display:flex; flex-direction:column; gap:7px; min-width:0;
}
.hm-legend-item { display:flex; align-items:center; gap:6px; }
.hm-legend-name { width:90px; font-size:11px; color:var(--text); opacity:.8; flex-shrink:0; }
.hm-legend-bar-wrap {
  flex:1; height:6px; background:var(--muted); border-radius:4px; overflow:hidden; min-width:0;
}
.hm-legend-bar { height:100%; border-radius:4px; transition:width .5s ease; }
.hm-legend-pct {
  width:30px; text-align:right; font-size:11px; font-weight:700;
  color:var(--text); flex-shrink:0;
}
.hm-no-data { color:var(--muted2); font-size:13px; padding:16px 0; text-align:center; }