/*
 * ═══════════════════════════════════════════════════════════════
 * BOOST IT UP — Design System CSS
 * Wersja: 2026-02-22
 * ═══════════════════════════════════════════════════════════════
 *
 * TEN PLIK JEST ŹRÓDŁEM PRAWDY DLA WSZYSTKICH STYLÓW.
 * NIE MODYFIKUJ wartości tokenów, kolorów, spacingu, radiusów,
 * fontów ani komponentów bez aktualizacji tego pliku.
 *
 * Struktura:
 *   1. Fonty (Google Fonts import)
 *   2. Tokeny globalne (:root) — typo, transitions, z-index
 *   3. Tryby kolorów (4 warianty: dark/light × front/back)
 *   4. Reset & Base
 *   5. Komponenty
 *   6. Responsive breakpoints
 *
 * Użycie:
 *   <link rel="stylesheet" href="boost-design-system.css">
 *   <body data-theme="dark" data-view="front">
 *
 * SVG Gradienty:
 *   Wklej boost-svg-defs.html na początku <body> — zawiera
 *   definicje gradientów #ph, #ph-soft, #green-g dla ikon.
 * ═══════════════════════════════════════════════════════════════
 */

/* ════════════════════════════════════════════════
   CSS CUSTOM PROPERTIES — 4 tryby
   data-theme="dark"  data-view="front"  → Orange Fire Dark
   data-theme="light" data-view="front"  → Orange Fire Light
   data-theme="dark"  data-view="back"   → Violet Admin Dark
   data-theme="light" data-view="back"   → Violet Admin Light
════════════════════════════════════════════════ */

:root {
  --mono: 'JetBrains Mono', monospace;
  --f: 'Outfit', sans-serif;
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --radius-xl: 18px;
  /* spacing scale */
  --sp1: 4px; --sp2: 8px; --sp3: 12px; --sp4: 16px;
  --sp5: 24px; --sp6: 32px; --sp7: 48px; --sp8: 64px;
}

/* ── DARK FRONT ── */
[data-theme="dark"][data-view="front"],
[data-theme="dark"] .view-front {
  --bg:     #070508;
  --surf:   #110d14;
  --elev:   #1a1520;
  --bdr:    rgba(255,255,255,0.07);
  --bdr2:   rgba(255,255,255,0.12);
  --nav:    #090610;
  --txt:    rgba(255,244,232,0.92);
  --txt2:   rgba(255,244,232,0.5);
  --txt3:   rgba(255,244,232,0.25);
  --acc:    #ff4d00;
  --acc-rgb: 255,77,0;
  --grad:   linear-gradient(135deg, #ff4d00, #ff8c00, #ffd700);
  --grad-t: linear-gradient(135deg, #ff4d00 0%, #ff8c00 50%, #ffd700 100%);
  --success: #10b981; --success-bg: rgba(16,185,129,0.08); --success-bdr: rgba(16,185,129,0.2);
  --warn:   #f59e0b;  --warn-bg:    rgba(245,158,11,0.08);  --warn-bdr:   rgba(245,158,11,0.2);
  --error:  #ef4444;  --error-bg:   rgba(239,68,68,0.08);   --error-bdr:  rgba(239,68,68,0.2);
  --info:   #60a5fa;  --info-bg:    rgba(96,165,250,0.08);  --info-bdr:   rgba(96,165,250,0.2);
  --input-bg: rgba(255,255,255,0.04);
  --input-bdr: rgba(255,255,255,0.1);
  --input-focus: rgba(255,77,0,0.4);
  --placeholder: rgba(255,244,232,0.25);
  --shadow: 0 24px 80px rgba(0,0,0,0.7);
}

/* ── LIGHT FRONT ── */
[data-theme="light"][data-view="front"],
[data-theme="light"] .view-front {
  --bg:     #faf7f3;
  --surf:   #ffffff;
  --elev:   #f2ede6;
  --bdr:    rgba(0,0,0,0.07);
  --bdr2:   rgba(0,0,0,0.12);
  --nav:    #ffffff;
  --txt:    rgba(25,10,0,0.9);
  --txt2:   rgba(25,10,0,0.5);
  --txt3:   rgba(25,10,0,0.25);
  --acc:    #e63e00;
  --acc-rgb: 230,62,0;
  --grad:   linear-gradient(135deg, #e63e00, #f07800, #f0b800);
  --grad-t: linear-gradient(135deg, #e63e00 0%, #f07800 50%, #f0b800 100%);
  --success: #059669; --success-bg: rgba(5,150,105,0.08); --success-bdr: rgba(5,150,105,0.25);
  --warn:   #d97706;  --warn-bg:    rgba(217,119,6,0.08);  --warn-bdr:   rgba(217,119,6,0.25);
  --error:  #dc2626;  --error-bg:   rgba(220,38,38,0.08);  --error-bdr:  rgba(220,38,38,0.25);
  --info:   #2563eb;  --info-bg:    rgba(37,99,235,0.08);  --info-bdr:   rgba(37,99,235,0.25);
  --input-bg: rgba(0,0,0,0.03);
  --input-bdr: rgba(0,0,0,0.12);
  --input-focus: rgba(230,62,0,0.35);
  --placeholder: rgba(25,10,0,0.3);
  --shadow: 0 24px 80px rgba(0,0,0,0.1);
}

/* ── DARK BACK ── */
[data-theme="dark"][data-view="back"],
[data-theme="dark"] .view-back {
  --bg:     #06050a;
  --surf:   #0e0c15;
  --elev:   #161320;
  --bdr:    rgba(255,255,255,0.07);
  --bdr2:   rgba(255,255,255,0.12);
  --nav:    #080612;
  --txt:    rgba(240,236,255,0.92);
  --txt2:   rgba(200,190,240,0.5);
  --txt3:   rgba(200,190,240,0.25);
  --acc:    #7c3aed;
  --acc-rgb: 124,58,237;
  --grad:   linear-gradient(135deg, #7c3aed, #9d4edd, #c084fc);
  --grad-t: linear-gradient(135deg, #7c3aed 0%, #9d4edd 50%, #c084fc 100%);
  --success: #10b981; --success-bg: rgba(16,185,129,0.08); --success-bdr: rgba(16,185,129,0.2);
  --warn:   #f59e0b;  --warn-bg:    rgba(245,158,11,0.08);  --warn-bdr:   rgba(245,158,11,0.2);
  --error:  #ef4444;  --error-bg:   rgba(239,68,68,0.08);   --error-bdr:  rgba(239,68,68,0.2);
  --info:   #60a5fa;  --info-bg:    rgba(96,165,250,0.08);  --info-bdr:   rgba(96,165,250,0.2);
  --input-bg: rgba(255,255,255,0.04);
  --input-bdr: rgba(255,255,255,0.1);
  --input-focus: rgba(124,58,237,0.5);
  --placeholder: rgba(200,190,240,0.3);
  --shadow: 0 24px 80px rgba(0,0,0,0.7);
}

/* ── LIGHT BACK ── */
[data-theme="light"][data-view="back"],
[data-theme="light"] .view-back {
  --bg:     #f5f3ff;
  --surf:   #ffffff;
  --elev:   #ede9fe;
  --bdr:    rgba(109,40,217,0.1);
  --bdr2:   rgba(109,40,217,0.18);
  --nav:    #ffffff;
  --txt:    rgba(15,5,40,0.9);
  --txt2:   rgba(55,30,100,0.55);
  --txt3:   rgba(55,30,100,0.28);
  --acc:    #6d28d9;
  --acc-rgb: 109,40,217;
  --grad:   linear-gradient(135deg, #6d28d9, #8b5cf6, #a78bfa);
  --grad-t: linear-gradient(135deg, #6d28d9 0%, #8b5cf6 50%, #a78bfa 100%);
  --success: #059669; --success-bg: rgba(5,150,105,0.08); --success-bdr: rgba(5,150,105,0.25);
  --warn:   #d97706;  --warn-bg:    rgba(217,119,6,0.08);  --warn-bdr:   rgba(217,119,6,0.25);
  --error:  #dc2626;  --error-bg:   rgba(220,38,38,0.08);  --error-bdr:  rgba(220,38,38,0.25);
  --info:   #2563eb;  --info-bg:    rgba(37,99,235,0.08);  --info-bdr:   rgba(37,99,235,0.25);
  --input-bg: rgba(109,40,217,0.03);
  --input-bdr: rgba(109,40,217,0.15);
  --input-focus: rgba(109,40,217,0.4);
  --placeholder: rgba(55,30,100,0.3);
  --shadow: 0 24px 80px rgba(109,40,217,0.08);
}

/* ════ RESET & BASE ════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
  font-family: var(--f);
  background: var(--bg);
  color: var(--txt);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  transition: background 0.35s, color 0.35s;
}

body::before {
  content: '';
  position: fixed; inset: 0; pointer-events: none; z-index: 9999;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");
}
[data-theme="light"] body::before { opacity: 0; }

/* ════ PAGE HEADER ════ */
/* Spec: boost-panel-layout-prompt.md + boost-page-layout-guide-mockup.html sekcja 02 */
.page-header { display:flex; align-items:flex-start; gap:16px; margin-bottom:24px; }
.page-header svg { flex-shrink:0; }
.page-header .ph-body { display:flex; flex-direction:column; gap:4px; }
.page-header .ph-body h2 { font-size:24px; font-weight:700; letter-spacing:-0.5px; color:var(--txt); line-height:1.2; margin:0; }
.page-header .ph-body h2 .grad { background:var(--grad-t); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.page-header .ph-body p { font-size:14px; color:var(--txt2); font-weight:400; margin:0; }
.page-container { max-width:1160px; margin:0 auto; padding:32px 28px 60px; }
.page-container.narrow { max-width:900px; }

/* ════ CONTROL BAR ════ */
.ctrl-bar {
  position: sticky; top: 0; z-index: 500;
  background: var(--nav);
  border-bottom: 1px solid var(--bdr);
  backdrop-filter: blur(24px);
  padding: 0 24px; height: 54px;
  display: flex; align-items: center; gap: 12px;
  transition: background 0.35s, border-color 0.35s;
}
.ctrl-logo {
  font-weight: 800; font-size: 15px; letter-spacing: -0.5px;
  background: var(--grad-t); -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  flex-shrink: 0;
}
.ctrl-sep { width: 1px; height: 18px; background: var(--bdr2); }
.ctrl-version {
  font-family: var(--mono); font-size: 9px; font-weight: 700;
  letter-spacing: 2px; text-transform: uppercase; color: var(--txt3);
}
.ctrl-sp { flex: 1; }

/* Toggle group */
.tgl-group {
  display: flex; align-items: center; gap: 3px;
  background: var(--elev); border: 1px solid var(--bdr);
  border-radius: 11px; padding: 3px;
}
.tgl-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 14px; border-radius: 8px; border: none; cursor: pointer;
  font-family: var(--f); font-size: 12px; font-weight: 700;
  color: var(--txt3); background: transparent;
  transition: all 0.22s;
}
.tgl-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.tgl-dot-o { background: #ff5520; }
.tgl-dot-v { background: #8b5cf6; }

.tgl-btn.act-front { background: rgba(255,77,0,0.12); border: 1px solid rgba(255,77,0,0.22); color: rgba(255,180,80,0.95); }
.tgl-btn.act-front .tgl-dot-o { box-shadow: 0 0 8px rgba(255,80,0,0.7); animation: bdot 2s infinite; }
.tgl-btn.act-back  { background: rgba(124,58,237,0.12); border: 1px solid rgba(124,58,237,0.25); color: rgba(180,150,255,0.95); }
.tgl-btn.act-back  .tgl-dot-v { box-shadow: 0 0 8px rgba(139,92,246,0.7); animation: bdot 2s infinite; }
.tgl-btn:not(.act-front):not(.act-back) { border: 1px solid transparent; }

[data-theme="light"] .tgl-btn.act-front { background: rgba(230,62,0,0.1); color: rgba(180,50,0,0.9); }
[data-theme="light"] .tgl-btn.act-back  { background: rgba(109,40,217,0.1); color: rgba(80,20,180,0.9); }

@keyframes bdot { 0%,100%{opacity:1} 50%{opacity:0.4} }

/* Theme toggle */
.theme-tgl {
  display: flex; align-items: center; gap: 7px;
  padding: 7px 14px; border-radius: 9px; border: 1px solid var(--bdr2);
  background: var(--surf); cursor: pointer;
  font-family: var(--f); font-size: 12px; font-weight: 600;
  color: var(--txt2);
  transition: all 0.22s;
}
.theme-tgl:hover { border-color: var(--bdr2); color: var(--txt); background: var(--elev); }
.theme-icon { font-size: 14px; }

/* ════ VIEWS ════ */
.view { display: none; }
.view.visible { display: block; }

/* ════ SECTION WRAPPER ════ */
.section {
  max-width: 1160px; margin: 0 auto;
  padding: 36px 28px 0;
}
.section:last-child { padding-bottom: 56px; }
.section + .section { padding-top: 48px; }

.sec-hdr {
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 24px;
}
.sec-eye {
  font-family: var(--mono); font-size: 9px; font-weight: 700;
  letter-spacing: 3px; text-transform: uppercase;
  color: var(--txt3);
}
.sec-hdr::after { content: ''; flex: 1; height: 1px; background: var(--bdr); }
.sec-title {
  font-weight: 800; font-size: 20px; letter-spacing: -0.5px;
  color: var(--txt); margin-bottom: 6px;
}
.sec-sub { font-size: 13px; color: var(--txt2); margin-bottom: 24px; }

/* ════════════════════════════════
   1. TYPOGRAFIA
════════════════════════════════ */
.type-grid { display: flex; flex-direction: column; gap: 6px; }
.type-row {
  display: flex; align-items: baseline; gap: 20px;
  padding: 14px 18px; border-radius: var(--radius-md);
  background: var(--surf); border: 1px solid var(--bdr);
  transition: background 0.3s, border-color 0.3s;
}
.type-meta {
  min-width: 180px; flex-shrink: 0;
  font-family: var(--mono); font-size: 9px; font-weight: 700;
  letter-spacing: 1.5px; text-transform: uppercase; color: var(--txt3);
  display: flex; flex-direction: column; gap: 3px;
}
.type-meta strong { color: var(--txt2); font-size: 10px; }
.t-display { font-weight: 800; font-size: 48px; letter-spacing: -2px; line-height: 1; color: var(--txt); }
.t-h1      { font-weight: 800; font-size: 32px; letter-spacing: -1px; color: var(--txt); }
.t-h2      { font-weight: 700; font-size: 24px; letter-spacing: -0.5px; color: var(--txt); }
.t-h3      { font-weight: 700; font-size: 18px; letter-spacing: -0.3px; color: var(--txt); }
.t-h4      { font-weight: 600; font-size: 15px; color: var(--txt); }
.t-body    { font-weight: 400; font-size: 14px; line-height: 1.7; color: var(--txt2); }
.t-small   { font-weight: 500; font-size: 12px; color: var(--txt2); }
.t-label   { font-family: var(--mono); font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--txt3); }
.t-grad { background: var(--grad-t); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }

/* ════════════════════════════════
   2. SPACING
════════════════════════════════ */
.spacing-row {
  display: flex; align-items: flex-end; gap: 10px; flex-wrap: wrap;
}
.sp-block-wrap { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.sp-block {
  background: var(--grad); border-radius: 4px; opacity: 0.7;
  min-width: 4px;
}
.sp-lbl { font-family: var(--mono); font-size: 9px; font-weight: 700; color: var(--txt3); text-align: center; }

/* ════════════════════════════════
   3. BUTTONY
════════════════════════════════ */
.btn-demo-grid {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px;
}
.btn-demo-col { display: flex; flex-direction: column; gap: 8px; }
.btn-demo-col-lbl {
  font-family: var(--mono); font-size: 9px; font-weight: 700;
  letter-spacing: 2px; text-transform: uppercase; color: var(--txt3);
  text-align: center; margin-bottom: 4px;
}

.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 7px;
  padding: 10px 20px; border-radius: var(--radius-md); border: none; cursor: pointer;
  font-family: var(--f); font-size: 13px; font-weight: 700;
  transition: all 0.18s; position: relative; overflow: hidden;
  text-decoration: none; white-space: nowrap;
}
.btn-full { width: 100%; }

/* Primary */
.btn-primary {
  background: var(--grad); color: #fff;
  box-shadow: 0 4px 18px rgba(var(--acc-rgb),0.3);
}
.btn-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 28px rgba(var(--acc-rgb),0.45);
}
.btn-primary:active { transform: translateY(0); box-shadow: 0 2px 10px rgba(var(--acc-rgb),0.3); }

/* Ghost */
.btn-ghost {
  background: var(--surf); border: 1px solid var(--bdr2);
  color: var(--txt2);
}
.btn-ghost:hover { border-color: rgba(var(--acc-rgb),0.4); color: var(--txt); background: var(--elev); }
.btn-ghost:active { background: var(--surf); }

/* Outline */
.btn-outline {
  background: transparent; border: 1.5px solid rgba(var(--acc-rgb),0.5);
  color: var(--txt);
}
.btn-outline:hover { background: rgba(var(--acc-rgb),0.08); border-color: rgba(var(--acc-rgb),0.8); }

/* Disabled */
.btn-disabled,
.btn:disabled {
  background: var(--elev); border: 1px solid var(--bdr);
  color: var(--txt3); cursor: not-allowed; pointer-events: none;
  box-shadow: none; transform: none;
}

/* Loading */
.btn-loading {
  background: var(--grad); color: rgba(255,255,255,0.7);
  cursor: wait; pointer-events: none;
}
.btn-loading::after {
  content: '';
  position: absolute; right: 14px;
  width: 14px; height: 14px; border-radius: 50%;
  border: 2px solid rgba(255,255,255,0.25);
  border-top-color: rgba(255,255,255,0.8);
  animation: spin 0.7s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* Danger */
.btn-danger { background: var(--error-bg); border: 1px solid var(--error-bdr); color: var(--error); }
.btn-danger:hover { background: rgba(239,68,68,0.15); }

/* Sizes */
.btn-sm { padding: 6px 14px; font-size: 12px; border-radius: var(--radius-sm); }
.btn-lg { padding: 13px 28px; font-size: 15px; border-radius: var(--radius-lg); }

/* Icon button */
.btn-icon {
  width: 38px; height: 38px; padding: 0; border-radius: var(--radius-md);
  background: var(--surf); border: 1px solid var(--bdr2); color: var(--txt2);
}
.btn-icon:hover { border-color: rgba(var(--acc-rgb),0.4); color: var(--txt); }

/* ════════════════════════════════
   4. FORMULARZE
════════════════════════════════ */
.form-demo { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.form-demo-wide { grid-column: span 2; }

.field { display: flex; flex-direction: column; gap: 6px; }
.field-label {
  font-family: var(--mono); font-size: 10px; font-weight: 700;
  letter-spacing: 1.5px; text-transform: uppercase; color: var(--txt2);
}
.field-hint { font-size: 11px; color: var(--txt3); }

.input {
  background: var(--input-bg); border: 1.5px solid var(--input-bdr);
  border-radius: var(--radius-md); padding: 10px 14px;
  font-family: var(--f); font-size: 14px; font-weight: 400;
  color: var(--txt); outline: none;
  transition: border-color 0.2s, box-shadow 0.2s, background 0.3s;
  width: 100%;
}
.input::placeholder { color: var(--placeholder); }
.input:focus {
  border-color: rgba(var(--acc-rgb),0.6);
  box-shadow: 0 0 0 3px rgba(var(--acc-rgb),0.12);
  background: var(--surf);
}
.input.error { border-color: var(--error-bdr); box-shadow: 0 0 0 3px var(--error-bg); }
.input.success { border-color: var(--success-bdr); box-shadow: 0 0 0 3px var(--success-bg); }

/* input with icon */
.input-wrap { position: relative; }
.input-wrap .input { padding-left: 38px; }
.input-icon {
  position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
  color: var(--txt3); pointer-events: none;
}
.input-wrap .input-action {
  position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
  background: none; border: none; cursor: pointer; color: var(--txt3);
  padding: 2px; border-radius: 4px; transition: color 0.15s;
}
.input-wrap .input-action:hover { color: var(--txt); }

/* Select */
.select-wrap { position: relative; }
.select-wrap::after {
  content: ''; position: absolute; right: 13px; top: 50%; transform: translateY(-50%);
  width: 0; height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid var(--txt3);
  pointer-events: none;
}
select.input { -webkit-appearance: none; appearance: none; padding-right: 36px; cursor: pointer; }

/* Textarea */
textarea.input { resize: vertical; min-height: 88px; }

/* Checkbox & Radio */
.check-group { display: flex; flex-direction: column; gap: 10px; }
.check-row { display: flex; align-items: center; gap: 10px; cursor: pointer; }
.check-row input { display: none; }
.check-box {
  width: 18px; height: 18px; border-radius: 5px; flex-shrink: 0;
  background: var(--input-bg); border: 1.5px solid var(--input-bdr);
  display: flex; align-items: center; justify-content: center;
  transition: all 0.18s;
}
.check-row input:checked + .check-box {
  background: var(--grad); border-color: transparent;
  box-shadow: 0 0 0 3px rgba(var(--acc-rgb),0.15);
}
.check-box svg { opacity: 0; transition: opacity 0.15s; }
.check-row input:checked + .check-box svg { opacity: 1; }
.check-lbl { font-size: 13px; color: var(--txt2); }
.check-row:hover .check-lbl { color: var(--txt); }

.radio-box {
  width: 18px; height: 18px; border-radius: 50%; flex-shrink: 0;
  background: var(--input-bg); border: 1.5px solid var(--input-bdr);
  display: flex; align-items: center; justify-content: center;
  transition: all 0.18s;
}
.check-row input:checked + .radio-box {
  background: transparent; border-color: var(--acc);
  box-shadow: 0 0 0 3px rgba(var(--acc-rgb),0.15);
}
.radio-inner {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--acc); opacity: 0; transform: scale(0);
  transition: all 0.18s;
}
.check-row input:checked + .radio-box .radio-inner { opacity: 1; transform: scale(1); }

/* Field validation */
.field-error { font-size: 11px; color: var(--error); display: flex; align-items: center; gap: 5px; }
.field-ok    { font-size: 11px; color: var(--success); display: flex; align-items: center; gap: 5px; }

/* Toggle switch */
.switch { display: flex; align-items: center; gap: 10px; cursor: pointer; }
.switch input { display: none; }
.switch-track {
  width: 40px; height: 22px; border-radius: 11px;
  background: var(--elev); border: 1.5px solid var(--bdr2);
  position: relative; transition: all 0.22s; flex-shrink: 0;
}
.switch-thumb {
  position: absolute; top: 2px; left: 2px;
  width: 14px; height: 14px; border-radius: 50%;
  background: var(--txt3); transition: all 0.22s;
}
.switch input:checked + .switch-track { background: var(--grad); border-color: transparent; }
.switch input:checked + .switch-track .switch-thumb { left: 20px; background: #fff; }
.switch-lbl { font-size: 13px; color: var(--txt2); }

/* ════════════════════════════════
   5. TOASTY
════════════════════════════════ */
.toast-stack { display: flex; flex-direction: column; gap: 8px; }
.toast {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 12px 16px; border-radius: var(--radius-md);
  border: 1px solid; backdrop-filter: blur(12px);
  position: relative; overflow: hidden;
  animation: toast-in 0.4s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}
@keyframes toast-in {
  from { opacity: 0; transform: translateX(20px); }
  to   { opacity: 1; transform: translateX(0); }
}
.toast::before {
  content: ''; position: absolute; top: 0; left: 0; bottom: 0; width: 3px;
  background: currentColor; opacity: 0.7;
}
.toast-success { background: var(--success-bg); border-color: var(--success-bdr); color: var(--success); }
.toast-warn    { background: var(--warn-bg);    border-color: var(--warn-bdr);    color: var(--warn); }
.toast-error   { background: var(--error-bg);   border-color: var(--error-bdr);   color: var(--error); }
.toast-info    { background: var(--info-bg);     border-color: var(--info-bdr);    color: var(--info); }

.toast-icon { flex-shrink: 0; margin-top: 1px; }
.toast-body { flex: 1; }
.toast-title { font-size: 13px; font-weight: 700; color: var(--txt); margin-bottom: 2px; }
.toast-msg   { font-size: 12px; color: var(--txt2); line-height: 1.5; }
.toast-close {
  background: none; border: none; cursor: pointer;
  color: var(--txt3); padding: 2px; border-radius: 4px;
  transition: color 0.15s; flex-shrink: 0;
}
.toast-close:hover { color: var(--txt); }
.toast-time {
  position: absolute; bottom: 0; left: 0; right: 0; height: 2px;
  background: currentColor; opacity: 0.3;
  transform-origin: left;
  animation: toast-bar 5s linear forwards;
}
@keyframes toast-bar { from { transform: scaleX(1); } to { transform: scaleX(0); } }

/* ════════════════════════════════
   6. EMPTY STATES
════════════════════════════════ */
.empty-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }
.empty {
  background: var(--surf); border: 1px solid var(--bdr);
  border-radius: var(--radius-lg); padding: 36px 24px;
  display: flex; flex-direction: column; align-items: center;
  text-align: center; gap: 12px;
  transition: background 0.3s, border-color 0.3s;
}
.empty-icon-wrap {
  width: 56px; height: 56px; border-radius: 16px;
  background: rgba(var(--acc-rgb),0.08); border: 1px solid rgba(var(--acc-rgb),0.15);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 4px;
}
.empty-title { font-weight: 700; font-size: 15px; color: var(--txt); }
.empty-sub   { font-size: 12px; color: var(--txt2); line-height: 1.6; }

/* ════════════════════════════════
   7. RESPONSIVE PREVIEW
════════════════════════════════ */
.phone-frame {
  width: 390px; margin: 0 auto;
  background: var(--bg); border-radius: 44px;
  border: 2px solid var(--bdr2);
  box-shadow: 0 32px 100px rgba(0,0,0,0.5), inset 0 0 0 6px var(--nav);
  overflow: hidden; position: relative;
}
[data-theme="light"] .phone-frame { box-shadow: 0 32px 100px rgba(0,0,0,0.15), inset 0 0 0 6px var(--nav); }
.phone-notch {
  width: 120px; height: 30px; background: var(--nav);
  border-radius: 0 0 20px 20px; margin: 0 auto 0;
  display: flex; align-items: center; justify-content: center; gap: 6px;
}
.phone-notch-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--elev); }
.phone-inner { overflow-y: auto; max-height: 700px; }
.phone-inner::-webkit-scrollbar { display: none; }

/* Inside phone — mini nav */
.ph-nav {
  background: var(--nav); border-bottom: 1px solid var(--bdr);
  padding: 0 16px; height: 44px;
  display: flex; align-items: center; gap: 3px;
}
.ph-logo-b {
  width: 24px; height: 24px; border-radius: 6px; background: var(--grad);
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 11px; color: #fff; margin-right: 8px;
  flex-shrink: 0;
}
.ph-logo-name { font-weight: 700; font-size: 13px; color: var(--txt); flex-shrink: 0; }
.ph-sp { flex: 1; }
.ph-pill {
  font-family: var(--mono); font-size: 9px; font-weight: 600;
  padding: 2px 7px; border-radius: 4px;
  color: rgba(var(--acc-rgb),0.7); background: rgba(var(--acc-rgb),0.08);
  border: 1px solid rgba(var(--acc-rgb),0.15);
}

/* phone hero */
.ph-hero {
  background: var(--bg); padding: 24px 18px 20px; text-align: center;
  position: relative; overflow: hidden;
}
.ph-hero::before {
  content: '';
  position: absolute; width: 300px; height: 150px;
  background: radial-gradient(ellipse, rgba(var(--acc-rgb),0.06) 0%, transparent 70%);
  top: 0; left: 50%; transform: translateX(-50%);
  pointer-events: none;
}
.ph-eye {
  font-family: var(--mono); font-size: 8px; font-weight: 700;
  letter-spacing: 2.5px; text-transform: uppercase;
  color: rgba(var(--acc-rgb),0.5); margin-bottom: 8px;
}
.ph-h1 { font-weight: 700; font-size: 24px; letter-spacing: -0.5px; color: var(--txt); margin-bottom: 6px; }
.ph-sub { font-size: 12px; color: var(--txt2); }

.ph-body { background: var(--bg); padding: 0 14px 24px; }
.ph-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: -4px; }

.ph-pkg {
  background: var(--surf); border: 1px solid var(--bdr);
  border-radius: 12px; padding: 14px 12px;
  position: relative; overflow: hidden;
}
.ph-pkg::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: rgba(255,255,255,0.04); }
.ph-pkg.feat::before { background: var(--grad); }
.ph-pkg.feat { border-color: rgba(var(--acc-rgb),0.18); }
.ph-pkg-badge { position: absolute; top: 0; right: 0; background: var(--grad); color: #fff; font-family: var(--mono); font-size: 7px; font-weight: 700; padding: 3px 8px; border-radius: 0 0 0 8px; }
.ph-pkg-icon { width: 18px; height: 18px; margin-bottom: 8px; }
.ph-pkg-icon-mt { margin-top: 12px; }
.ph-pkg-name { font-weight: 700; font-size: 15px; color: var(--txt); margin-bottom: 1px; }
.ph-pkg-desc { font-size: 11px; color: var(--txt2); margin-bottom: 8px; }
.ph-pkg-div  { height: 1px; background: var(--bdr); margin-bottom: 8px; }
.ph-pkg-bonus {
  font-family: var(--mono); font-size: 8px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  display: inline-block; padding: 2px 7px; border-radius: 4px; margin-bottom: 6px;
}
.ph-b-neg  { background: rgba(255,80,80,0.07);  border: 1px solid rgba(255,80,80,0.15);  color: rgba(255,140,120,0.8); }
.ph-b-std  { background: rgba(255,255,255,0.04); border: 1px solid var(--bdr); color: var(--txt3); }
.ph-b-plus { background: rgba(255,200,50,0.06); border: 1px solid rgba(255,200,50,0.15); color: rgba(255,210,80,0.8); }
.ph-b-gold { background: rgba(255,215,0,0.08);  border: 1px solid rgba(255,215,0,0.2);  color: rgba(255,220,80,0.9); }
.ph-mbt-num { font-weight: 800; font-size: 18px; letter-spacing: -0.5px; color: var(--txt); }
.ph-pkg.feat .ph-mbt-num { background: var(--grad-t); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
.ph-mbt-lbl { font-family: var(--mono); font-size: 9px; color: var(--txt3); }
.ph-price   { font-weight: 700; font-size: 13px; color: var(--txt2); }
.ph-rate    { font-family: var(--mono); font-size: 9px; color: var(--txt3); margin-bottom: 10px; }
.ph-btn {
  width: 100%; padding: 8px; border-radius: 7px; border: none; cursor: pointer;
  font-family: var(--f); font-size: 11px; font-weight: 700;
}
.ph-btn-ghost { background: var(--elev); border: 1px solid var(--bdr); color: var(--txt2); }
.ph-btn-fire  { background: var(--grad); color: #fff; box-shadow: 0 3px 12px rgba(var(--acc-rgb),0.3); }

/* Phone bottom nav */
.ph-bottom-nav {
  background: var(--nav); border-top: 1px solid var(--bdr);
  padding: 10px 0 20px;
  display: flex; justify-content: space-around;
}
.ph-bnav-item {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  flex: 1;
}
.ph-bnav-icon { opacity: 0.35; transition: opacity 0.15s; }
.ph-bnav-item.on .ph-bnav-icon { opacity: 1; }
.ph-bnav-lbl { font-size: 9px; font-weight: 600; color: var(--txt3); }
.ph-bnav-item.on .ph-bnav-lbl { color: var(--txt); }

/* ════ CARD ════ */
.card {
  background: var(--surf); border: 1px solid var(--bdr);
  border-radius: var(--radius-lg); overflow: hidden;
  transition: background 0.3s, border-color 0.3s;
}
.card-hdr {
  padding: 14px 18px 12px; border-bottom: 1px solid var(--bdr);
  display: flex; align-items: center; justify-content: space-between;
}
.card-title { font-weight: 700; font-size: 14px; color: var(--txt); }
.card-body  { padding: 18px; }

/* ════════════════════════════════
   8. MODAL
════════════════════════════════ */
.modal-overlay {
  position: fixed; inset: 0; z-index: 900;
  background: rgba(0,0,0,0.65); backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  opacity: 0; pointer-events: none;
  transition: opacity 0.22s;
}
.modal-overlay.open { opacity: 1; pointer-events: all; }

.modal {
  background: var(--surf); border: 1px solid var(--bdr2);
  border-radius: var(--radius-xl);
  box-shadow: 0 32px 80px rgba(0,0,0,0.6);
  width: 100%; max-width: 480px;
  transform: translateY(16px) scale(0.97);
  transition: transform 0.25s cubic-bezier(0.34,1.56,0.64,1);
}
.modal-overlay.open .modal { transform: translateY(0) scale(1); }

.modal-hdr {
  padding: 20px 22px 16px;
  border-bottom: 1px solid var(--bdr);
  display: flex; align-items: flex-start; justify-content: space-between; gap: 12px;
}
.modal-title { font-weight: 700; font-size: 16px; letter-spacing: -0.3px; color: var(--txt); }
.modal-sub   { font-size: 12px; color: var(--txt2); margin-top: 3px; }
.modal-close {
  background: none; border: none; cursor: pointer; color: var(--txt3);
  padding: 4px; border-radius: 6px; transition: color 0.15s; flex-shrink: 0;
}
.modal-close:hover { color: var(--txt); background: var(--elev); }
.modal-body  { padding: 20px 22px; }
.modal-footer {
  padding: 14px 22px 20px;
  border-top: 1px solid var(--bdr);
  display: flex; justify-content: flex-end; gap: 8px;
}

/* Modal variants */
.modal-danger .modal-hdr { border-bottom-color: rgba(239,68,68,0.15); }
.modal-danger .modal-title { color: var(--error); }
.modal-icon-wrap {
  width: 48px; height: 48px; border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; margin-bottom: 14px;
}
.modal-icon-danger { background: var(--error-bg); border: 1px solid var(--error-bdr); }
.modal-icon-info   { background: var(--info-bg);  border: 1px solid var(--info-bdr); }
.modal-icon-warn   { background: var(--warn-bg);  border: 1px solid var(--warn-bdr); }

/* ════════════════════════════════
   9. TABELA z paginacją
════════════════════════════════ */
.data-table-wrap { overflow-x: auto; }
.data-table {
  width: 100%; border-collapse: collapse;
  font-size: 13px;
}
.data-table thead th {
  font-family: var(--mono); font-size: 9px; font-weight: 700;
  letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--txt3); text-align: left;
  padding: 0 12px 10px;
  border-bottom: 1px solid var(--bdr);
  white-space: nowrap; cursor: pointer;
  user-select: none;
  transition: color 0.15s;
}
.data-table thead th:hover { color: var(--txt2); }
.data-table thead th.sort-asc::after  { content: ' ↑'; opacity: 0.7; }
.data-table thead th.sort-desc::after { content: ' ↓'; opacity: 0.7; }

.data-table tbody tr {
  border-bottom: 1px solid rgba(255,255,255,0.03);
  transition: background 0.12s;
}
.data-table tbody tr:hover { background: rgba(var(--acc-rgb),0.04); }
.data-table tbody tr:last-child { border-bottom: none; }
.data-table td {
  padding: 11px 12px; color: var(--txt2);
  font-weight: 500; vertical-align: middle;
}
.data-table td.td-name  { color: var(--txt); font-weight: 600; }
.data-table td.td-mono  { font-family: var(--mono); font-size: 11px; color: var(--txt3); }
.data-table td.td-hi    {
  font-weight: 800; font-size: 14px;
  background: var(--grad-t); -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.data-table td.td-num   { font-family: var(--mono); font-size: 12px; font-weight: 600; color: var(--txt); }

/* Row checkbox */
.data-table td.td-check { width: 36px; padding-right: 0; }
.data-table thead th.td-check { padding-right: 0; }

/* Status pill */
.tbl-status {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 8px; border-radius: 5px;
  font-family: var(--mono); font-size: 9px; font-weight: 700;
  letter-spacing: 1px; text-transform: uppercase;
}
.ts-ok   { color: var(--success); background: var(--success-bg); border: 1px solid var(--success-bdr); }
.ts-warn { color: var(--warn);    background: var(--warn-bg);    border: 1px solid var(--warn-bdr); }
.ts-err  { color: var(--error);   background: var(--error-bg);   border: 1px solid var(--error-bdr); }
.ts-info { color: var(--info);    background: var(--info-bg);    border: 1px solid var(--info-bdr); }
.ts-neu  { color: var(--txt3);    background: var(--elev);       border: 1px solid var(--bdr); }

/* Context menu button in row */
.row-action {
  background: none; border: none; cursor: pointer; color: var(--txt3);
  padding: 4px 6px; border-radius: 5px; transition: all 0.15s;
}
.row-action:hover { color: var(--txt); background: var(--elev); }

/* Pagination */
.pagination {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 18px 14px;
  border-top: 1px solid var(--bdr);
}
.pagination-info {
  font-family: var(--mono); font-size: 10px; font-weight: 600; color: var(--txt3);
}
.pagination-btns { display: flex; align-items: center; gap: 3px; }
.pg-btn {
  min-width: 30px; height: 30px; padding: 0 6px;
  border-radius: var(--radius-sm); border: 1px solid var(--bdr);
  background: transparent; color: var(--txt2);
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  cursor: pointer; transition: all 0.15s;
  display: flex; align-items: center; justify-content: center;
}
.pg-btn:hover { border-color: rgba(var(--acc-rgb),0.4); color: var(--txt); }
.pg-btn.active { background: var(--grad); border-color: transparent; color: #fff; }
.pg-btn:disabled { opacity: 0.3; cursor: not-allowed; }

/* Table toolbar */
.tbl-toolbar {
  padding: 12px 18px;
  border-bottom: 1px solid var(--bdr);
  display: flex; align-items: center; gap: 10px;
}
.tbl-search-wrap { position: relative; flex: 1; max-width: 280px; }
.tbl-search {
  background: var(--input-bg); border: 1px solid var(--input-bdr);
  border-radius: var(--radius-md); padding: 7px 12px 7px 34px;
  font-family: var(--f); font-size: 12px; color: var(--txt); outline: none; width: 100%;
}
.tbl-search::placeholder { color: var(--placeholder); }
.tbl-search:focus { border-color: rgba(var(--acc-rgb),0.5); box-shadow: 0 0 0 2px rgba(var(--acc-rgb),0.1); }
.tbl-search-icon { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); color: var(--txt3); }
.tbl-sp { flex: 1; }
.tbl-count {
  font-family: var(--mono); font-size: 10px; font-weight: 700; color: var(--txt3);
  padding: 5px 10px; border-radius: 6px; border: 1px solid var(--bdr); background: var(--elev);
}

/* ════════════════════════════════
   10. SKELETON LOADER
════════════════════════════════ */
@keyframes shimmer {
  0%   { background-position: -600px 0; }
  100% { background-position: 600px 0; }
}
.skeleton {
  background: linear-gradient(90deg,
    rgba(255,255,255,0.04) 0%,
    rgba(255,255,255,0.09) 40%,
    rgba(255,255,255,0.04) 80%
  );
  background-size: 600px 100%;
  animation: shimmer 1.6s infinite linear;
  border-radius: 6px;
}
[data-theme="light"] .skeleton {
  background: linear-gradient(90deg,
    rgba(0,0,0,0.05) 0%,
    rgba(0,0,0,0.10) 40%,
    rgba(0,0,0,0.05) 80%
  );
  background-size: 600px 100%;
}
.skel-card {
  background: var(--surf); border: 1px solid var(--bdr);
  border-radius: var(--radius-lg); padding: 18px; overflow: hidden;
}
.skel-line  { height: 12px; margin-bottom: 8px; }
.skel-title { height: 20px; width: 55%; margin-bottom: 12px; }
.skel-avatar { width: 36px; height: 36px; border-radius: 50%; flex-shrink: 0; }
.skel-avatar-sq { width: 36px; height: 36px; border-radius: 10px; flex-shrink: 0; }
.skel-btn  { height: 36px; border-radius: var(--radius-md); }
.skel-row  { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.skel-row:last-child { margin-bottom: 0; }

/* KPI skeleton */
.skel-kpi-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; margin-bottom: 12px; }
.skel-kpi {
  background: var(--surf); border: 1px solid var(--bdr);
  border-radius: var(--radius-lg); padding: 16px;
}

/* ════════════════════════════════
   11. DROPDOWN / CONTEXT MENU
════════════════════════════════ */
.dropdown-wrap { position: relative; display: inline-block; }

.dropdown-menu {
  position: absolute; top: calc(100% + 6px); left: 0; z-index: 300;
  background: var(--surf); border: 1px solid var(--bdr2);
  border-radius: var(--radius-lg);
  box-shadow: 0 16px 48px rgba(0,0,0,0.4), 0 2px 8px rgba(0,0,0,0.2);
  min-width: 200px; overflow: hidden;
  transform: translateY(-6px) scale(0.97);
  opacity: 0; pointer-events: none;
  transition: all 0.18s cubic-bezier(0.34,1.56,0.64,1);
}
[data-theme="light"] .dropdown-menu { box-shadow: 0 16px 48px rgba(0,0,0,0.12), 0 2px 8px rgba(0,0,0,0.08); }
.dropdown-menu.open { transform: translateY(0) scale(1); opacity: 1; pointer-events: all; }
.dropdown-menu.align-right { left: auto; right: 0; }

.dd-section { padding: 6px; }
.dd-section + .dd-section { border-top: 1px solid var(--bdr); }
.dd-label {
  font-family: var(--mono); font-size: 8px; font-weight: 700;
  letter-spacing: 2px; text-transform: uppercase; color: var(--txt3);
  padding: 6px 10px 4px; display: block;
}
.dd-item {
  display: flex; align-items: center; gap: 9px;
  padding: 8px 10px; border-radius: var(--radius-sm);
  font-size: 13px; font-weight: 500; color: var(--txt2);
  cursor: pointer; transition: all 0.12s; border: none; background: none;
  width: 100%; text-align: left;
}
.dd-item:hover { background: rgba(var(--acc-rgb),0.07); color: var(--txt); }
.dd-item svg   { color: var(--txt3); flex-shrink: 0; transition: color 0.12s; }
.dd-item:hover svg { color: var(--txt2); }
.dd-item.danger { color: var(--error); }
.dd-item.danger:hover { background: var(--error-bg); }
.dd-item.danger svg { color: var(--error); opacity: 0.7; }
.dd-item-sp { flex: 1; }
.dd-kbd {
  font-family: var(--mono); font-size: 9px; font-weight: 600;
  color: var(--txt3); background: var(--elev); border: 1px solid var(--bdr);
  padding: 2px 5px; border-radius: 4px;
}

/* Context menu (prawy przycisk / "...") */
.ctx-menu { min-width: 180px; }

/* ════════════════════════════════
   12. TABS
════════════════════════════════ */
/* Variant A — underline */
.tabs { display: flex; border-bottom: 1px solid var(--bdr); gap: 0; }
.tab-item {
  padding: 10px 16px; font-size: 13px; font-weight: 600; color: var(--txt3);
  border-bottom: 2px solid transparent; margin-bottom: -1px;
  cursor: pointer; transition: all 0.18s; border: none; background: none;
  display: flex; align-items: center; gap: 6px;
  white-space: nowrap;
}
.tab-item:hover { color: var(--txt2); }
.tab-item.active { color: var(--txt); border-bottom-color: var(--acc); }
.tab-badge {
  font-family: var(--mono); font-size: 9px; font-weight: 700;
  padding: 1px 6px; border-radius: 10px;
  background: rgba(var(--acc-rgb),0.12); color: rgba(var(--acc-rgb),0.8);
  border: 1px solid rgba(var(--acc-rgb),0.18);
}
.tab-panel { display: none; }
.tab-panel.active { display: block; }

/* Variant B — pill tabs */
.tabs-pill {
  display: flex; gap: 3px;
  background: var(--elev); border: 1px solid var(--bdr);
  border-radius: var(--radius-lg); padding: 4px;
  width: fit-content;
}
.tab-pill {
  padding: 7px 16px; border-radius: var(--radius-md);
  font-size: 12px; font-weight: 700; color: var(--txt3);
  cursor: pointer; transition: all 0.18s; border: none; background: transparent;
}
.tab-pill:hover { color: var(--txt2); }
.tab-pill.active {
  background: var(--surf); color: var(--txt);
  box-shadow: 0 1px 6px rgba(0,0,0,0.2);
  border: 1px solid var(--bdr);
}
[data-theme="light"] .tab-pill.active { box-shadow: 0 1px 6px rgba(0,0,0,0.08); }

/* ════════════════════════════════
   13. AVATAR
════════════════════════════════ */
.avatar {
  border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; letter-spacing: -0.5px;
  background: var(--grad); color: #fff;
  position: relative; overflow: hidden;
}
.av-xs  { width: 24px; height: 24px; font-size: 9px; }
.av-sm  { width: 32px; height: 32px; font-size: 12px; }
.av-md  { width: 40px; height: 40px; font-size: 14px; }
.av-lg  { width: 52px; height: 52px; font-size: 18px; }
.av-xl  { width: 68px; height: 68px; font-size: 22px; }

/* Status dot on avatar */
.av-wrap { position: relative; display: inline-flex; flex-shrink: 0; }
.av-status {
  position: absolute; bottom: 1px; right: 1px;
  width: 10px; height: 10px; border-radius: 50%;
  border: 2px solid var(--surf);
}
.av-status.online  { background: var(--success); }
.av-status.away    { background: var(--warn); }
.av-status.offline { background: var(--txt3); }

/* Avatar group (stack) */
.av-group { display: flex; }
.av-group .av-wrap { margin-left: -10px; }
.av-group .av-wrap:first-child { margin-left: 0; }
.av-group .avatar { border: 2px solid var(--surf); }
.av-more {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--elev); border: 2px solid var(--surf);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--mono); font-size: 10px; font-weight: 700; color: var(--txt3);
  margin-left: -10px; flex-shrink: 0;
}

/* Avatar with info row */
.av-row { display: flex; align-items: center; gap: 10px; }
.av-info-name  { font-size: 13px; font-weight: 600; color: var(--txt); }
.av-info-sub   { font-size: 11px; color: var(--txt3); margin-top: 1px; }

/* ════════════════════════════════
   14. TOOLTIP
════════════════════════════════ */
.has-tooltip { position: relative; }
.has-tooltip .tooltip {
  position: absolute; bottom: calc(100% + 8px); left: 50%;
  transform: translateX(-50%) translateY(4px);
  background: var(--elev); border: 1px solid var(--bdr2);
  color: var(--txt); font-size: 11px; font-weight: 500;
  padding: 5px 10px; border-radius: 7px; white-space: nowrap;
  pointer-events: none; opacity: 0;
  transition: opacity 0.15s, transform 0.15s;
  box-shadow: 0 8px 24px rgba(0,0,0,0.3);
  z-index: 400;
}
[data-theme="light"] .has-tooltip .tooltip { box-shadow: 0 8px 24px rgba(0,0,0,0.12); }
.has-tooltip .tooltip::after {
  content: '';
  position: absolute; top: 100%; left: 50%; transform: translateX(-50%);
  border: 5px solid transparent;
  border-top-color: var(--bdr2);
}
.has-tooltip:hover .tooltip {
  opacity: 1; transform: translateX(-50%) translateY(0);
}
/* Tooltip right */
.has-tooltip.tip-right .tooltip {
  bottom: auto; left: calc(100% + 8px); top: 50%;
  transform: translateY(-50%) translateX(-4px);
}
.has-tooltip.tip-right .tooltip::after {
  top: 50%; left: 0; transform: translateY(-50%) translateX(-100%);
  border-top-color: transparent; border-right-color: var(--bdr2);
}
.has-tooltip.tip-right:hover .tooltip { transform: translateY(-50%) translateX(0); }

/* Tooltip gradient variant */
.has-tooltip .tooltip-grad {
  background: var(--grad); border: none; color: #fff;
  box-shadow: 0 4px 14px rgba(var(--acc-rgb),0.35);
}
.has-tooltip .tooltip-grad::after { border-top-color: var(--acc); }

/* ════════════════════════════════
   15. ACCORDION
════════════════════════════════ */
.accordion { display: flex; flex-direction: column; gap: 4px; }
.acc-item {
  background: var(--surf); border: 1px solid var(--bdr);
  border-radius: var(--radius-md); overflow: hidden;
  transition: border-color 0.2s, background 0.3s;
}
.acc-item.open { border-color: rgba(var(--acc-rgb), 0.25); }

.acc-trigger {
  width: 100%; display: flex; align-items: center; gap: 12px;
  padding: 14px 16px; background: none; border: none; cursor: pointer;
  text-align: left; transition: background 0.15s;
}
.acc-trigger:hover { background: rgba(var(--acc-rgb), 0.04); }
.acc-icon {
  width: 28px; height: 28px; border-radius: 8px; flex-shrink: 0;
  background: rgba(var(--acc-rgb), 0.08); border: 1px solid rgba(var(--acc-rgb), 0.15);
  display: flex; align-items: center; justify-content: center;
}
.acc-label {
  flex: 1;
  font-size: 14px; font-weight: 600; color: var(--txt);
}
.acc-sub {
  font-size: 12px; color: var(--txt3); margin-top: 1px;
}
.acc-chevron {
  color: var(--txt3); transition: transform 0.25s cubic-bezier(0.4,0,0.2,1); flex-shrink: 0;
}
.acc-item.open .acc-chevron { transform: rotate(180deg); color: var(--txt2); }

.acc-body {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.28s cubic-bezier(0.4,0,0.2,1);
}
.acc-item.open .acc-body { grid-template-rows: 1fr; }
.acc-inner {
  overflow: hidden;
  border-top: 1px solid transparent;
  transition: border-color 0.2s;
}
.acc-item.open .acc-inner { border-top-color: var(--bdr); }
.acc-content {
  padding: 14px 16px 16px;
  font-size: 13px; color: var(--txt2); line-height: 1.7;
}

/* ════════════════════════════════
   16. STEPPER
════════════════════════════════ */
.stepper {
  display: flex; align-items: flex-start; gap: 0;
  position: relative;
}
/* horizontal connector line */
.stepper::before {
  content: ''; position: absolute;
  top: 17px; left: 17px; right: 17px; height: 2px;
  background: var(--bdr2); z-index: 0;
}
.step {
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  flex: 1; position: relative; z-index: 1;
}
.step-dot-wrap {
  width: 34px; height: 34px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: var(--surf); border: 2px solid var(--bdr2);
  transition: all 0.25s; flex-shrink: 0;
}
.step.done .step-dot-wrap {
  background: var(--grad); border-color: transparent;
  box-shadow: 0 0 0 4px rgba(var(--acc-rgb), 0.12);
}
.step.active .step-dot-wrap {
  background: var(--surf); border-color: var(--acc);
  box-shadow: 0 0 0 4px rgba(var(--acc-rgb), 0.12);
}
.step-num {
  font-family: var(--mono); font-size: 11px; font-weight: 700;
  color: var(--txt3);
}
.step.active .step-num { color: var(--acc); }
.step-check { display: none; }
.step.done .step-num  { display: none; }
.step.done .step-check { display: block; }

.step-info { text-align: center; }
.step-label {
  font-size: 12px; font-weight: 700; color: var(--txt3);
  transition: color 0.2s;
}
.step.active .step-label { color: var(--txt); }
.step.done  .step-label  { color: var(--txt2); }
.step-sublabel {
  font-size: 10px; color: var(--txt3); margin-top: 2px;
  font-family: var(--mono);
}

/* progress bar under stepper */
.step-progress {
  height: 3px; border-radius: 2px;
  background: var(--bdr2); margin-top: 16px; overflow: hidden;
}
.step-progress-fill {
  height: 100%; background: var(--grad); border-radius: 2px;
  transition: width 0.4s cubic-bezier(0.4,0,0.2,1);
}

/* Vertical stepper variant */
.stepper-v {
  display: flex; flex-direction: column; gap: 0;
}
.stepper-v::before { display: none; }
.step-v {
  display: flex; gap: 14px; align-items: flex-start;
  position: relative;
}
.step-v-left { display: flex; flex-direction: column; align-items: center; }
.step-v-connector {
  width: 2px; flex: 1; min-height: 24px;
  background: var(--bdr2); margin: 4px auto;
  transition: background 0.25s;
}
.step-v.done .step-v-connector { background: var(--acc); opacity: 0.4; }
.step-v:last-child .step-v-connector { display: none; }
.step-v-content { padding-bottom: 20px; flex: 1; }
.step-v-label {
  font-size: 13px; font-weight: 700; color: var(--txt3);
  margin-bottom: 4px; transition: color 0.2s;
}
.step-v.active .step-v-label { color: var(--txt); }
.step-v.done  .step-v-label  { color: var(--txt2); }
.step-v-desc  { font-size: 12px; color: var(--txt3); line-height: 1.6; }
.step-v.active .step-v-desc { color: var(--txt2); }

/* ════════════════════════════════
   17. BADGE (notification dot)
════════════════════════════════ */
.badge-wrap { position: relative; display: inline-flex; }

/* Dot only */
.notif-dot {
  position: absolute; top: -3px; right: -3px;
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--error); border: 2px solid var(--nav);
  animation: pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot {
  0%,100% { box-shadow: 0 0 0 0 rgba(239,68,68,0.4); }
  50%      { box-shadow: 0 0 0 5px rgba(239,68,68,0); }
}

/* Count badge */
.notif-count {
  position: absolute; top: -6px; right: -8px;
  min-width: 18px; height: 18px; padding: 0 5px;
  border-radius: 9px; border: 2px solid var(--nav);
  background: var(--error); color: #fff;
  font-family: var(--mono); font-size: 9px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  line-height: 1;
}

/* Inline badge / tag */
.badge-inline {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 8px; border-radius: 20px;
  font-family: var(--mono); font-size: 9px; font-weight: 700;
  letter-spacing: 0.5px; text-transform: uppercase;
  border: 1px solid;
}
.badge-new     { background: rgba(var(--acc-rgb),0.1);  border-color: rgba(var(--acc-rgb),0.25); color: var(--acc); }
.badge-hot     { background: rgba(239,68,68,0.09);       border-color: rgba(239,68,68,0.22);      color: var(--error); }
.badge-promo   { background: rgba(16,185,129,0.08);      border-color: rgba(16,185,129,0.2);       color: var(--success); }
.badge-beta    { background: rgba(96,165,250,0.09);      border-color: rgba(96,165,250,0.22);      color: var(--info); }
.badge-locked  { background: rgba(255,255,255,0.04);     border-color: var(--bdr2);                color: var(--txt3); }

/* Badge on nav item */
.nav-badge-item {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 12px; border-radius: var(--radius-md);
  font-size: 13px; font-weight: 600; color: var(--txt2);
  cursor: pointer; transition: all 0.15s;
  border: none; background: none; width: 100%; text-align: left;
}
.nav-badge-item:hover { background: var(--elev); color: var(--txt); }

/* ════════════════════════════════
   18. PAGE TRANSITIONS
════════════════════════════════ */
/* Fade slide (default — do routera) */
@keyframes page-in {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes page-out {
  from { opacity: 1; transform: translateY(0); }
  to   { opacity: 0; transform: translateY(-8px); }
}

/* Slide left (do przodu) */
@keyframes slide-in-right {
  from { opacity: 0; transform: translateX(32px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes slide-in-left {
  from { opacity: 0; transform: translateX(-32px); }
  to   { opacity: 1; transform: translateX(0); }
}

/* Scale in (modal-like) */
@keyframes scale-in {
  from { opacity: 0; transform: scale(0.96); }
  to   { opacity: 1; transform: scale(1); }
}

/* Demo boxes */
.trans-demo-box {
  background: var(--surf); border: 1px solid var(--bdr);
  border-radius: var(--radius-lg); padding: 24px;
  text-align: center;
}
.trans-demo-box.playing-fade   { animation: page-in 0.35s ease both; }
.trans-demo-box.playing-right  { animation: slide-in-right 0.35s cubic-bezier(0.4,0,0.2,1) both; }
.trans-demo-box.playing-left   { animation: slide-in-left  0.35s cubic-bezier(0.4,0,0.2,1) both; }
.trans-demo-box.playing-scale  { animation: scale-in 0.3s cubic-bezier(0.34,1.56,0.64,1) both; }

.trans-name {
  font-family: var(--mono); font-size: 10px; font-weight: 700;
  letter-spacing: 2px; text-transform: uppercase; color: var(--txt3);
  margin-bottom: 8px;
}
.trans-desc { font-size: 12px; color: var(--txt2); margin-bottom: 14px; line-height: 1.6; }
.trans-usage {
  font-family: var(--mono); font-size: 10px; color: rgba(var(--acc-rgb),0.7);
  background: rgba(var(--acc-rgb),0.06); border: 1px solid rgba(var(--acc-rgb),0.12);
  padding: 4px 10px; border-radius: 6px; display: inline-block;
}


/* ════ mBT TOKEN BADGE ════ */
.mbt-pill { display:inline-flex; align-items:center; gap:3px; padding:2px 8px 2px 4px; border-radius:8px; background:linear-gradient(140deg, rgba(var(--acc-rgb),0.12), rgba(var(--acc-rgb),0.04)); border:1px solid rgba(var(--acc-rgb),0.25); box-shadow:inset 0 1px 0 rgba(255,255,255,0.04), 0 2px 8px rgba(0,0,0,0.3); }
.mbt-tok { width:18px; height:12px; border-radius:3px; background:linear-gradient(160deg, rgba(var(--acc-rgb),0.2), rgba(var(--acc-rgb),0.08)); border:1px solid rgba(var(--acc-rgb),0.4); display:flex; align-items:center; justify-content:center; font-family:var(--mono); font-size:5px; font-weight:900; letter-spacing:0.2px; color:var(--acc); position:relative; overflow:hidden; flex-shrink:0; text-transform:uppercase; }
.mbt-tok::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:var(--grad); }
.mbt-val { font-family:var(--f); font-size:11px; font-weight:800; color:#f59e0b; letter-spacing:-0.5px; text-shadow:0 0 10px rgba(245,158,11,0.3); }
[data-theme="light"] .mbt-val { color:#d97706; text-shadow:none; }
.mbt-md { gap:5px; padding:4px 12px 4px 6px; border-radius:10px; }
.mbt-md .mbt-tok { width:24px; height:16px; border-radius:4px; font-size:6px; }
.mbt-md .mbt-val { font-size:15px; letter-spacing:-0.8px; }
.mbt-lg { gap:8px; padding:8px 20px 8px 10px; border-radius:14px; position:relative; overflow:hidden; box-shadow:0 0 40px rgba(var(--acc-rgb),0.08), inset 0 1px 0 rgba(255,255,255,0.06), 0 8px 32px rgba(0,0,0,0.4); }
.mbt-lg::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 30% 50%, rgba(var(--acc-rgb),0.06) 0%, transparent 60%); pointer-events:none; }
.mbt-lg .mbt-tok { width:36px; height:24px; border-radius:6px; font-size:8px; letter-spacing:0.3px; }
.mbt-lg .mbt-tok::before { height:3px; }
.mbt-lg .mbt-val { font-size:24px; font-weight:900; letter-spacing:-1.5px; text-shadow:0 0 20px rgba(245,158,11,0.4); }
.mbt-lg .mbt-unit { font-size:10px; color:rgba(245,158,11,0.5); font-weight:600; align-self:flex-end; padding-bottom:3px; letter-spacing:0.5px; }


/* ════ DESIGN TOKENS — Typography Scale ════ */
:root {
  --type-display: 800 48px/1.1 var(--f);
  --type-h1: 800 32px/1.2 var(--f);
  --type-h2: 700 24px/1.25 var(--f);
  --type-h3: 700 18px/1.3 var(--f);
  --type-h4: 600 15px/1.4 var(--f);
  --type-body: 400 14px/1.7 var(--f);
  --type-body-sm: 500 12px/1.5 var(--f);
  --type-caption: 500 11px/1.4 var(--f);
  --type-label: 700 10px/1 var(--mono);
  --type-micro: 700 8px/1 var(--mono);
}

/* ════ DESIGN TOKENS — Transition ════ */
:root {
  --dur-fast: 120ms;
  --dur-base: 200ms;
  --dur-slow: 350ms;
  --dur-page: 500ms;
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-bounce: cubic-bezier(0.34, 1.56, 0.64, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
}

/* ════ DESIGN TOKENS — Z-index layers ════ */
:root {
  --z-base: 0;
  --z-sticky: 100;
  --z-dropdown: 300;
  --z-overlay: 400;
  --z-modal: 500;
  --z-toast: 900;
  --z-top: 9999;
}

/* ════ DESIGN TOKENS — Breakpoints (reference) ════ */
/* --bp-sm: 640px; --bp-md: 768px; --bp-lg: 1024px; --bp-xl: 1280px; --bp-2xl: 1440px; */

/* ════ FOCUS RING — Global a11y ════ */
*:focus-visible {
  outline: 2px solid var(--acc);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}
.btn:focus-visible { outline-offset: 3px; }
input:focus-visible, select:focus-visible, textarea:focus-visible { outline: none; box-shadow: 0 0 0 2px var(--input-focus); }

/* ════ PROFILE DROPDOWN (Avatar Menu) ════ */
.profile-dd { position:absolute; top:calc(100% + 8px); right:0; min-width:260px; background:var(--surf); border:1px solid var(--bdr2); border-radius:var(--radius-lg); box-shadow:0 16px 48px rgba(0,0,0,0.35); z-index:var(--z-dropdown); overflow:hidden; opacity:0; pointer-events:none; transform:translateY(-4px); transition:all var(--dur-fast) var(--ease-out); }
.profile-dd.open { opacity:1; pointer-events:auto; transform:translateY(0); }
.profile-dd-header { padding:var(--sp4) var(--sp4) var(--sp3); border-bottom:1px solid var(--bdr); }
.profile-dd-name { font-size:15px; font-weight:800; color:var(--txt); letter-spacing:-0.3px; }
.profile-dd-email { font-size:11px; color:var(--txt3); margin-top:2px; }
.profile-dd-body { padding:var(--sp2) var(--sp2); }
.profile-dd-item { display:flex; align-items:center; gap:var(--sp2); width:100%; padding:8px var(--sp3); border-radius:var(--radius-sm); font-size:13px; font-weight:500; color:var(--txt2); cursor:pointer; transition:all var(--dur-fast); border:none; background:none; text-align:left; font-family:var(--f); }
.profile-dd-item:hover { background:rgba(var(--acc-rgb),0.06); color:var(--txt); }
.profile-dd-item svg { width:15px; height:15px; stroke:currentColor; fill:none; stroke-width:1.8; flex-shrink:0; }
.profile-dd-item .pdd-right { margin-left:auto; font-family:var(--mono); font-size:11px; font-weight:700; }
.profile-dd-item .pdd-kbd { margin-left:auto; font-family:var(--mono); font-size:9px; padding:2px 6px; border-radius:4px; background:var(--elev); border:1px solid var(--bdr); color:var(--txt3); }
.profile-dd-item.pdd-admin { color:var(--acc); }
.profile-dd-item.pdd-role { color:#ec4899; }
.profile-dd-item.pdd-danger { color:var(--error); }
.profile-dd-item.pdd-danger:hover { background:var(--error-bg); }
.profile-dd-sep { height:1px; background:var(--bdr); margin:var(--sp1) var(--sp2); }
[data-theme="light"] .profile-dd { box-shadow:0 16px 48px rgba(0,0,0,0.12); }

/* ════ TIMEZONE CLOCKS ════ */
.tz-clock { text-align:right; line-height:1.15; padding:4px 10px; border-radius:var(--radius-sm); background:rgba(var(--acc-rgb),0.04); border:1px solid rgba(var(--acc-rgb),0.1); }
.tz-label { font-family:var(--mono); font-size:7px; font-weight:800; letter-spacing:2px; text-transform:uppercase; background:var(--grad-t); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.tz-row { display:flex; align-items:baseline; gap:4px; justify-content:flex-end; }
.tz-code { font-family:var(--mono); font-size:10px; font-weight:800; color:var(--acc); }
.tz-time { font-family:var(--mono); font-size:18px; font-weight:900; color:var(--txt); letter-spacing:-1px; }
.tz-date { font-family:var(--mono); font-size:7px; color:var(--txt3); opacity:0.6; }
[data-theme="light"] .tz-clock { background:rgba(var(--acc-rgb),0.06); }
.top-bar-sep { width:1px; height:20px; background:var(--bdr); flex-shrink:0; }
/* ════ NAVIGATION — Top Bar ════ */
.top-bar { display:flex; align-items:center; gap:var(--sp4); padding:var(--sp3) var(--sp5); background:var(--nav); border-bottom:1px solid var(--bdr); position:sticky; top:0; z-index:var(--z-sticky); min-height:52px; }
.top-bar-logo { display:flex; align-items:center; gap:var(--sp2); font-weight:800; font-size:15px; color:var(--txt); letter-spacing:-0.5px; flex-shrink:0; }
.top-bar-logo-mark { width:28px; height:28px; border-radius:var(--radius-sm); background:var(--grad); display:flex; align-items:center; justify-content:center; font-weight:900; font-size:12px; color:#fff; }
.top-bar-tabs { display:flex; align-items:center; gap:var(--sp1); margin-left:var(--sp4); overflow:hidden; flex:1; scrollbar-width:none; -ms-overflow-style:none; }
.top-bar-tabs::-webkit-scrollbar { display:none; }
.top-bar-tab { display:flex; align-items:center; gap:6px; padding:6px 14px; border-radius:var(--radius-md); font-size:13px; font-weight:500; color:var(--txt2); cursor:pointer; transition:all var(--dur-fast); white-space:nowrap; border:1px solid transparent; }
.top-bar-tab:hover { color:var(--txt); background:rgba(var(--acc-rgb),0.06); }
.top-bar-tab.active { color:#fff; background:var(--acc); border-color:var(--acc); font-weight:600; }
[data-theme="light"] .top-bar-tab.active { color:#fff; }
.top-bar-tab svg { width:14px; height:14px; stroke:currentColor; fill:none; stroke-width:1.8; }
.top-bar-right { display:flex; align-items:center; gap:var(--sp3); margin-left:auto; flex-shrink:0; }
.top-bar-timer { display:flex; align-items:center; gap:6px; font-family:var(--mono); font-size:11px; font-weight:600; color:var(--txt3); }
.top-bar-timer svg { width:14px; height:14px; }

/* Sub-nav */
.sub-nav { display:flex; align-items:center; gap:var(--sp1); padding:var(--sp2) var(--sp5); border-bottom:1px solid var(--bdr); background:var(--bg); }
.sub-nav-item { display:flex; align-items:center; gap:5px; padding:5px 12px; font-size:12px; font-weight:500; color:var(--txt3); cursor:pointer; border-radius:var(--radius-sm); transition:all var(--dur-fast); white-space:nowrap; }
.sub-nav-item:hover { color:var(--txt); background:rgba(var(--acc-rgb),0.06); }
.sub-nav-item.active { color:var(--txt); font-weight:600; }
.sub-nav-item svg { width:13px; height:13px; stroke:currentColor; fill:none; stroke-width:1.8; }
.sub-nav-sep { width:1px; height:16px; background:var(--bdr); margin:0 var(--sp1); flex-shrink:0; }
.sub-nav-star { color:#f59e0b; font-size:11px; }

/* Breadcrumbs */
.breadcrumbs { display:flex; align-items:center; gap:6px; padding:var(--sp2) var(--sp5); font-size:12px; color:var(--txt3); }
.breadcrumbs a, .breadcrumbs span { color:var(--txt3); text-decoration:none; cursor:pointer; }
.breadcrumbs span:last-child { color:var(--txt); font-weight:600; }
.breadcrumbs .bc-sep { font-size:10px; opacity:0.4; }

/* Sidebar */
.sidebar-demo { width:220px; background:var(--nav); border-right:1px solid var(--bdr); padding:var(--sp4) 0; border-radius:var(--radius-lg); overflow:hidden; }
.sidebar-demo.collapsed { width:56px; }
.sidebar-section-label { font-family:var(--mono); font-size:8px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--txt3); padding:var(--sp3) var(--sp4) var(--sp1); }
.sidebar-item { display:flex; align-items:center; gap:var(--sp2); padding:8px var(--sp4); font-size:13px; font-weight:500; color:var(--txt2); cursor:pointer; transition:all var(--dur-fast); border-left:2px solid transparent; }
.sidebar-item:hover { color:var(--txt); background:rgba(var(--acc-rgb),0.06); }
.sidebar-item.active { color:var(--acc); background:rgba(var(--acc-rgb),0.08); border-left-color:var(--acc); font-weight:600; }
.sidebar-item svg { width:16px; height:16px; stroke:currentColor; fill:none; stroke-width:1.8; flex-shrink:0; }
.sidebar-item .sidebar-badge { margin-left:auto; background:rgba(var(--acc-rgb),0.15); color:var(--acc); font-size:9px; font-weight:700; padding:1px 6px; border-radius:99px; }

/* ════ COLOR PALETTE ════ */
.palette-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(100px, 1fr)); gap:8px; }
.swatch { border-radius:var(--radius-md); overflow:hidden; border:1px solid var(--bdr); }
.swatch-color { height:56px; position:relative; }
.swatch-info { padding:8px; background:var(--surf); }
.swatch-name { font-family:var(--mono); font-size:8px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--txt2); }
.swatch-val { font-family:var(--mono); font-size:9px; color:var(--txt3); margin-top:2px; }

/* ════ STAT CARD / KPI ════ */
.stat-card { background:var(--surf); border:1px solid var(--bdr); border-radius:var(--radius-lg); padding:var(--sp4) var(--sp5); }
.stat-card-label { font-family:var(--mono); font-size:9px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:var(--txt3); margin-bottom:var(--sp1); }
.stat-card-value { font-size:28px; font-weight:900; color:var(--txt); letter-spacing:-1.5px; }
.stat-card-delta { display:inline-flex; align-items:center; gap:3px; font-size:11px; font-weight:700; margin-top:var(--sp1); padding:2px 8px; border-radius:99px; }
.stat-card-delta.up { color:var(--success); background:var(--success-bg); }
.stat-card-delta.down { color:var(--error); background:var(--error-bg); }
.stat-card-sub { font-size:11px; color:var(--txt3); margin-top:var(--sp1); }

/* ════ PROGRESS BAR ════ */
.progress-track { height:6px; background:var(--elev); border-radius:99px; overflow:hidden; }
.progress-fill { height:100%; border-radius:99px; background:var(--grad); transition:width var(--dur-slow) var(--ease-out); }
.progress-track.lg { height:10px; }

/* ════ CHIP / TAG ════ */
.chip { display:inline-flex; align-items:center; gap:4px; padding:3px 10px; border-radius:99px; font-size:11px; font-weight:600; border:1px solid var(--bdr); background:var(--surf); color:var(--txt2); cursor:pointer; transition:all var(--dur-fast); }
.chip:hover { border-color:rgba(var(--acc-rgb),0.3); color:var(--txt); }
.chip.active { background:rgba(var(--acc-rgb),0.12); border-color:rgba(var(--acc-rgb),0.3); color:var(--acc); }
.chip svg { width:12px; height:12px; }
.chip-close { width:14px; height:14px; border-radius:50%; display:flex; align-items:center; justify-content:center; cursor:pointer; opacity:0.5; }
.chip-close:hover { opacity:1; background:rgba(var(--acc-rgb),0.15); }

/* ════ SEARCH BAR ════ */
.search-bar { display:flex; align-items:center; gap:8px; padding:8px 14px; background:var(--input-bg); border:1px solid var(--input-bdr); border-radius:var(--radius-md); transition:all var(--dur-fast); }
.search-bar:focus-within { border-color:var(--acc); box-shadow:0 0 0 3px var(--input-focus); }
.search-bar svg { width:16px; height:16px; stroke:var(--txt3); fill:none; stroke-width:1.8; flex-shrink:0; }
.search-bar input { border:none; background:none; outline:none; font-family:var(--f); font-size:13px; color:var(--txt); width:100%; }
.search-bar input::placeholder { color:var(--placeholder); }
.search-bar kbd { font-family:var(--mono); font-size:9px; padding:2px 6px; border-radius:4px; background:var(--elev); border:1px solid var(--bdr); color:var(--txt3); flex-shrink:0; }

/* ════ DIVIDER ════ */
.divider { height:1px; background:var(--bdr); margin:var(--sp5) 0; }
.divider-label { display:flex; align-items:center; gap:var(--sp3); color:var(--txt3); font-size:11px; }
.divider-label::before, .divider-label::after { content:''; flex:1; height:1px; background:var(--bdr); }

/* ════ RESPONSIVE BREAKPOINTS ════ */
@media (max-width: 1280px) {
  .top-bar-tabs { gap:0; }
  .top-bar-tab { padding:6px 10px; font-size:12px; }
}
@media (max-width: 1024px) {
  .palette-grid { grid-template-columns:repeat(auto-fill, minmax(80px, 1fr)); }
  .icon-sys-grid { grid-template-columns:repeat(auto-fill, minmax(110px, 1fr)); }
}
@media (max-width: 768px) {
  .top-bar { padding:var(--sp2) var(--sp3); }
  .top-bar-tabs { display:none; }
  .sub-nav { overflow:hidden; padding:var(--sp2) var(--sp3); }
  .btn-demo-grid { grid-template-columns:repeat(2, 1fr); }
  .palette-grid { grid-template-columns:repeat(3, 1fr); }
}
@media (max-width: 640px) {
  .palette-grid { grid-template-columns:repeat(2, 1fr); }
  .icon-sys-grid { grid-template-columns:repeat(2, 1fr); }
  .stat-card-value { font-size:22px; }
}

/* ════ LIGHT MODE ICON FIX ════ */
[data-theme="light"] .icon-sys-card-icon svg { stroke: #c2410c !important; }
[data-theme="light"] .icon-sys-card-icon svg [stroke="url(#green-g)"] { stroke: #059669 !important; }
[data-theme="light"] .icon-sys-card-icon svg[fill="url(#ph-soft)"] { fill: rgba(234,88,12,0.12) !important; }
[data-theme="light"] .icon-size-item svg { stroke: #c2410c !important; }
[data-theme="light"] .icon-size-item svg[fill="url(#ph-soft)"] { fill: rgba(234,88,12,0.12) !important; }
[data-theme="light"] .icon-badge-demo svg { stroke: #c2410c !important; }
[data-theme="light"] .icon-badge-demo svg[fill="url(#ph-soft)"] { fill: rgba(234,88,12,0.12) !important; }
[data-view="back"][data-theme="light"] .icon-sys-card-icon svg { stroke: #7c3aed !important; }
[data-view="back"][data-theme="light"] .icon-sys-card-icon svg[fill="url(#ph-soft)"] { fill: rgba(124,58,237,0.12) !important; }

/* ════ ICON SYSTEM ════ */
.icon-sys-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(130px, 1fr)); gap:8px; }
.icon-sys-card { background:var(--surf); border:1px solid var(--bdr); border-radius:var(--radius-md); padding:16px 10px; text-align:center; cursor:pointer; transition:all 0.2s; position:relative; overflow:hidden; }
.icon-sys-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:var(--bdr); transition:background 0.2s; }
.icon-sys-card:hover { border-color:rgba(var(--acc-rgb),0.35); transform:translateY(-2px); }
.icon-sys-card:hover::before { background:var(--grad); }
.icon-sys-card-icon { margin-bottom:6px; display:flex; justify-content:center; }
.icon-sys-card-icon svg { width:28px; height:28px; }
.icon-sys-card-name { font-family:var(--mono); font-size:8px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--txt2); margin-bottom:1px; }
.icon-sys-card-usage { font-size:9px; color:var(--txt3); }
.icon-sizes-row { display:flex; align-items:flex-end; gap:20px; flex-wrap:wrap; }
.icon-size-item { display:flex; flex-direction:column; align-items:center; gap:8px; }
.icon-size-item svg { display:block; }
.icon-size-lbl { font-family:var(--mono); font-size:8px; font-weight:700; color:var(--txt3); text-align:center; }
.icon-badge-demo { display:inline-flex; align-items:center; justify-content:center; border-radius:var(--radius-md); background:rgba(var(--acc-rgb),0.08); border:1px solid rgba(var(--acc-rgb),0.15); }
.icon-badge-sm { width:28px; height:28px; border-radius:7px; }
.icon-badge-md { width:36px; height:36px; border-radius:10px; }
.icon-badge-lg { width:48px; height:48px; border-radius:12px; }
.icon-badge-xl { width:56px; height:56px; border-radius:14px; }