*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
input[type="checkbox"]{appearance:none;-webkit-appearance:none;width:16px;height:16px;border:1.5px solid var(--border2);border-radius:4px;background:var(--surface);cursor:pointer;flex-shrink:0;position:relative;transition:background .15s,border-color .15s;vertical-align:middle}
input[type="checkbox"]:checked{background:var(--accent);border-color:var(--accent)}
input[type="checkbox"]:checked::after{content:'';position:absolute;left:4px;top:1px;width:5px;height:9px;border:2px solid #fff;border-top:none;border-left:none;transform:rotate(45deg)}
:root{
  /* Palette */
  --bg:#eef2f7;
  --surface:#ffffff;
  --surface2:#f1f5f9;
  --surface3:#e2e8f0;
  --text:#111827;
  --text2:#334155;
  --muted:#64748b;
  --ink:#111827;
  --border:rgba(15,23,42,.08);
  --border2:rgba(15,23,42,.16);
  /* Accent */
  --accent:#2563eb;
  --accent2:#1d4ed8;
  --accent3:#38bdf8;
  --accent-glow:rgba(37,99,235,.16);
  --accent-soft:rgba(37,99,235,.09);
  /* Semantic */
  --success:#16a34a;
  --success-soft:rgba(0,168,107,0.08);
  --danger:#ef4444;
  --danger-soft:rgba(224,48,80,0.07);
  --warn:#f59e0b;
  --warn-soft:rgba(224,124,0,0.08);
  --purple:#7c3aed;
  --purple-soft:rgba(108,61,212,0.08);
  /* Named tokens (used by garage/calendar components) */
  --graphite:#111827;
  --graphite-2:#1f2937;
  --graphite2:#59606d;
  --stone:#cbd5e1;
  --stone-2:#e2e8f0;
  --warm:#faf8f2;
  --sand:#eee9df;
  --sage:#82947f;
  --clay:#b9836a;
  --moss:#65745f;
  --sky-muted:#7b8ea3;
  --white-warm:#ffffff;
  --white-soft:#f8fafc;
  /* Gradients */
  --grad1:linear-gradient(135deg,#5b2a86 0%,#8b5cf6 100%);
  --grad2:linear-gradient(135deg,#a78bfa 0%,#5b2a86 100%);
  --grad3:linear-gradient(135deg,#e03050 0%,#e07c00 100%);
  /* Typography */
  --font-display:'Barlow','Segoe UI',system-ui,sans-serif;
  --font-body:'Barlow','Segoe UI',system-ui,sans-serif;
  --font-mono:'Barlow','Segoe UI',system-ui,sans-serif;
  /* Radii */
  --r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:22px;
  /* Shadows */
  --shadow-sm:0 2px 8px rgba(15,23,42,.06);
  --shadow-md:0 10px 28px rgba(15,23,42,.10);
  --shadow-lg:0 18px 44px rgba(15,23,42,.14);
  --shadow-accent:0 12px 26px rgba(37,99,235,.22);
}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;font-size:15px;line-height:1.45;-webkit-font-smoothing:antialiased;text-rendering:geometricPrecision}

/* LOGIN */
#login-screen{display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:1.5rem;position:fixed;inset:0;z-index:9999;overflow:auto;background:linear-gradient(160deg,#eef2ff 0%,#f7f9ff 52%,#eff4ff 100%)}
.login-orb{display:none}
.login-orb-1{width:400px;height:400px;background:radial-gradient(circle,rgba(45,91,227,.12) 0%,transparent 70%);top:-100px;right:-80px}
.login-orb-2{width:350px;height:350px;background:radial-gradient(circle,rgba(108,61,212,.08) 0%,transparent 70%);bottom:-80px;left:-60px;animation-delay:-5s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
@keyframes slideIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.login-box{width:100%;max-width:420px;animation:none;position:relative;z-index:1}
.login-logo{margin-bottom:1.4rem;text-align:center;background:transparent;border:0;box-shadow:none;padding:0}
.login-logo img,.login-logo svg,.login-logo .zoplie-login-img-final{display:none!important}
.login-logo p{font-size:13px;color:var(--muted);margin-top:6px;letter-spacing:.01em}
.zoplie-login-wordmark-fixed{display:inline-flex;align-items:center;justify-content:center;gap:8px;margin:0 auto 14px;background:transparent;border:0;box-shadow:none;color:#0f1e3d;font-family:var(--font-display),Arial,sans-serif;font-size:34px;font-weight:900;line-height:1;letter-spacing:.11em}
.zoplie-login-e-fixed{width:36px;height:36px;display:inline-grid;place-items:center;border-radius:10px;background:linear-gradient(145deg,#00c7b6 0%,#1584f4 100%);color:#fff;font-size:29px;font-weight:950;letter-spacing:-.08em;transform:translateY(-1px) skewX(-7deg);position:relative;overflow:hidden;box-shadow:0 12px 24px rgba(21,132,244,.18)}
.zoplie-login-e-fixed::before{content:'';position:absolute;left:8px;top:8px;width:2px;height:20px;border-radius:999px;background:rgba(255,255,255,.42)}
.zoplie-login-e-fixed span{position:relative;z-index:1}
.login-card{background:rgba(255,255,255,.92);backdrop-filter:none;border:1px solid var(--border2);border-radius:var(--r-xl);padding:2.2rem;box-shadow:var(--shadow-lg),0 0 0 1px rgba(255,255,255,.6)}
.login-tabs{display:flex;gap:4px;background:var(--surface2);border-radius:var(--r-md);padding:4px;margin-bottom:1.6rem;border:1px solid var(--border)}
.login-tab{flex:1;padding:8px;text-align:center;font-size:13px;font-weight:600;border-radius:var(--r-sm);cursor:pointer;color:var(--muted);border:none;background:transparent;font-family:var(--font-body);transition:all .2s;letter-spacing:.01em}
.login-tab.active{background:var(--grad1);color:#fff;box-shadow:var(--shadow-accent)}
.field{margin-bottom:1rem}
.field label{display:block;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}
.field input,.field select{width:100%;background:var(--surface);border:1.5px solid var(--border2);border-radius:var(--r-md);padding:11px 14px;color:var(--text);font-family:var(--font-body);font-size:14px;outline:none;-webkit-appearance:none;transition:all .2s;box-shadow:var(--shadow-sm)}
.field input:focus,.field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow),var(--shadow-sm)}
.field input::placeholder{color:var(--muted)}
.field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237a8eb0' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;cursor:pointer}
.btn-primary{width:100%;padding:13px;border-radius:var(--r-md);border:none;background:var(--grad1);color:#fff;font-family:var(--font-display);font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:.5rem;box-shadow:var(--shadow-accent);letter-spacing:.01em}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(45,91,227,.35)}
.btn-primary:active{transform:scale(.98)}
.btn-primary:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}
.login-error{font-size:12px;color:var(--danger);text-align:center;margin-top:.8rem;min-height:18px}
.forgot-link{font-size:12px;color:var(--accent);text-align:center;margin-top:.6rem;cursor:pointer;text-decoration:underline;text-underline-offset:3px;font-weight:500}
.forgot-link:hover{color:var(--accent2)}
.simple-captcha-fixed{display:grid;grid-template-columns:auto 1fr 76px;align-items:center;gap:10px;width:100%;min-height:48px;margin:1rem 0 .75rem;border:1.5px solid var(--border2);border-radius:var(--r-md);background:#f8fbff;color:#0f1e3d;padding:8px 10px;box-shadow:var(--shadow-sm)}
.simple-captcha-icon{width:28px;height:28px;display:grid;place-items:center;border-radius:8px;background:linear-gradient(145deg,#eaf1ff,#fff);color:var(--accent);font-weight:900}
.simple-captcha-fixed label{font-size:12px;font-weight:750;color:#536681;line-height:1.25}
.simple-captcha-fixed strong{display:block;color:#0f1e3d;font-size:13px;margin-top:1px}
.simple-captcha-fixed input{width:100%;height:32px;border:1.5px solid var(--border2);border-radius:10px;background:#fff;text-align:center;color:#0f1e3d;font-weight:800;outline:none}
.simple-captcha-fixed input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}

/* APP */
#app{display:none;min-height:100vh}
.layout{display:flex;min-height:100vh}

/* SIDEBAR */
.sidebar{width:240px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:1.4rem 1rem;position:fixed;top:0;left:0;height:100vh;z-index:50;transition:transform .3s cubic-bezier(.16,1,.3,1);box-shadow:var(--shadow-sm)}
.sidebar-logo{margin-bottom:1.8rem;padding:.2rem .5rem}
.nav-section{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;padding:0 .5rem;margin-bottom:.55rem;margin-top:1rem}
.nav-item{display:flex;align-items:center;gap:10px;padding:9.5px 12px;margin-bottom:3px;border-radius:var(--r-md);cursor:pointer;color:var(--muted);font-size:13px;font-weight:500;transition:all .15s;border:none;background:transparent;width:100%;text-align:left;font-family:var(--font-body);position:relative;letter-spacing:.01em;line-height:1.25}
.nav-item:hover{background:var(--accent-soft);color:var(--text2)}
.nav-item.active{background:var(--accent-soft);color:var(--accent);font-weight:600}
.nav-item.active::before{display:none}
.nav-item svg{width:15px;height:15px;flex-shrink:0}
.sidebar-bottom{margin-top:auto}
.user-chip{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r-md);background:var(--surface2);border:1px solid var(--border)}
.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--grad1);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}
.user-info{flex:1;min-width:0}
.user-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{font-size:10px;color:var(--muted);text-transform:capitalize}
.logout-btn{background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;border-radius:6px;transition:color .15s}
.logout-btn:hover{color:var(--danger)}
.logout-btn svg{width:14px;height:14px}

/* LANG TOGGLE */
.lang-toggle{display:flex;gap:4px;margin-bottom:1rem;padding:0 .5rem}
.lang-btn{flex:1;padding:5px;text-align:center;font-size:11px;font-weight:700;border-radius:6px;cursor:pointer;border:1px solid var(--border2);background:transparent;color:var(--muted);font-family:var(--font-body);transition:all .15s;letter-spacing:.04em}
.lang-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* MAIN */
.main{flex:1;margin-left:240px;padding:2rem 2.5rem;min-height:100vh}
.page-header{margin-bottom:2rem}
.page-title{font-family:var(--font-display);font-size:26px;font-weight:700;color:var(--text);letter-spacing:-.02em;line-height:1}
.page-sub{font-size:13px;color:var(--muted);margin-top:5px}

/* STATS */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:2rem}
.stat-card{border-radius:var(--r-lg);padding:1.4rem;position:relative;overflow:hidden;border:1px solid transparent;background:var(--surface);box-shadow:var(--shadow-sm)}
.stat-card.blue{border-color:rgba(45,91,227,.15);background:linear-gradient(145deg,rgba(45,91,227,.06) 0%,#fff 100%)}
.stat-card.green{border-color:rgba(0,168,107,.15);background:linear-gradient(145deg,rgba(0,168,107,.06) 0%,#fff 100%)}
.stat-card.warn{border-color:rgba(224,124,0,.15);background:linear-gradient(145deg,rgba(224,124,0,.06) 0%,#fff 100%)}
.stat-card.purple{border-color:rgba(108,61,212,.15);background:linear-gradient(145deg,rgba(108,61,212,.06) 0%,#fff 100%)}
.stat-dot{display:none}
.stat-num{font-family:var(--font-display);font-size:32px;font-weight:700;line-height:1;margin-bottom:6px}
.stat-card.blue .stat-num{color:var(--accent)}
.stat-card.green .stat-num{color:var(--success)}
.stat-card.warn .stat-num{color:var(--warn)}
.stat-card.purple .stat-num{color:var(--purple)}
.stat-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}

/* CARDS */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.4rem;margin-bottom:1rem;box-shadow:var(--shadow-sm)}
.label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* INPUTS */
select,input[type="date"],input[type="time"],input[type="text"],input[type="email"],input[type="number"],textarea{
  width:100%;background:var(--surface);border:1.5px solid var(--border2);border-radius:var(--r-md);
  padding:10px 14px;color:var(--text);font-family:var(--font-body);font-size:14px;
  appearance:none;outline:none;-webkit-appearance:none;transition:all .2s;box-shadow:var(--shadow-sm)
}
select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237a8eb0' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;cursor:pointer}
select:focus,input:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
input::placeholder,textarea::placeholder{color:var(--muted)}
textarea{resize:vertical;min-height:85px;line-height:1.6}
select option{background:var(--surface)}

/* SW BUTTONS */
.sw-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.sw-btn{display:flex;flex-direction:column;align-items:flex-start;background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--r-md);padding:14px;cursor:pointer;transition:all .2s;text-align:left;width:100%;box-shadow:var(--shadow-sm)}
.sw-btn:hover{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.sw-btn.active{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.sw-btn .sw-name{font-size:13px;font-weight:600;margin-top:8px;color:var(--text)}
.sw-btn .sw-sub{font-size:10px;color:var(--muted);margin-top:2px}
.sw-dot{width:9px;height:9px;border-radius:50%}
.sw-btn[data-sw="Soul Suite"] .sw-dot{background:#7c3aed}.sw-btn[data-sw="Soul Suite"].active{border-color:#7c3aed;background:rgba(124,58,237,.06)}
.sw-btn[data-sw="Sistema Demo"] .sw-dot{background:#00a86b}.sw-btn[data-sw="Sistema Demo"].active{border-color:#00a86b;background:rgba(0,168,107,.06)}
.sw-btn[data-sw="Salto"] .sw-dot{background:#e07c00}.sw-btn[data-sw="Salto"].active{border-color:#e07c00;background:rgba(224,124,0,.06)}
.sw-btn[data-sw="Portal Demo"] .sw-dot{background:#2d5be3}.sw-btn[data-sw="Portal Demo"].active{border-color:#2d5be3;background:rgba(45,91,227,.06)}
.sw-btn[data-sw="Canary"] .sw-dot{background:#d95f20}.sw-btn[data-sw="Canary"].active{border-color:#d95f20;background:rgba(217,95,32,.06)}
.sw-btn[data-sw="Acceso Demo"] .sw-dot{background:#c2185b}.sw-btn[data-sw="Acceso Demo"].active{border-color:#c2185b;background:rgba(194,24,91,.06)}

/* PRIORITY */
.prio-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.prio-btn{padding:10px 4px;text-align:center;font-size:12px;font-weight:600;border-radius:var(--r-md);border:1.5px solid var(--border2);background:var(--surface2);cursor:pointer;color:var(--muted);font-family:var(--font-body);transition:all .15s;box-shadow:var(--shadow-sm)}
.prio-btn:hover{border-color:var(--accent);color:var(--text)}
.prio-btn.active-urgente{border-color:#e03050;background:rgba(224,48,80,.07);color:#e03050}
.prio-btn.active-alta{border-color:#d95f20;background:rgba(217,95,32,.07);color:#d95f20}
.prio-btn.active-media{border-color:#e07c00;background:rgba(224,124,0,.07);color:#e07c00}
.prio-btn.active-baja{border-color:#00a86b;background:rgba(0,168,107,.07);color:#00a86b}

/* SUBMIT */
.submit-btn{width:100%;padding:13px;border-radius:var(--r-md);border:none;background:var(--grad1);color:#fff;font-family:var(--font-display);font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:.3rem;box-shadow:var(--shadow-accent);letter-spacing:.01em}
.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 16px 40px rgba(45,91,227,.35)}
.submit-btn:active{transform:scale(.98)}
.submit-btn:disabled{opacity:.35;cursor:not-allowed;transform:none;box-shadow:none}

/* TOOLBAR */
.toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:1rem}
.filters{display:flex;gap:6px;flex-wrap:wrap}
.filter-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;border:1.5px solid var(--border2);background:var(--surface);color:var(--muted);cursor:pointer;font-family:var(--font-body);transition:all .15s;box-shadow:var(--shadow-sm)}
.filter-btn:hover{border-color:var(--accent);color:var(--text2)}
.filter-btn.active{background:var(--grad1);color:#fff;border-color:transparent;box-shadow:var(--shadow-accent)}
.filter-btn .btn-icon{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.export-btn{display:flex;align-items:center;gap:7px;padding:8px 16px;border-radius:var(--r-md);border:1.5px solid var(--border2);background:var(--surface);color:var(--accent);font-family:var(--font-body);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;box-shadow:var(--shadow-sm)}
.export-btn:hover{border-color:var(--accent);background:var(--accent-soft)}
.export-btn svg{width:13px;height:13px}

/* LOG ITEMS */
.inc-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.2rem 1.4rem;margin-bottom:.8rem;animation:slideIn .25s cubic-bezier(.16,1,.3,1);transition:box-shadow .2s,border-color .2s;box-shadow:var(--shadow-sm)}
.inc-item:hover{border-color:var(--border2);box-shadow:var(--shadow-md)}
.inc-top{display:flex;align-items:flex-start;gap:12px;margin-bottom:10px}
.inc-badge{font-size:10px;font-weight:700;padding:3px 9px;border-radius:20px;white-space:nowrap;flex-shrink:0;letter-spacing:.04em}
.inc-title{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--text)}
.inc-meta{font-size:11px;color:var(--muted);font-family:var(--font-mono);margin-top:3px}
.inc-desc{font-size:13px;color:var(--text2);line-height:1.6;margin-bottom:10px;padding:10px 13px;background:var(--surface2);border-radius:var(--r-md);border:1px solid var(--border)}
.inc-author{display:inline-flex;align-items:center;gap:7px;font-size:12px;color:var(--muted)}
.avatar{width:22px;height:22px;border-radius:50%;background:var(--grad1);color:#fff;font-size:9px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.resol-section{border-top:1px solid var(--border);margin-top:12px;padding-top:12px}
.status-row{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.status-select{font-size:12px;padding:5px 10px;border-radius:var(--r-sm);border:1.5px solid var(--border2);background:var(--surface);font-family:var(--font-body);cursor:pointer;outline:none;color:var(--text);-webkit-appearance:none;box-shadow:var(--shadow-sm)}
.resol-input{width:100%;background:var(--surface);border:1.5px solid var(--border2);border-radius:var(--r-md);padding:10px 13px;color:var(--text);font-family:var(--font-body);font-size:13px;outline:none;resize:none;min-height:65px;line-height:1.5;margin-bottom:8px;transition:all .2s;box-shadow:var(--shadow-sm)}
.resol-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.resol-input::placeholder{color:var(--muted)}
.save-btn{padding:8px 18px;border-radius:var(--r-md);border:none;background:var(--grad1);color:#fff;font-family:var(--font-body);font-size:12px;font-weight:700;cursor:pointer;transition:all .15s;box-shadow:var(--shadow-accent)}
.save-btn:hover{transform:translateY(-1px);box-shadow:0 8px 20px rgba(45,91,227,.3)}
.resol-saved{font-size:12px;color:var(--text2);padding:8px 13px;background:var(--success-soft);border-radius:var(--r-md);border-left:3px solid var(--success);line-height:1.5}
.empty-state{text-align:center;padding:3.5rem 0;color:var(--muted);font-size:14px}
.empty-icon{font-size:36px;margin-bottom:1rem;display:block}

/* TABS */
.page-tabs{display:flex;gap:4px;background:var(--surface2);border-radius:var(--r-md);padding:4px;margin-bottom:1.5rem;border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.page-tab{flex:1;padding:8px;text-align:center;font-size:12px;font-weight:600;border-radius:var(--r-sm);cursor:pointer;color:var(--muted);transition:all .2s;border:none;background:transparent;font-family:var(--font-body);letter-spacing:.01em}
.page-tab.active{background:var(--grad1);color:#fff;box-shadow:var(--shadow-accent)}

/* TOAST */
.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(100px);background:var(--surface);border:1px solid var(--border2);color:var(--text);padding:12px 24px;border-radius:var(--r-md);font-size:13px;font-weight:600;transition:transform .4s cubic-bezier(.16,1,.3,1);white-space:nowrap;z-index:200;box-shadow:var(--shadow-lg)}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast.error{background:var(--danger-soft);border-color:var(--danger);color:var(--danger)}

/* NOTIF PANEL */
#notif-panel{background:var(--surface);border-left:1px solid var(--border);box-shadow:-4px 0 24px rgba(15,30,61,.08)}

/* PUSH BANNER */
#push-banner{background:rgba(45,91,227,.05);border:1px solid rgba(45,91,227,.15)}

/* MENU TOGGLE */
.menu-toggle{display:none;position:fixed;top:1rem;left:1rem;z-index:60;background:var(--surface);border:1px solid var(--border2);border-radius:var(--r-md);padding:9px;cursor:pointer;box-shadow:var(--shadow-md)}
.menu-toggle svg{width:18px;height:18px;stroke:var(--text);fill:none;stroke-width:2;stroke-linecap:round}
.overlay{display:none;position:fixed;inset:0;background:rgba(15,30,61,.4);z-index:40;backdrop-filter:blur(4px)}

/* RESPONSIVE */
@media(max-width:768px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .main{margin-left:0;padding:1.2rem;padding-top:4.5rem}
  .menu-toggle{display:flex}
  .overlay.show{display:block}
  .stats-grid{grid-template-columns:1fr 1fr}
  .row2{grid-template-columns:1fr}
  .sw-grid{grid-template-columns:1fr 1fr}
  .prio-row{grid-template-columns:1fr 1fr}
  .toolbar{flex-direction:column;align-items:stretch}
  .export-btn{justify-content:center}
}

/* ── Grid utilities ──────────────────────────────────────────── */
.grid-2col  {display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.grid-2-1col{display:grid;grid-template-columns:2fr 1fr;gap:14px;margin-bottom:14px}
.grid-4col  {display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:2rem}
@media(max-width:768px){
  .grid-4col,.grid-2-1col,.grid-2col{grid-template-columns:1fr}
}

/* ── Flex utilities ──────────────────────────────────────────── */
.flex-row    {display:flex;align-items:center;gap:8px}
.flex-row-md {display:flex;align-items:center;gap:10px;font-size:13px}
.flex-gap    {display:flex;gap:8px}
.flex-between-box{display:flex;align-items:center;justify-content:space-between;padding:.8rem 1rem;background:var(--surface2);border-radius:9px}

/* ── Typography utilities ────────────────────────────────────── */
.mb-md      {margin-bottom:1rem}
.mb-sm      {margin-bottom:.8rem}
.t-muted-sm {font-size:11px;color:var(--muted)}
.t-muted-xs {font-size:12px;color:var(--muted);margin-top:2px}
.t-md       {font-size:13px;font-weight:500;color:var(--text)}
.t-md-label {font-size:12px;font-weight:500;color:var(--text);margin-bottom:6px}
.t-lg-bold  {font-size:15px;font-weight:800;color:var(--text);margin-bottom:.8rem}

/* ── Component utilities ─────────────────────────────────────── */
.surface-box{background:var(--surface2);border-radius:8px;padding:.8rem}
.icon-sm    {width:14px;height:14px}
.input-xs   {padding:5px 8px;font-size:12px;width:80px}

/* ── Table cell utilities ────────────────────────────────────── */
.td-cell   {padding:7px 10px;font-size:13px}
.th-cell   {padding:8px 12px;text-align:left;color:var(--muted);font-weight:500;border-bottom:1px solid var(--border2)}
.th-center {text-align:center;font-size:10px;font-weight:700;color:var(--muted);padding:4px;text-transform:uppercase;letter-spacing:.05em}

/* ── Row-link utilities ──────────────────────────────────────── */
.row-link    {display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer}
.row-link-xs {display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted)}
.row-link-sm {display:flex;align-items:center;gap:5px;cursor:pointer}
