/* ═══════════════════════════════════════════════════════════════════════════
   Rafias IA — Design System GO
   Tokens: Grupo Ortiz / context_desing_go
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Design Tokens ───────────────────────────────────────────────────────── */

:root {
  --go-orange:      #FB670B;
  --go-orange-hot:  #FF7A22;
  --go-orange-deep: #D95C00;
  --go-orange-tint: rgba(251,103,11,0.10);

  --go-black:   #262626;
  --go-gray-1:  #535353;
  --go-gray-2:  #C5C5C5;
  --go-cream:   #ECEBE0;
  --go-white:   #FFFFFF;

  --green:  #00A36E;
  --red:    #DC2626;
  --yellow: #D97706;
  --blue:   #3B82F6;

  --bg:            var(--go-cream);
  --surface:       var(--go-white);
  --border:        var(--go-gray-2);
  --text:          var(--go-black);
  --text-muted:    var(--go-gray-1);
  --accent:        var(--go-orange);
  --accent-hot:    var(--go-orange-hot);
  --accent-tint:   var(--go-orange-tint);

  --font-display:  "Blauer Nue", Nunito, Poppins, Inter, sans-serif;
  --font-body:     Conthic, Inter, "Segoe UI", system-ui, sans-serif;
  --font-mono:     "JetBrains Mono", "SF Mono", Consolas, monospace;

  --space-xs: 4px;  --space-sm: 8px;  --space-md: 16px;
  --space-lg: 24px; --space-xl: 32px; --space-2xl: 48px;

  --radius-sm: 6px; --radius-md: 10px; --radius-lg: 14px; --radius-xl: 20px;
  --radius-full: 999px;

  --shadow-sm: 0 1px 3px rgba(38,38,38,0.08);
  --shadow-md: 0 4px 12px rgba(38,38,38,0.10);
  --shadow-lg: 0 8px 24px rgba(38,38,38,0.14);

  --sidebar-w: 240px;
  --chat-w: 340px;
  --topbar-h: 56px;

  --transition: 180ms ease;
}

html.dark {
  --bg:          #111111;
  --surface:     #1c1c1e;
  --border:      #3a3a3c;
  --text:        #ECEBE0;
  --text-muted:  #A0A0A0;
  --bg-warm:     #181818;
  --go-cream:    #2a2a2a;
  /* --accent = #FB670B en ambos modos */
}

/* ── Reset ────────────────────────────────────────────────────────────────── */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px;-webkit-font-smoothing:antialiased}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  min-height:100vh;
  display:flex;
  overflow-x:hidden;
}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--accent-hot)}
button{cursor:pointer;font-family:inherit}
input,select,textarea{font-family:inherit;font-size:inherit}

/* ── Scrollbar ────────────────────────────────────────────────────────────── */

::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}

/* ── Layout ───────────────────────────────────────────────────────────────── */

#sidebar{
  width:var(--sidebar-w);min-width:var(--sidebar-w);
  background:var(--go-black);color:var(--go-white);
  display:flex;flex-direction:column;
  position:fixed;top:0;left:0;bottom:0;z-index:100;
  transition:transform var(--transition);
}
#sidebar .sb-brand{
  display:flex;align-items:center;gap:12px;
  padding:16px 20px;border-bottom:1px solid rgba(255,255,255,0.08);
}
.sb-logo{
  width:36px;height:36px;background:var(--accent);border-radius:8px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.sb-logo img{width:24px;height:24px;object-fit:contain}
.sb-brand-text{font-family:var(--font-display);font-size:16px;font-weight:700;line-height:1.2}
.sb-brand-text small{display:block;font-size:10px;font-weight:400;color:rgba(255,255,255,0.45);text-transform:uppercase;letter-spacing:0.12em}

.sb-nav{flex:1;padding:12px 0;overflow-y:auto}
.sb-nav-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 20px;font-size:13px;font-weight:600;color:rgba(255,255,255,0.55);
  border:none;background:none;width:100%;text-align:left;
  border-left:3px solid transparent;transition:all var(--transition);
}
.sb-nav-item:hover{color:rgba(255,255,255,0.85);background:rgba(255,255,255,0.04)}
.sb-nav-item.active{color:var(--accent);background:rgba(251,103,11,0.10);border-left-color:var(--accent)}
.sb-nav-item svg{width:18px;height:18px;flex-shrink:0}
.sb-nav-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.12em;color:rgba(255,255,255,0.25);padding:16px 20px 6px}

.sb-footer{padding:12px 20px;border-top:1px solid rgba(255,255,255,0.08)}
.sb-user{display:flex;align-items:center;gap:10px}
.sb-avatar{
  width:30px;height:30px;border-radius:var(--radius-sm);background:var(--accent);
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;font-family:var(--font-display);
}
.sb-user-info{flex:1;min-width:0}
.sb-user-name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-user-role{font-size:10px;color:rgba(255,255,255,0.4);text-transform:uppercase;letter-spacing:0.08em}
.sb-btn-logout{
  background:none;border:1px solid rgba(255,255,255,0.15);border-radius:var(--radius-sm);
  color:rgba(255,255,255,0.5);padding:4px 10px;font-size:11px;font-weight:600;
  transition:all var(--transition);
}
.sb-btn-logout:hover{border-color:var(--red);color:var(--red)}

#main-wrap{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh}

/* ── Topbar ────────────────────────────────────────────────────────────────── */

#topbar{
  background:var(--surface);border-bottom:1px solid var(--border);
  height:var(--topbar-h);display:flex;align-items:center;justify-content:space-between;
  padding:0 var(--space-lg);position:sticky;top:0;z-index:50;
}
.topbar-left{display:flex;align-items:center;gap:var(--space-md)}
.topbar-title{font-family:var(--font-display);font-size:16px;font-weight:700}
.topbar-subtitle{font-size:12px;color:var(--text-muted)}
.topbar-right{display:flex;align-items:center;gap:var(--space-sm)}
.topbar-btn{
  background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);
  padding:6px 12px;font-size:12px;font-weight:600;color:var(--text);
  display:flex;align-items:center;gap:6px;transition:all var(--transition);
}
.topbar-btn:hover{border-color:var(--accent);color:var(--accent)}
.topbar-btn.has-badge::after{content:'';width:8px;height:8px;background:var(--red);border-radius:50%;margin-left:2px}
#theme-toggle{width:34px;height:34px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:center;transition:all var(--transition)}
#theme-toggle:hover{border-color:var(--accent)}
#theme-toggle svg{width:16px;height:16px;stroke:var(--text);fill:none}

/* ── Main Content ──────────────────────────────────────────────────────────── */

#content{padding:var(--space-lg);flex:1;max-width:1400px;width:100%}

/* ── Cards ─────────────────────────────────────────────────────────────────── */

.card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:var(--space-lg);box-shadow:var(--shadow-sm);
}
.card-header{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:var(--space-md);padding-bottom:12px;border-bottom:1px solid var(--border);
}
.card-title{
  font-family:var(--font-display);font-weight:700;font-size:14px;
  text-transform:uppercase;letter-spacing:0.06em;color:var(--text);
}
.card+.card{margin-top:var(--space-lg)}

/* ── KPI Grid ──────────────────────────────────────────────────────────────── */

.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md);margin-bottom:var(--space-lg)}
.kpi-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:var(--space-lg);box-shadow:var(--shadow-sm);
}
.kpi-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.10em;color:var(--accent);margin-bottom:6px}
.kpi-value{font-family:var(--font-mono);font-size:32px;font-weight:700;color:var(--text);letter-spacing:-0.02em}
.kpi-sub{font-size:12px;color:var(--text-muted);margin-top:4px}

/* ── Buttons ───────────────────────────────────────────────────────────────── */

.btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 18px;border-radius:var(--radius-sm);font-size:13px;font-weight:700;
  font-family:var(--font-display);letter-spacing:0.02em;
  border:none;transition:all var(--transition);white-space:nowrap;
}
.btn:disabled{opacity:0.5;cursor:not-allowed}
.btn svg{width:16px;height:16px;flex-shrink:0}

.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover:not(:disabled){background:var(--accent-hot)}
.btn-primary:active:not(:disabled){background:var(--go-orange-deep)}

.btn-ghost{background:transparent;color:var(--text);border:1.5px solid var(--border)}
.btn-ghost:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}

.btn-danger{background:var(--red);color:#fff}
.btn-danger:hover:not(:disabled){background:#B91C1C}

.btn-sm{padding:4px 10px;font-size:11px;border-radius:6px}
.btn-xs{padding:2px 8px;font-size:10px;border-radius:4px}
.btn-icon-xs{width:28px;height:28px;padding:0;font-size:14px;line-height:28px;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}

/* ── Tables ────────────────────────────────────────────────────────────────── */

.go-table{width:100%;border-collapse:collapse;font-size:13px;min-width:700px}
.go-table tbody td{white-space:nowrap}
.go-table .actions-cell{white-space:nowrap;text-align:right}
.go-table .actions-cell .btn+.btn{margin-left:4px}
.go-table thead tr{border-bottom:2px solid var(--accent)}
.go-table thead th{
  padding:10px 12px;text-align:left;font-family:var(--font-display);
  font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:0.10em;
  color:var(--text-muted);white-space:nowrap;
}
.go-table tbody tr{border-bottom:1px solid var(--border);transition:background 150ms}
.go-table tbody tr:hover{background:var(--accent-tint)}
.go-table tbody tr.clickable{cursor:pointer}
.go-table tbody td{padding:10px 12px;vertical-align:middle}
.go-table tbody tr:last-child{border-bottom:none}
.go-table td.num{font-family:var(--font-mono);font-variant-numeric:tabular-nums;text-align:right}

.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}

/* ── Badges / Pills ────────────────────────────────────────────────────────── */

.pill{
  display:inline-flex;align-items:center;gap:4px;
  padding:2px 10px;border-radius:var(--radius-full);
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;
  white-space:nowrap;
}
.pill-green{background:rgba(0,163,110,0.12);color:var(--green);border:1px solid rgba(0,163,110,0.25)}
.pill-red{background:rgba(220,38,38,0.10);color:var(--red);border:1px solid rgba(220,38,38,0.20)}
.pill-orange{background:rgba(217,119,6,0.12);color:var(--yellow);border:1px solid rgba(217,119,6,0.25)}
.pill-gray{background:rgba(83,83,83,0.08);color:var(--text-muted);border:1px solid var(--border)}
.pill-blue{background:rgba(59,130,246,0.10);color:var(--blue);border:1px solid rgba(59,130,246,0.20)}
.pill-accent{background:var(--accent-tint);color:var(--accent);border:1px solid rgba(251,103,11,0.25)}
.pill-amber{background:rgba(217,119,6,0.10);color:#B45309;border:1px solid rgba(217,119,6,0.25)}

.tipo-farming{background:rgba(0,163,110,0.12);color:var(--green);font-size:10px;font-weight:800;padding:2px 7px;border-radius:6px;letter-spacing:0.08em}
.tipo-hunting{background:rgba(220,38,38,0.10);color:var(--red);font-size:10px;font-weight:800;padding:2px 7px;border-radius:6px;letter-spacing:0.08em}

/* ── Inputs ────────────────────────────────────────────────────────────────── */

.input{
  width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);
  font-size:14px;color:var(--text);background:var(--surface);
  transition:border-color var(--transition);outline:none;
}
.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-tint)}
.input-sm{padding:6px 10px;font-size:12px}
select.input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23535353'%3E%3Cpath d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px}

/* ── Forms ─────────────────────────────────────────────────────────────────── */

.form-group{margin-bottom:var(--space-md)}
.form-label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--text-muted);margin-bottom:4px}
.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-md)}
.form-row-inline{display:flex;gap:var(--space-sm);align-items:center}
.form-row-inline .input{flex:1;min-width:0}

/* ── Modal ─────────────────────────────────────────────────────────────────── */

.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:200;
  display:flex;align-items:center;justify-content:center;
  animation:fadeIn 150ms ease;
}
.modal{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);max-width:90vw;max-height:85vh;overflow-y:auto;
  animation:slideUp 200ms ease;
}
.modal-sm{width:420px}
.modal-md{width:600px}
.modal-lg{width:780px}
.modal-header{
  display:flex;justify-content:space-between;align-items:center;
  padding:var(--space-lg);border-bottom:1px solid var(--border);
}
.modal-title{font-family:var(--font-display);font-size:16px;font-weight:700}
.modal-close{
  width:28px;height:28px;border-radius:var(--radius-sm);border:1px solid var(--border);
  background:var(--surface);display:flex;align-items:center;justify-content:center;
  font-size:16px;color:var(--text-muted);transition:all var(--transition);
}
.modal-close:hover{border-color:var(--red);color:var(--red)}
.modal-body{padding:var(--space-lg)}
.modal-footer{
  display:flex;justify-content:flex-end;gap:var(--space-sm);
  padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border);
}

@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ── Toast ─────────────────────────────────────────────────────────────────── */

#toast-container{
  position:fixed;bottom:var(--space-lg);right:var(--space-lg);z-index:300;
  display:flex;flex-direction:column-reverse;gap:8px;
}
.toast{
  background:var(--go-black);color:var(--go-white);border-radius:var(--radius-sm);
  padding:12px 18px;font-size:13px;font-weight:600;min-width:280px;max-width:420px;
  box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:10px;
  animation:slideIn 250ms ease;
}
.toast-success{border-left:3px solid var(--green)}
.toast-error{border-left:3px solid var(--red)}
.toast-info{border-left:3px solid var(--accent)}
.toast-msg{flex:1}
.toast-close{
  background:none;border:none;color:rgba(255,255,255,0.5);font-size:16px;
  cursor:pointer;padding:0 4px;
}
.toast-close:hover{color:#fff}

@keyframes slideIn{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}

/* ── States ────────────────────────────────────────────────────────────────── */

.empty-state{
  text-align:center;padding:var(--space-2xl) var(--space-lg);
}
.empty-state-icon{
  width:64px;height:64px;border-radius:var(--radius-xl);background:var(--accent-tint);
  margin:0 auto var(--space-lg);display:flex;align-items:center;justify-content:center;
}
.empty-state-icon svg{width:28px;height:28px;stroke:var(--accent)}
.empty-state h3{font-family:var(--font-display);font-size:18px;font-weight:700;margin-bottom:6px}
.empty-state p{color:var(--text-muted);font-size:14px;margin-bottom:var(--space-lg)}

.skeleton{
  background:linear-gradient(90deg,var(--border) 25%,transparent 50%,var(--border) 75%);
  background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm);
}
.skeleton-row{height:40px;margin-bottom:8px}
.skeleton-text{height:14px;width:60%;margin-bottom:8px}
.skeleton-text.short{width:30%}

@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

.error-state{
  text-align:center;padding:var(--space-xl);color:var(--red);
}

/* ── Chat Backdrop ─────────────────────────────────────────────────────────── */

#chat-backdrop{
  position:fixed;inset:0;background:rgba(0,0,0,0.3);z-index:249;
  display:none;
}
#chat-backdrop.show{display:block}

/* ── Chat Widget ──────────────────────────────────────────────────────────── */

#chat-panel{
  position:fixed;bottom:24px;right:24px;width:400px;max-width:calc(100vw - 32px);
  height:540px;max-height:calc(100vh - 48px);
  background:var(--surface);border:1px solid var(--border);
  border-radius:16px;z-index:250;display:flex;flex-direction:column;
  transform:translateY(calc(100% + 32px));
  transition:transform 250ms cubic-bezier(0.16,1,0.3,1);
  box-shadow:0 8px 40px rgba(0,0,0,0.18),0 2px 8px rgba(0,0,0,0.08);
  overflow:hidden;
}
#chat-panel.open{transform:translateY(0)}

.chat-widget-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 16px;border-bottom:1px solid var(--border);
  background:var(--accent);color:#fff;flex-shrink:0;
}
.chat-widget-brand{
  display:flex;align-items:center;gap:8px;
  font-family:var(--font-display);font-size:14px;font-weight:700;
}
.chat-widget-actions{display:flex;align-items:center;gap:4px}
.chat-widget-btn{
  background:none;border:none;color:inherit;cursor:pointer;
  padding:4px 6px;border-radius:6px;display:flex;align-items:center;
  opacity:0.85;transition:opacity .15s;
}
.chat-widget-btn:hover{opacity:1;background:rgba(255,255,255,0.15)}

.chat-widget-convs{
  position:absolute;top:48px;left:0;right:0;bottom:60px;
  background:var(--surface);z-index:2;overflow-y:auto;
  border-bottom:1px solid var(--border);
}
.chat-convs-list-inner{padding:4px 0}
.chat-convs-list-inner .chat-conv-item{
  display:flex;flex-direction:column;gap:2px;
  padding:10px 16px;cursor:pointer;transition:all .15s;
  border-left:3px solid transparent;
}
.chat-convs-list-inner .chat-conv-item:hover{background:var(--accent-tint)}
.chat-convs-list-inner .chat-conv-item.active{background:var(--accent-tint);border-left-color:var(--accent)}
.chat-conv-title{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-conv-meta{font-size:10px;color:var(--text-muted)}
.chat-conv-empty{text-align:center;padding:20px;color:var(--text-muted);font-size:12px}

.chat-widget-msgs{flex:1;overflow-y:auto;padding:12px 16px;min-height:0}
.chat-msg{margin-bottom:12px;max-width:88%}
.chat-msg.user{margin-left:auto;text-align:right}
.chat-msg-bubble{
  display:inline-block;padding:8px 12px;border-radius:12px;
  font-size:13px;line-height:1.45;word-break:break-word;
}
.chat-msg.user .chat-msg-bubble{background:var(--accent);color:#fff;border-bottom-right-radius:4px}
.chat-msg.assistant .chat-msg-bubble{background:var(--bg);color:var(--text);border-bottom-left-radius:4px}
.chat-msg-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;color:var(--text-muted);margin-bottom:3px}

.chat-widget-input{
  display:flex;gap:6px;padding:10px 12px;
  border-top:1px solid var(--border);flex-shrink:0;align-items:center;
}
.chat-widget-input input{
  flex:1;border:1px solid var(--border);border-radius:20px;
  padding:8px 14px;font-size:13px;background:var(--bg);color:var(--text);
  outline:none;
}
.chat-widget-input input:focus{border-color:var(--accent)}
.chat-widget-input .chat-widget-btn{color:var(--text-muted)}
.chat-widget-input .chat-widget-btn:hover{color:var(--accent);background:var(--accent-tint)}
.chat-send-btn{color:var(--accent) !important}

.chat-empty{text-align:center;padding:32px 16px;color:var(--text-muted);font-size:13px}

/* Mobile: fullscreen */
@media (max-width:480px){
  #chat-panel{bottom:0;right:0;width:100%;max-width:100%;height:100%;max-height:100%;border-radius:0}
}

/* ── Tabs ──────────────────────────────────────────────────────────────────── */

.tabs{display:flex;border-bottom:2px solid var(--border);margin-bottom:var(--space-lg)}
.tab-btn{
  padding:10px 18px;font-size:13px;font-weight:700;cursor:pointer;
  border:none;background:none;color:var(--text-muted);
  border-bottom:2px solid transparent;margin-bottom:-2px;
  font-family:var(--font-display);letter-spacing:0.02em;
  transition:all var(--transition);
}
.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}
.tab-btn:hover:not(.active){color:var(--text)}

.tab-panel{display:none}
.tab-panel.active{display:block}

/* ── Filter Bar ────────────────────────────────────────────────────────────── */

.filter-bar{
  display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap;
  margin-bottom:var(--space-md);
}
.filter-bar .input{max-width:220px}

/* ── CSV Dropzone ──────────────────────────────────────────────────────────── */

.dropzone{
  border:2px dashed var(--border);border-radius:var(--radius-lg);
  padding:var(--space-2xl);text-align:center;cursor:pointer;
  transition:all var(--transition);background:var(--surface);
}
.dropzone:hover,.dropzone.dragover{border-color:var(--accent);background:var(--accent-tint)}
.dropzone-icon{margin-bottom:var(--space-md);color:var(--accent)}
.dropzone-text{font-weight:600;font-size:14px}
.dropzone-hint{font-size:12px;color:var(--text-muted);margin-top:4px}

/* ── Confirm Dialog ────────────────────────────────────────────────────────── */

.confirm-icon{
  width:48px;height:48px;border-radius:50%;background:rgba(220,38,38,0.10);
  display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-md);
}
.confirm-icon svg{width:24px;height:24px;stroke:var(--red)}

/* ── Section header ────────────────────────────────────────────────────────── */

.section-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:var(--space-md);flex-wrap:wrap;gap:var(--space-sm);
}
.section-header h2{font-family:var(--font-display);font-size:18px;font-weight:700}

/* ── Responsive ────────────────────────────────────────────────────────────── */

@media(max-width:1024px){
  #sidebar{transform:translateX(-100%)}
  #sidebar.mobile-open{transform:translateX(0)}
  #main-wrap{margin-left:0}
  .kpi-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}
}
@media(max-width:640px){
  #content{padding:var(--space-md)}
  .modal{max-width:95vw;max-height:90vh}
  .kpi-grid{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
  .filter-bar{flex-direction:column;align-items:stretch}
  .filter-bar .input{max-width:100%}
}

/* ── Utility ────────────────────────────────────────────────────────────────── */

.text-muted{color:var(--text-muted)}
.text-accent{color:var(--accent)}
.text-sm{font-size:12px}
.text-xs{font-size:10px}
.mt-sm{margin-top:var(--space-sm)}
.mt-md{margin-top:var(--space-md)}
.mb-md{margin-bottom:var(--space-md)}
.flex-between{display:flex;justify-content:space-between;align-items:center}
.gap-sm{display:flex;gap:var(--space-sm);align-items:center}
.gap-md{display:flex;gap:var(--space-md);align-items:center}
.w-full{width:100%}
.hidden{display:none!important}
.inline-code{
  font-family:var(--font-mono);font-size:11px;background:var(--bg);
  padding:1px 6px;border-radius:4px;color:var(--accent);
}
