/* ============================================================
   FUEL — components.css
   All UI components: cards, buttons, modals, forms, charts
   ============================================================ */

/* ── TOAST ───────────────────────────────────────────────────── */
.toast {
  position:fixed; bottom:calc(var(--safe-bottom) + 80px); left:50%;
  transform:translateX(-50%); padding:12px 20px;
  border-radius:999px!important;
  background:rgba(18,22,20,.92)!important; color:var(--white)!important;
  border:1px solid var(--border); box-shadow:var(--shadow-lg);
  backdrop-filter:var(--glass-blur);
  font-size:13px; font-weight:500; z-index:400;
  opacity:0; transition:opacity .2s;
  max-width:320px; text-align:center; pointer-events:none; white-space:nowrap;
}
.toast.visible { opacity:1; }

/* ── SPINNER / ANALYZING ────────────────────────────────────── */
.analyzing-overlay {
  display:none; position:fixed; inset:0;
  background:rgba(10,10,10,0.9); backdrop-filter:blur(10px);
  z-index:300; align-items:center; justify-content:center;
  flex-direction:column; gap:20px;
}
.analyzing-overlay.visible { display:flex; }
.spinner {
  width:48px; height:48px;
  border:3px solid var(--surface2); border-top-color:var(--green);
  border-radius:50%; animation:spin .8s linear infinite;
}
.analyzing-text { font-family:'DM Mono',monospace; font-size:12px; letter-spacing:2px; text-transform:uppercase; color:var(--muted); }

/* ── BUTTONS ─────────────────────────────────────────────────── */
.btn {
  padding:11px 4px; border-radius:16px!important; border:none;
  font-family:'DM Mono',monospace; font-size:9px; letter-spacing:.8px; text-transform:uppercase;
  cursor:pointer; font-weight:500;
  display:flex; flex-direction:column; align-items:center; gap:4px;
  transition:transform .16s ease, opacity .16s ease, box-shadow .16s ease,
             background .16s ease, color .16s ease!important;
}
.btn-icon { font-size:18px; }
.btn-primary { background:var(--green); color:var(--bg); box-shadow:0 12px 24px var(--accent-glow)!important; }
.btn-secondary { background:var(--surface2); color:var(--white); }
.btn-amber { background:var(--amber-dim); color:var(--amber); border:1px solid rgba(224,123,42,0.3); }
.btn-purple { background:var(--purple-dim); color:var(--purple); border:1px solid rgba(167,139,250,0.3); }
.btn:active, .btn-primary:active { transform:scale(.97)!important; }
.btn-secondary:active { opacity:.75; }

.btn-inline {
  flex:1; padding:11px; border-radius:16px!important; border:none;
  font-family:'DM Mono',monospace; font-size:11px; letter-spacing:1.5px; text-transform:uppercase;
  cursor:pointer; font-weight:500;
  transition:transform .16s ease, opacity .16s ease!important;
}
.btn-inline:active { transform:scale(.97)!important; }

/* ── FORM INPUTS ─────────────────────────────────────────────── */
.manual-input, .settings-input, .weight-input, .login-input,
.serving-input, .set-input, .analytics-input,
select.manual-input, textarea.manual-input {
  border-radius:16px!important;
  background:rgba(255,255,255,.07)!important;
  border:1px solid var(--border)!important;
  color:var(--white)!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
  outline:none;
  transition:border-color .2s;
}
.manual-input:focus, .settings-input:focus, .weight-input:focus,
.login-input:focus, .serving-input:focus, .set-input:focus, .analytics-input:focus {
  border-color:var(--green)!important;
  box-shadow:0 0 0 4px var(--green-dim)!important;
}

/* ── LOGIN ───────────────────────────────────────────────────── */
.login-screen {
  display:none; position:fixed; inset:0; background:var(--bg); z-index:500;
  align-items:center; justify-content:center; flex-direction:column;
  padding:40px 32px; max-width:480px; margin:0 auto;
}
.login-screen.visible { display:flex; }
.login-logo { font-family:'Bebas Neue',sans-serif; font-size:64px; letter-spacing:2px; margin-bottom:4px; }
.login-logo span { color:var(--green); }
.login-tagline { font-family:'DM Mono',monospace; font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--muted); margin-bottom:48px; }
.login-field { display:flex; flex-direction:column; gap:6px; width:100%; margin-bottom:14px; }
.login-label { font-family:'DM Mono',monospace; font-size:10px; letter-spacing:1.5px; text-transform:uppercase; color:var(--muted); }
.login-input { padding:13px 14px; font-size:15px; width:100%; font-family:'DM Sans',sans-serif; }
.login-remember { display:flex; align-items:center; gap:10px; width:100%; margin:6px 0 24px; cursor:pointer; }
.login-remember input[type="checkbox"] { width:18px; height:18px; accent-color:var(--green); cursor:pointer; flex-shrink:0; }
.login-remember span { font-size:13.5px; color:var(--muted); }
.login-btn {
  width:100%; padding:15px; border-radius:16px!important; border:none;
  background:var(--green); color:var(--bg);
  font-family:'DM Mono',monospace; font-size:12px; letter-spacing:2px; text-transform:uppercase;
  font-weight:500; cursor:pointer;
  box-shadow:0 12px 24px var(--accent-glow)!important;
  transition:opacity .15s, transform .16s ease!important;
}
.login-btn:active { opacity:.8; transform:scale(.97)!important; }
.login-error { color:var(--red); font-size:12px; font-family:'DM Mono',monospace; margin-top:10px; min-height:16px; text-align:center; }

/* ── SUMMARY CARD ────────────────────────────────────────────── */
.summary-card {
  background:var(--surface)!important; border:1px solid var(--border)!important;
  border-radius:var(--radius)!important; box-shadow:var(--shadow-md)!important;
  backdrop-filter:var(--glass-blur); padding:24px!important; margin-bottom:16px;
}
.summary-top { display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
.cal-num { font-family:'Bebas Neue',sans-serif; font-size:52px; line-height:1; color:var(--green); letter-spacing:.5px; }
.cal-label { font-family:'DM Mono',monospace; font-size:10px; letter-spacing:1.5px; text-transform:uppercase; color:var(--muted); margin-top:2px; }
.cal-rem-num { font-family:'Bebas Neue',sans-serif; font-size:28px; line-height:1; color:var(--white); text-align:right; }
.cal-rem-label { font-family:'DM Mono',monospace; font-size:9px; letter-spacing:1px; color:var(--muted); text-transform:uppercase; text-align:right; }
.macro-bars { display:flex; flex-direction:column; gap:10px; }
.macro-row { display:flex; flex-direction:column; gap:4px; }
.macro-row-top { display:flex; justify-content:space-between; align-items:center; }
.macro-name { font-family:'DM Mono',monospace; font-size:10px; letter-spacing:1px; text-transform:uppercase; }
.macro-val { font-family:'DM Mono',monospace; font-size:10px; color:var(--muted); }
.bar-track { height:9px!important; background:var(--surface2)!important; border-radius:999px!important; overflow:hidden; }
.bar-fill { height:100%; border-radius:999px!important; transition:width .5s cubic-bezier(0.34,1.56,0.64,1); box-shadow:0 0 20px currentColor; }
.bar-protein { background:var(--green); }
.bar-carbs   { background:var(--amber); }
.bar-fat     { background:var(--blue); }

/* ── STATS ROW ───────────────────────────────────────────────── */
.stats-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:16px; }
.stat-card {
  background:var(--surface)!important; border-radius:var(--radius)!important;
  padding:18px!important; border:1px solid var(--border)!important;
  box-shadow:var(--shadow-md)!important; backdrop-filter:var(--glass-blur);
  cursor:pointer; transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.stat-card:hover { transform:translateY(-2px); box-shadow:var(--shadow-lg)!important; border-color:var(--accent-glow-border)!important; }
.stat-card-label { font-family:'DM Mono',monospace; font-size:9px; letter-spacing:2px; text-transform:uppercase; color:var(--muted); margin-bottom:8px; }
.stat-card-main { display:flex; align-items:baseline; gap:6px; }
.stat-card-num { font-family:'Bebas Neue',sans-serif; font-size:40px; line-height:1; }
.stat-card-unit { font-family:'DM Mono',monospace; font-size:11px; color:var(--muted); }
.stat-card-sub { font-size:11px; color:var(--muted); margin-top:4px; }
.stat-card-sub strong { color:var(--white); font-weight:500; }
.streak-fire { font-size:22px; margin-bottom:4px; }

/* ── WEIGHT LOG CARD ─────────────────────────────────────────── */
.weight-log-card {
  background:var(--surface)!important; border-radius:var(--radius)!important;
  padding:24px!important; margin-bottom:16px;
  border:1px solid var(--border)!important; box-shadow:var(--shadow-md)!important;
  backdrop-filter:var(--glass-blur);
}
.weight-log-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.weight-log-title { font-family:'Bebas Neue',sans-serif; font-size:22px; }
.weight-goal-badge { font-family:'DM Mono',monospace; font-size:9px; letter-spacing:1px; text-transform:uppercase; padding:4px 10px; border-radius:20px; background:var(--green-dim); color:var(--green); }
.weight-input-row { display:flex; gap:10px; margin-bottom:16px; }
.weight-input { flex:1; padding:11px 14px; font-size:18px; font-family:'DM Mono',monospace; }
.weight-log-btn {
  padding:11px 18px; border-radius:16px!important; border:none;
  background:var(--green); color:var(--bg);
  font-family:'DM Mono',monospace; font-size:11px; letter-spacing:1.5px; text-transform:uppercase;
  font-weight:500; cursor:pointer; white-space:nowrap;
  box-shadow:0 12px 24px var(--accent-glow)!important;
  transition:transform .16s ease, opacity .16s ease!important;
}
.weight-log-btn:active { transform:scale(.97)!important; }
.weight-entries { display:flex; flex-direction:column; gap:0; max-height:160px; overflow-y:auto; }
.weight-entry { display:flex; justify-content:space-between; align-items:center; padding:8px 0; border-bottom:1px solid var(--border); }
.weight-entry:last-child { border-bottom:none; }
.weight-entry-date { font-family:'DM Mono',monospace; font-size:11px; color:var(--muted); }
.weight-entry-val { font-family:'Bebas Neue',sans-serif; font-size:20px; color:var(--green); }
.weight-entry-del { background:none; border:none; color:var(--muted); font-size:14px; cursor:pointer; padding:2px 6px; }
.weight-pill-delete {
  display:inline-flex; align-items:center; justify-content:center;
  width:18px; height:18px; margin-left:7px; border-radius:50%;
  border:1px solid rgba(255,255,255,.14); background:var(--red-dim); color:var(--red);
  font-size:11px; line-height:1; cursor:pointer; vertical-align:middle;
  opacity:.85; transition:opacity .12s, transform .12s, background .12s, color .12s;
}
.weight-pill-delete:hover { opacity:1; transform:scale(1.05); background:var(--red); color:#fff; }
.weight-point-delete {
  display:inline-flex; align-items:center; justify-content:center;
  width:20px; height:20px; border-radius:50%; border:none;
  background:var(--red); color:white; font-size:12px; cursor:pointer;
}

/* ── WEIGHT CHART ────────────────────────────────────────────── */
.weight-chart { position:relative; height:150px; margin-bottom:12px; }
.weight-chart svg { width:100%; height:100%; overflow:visible; }
.weight-chart-tooltip {
  position:absolute; z-index:5; display:none;
  transform:translate(-50%,-120%);
  background:rgba(10,12,11,.92); color:#fff;
  border:1px solid rgba(255,255,255,.14); border-radius:999px;
  padding:8px 10px; font-family:'DM Mono',monospace; font-size:10px;
  box-shadow:var(--shadow-lg); white-space:nowrap;
  align-items:center; gap:8px; backdrop-filter:var(--glass-blur);
}
.weight-chart-tooltip.visible { display:flex; }
.weight-data-point {
  opacity:0; cursor:pointer; transform-origin:center;
  transition:opacity .16s ease, r .16s ease, filter .16s ease; pointer-events:auto;
}
svg:hover .weight-data-point, .weight-data-point.active, .weight-data-point:focus {
  opacity:1; filter:drop-shadow(0 0 10px var(--accent-drop-shadow)); outline:none;
}
.weight-chart-legend, .analytics-weight-log-list { display:flex; flex-wrap:wrap; gap:8px; margin-top:12px; }
.weight-legend-pill {
  border:1px solid var(--border); background:var(--surface2); color:var(--muted);
  border-radius:999px; padding:7px 10px;
  font-family:'DM Mono',monospace; font-size:10px; cursor:pointer;
}
.weight-legend-pill.active { background:var(--green-dim); color:var(--green); border-color:var(--accent-border-mid); }

/* ── CALORIES INLINE CHART ───────────────────────────────────── */
.calories-inline-chart { position:relative; height:128px; margin-top:18px; padding-top:4px; }
.calories-inline-chart svg { width:100%; height:100%; overflow:visible; }
.calories-chart-tooltip {
  position:absolute; display:none; transform:translate(-50%,-120%);
  background:rgba(10,12,11,.92); color:#fff;
  border:1px solid rgba(255,255,255,.14); border-radius:999px;
  padding:8px 10px; font-family:'DM Mono',monospace; font-size:10px;
  white-space:nowrap; align-items:center; gap:8px;
  box-shadow:var(--shadow-lg); z-index:12; backdrop-filter:var(--glass-blur); pointer-events:none;
}
.calories-chart-tooltip.visible { display:flex; }
.calories-data-point {
  opacity:0; cursor:pointer;
  transition:opacity .16s ease, r .16s ease, filter .16s ease; pointer-events:auto;
}
.calories-inline-chart svg:hover .calories-data-point,
.calories-data-point.active, .calories-data-point:focus {
  opacity:1; filter:drop-shadow(0 0 10px var(--accent-drop-shadow)); outline:none;
}
.calories-target-label { font-family:'DM Mono',monospace; font-size:8px; letter-spacing:1px; text-transform:uppercase; fill:var(--muted); }

/* ── LOCKED / INPUT CARD ─────────────────────────────────────── */
.locked-banner {
  background:var(--surface); border:1.5px solid rgba(224,123,42,0.3);
  border-radius:var(--radius); padding:18px 20px; margin-bottom:16px;
  display:flex; align-items:center; gap:14px;
}
.locked-icon { font-size:24px; flex-shrink:0; }
.locked-text { flex:1; }
.locked-text strong { display:block; font-size:14px; font-weight:600; margin-bottom:3px; }
.locked-text span { font-size:12px; color:var(--muted); }
.locked-login-btn {
  background:var(--amber); color:var(--bg); border:none; border-radius:16px!important;
  padding:9px 14px; font-family:'DM Mono',monospace; font-size:10px;
  letter-spacing:1px; text-transform:uppercase; font-weight:500; cursor:pointer;
  white-space:nowrap; flex-shrink:0;
  transition:transform .16s ease, opacity .16s ease!important;
}
.locked-login-btn:active { transform:scale(.97)!important; }
.locked-data-card {
  background:var(--surface); border:1px dashed var(--border); border-radius:24px;
  padding:28px 22px; text-align:center; color:var(--muted);
}
.locked-data-card .lock-icon { font-size:34px; margin-bottom:10px; }
.locked-data-card strong { display:block; color:var(--white); font-size:16px; margin-bottom:6px; }
.locked-data-card button {
  margin-top:14px; border:0; border-radius:14px; background:var(--green);
  color:var(--bg); padding:11px 16px; font-family:'DM Mono',monospace;
  font-size:10px; letter-spacing:1px; text-transform:uppercase; font-weight:700; cursor:pointer;
}
.input-card {
  background:var(--surface)!important; border:1.5px solid rgba(82,183,136,0.3);
  border-radius:var(--radius)!important; box-shadow:var(--shadow-md)!important;
  backdrop-filter:var(--glass-blur); padding:24px 20px; margin-bottom:16px;
  display:flex; flex-direction:column; align-items:center; gap:14px;
}
.input-card.locked { border-color:rgba(255,255,255,0.08); opacity:.45; pointer-events:none; }
.input-icon {
  width:52px; height:52px; border-radius:50%;
  background:linear-gradient(135deg,var(--green-dim),var(--blue-dim));
  box-shadow:inset 0 0 0 1px var(--border);
  display:flex; align-items:center; justify-content:center; font-size:22px;
}
.input-title { font-size:15px; font-weight:600; }
.input-sub { font-size:12px; color:var(--muted); font-family:'DM Mono',monospace; letter-spacing:.5px; text-align:center; }
.input-actions { display:grid; grid-template-columns:1fr 1fr 1fr 1fr; gap:8px; width:100%; }

/* ── MANUAL ENTRY ────────────────────────────────────────────── */
.manual-entry {
  background:var(--surface)!important; border-radius:var(--radius)!important;
  padding:20px; margin-bottom:16px; border:1px solid var(--border)!important;
  box-shadow:var(--shadow-md)!important; backdrop-filter:var(--glass-blur);
  display:none; animation:slideUp .3s ease;
}
.manual-entry.visible { display:block; }
.manual-title { font-family:'Bebas Neue',sans-serif; font-size:20px; margin-bottom:16px; color:var(--green); }
.manual-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:14px; }
.manual-field { display:flex; flex-direction:column; gap:5px; }
.manual-field.full { grid-column:1/-1; }
.manual-lbl { font-family:'DM Mono',monospace; font-size:9px; letter-spacing:1.5px; text-transform:uppercase; color:var(--muted); }
.manual-input { padding:9px 11px; font-size:14px; width:100%; font-family:'DM Sans',sans-serif; }
.manual-actions { display:flex; gap:10px; }
.manual-submit {
  flex:1; padding:12px; border-radius:16px!important; border:none;
  background:var(--green); color:var(--bg);
  font-family:'DM Mono',monospace; font-size:11px; letter-spacing:2px; text-transform:uppercase;
  font-weight:500; cursor:pointer;
  box-shadow:0 12px 24px var(--accent-glow)!important;
  transition:transform .16s ease, opacity .16s ease!important;
}
.manual-submit:active { transform:scale(.97)!important; }
.manual-cancel {
  padding:12px 16px; border-radius:16px!important; border:none;
  background:var(--surface2); color:var(--white);
  font-family:'DM Mono',monospace; font-size:11px; letter-spacing:1px; text-transform:uppercase; cursor:pointer;
  transition:transform .16s ease, opacity .16s ease!important;
}
.manual-cancel:active { transform:scale(.97)!important; }

/* Food autocomplete */
.food-autocomplete { position:relative; }
.food-suggestions {
  position:absolute; top:100%; left:0; right:0;
  background:var(--surface); border:1px solid var(--border);
  border-radius:0 0 10px 10px; z-index:200; max-height:220px; overflow-y:auto; display:none;
}
.food-suggestions.visible { display:block; }
.food-suggestion-item { padding:10px 14px; cursor:pointer; border-bottom:1px solid var(--border); transition:background .1s; }
.food-suggestion-item:last-child { border-bottom:none; }
.food-suggestion-item:hover { background:var(--surface2); }
.food-sugg-name { font-size:13.5px; font-weight:500; margin-bottom:2px; }
.food-sugg-macros { font-family:'DM Mono',monospace; font-size:10px; color:var(--muted); }

/* ── PREVIEW / SCANNER ───────────────────────────────────────── */
.preview-section {
  background:var(--surface)!important; border-radius:var(--radius)!important;
  overflow:hidden; margin-bottom:16px; border:1px solid var(--border)!important;
  box-shadow:var(--shadow-md)!important; backdrop-filter:var(--glass-blur); display:none;
}
.preview-section.visible { display:block; }
.preview-img { width:100%; max-height:220px; object-fit:cover; display:block; }
.preview-actions { padding:12px 16px; display:flex; gap:10px; }
.scanner-overlay { display:none; position:fixed; inset:0; background:#000; z-index:200; flex-direction:column; }
.scanner-overlay.visible { display:flex; }
.scanner-header { padding:calc(var(--safe-top) + 16px) 20px 14px; display:flex; align-items:center; justify-content:space-between; background:rgba(0,0,0,0.8); flex-shrink:0; }
.scanner-title { font-family:'Bebas Neue',sans-serif; font-size:22px; color:var(--white); }
.scanner-close { background:var(--surface2); border:none; color:var(--white); width:36px; height:36px; border-radius:50%; font-size:16px; cursor:pointer; display:flex; align-items:center; justify-content:center; }
#scannerView { flex:1; position:relative; }
.scanner-hint { padding:16px 20px calc(var(--safe-bottom) + 16px); text-align:center; background:rgba(0,0,0,0.8); font-family:'DM Mono',monospace; font-size:11px; letter-spacing:1px; color:var(--muted); text-transform:uppercase; flex-shrink:0; }

/* ── RESULT CARD ─────────────────────────────────────────────── */
.result-card {
  background:var(--surface)!important; border-radius:var(--radius)!important;
  margin-bottom:16px; border:1px solid var(--border)!important;
  box-shadow:var(--shadow-md)!important; backdrop-filter:var(--glass-blur);
  overflow:hidden; display:none; animation:slideUp .35s cubic-bezier(0.34,1.2,0.64,1);
}
.result-card.visible { display:block; }
.result-header { padding:16px 18px 12px; border-bottom:1px solid var(--border); display:flex; justify-content:space-between; align-items:flex-start; gap:10px; }
.result-meal-name { font-family:'Bebas Neue',sans-serif; font-size:22px; letter-spacing:.3px; line-height:1.1; }
.result-source-badge { font-family:'DM Mono',monospace; font-size:9px; letter-spacing:1px; text-transform:uppercase; padding:3px 8px; border-radius:20px; white-space:nowrap; }
.source-ai { background:var(--blue-dim); color:var(--blue); }
.source-barcode { background:var(--green-dim); color:var(--green); }
.source-manual { background:var(--purple-dim); color:var(--purple); }
.confidence-badge { font-family:'DM Mono',monospace; font-size:9px; letter-spacing:1.5px; text-transform:uppercase; padding:3px 8px; border-radius:20px; white-space:nowrap; }
.conf-high { background:var(--green-dim); color:var(--green); }
.conf-medium { background:var(--amber-dim); color:var(--amber); }
.conf-low { background:var(--red-dim); color:var(--red); }
.result-macros { display:grid; grid-template-columns:repeat(4,1fr); padding:14px 18px; gap:8px; border-bottom:1px solid var(--border); }
.rmacro { text-align:center; }
.rmacro-val { font-family:'Bebas Neue',sans-serif; font-size:26px; line-height:1; }
.rmacro-val.cal, .rmacro-val.pro { color:var(--green); }
.rmacro-val.carb { color:var(--amber); }
.rmacro-val.fat  { color:var(--blue); }
.rmacro-unit { font-family:'DM Mono',monospace; font-size:8px; letter-spacing:1px; text-transform:uppercase; color:var(--muted); margin-top:2px; }
.serving-section { border-bottom:1px solid var(--border); padding:14px 18px 16px; background:rgba(82,183,136,0.04); }
.serving-question { font-size:13.5px; font-weight:600; display:block; margin-bottom:12px; }
.serving-chips { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:10px; }
.serving-chip { padding:7px 14px; border-radius:20px; border:1.5px solid var(--border); background:var(--surface2); color:var(--white); font-family:'DM Mono',monospace; font-size:12px; letter-spacing:.5px; cursor:pointer; transition:all .15s; }
.serving-chip:active { transform:scale(.95); }
.serving-chip.selected { background:var(--green); color:var(--bg); border-color:var(--green); font-weight:500; }
.serving-custom-row { display:flex; align-items:center; gap:10px; }
.serving-or { font-size:11px; color:var(--muted); font-family:'DM Mono',monospace; white-space:nowrap; }
.serving-input { width:80px; padding:7px 10px; font-family:'DM Mono',monospace; font-size:13px; }
.serving-meal, .serving-snack { display:none; }
.serving-meal.visible, .serving-snack.visible { display:block; }
.result-items { padding:12px 18px; }
.result-items-label { font-family:'DM Mono',monospace; font-size:9px; letter-spacing:2px; text-transform:uppercase; color:var(--muted); margin-bottom:10px; }
.food-item { display:flex; justify-content:space-between; align-items:center; padding:8px 0; border-bottom:1px solid var(--border); gap:12px; }
.food-item:last-child { border-bottom:none; }
.food-item-name { font-size:13.5px; font-weight:500; }
.food-item-portion { font-size:11px; color:var(--muted); font-family:'DM Mono',monospace; }
.food-item-cal { font-family:'Bebas Neue',sans-serif; font-size:18px; color:var(--green); white-space:nowrap; }
.result-note { padding:8px 18px 12px; font-size:12px; color:var(--muted); font-style:italic; line-height:1.5; }
.result-add-btn {
  width:calc(100% - 36px); margin:0 18px 16px; padding:14px;
  border-radius:16px!important; border:none;
  background:var(--green); color:var(--bg);
  font-family:'DM Mono',monospace; font-size:11px; letter-spacing:2px; text-transform:uppercase;
  font-weight:500; cursor:pointer;
  box-shadow:0 12px 24px var(--accent-glow)!important;
  transition:opacity .15s, transform .16s ease!important;
}
.result-add-btn:hover { opacity:.88; }
.result-add-btn:active { transform:scale(.97)!important; }

/* ── LOG ─────────────────────────────────────────────────────── */
.log-label { font-family:'DM Mono',monospace; font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--muted); margin-bottom:10px; padding:0 4px; }
.log-empty { background:var(--surface); border-radius:var(--radius); padding:24px; text-align:center; border:1px solid var(--border); color:var(--muted); font-size:13px; }
.log-entry {
  background:var(--surface)!important; border-radius:12px; margin-bottom:10px;
  border:1px solid var(--border)!important; box-shadow:var(--shadow-md)!important;
  backdrop-filter:var(--glass-blur); display:flex; align-items:center; padding:12px 14px; gap:12px;
  animation:slideUp .3s ease; transition:background .15s;
}
.log-entry:hover { background:var(--surface2)!important; }
.log-entry-icon { width:36px; height:36px; border-radius:10px; background:var(--green-dim); display:flex; align-items:center; justify-content:center; font-size:16px; flex-shrink:0; }
.log-entry-info { flex:1; min-width:0; }
.log-entry-name { font-size:13.5px; font-weight:500; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.log-entry-meta { font-family:'DM Mono',monospace; font-size:10px; color:var(--muted); margin-top:2px; }
.log-entry-cal { font-family:'Bebas Neue',sans-serif; font-size:22px; color:var(--green); white-space:nowrap; }
.log-entry-del { background:none; border:none; color:var(--muted); font-size:16px; cursor:pointer; padding:4px; }

/* ── SETTINGS ────────────────────────────────────────────────── */
.settings-section {
  background:var(--surface)!important; border-radius:var(--radius)!important;
  padding:20px; margin-bottom:16px; border:1px solid var(--border)!important;
  box-shadow:var(--shadow-md)!important; backdrop-filter:var(--glass-blur);
}
.settings-title { font-family:'Bebas Neue',sans-serif; font-size:20px; margin-bottom:14px; color:var(--green); }
.settings-row { display:flex; flex-direction:column; gap:6px; margin-bottom:14px; }
.settings-label { font-family:'DM Mono',monospace; font-size:10px; letter-spacing:1.5px; text-transform:uppercase; color:var(--muted); }
.settings-input { padding:10px 12px; font-family:'DM Mono',monospace; font-size:13px; width:100%; }
.settings-hint { font-size:12px; color:var(--muted); line-height:1.5; margin-bottom:12px; }
.settings-hint strong { color:var(--white); font-weight:600; }
.settings-save-btn {
  width:100%; padding:13px; border-radius:16px!important; border:none;
  background:var(--green); color:var(--bg);
  font-family:'DM Mono',monospace; font-size:11px; letter-spacing:2px; text-transform:uppercase;
  font-weight:500; cursor:pointer;
  box-shadow:0 12px 24px var(--accent-glow)!important;
  transition:transform .16s ease, opacity .16s ease!important;
}
.settings-save-btn:active { transform:scale(.97)!important; }

/* ── WORKOUT COMPONENTS ──────────────────────────────────────── */
.workout-today {
  background:var(--surface)!important; border-radius:var(--radius)!important;
  padding:24px!important; margin-bottom:16px;
  border:1px solid var(--border)!important; box-shadow:var(--shadow-md)!important;
  backdrop-filter:var(--glass-blur);
}
.workout-today-label { font-family:'DM Mono',monospace; font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--muted); margin-bottom:8px; }
.workout-today-name { font-family:'Bebas Neue',sans-serif; font-size:36px; line-height:1; margin-bottom:4px; }
.workout-today-focus { font-family:'DM Mono',monospace; font-size:11px; letter-spacing:1px; color:var(--green); margin-bottom:16px; }
.workout-section-label { font-family:'DM Mono',monospace; font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--muted); margin-bottom:12px; padding:0 4px; }
.workout-detail-card {
  background:var(--surface)!important; border-radius:var(--radius)!important;
  padding:20px; border:1px solid var(--border)!important;
  box-shadow:var(--shadow-md)!important; backdrop-filter:var(--glass-blur);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.workout-detail-card:hover { transform:translateY(-2px); box-shadow:var(--shadow-lg)!important; border-color:var(--accent-glow-border)!important; }
.workout-detail-title { font-family:'Bebas Neue',sans-serif; font-size:26px; margin-bottom:4px; }
.workout-detail-focus { font-family:'DM Mono',monospace; font-size:11px; letter-spacing:1px; color:var(--green); margin-bottom:16px; }
.exercise-list { list-style:none; }
.exercise-item { display:flex; justify-content:space-between; align-items:center; padding:11px 0; border-bottom:1px solid var(--border); gap:12px; }
.exercise-item:last-child { border-bottom:none; }
.exercise-name { font-size:14px; font-weight:500; }
.exercise-sets { font-family:'DM Mono',monospace; font-size:11px; color:var(--muted); white-space:nowrap; }
.exercise-tip { font-size:11px; color:var(--muted); font-style:italic; margin-top:2px; }
.exercise-actions { display:flex; gap:8px; margin-top:6px; }
.ex-btn { padding:6px 12px; border-radius:16px!important; border:none; font-family:'DM Mono',monospace; font-size:9px; letter-spacing:1px; text-transform:uppercase; cursor:pointer; font-weight:500; transition:all .15s; }
.ex-btn-complete { background:var(--green-dim); color:var(--green); }
.ex-btn-complete:hover, .ex-btn-complete.done { background:var(--green); color:var(--bg); }
.ex-btn-customize { background:var(--surface2); color:var(--muted); }
.ex-btn-customize:hover { background:var(--surface); color:var(--white); }
.ex-btn:active { transform:scale(.97)!important; }
.rest-card { background:var(--surface2); border-radius:12px; padding:24px; text-align:center; }
.rest-emoji { font-size:40px; margin-bottom:12px; }
.rest-title { font-family:'Bebas Neue',sans-serif; font-size:28px; margin-bottom:8px; color:var(--muted); }
.rest-note { font-size:13px; color:var(--muted); line-height:1.6; }
.workout-day-summary { background:var(--green-dim); border-radius:10px; padding:12px 16px; margin-bottom:16px; display:none; }
.workout-day-summary.visible { display:block; }
.workout-day-summary-title { font-family:'DM Mono',monospace; font-size:10px; letter-spacing:1.5px; text-transform:uppercase; color:var(--green); margin-bottom:6px; }
.workout-library-btn {
  width:100%; padding:14px; border-radius:16px!important; border:none;
  background:var(--green); color:var(--bg);
  font-family:'DM Mono',monospace; font-size:11px; letter-spacing:2px; text-transform:uppercase;
  font-weight:500; cursor:pointer; margin-bottom:16px;
  display:flex; align-items:center; justify-content:center; gap:8px;
  box-shadow:0 12px 24px var(--accent-glow)!important;
  transition:transform .16s ease, opacity .16s ease!important;
}
.workout-library-btn:active { transform:scale(.97)!important; }
.workout-log-entry { background:var(--surface2); border-radius:10px; padding:12px; margin-bottom:8px; }
.workout-log-entry-name { font-size:13.5px; font-weight:500; margin-bottom:4px; }
.workout-log-entry-sets { font-family:'DM Mono',monospace; font-size:10px; color:var(--muted); }

/* Set logger */
.set-row { display:grid; grid-template-columns:32px 1fr 1fr auto; gap:8px; align-items:center; margin-bottom:10px; }
.set-label { font-family:'DM Mono',monospace; font-size:11px; color:var(--muted); text-align:center; }
.set-input { padding:9px; font-family:'DM Mono',monospace; font-size:14px; text-align:center; width:100%; }
.set-del { background:none; border:none; color:var(--muted); font-size:16px; cursor:pointer; padding:4px; }
.add-set-btn { background:var(--surface2); border:1px dashed var(--border); border-radius:8px; padding:10px; width:100%; color:var(--muted); font-family:'DM Mono',monospace; font-size:10px; letter-spacing:1px; text-transform:uppercase; cursor:pointer; margin-bottom:16px; }
.workout-complete-btn {
  width:100%; padding:14px; border-radius:16px!important; border:none;
  background:var(--green); color:var(--bg);
  font-family:'DM Mono',monospace; font-size:11px; letter-spacing:2px; text-transform:uppercase;
  font-weight:500; cursor:pointer; margin-bottom:10px;
  box-shadow:0 12px 24px var(--accent-glow)!important;
  transition:transform .16s ease!important;
}
.workout-complete-btn:active { transform:scale(.97)!important; }

/* Workout library fields */
.workout-lib-row { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:12px; }
.workout-lib-row.single { grid-template-columns:1fr; }
.workout-lib-field { display:flex; flex-direction:column; gap:5px; }
.workout-lib-label { font-family:'DM Mono',monospace; font-size:9px; letter-spacing:1.5px; text-transform:uppercase; color:var(--muted); }
.workout-lib-input { padding:10px 11px; font-size:13px; width:100%; font-family:'DM Sans',sans-serif; }
.workout-lib-help { font-size:12px; color:var(--muted); line-height:1.5; margin:4px 0 14px; }

/* ── MEAL PREP ────────────────────────────────────────────────── */
.meal-prep-card {
  background:var(--surface)!important; border-radius:var(--radius)!important;
  padding:20px; margin-bottom:14px; border:1px solid var(--border)!important;
  box-shadow:var(--shadow-md)!important; backdrop-filter:var(--glass-blur);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.meal-prep-card:hover { transform:translateY(-2px); box-shadow:var(--shadow-lg)!important; border-color:rgba(82,183,136,0.35)!important; }
.meal-prep-card.smart { border-color:rgba(167,139,250,.32); background:linear-gradient(145deg,var(--surface),rgba(167,139,250,.08))!important; }
.meal-prep-title { font-family:'Bebas Neue',sans-serif; font-size:22px; margin-bottom:4px; }
.meal-prep-time { font-family:'DM Mono',monospace; font-size:10px; letter-spacing:1px; color:var(--muted); margin-bottom:12px; }
.meal-prep-macros { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:12px; }
.mp-chip { font-family:'DM Mono',monospace; font-size:10px; padding:3px 8px; border-radius:20px; }
.mp-chip.cal { background:var(--red-dim); color:var(--red); }
.mp-chip.p   { background:var(--green-dim); color:var(--green); }
.mp-chip.c   { background:var(--amber-dim); color:var(--amber); }
.mp-chip.f   { background:var(--blue-dim); color:var(--blue); }
.meal-prep-items { list-style:none; }
.meal-prep-items li { display:flex; justify-content:space-between; padding:7px 0; border-bottom:1px solid var(--border); font-size:13.5px; }
.meal-prep-items li:last-child { border-bottom:none; }
.mp-qty { color:var(--muted); font-family:'DM Mono',monospace; font-size:11px; }
.plan-tab {
  padding:7px 16px; border-radius:20px; border:1.5px solid var(--border);
  background:var(--surface2); color:var(--muted);
  font-family:'DM Mono',monospace; font-size:10px; letter-spacing:1px; text-transform:uppercase;
  cursor:pointer; white-space:nowrap; transition:all .15s;
}
.plan-tab.active { background:var(--green); color:var(--bg); border-color:var(--green); font-weight:500; }
.plan-tab:hover:not(.active) { background:var(--surface); color:var(--white); }
.plan-tab:active { transform:scale(.97)!important; }
.lib-item { background:var(--surface2); border-radius:12px; padding:14px; margin-bottom:10px; cursor:pointer; border:1.5px solid transparent; transition:all .15s; }
.lib-item:hover, .lib-item:active { border-color:var(--green); background:var(--green-dim); }
.lib-item-name { font-weight:600; font-size:14px; margin-bottom:3px; }
.lib-item-meta { font-family:'DM Mono',monospace; font-size:10px; color:var(--muted); }
.meal-prep-del { background:none; border:none; color:var(--muted); font-size:14px; cursor:pointer; padding:4px 8px; margin-left:auto; }
.meal-log-btn {
  width:100%; padding:11px; border-radius:16px!important; border:none;
  background:var(--green-dim); color:var(--green);
  font-family:'DM Mono',monospace; font-size:10px; letter-spacing:1.5px; text-transform:uppercase;
  font-weight:500; cursor:pointer; margin-top:14px; transition:all .15s;
}
.meal-log-btn:hover, .meal-log-btn:active { background:var(--green); color:var(--bg); transform:scale(.97)!important; }
.meal-edit-btn { background:var(--surface2); border:none; color:var(--muted); font-family:'DM Mono',monospace; font-size:9px; letter-spacing:1px; text-transform:uppercase; padding:5px 10px; border-radius:6px; cursor:pointer; }
.meal-timestamp { font-family:'DM Mono',monospace; font-size:10px; color:var(--muted); margin-bottom:8px; cursor:pointer; display:flex; align-items:center; gap:6px; }
.meal-timestamp:hover { color:var(--amber); }
.batch-badge { background:var(--amber-dim); color:var(--amber); font-family:'DM Mono',monospace; font-size:9px; letter-spacing:1px; text-transform:uppercase; padding:3px 8px; border-radius:20px; display:inline-block; margin-bottom:10px; }
.macro-fit-badge { display:inline-flex; align-items:center; gap:5px; background:var(--green-dim); color:var(--green); font-family:'DM Mono',monospace; font-size:9px; letter-spacing:1px; text-transform:uppercase; border-radius:999px; padding:4px 9px; margin-bottom:8px; }
.profile-chip { display:inline-flex; align-items:center; gap:6px; border-radius:999px; background:var(--surface2); border:1px solid var(--border); padding:6px 10px; color:var(--muted); font-family:'DM Mono',monospace; font-size:10px; margin:4px 4px 0 0; }
.split-pill-row { display:flex; gap:7px; flex-wrap:wrap; margin-top:8px; }
.split-pill { font-family:'DM Mono',monospace; font-size:9px; letter-spacing:.6px; text-transform:uppercase; padding:5px 9px; border-radius:999px; background:var(--surface2); border:1px solid var(--border); color:var(--muted); }

/* ── ANALYTICS MODAL ─────────────────────────────────────────── */
.analytics-chart {
  height:240px;
  background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.035))!important;
  border:1px solid var(--border); border-radius:20px!important;
  padding:14px; margin-bottom:14px; position:relative;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}
.analytics-chart svg { width:100%; height:100%; overflow:visible; }
.analytics-empty { height:100%; display:flex; align-items:center; justify-content:center; text-align:center; color:var(--muted); font-size:13px; line-height:1.5; padding:20px; }
.analytics-legend { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:10px; }
.analytics-legend-item { display:flex; align-items:center; gap:6px; font-family:'DM Mono',monospace; font-size:10px; color:var(--muted); }
.analytics-dot { width:8px; height:8px; border-radius:50%; }
.analytics-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:8px; }
.analytics-stat { background:var(--surface2); border-radius:10px; padding:11px; text-align:center; }
.analytics-stat-val { font-family:'Bebas Neue',sans-serif; font-size:24px; line-height:1; color:var(--green); }
.analytics-stat-lbl { font-family:'DM Mono',monospace; font-size:8px; color:var(--muted); letter-spacing:1px; text-transform:uppercase; margin-top:3px; }
.analytics-ranges { display:flex; gap:7px; flex-wrap:wrap; margin-bottom:16px; }
.analytics-range-btn {
  background:var(--surface2); border:1px solid var(--border); color:var(--muted);
  border-radius:20px; padding:7px 11px;
  font-family:'DM Mono',monospace; font-size:9px; letter-spacing:1px; text-transform:uppercase; cursor:pointer;
  transition:transform .16s ease!important;
}
.analytics-range-btn.active { background:var(--green); border-color:var(--green); color:var(--bg); font-weight:500; }
.analytics-range-btn:active { transform:scale(.97)!important; }
.analytics-controls { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:12px; }
.analytics-field { display:flex; flex-direction:column; gap:5px; }
.analytics-label { font-family:'DM Mono',monospace; font-size:9px; letter-spacing:1.5px; text-transform:uppercase; color:var(--muted); }
.analytics-input { padding:9px 10px; font-family:'DM Mono',monospace; font-size:11px; }
.analytics-weight-log-list { display:flex; flex-wrap:wrap; gap:8px; margin-top:12px; }
.analytics-weight-pill { border:1px solid var(--border); background:var(--surface2); color:var(--muted); border-radius:999px; padding:7px 10px; font-family:'DM Mono',monospace; font-size:10px; cursor:pointer; }
.analytics-weight-pill.active { background:var(--green-dim); color:var(--green); border-color:var(--accent-border-mid); }

/* Chart tooltips */
.chart-tooltip {
  position:absolute; z-index:6;
  background:rgba(10,12,11,.92); color:#fff;
  border:1px solid rgba(255,255,255,.14); border-radius:999px;
  padding:6px 8px; font-family:'DM Mono',monospace; font-size:10px;
  box-shadow:var(--shadow-lg); pointer-events:none;
  opacity:0; transform:translate(-50%,-120%); transition:opacity .12s;
  white-space:nowrap; backdrop-filter:var(--glass-blur);
}
.chart-tooltip.visible { opacity:1; }
.chart-data-point {
  opacity:0; transform-origin:center;
  transition:opacity .16s ease, r .16s ease, filter .16s ease;
  cursor:pointer; pointer-events:auto;
}
svg:hover .chart-data-point, .chart-data-point.active, .chart-data-point:focus {
  opacity:1; filter:drop-shadow(0 0 10px var(--accent-drop-shadow)); outline:none;
}

/* ── RECIPE MODAL ────────────────────────────────────────────── */
.recipe-sheet-header { position:sticky; top:0; background:var(--surface); border-bottom:1px solid var(--border); padding:20px 24px 16px; z-index:10; }
.recipe-sheet-title { font-family:'Bebas Neue',sans-serif; font-size:26px; margin-bottom:10px; }
.recipe-serving-toggle { display:flex; gap:0; background:var(--surface2); border-radius:10px; padding:3px; }
.recipe-serving-btn { flex:1; padding:8px; border-radius:8px; border:none; background:transparent; color:var(--muted); font-family:'DM Mono',monospace; font-size:10px; letter-spacing:1px; text-transform:uppercase; cursor:pointer; transition:all .15s; }
.recipe-serving-btn.active { background:var(--green); color:var(--bg); font-weight:500; }
.recipe-sheet-body { padding:20px 24px 32px; }
.recipe-section { margin-bottom:24px; }
.recipe-section-title { font-family:'DM Mono',monospace; font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--green); margin-bottom:10px; padding-bottom:6px; border-bottom:1px solid var(--border); }
.recipe-ingredient { display:flex; justify-content:space-between; padding:7px 0; border-bottom:1px solid var(--border); font-size:13.5px; }
.recipe-ingredient:last-child { border-bottom:none; }
.recipe-ing-qty { font-family:'DM Mono',monospace; font-size:11px; color:var(--muted); }
.recipe-step { display:flex; gap:14px; padding:10px 0; border-bottom:1px solid var(--border); }
.recipe-step:last-child { border-bottom:none; }
.recipe-step-num { width:24px; height:24px; border-radius:50%; background:var(--green); color:var(--bg); font-family:'DM Mono',monospace; font-size:10px; display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-top:1px; font-weight:500; }
.recipe-step-text { font-size:13.5px; line-height:1.6; color:var(--white); }
.recipe-info-box { background:var(--surface2); border-radius:10px; padding:14px 16px; font-size:13px; line-height:1.7; color:var(--muted); }
.recipe-info-box strong { color:var(--white); font-weight:500; }

/* ── MOVABLE CARDS ───────────────────────────────────────────── */
.drag-handle { cursor:move; user-select:none; touch-action:none; }
.movable-card { position:relative; transition:box-shadow .15s; }
.movable-card.dragging { box-shadow:0 18px 50px rgba(0,0,0,.38); }

/* ── HISTORY DAY POPUP ───────────────────────────────────────── */
.cal-detail-macros { display:grid; grid-template-columns:repeat(4,1fr); gap:8px; margin-bottom:16px; padding:14px; background:var(--surface2); border-radius:10px; }
.cal-detail-macro { text-align:center; }
.cal-detail-macro-val { font-family:'Bebas Neue',sans-serif; font-size:22px; line-height:1; }
.cal-detail-macro-lbl { font-family:'DM Mono',monospace; font-size:8px; letter-spacing:1px; text-transform:uppercase; color:var(--muted); }
.cal-detail-section { font-family:'DM Mono',monospace; font-size:9px; letter-spacing:2px; text-transform:uppercase; color:var(--muted); margin:14px 0 8px; padding-bottom:6px; border-bottom:1px solid var(--border); }

/* ── ONBOARDING ──────────────────────────────────────────────── */
.onboard-choice {
  display:flex; align-items:center; gap:14px;
  background:var(--surface2); border:1.5px solid var(--border);
  border-radius:16px; padding:16px 18px; cursor:pointer;
  width:100%; text-align:left; transition:all .18s ease; font-family:'DM Sans',sans-serif;
}
.onboard-choice.selected, .onboard-choice:active { border-color:var(--green); background:var(--green-dim); }
.onboard-choice:hover { border-color:var(--green); }


/* ── CARD STYLE — driven by body[data-card-style] ───────────────────────── */
body[data-card-style="solid"] .summary-card,
body[data-card-style="solid"] .stat-card,
body[data-card-style="solid"] .weight-log-card,
body[data-card-style="solid"] .meal-prep-card,
body[data-card-style="solid"] .workout-today,
body[data-card-style="solid"] .workout-detail-card,
body[data-card-style="solid"] .log-entry,
body[data-card-style="solid"] .result-card,
body[data-card-style="solid"] .input-card,
body[data-card-style="solid"] .manual-entry,
body[data-card-style="solid"] .settings-section {
  background:var(--surface)!important;
  backdrop-filter:none!important;
  border-color:var(--border)!important;
}

body[data-card-style="outline"] .summary-card,
body[data-card-style="outline"] .stat-card,
body[data-card-style="outline"] .weight-log-card,
body[data-card-style="outline"] .meal-prep-card,
body[data-card-style="outline"] .workout-today,
body[data-card-style="outline"] .workout-detail-card,
body[data-card-style="outline"] .log-entry,
body[data-card-style="outline"] .result-card,
body[data-card-style="outline"] .input-card,
body[data-card-style="outline"] .manual-entry,
body[data-card-style="outline"] .settings-section {
  background:transparent!important;
  backdrop-filter:none!important;
  border:1.5px solid var(--border)!important;
  box-shadow:none!important;
}

/* ── CARD DENSITY — driven by body[data-card-density] ───────────────────── */
body[data-card-density="compact"] .summary-card,
body[data-card-density="compact"] .weight-log-card,
body[data-card-density="compact"] .workout-today { padding:14px!important; }

body[data-card-density="compact"] .stat-card,
body[data-card-density="compact"] .meal-prep-card,
body[data-card-density="compact"] .workout-detail-card,
body[data-card-density="compact"] .settings-section { padding:12px!important; }

body[data-card-density="compact"] .log-entry { padding:8px 10px!important; }
body[data-card-density="compact"] .input-card { padding:14px 12px!important; gap:10px!important; }
body[data-card-density="compact"] .manual-entry { padding:14px!important; }
body[data-card-density="compact"] .cal-num { font-size:40px!important; }
body[data-card-density="compact"] .macro-bars { gap:7px!important; }

/* ── CARD GLOW — driven by body[data-card-glow] ─────────────────────────── */
body[data-card-glow="false"] .summary-card,
body[data-card-glow="false"] .stat-card,
body[data-card-glow="false"] .weight-log-card,
body[data-card-glow="false"] .meal-prep-card,
body[data-card-glow="false"] .workout-today,
body[data-card-glow="false"] .workout-detail-card,
body[data-card-glow="false"] .log-entry,
body[data-card-glow="false"] .result-card,
body[data-card-glow="false"] .settings-section {
  box-shadow:var(--shadow-sm)!important;
}
body[data-card-glow="false"] .bar-fill { box-shadow:none!important; }
body[data-card-glow="false"] .btn-primary,
body[data-card-glow="false"] .login-btn,
body[data-card-glow="false"] .settings-save-btn,
body[data-card-glow="false"] .weight-log-btn,
body[data-card-glow="false"] .workout-library-btn,
body[data-card-glow="false"] .workout-complete-btn,
body[data-card-glow="false"] .result-add-btn,
body[data-card-glow="false"] .manual-submit { box-shadow:none!important; }

/* ── SMART PLAN PICKER PILLS ─────────────────────────────────────────────── */
.spm-pill {
  padding: 11px 14px; border-radius: 12px;
  border: 1.5px solid var(--border);
  background: var(--surface2); color: var(--muted);
  font-family: 'DM Mono', monospace; font-size: 11px;
  letter-spacing: .4px; cursor: pointer; transition: all .15s ease;
  text-align: center; width: 100%;
}
.spm-pill.selected {
  border-color: var(--green); background: var(--green-dim); color: var(--green);
}
.spm-pill:hover:not(.selected) { border-color: rgba(255,255,255,0.2); color: var(--white); }
.spm-pill:active { transform: scale(.96); }
