*{box-sizing:border-box;margin:0;padding:0;}
:root{
  /* Brand */
  --navy:#1a3a6b;--navy-light:#f97316;
  --ferrari:#f97316;--ferrari-dim:rgba(249,115,22,0.35);
  --silver:#9eaab8;
  /* Semantic */
  --teal:#34d399;--coral:#f97316;--amber:#fbbf24;--purple:#a78bfa;--green:#34d399;
  --font:'Inter',sans-serif;--mono:'DM Mono',monospace;
  --r:10px;--r2:14px;--sidebar:220px;
  /* Dark defaults (system black) */
  --bg:#000000;--bg2:#0d0d0f;--bg3:#161618;--bg4:#1e1e22;
  --border:rgba(255,255,255,0.06);--border2:rgba(255,255,255,0.11);--border3:rgba(255,255,255,0.17);
  --text:#f2f2f2;--text2:#8a8a96;--text3:#505058;
  --accent:#f97316;--accent2:#1a3a6b;--blue:#f97316;
  --shadow:0 2px 20px rgba(0,0,0,0.7);
}
html,body{height:100%;background:var(--bg);color:var(--text);font-family:var(--font);}
a{color:inherit;text-decoration:none;}
button{cursor:pointer;font-family:var(--font);}
input,select,textarea{font-family:var(--font);}
::-webkit-scrollbar{width:4px;height:4px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px;}

/* ─── LAYOUT ─── */
.app{display:grid;grid-template-columns:var(--sidebar) 1fr;min-height:100vh;}

/* ─── SIDEBAR ─── */
.sidebar{
  background:var(--bg2);border-right:1.5px solid rgba(26,58,107,0.25);
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;
}
.logo{padding:20px 18px 16px;border-bottom:0.5px solid var(--border);display:flex;align-items:center;gap:10px;}
.logo-icon{width:32px;height:32px;background:var(--accent);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.logo-icon svg{width:18px;height:18px;}
.logo-text{font-size:15px;font-weight:700;color:var(--text);letter-spacing:-0.3px;}
.logo-sub{font-size:10px;color:var(--text3);font-family:var(--mono);margin-top:1px;}
.nav{padding:12px 10px;flex:1;}
.nav-section{font-size:10px;color:var(--text3);font-family:var(--mono);letter-spacing:1px;padding:10px 8px 6px;text-transform:uppercase;}
.nav-item{
  display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;
  font-size:13px;color:var(--text2);font-weight:500;transition:all 0.15s;margin-bottom:2px;
  border:none;background:none;width:100%;text-align:left;
;position:relative}
.nav-item:hover{background:rgba(255,255,255,0.05);color:var(--text);}
.nav-item.active{background:rgba(26,58,107,0.15);color:var(--ferrari);}
.nav-item.active::before{content:'';position:absolute;left:0;top:6px;bottom:6px;width:3px;background:var(--ferrari);border-radius:0 2px 2px 0;}
.nav-item svg{width:16px;height:16px;flex-shrink:0;}
.nav-badge{
  margin-left:auto;background:var(--bg3);border-radius:20px;
  font-size:10px;padding:2px 7px;font-family:var(--mono);color:var(--text3);
}
.nav-item.active .nav-badge{background:rgba(249,115,22,0.15);color:var(--ferrari);font-weight:700;}
.sidebar-footer{padding:14px 10px;border-top:0.5px solid var(--border);}
.printer-status{background:var(--bg3);border-radius:var(--r);padding:12px;border:0.5px solid var(--border);}
.printer-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;}
.status-dot{width:7px;height:7px;border-radius:50%;background:var(--teal);animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:0.4;}}
.printer-name{font-size:12px;font-weight:600;color:var(--text);}
.printer-model{font-size:10px;color:var(--text3);font-family:var(--mono);}
.printer-progress{height:3px;background:var(--border);border-radius:2px;overflow:hidden;margin-top:6px;}
.printer-bar{height:100%;background:var(--teal);border-radius:2px;transition:width 1s;}
.printer-info{display:flex;justify-content:space-between;margin-top:5px;}
.printer-info span{font-size:10px;color:var(--text3);font-family:var(--mono);}

/* ─── MAIN ─── */
.main{background:var(--bg);overflow-y:auto;min-width:0;overflow-x:hidden;width:100%;box-sizing:border-box;}
.topbar{
  padding:16px 24px;border-bottom:0.5px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;background:var(--bg2);border-bottom:1px solid var(--border);box-shadow:0 1px 0 var(--ferrari-dim);backdrop-filter:blur(8px);z-index:10;
}
.topbar-left{display:flex;flex-direction:column;gap:2px;}
.page-title{
  font-size:20px;font-weight:700;color:var(--text);letter-spacing:-0.5px;
  background:var(--bg3);display:inline-block;padding:4px 12px;
  border-radius:8px;border:0.5px solid var(--border2);
  border-bottom:2px solid var(--ferrari);
}
.page-date{font-size:11px;color:var(--text3);font-family:var(--mono);margin-top:2px;}
.topbar-actions{display:flex;align-items:center;gap:8px;}
.btn{padding:8px 14px;border-radius:8px;font-size:12px;font-weight:600;transition:all 0.15s;border:none;}
.btn-ghost{background:var(--bg3);color:var(--text2);border:0.5px solid var(--border2);}
.btn-ghost:hover{background:var(--bg4);color:var(--text);}
.btn-accent{background:#f97316;color:#ffffff;}
.btn-accent:hover{background:var(--navy);box-shadow:0 0 0 2px var(--ferrari-dim);}
.btn-accent:hover{background:var(--accent2);}
.btn-danger{background:rgba(204,34,0,0.1);color:var(--coral);border:0.5px solid rgba(204,34,0,0.25);}
.btn-danger:hover{background:rgba(255,107,91,0.2);}
.btn-sm{padding:5px 10px;font-size:11px;border-radius:7px;}
.notif-btn{
  width:34px;height:34px;background:var(--bg3);border-radius:8px;
  display:flex;align-items:center;justify-content:center;border:0.5px solid var(--border);
  position:relative;cursor:pointer;
}
.notif-dot{position:absolute;top:6px;right:7px;width:6px;height:6px;border-radius:50%;background:var(--coral);}

/* ─── SECTIONS ─── */
.section{display:none;padding:20px 24px 40px;width:100%;box-sizing:border-box;}
.section.active{display:block;width:100%;box-sizing:border-box;}
.section-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;margin-top:24px;}
.section-title{font-size:14px;font-weight:700;color:var(--text);letter-spacing:-0.2px;border-left:3px solid var(--ferrari);padding-left:10px;}
.section-action{font-size:11px;color:var(--ferrari);cursor:pointer;font-family:var(--mono);background:none;border:none;padding:0;}
.section-action:hover{text-decoration:underline;}

/* ─── STATS ROW ─── */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:4px;}
.stat-card{
  background:var(--bg2);border-radius:var(--r2);border:0.5px solid var(--border);
  padding:16px;position:relative;overflow:hidden;transition:border-color 0.15s;
}
.stat-card{transition:border-color 0.2s,box-shadow 0.2s;}
.stat-card:hover{border-color:var(--ferrari-dim);box-shadow:0 0 0 1px var(--ferrari-dim);}
.stat-card:hover{border-color:var(--border2);}
.stat-label{font-size:11px;color:var(--text3);font-family:var(--mono);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:8px;}
.stat-value{font-size:26px;font-weight:700;color:var(--text);line-height:1;margin-bottom:4px;}
.stat-delta{font-size:11px;font-family:var(--mono);}
.stat-delta.up{color:var(--teal);}
.stat-delta.down{color:var(--coral);}
.stat-delta.neutral{color:var(--text3);}
.stat-icon{position:absolute;right:14px;top:14px;opacity:0.15;}
.stat-icon svg{width:28px;height:28px;}

/* ─── GRID LAYOUTS ─── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.grid-2-1{display:grid;grid-template-columns:2fr 1fr;gap:12px;}
.grid-1-2{display:grid;grid-template-columns:1fr 2fr;gap:12px;}

/* ─── PANEL ─── */
.panel{background:var(--bg2);border-radius:var(--r2);border:0.5px solid var(--border);padding:16px;;transition:border-color 0.2s,box-shadow 0.2s;}
.panel:hover{border-color:var(--ferrari-dim);box-shadow:0 0 0 1px var(--ferrari-dim);}
.panel-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:12px;}

/* ─── TABS ─── */
.tabs{display:flex;gap:4px;margin-bottom:14px;background:var(--bg3);padding:3px;border-radius:8px;border:0.5px solid var(--border);}
.tab{flex:1;padding:6px 8px;border-radius:6px;font-size:11px;font-weight:600;text-align:center;color:var(--text3);transition:all 0.15s;font-family:var(--mono);border:none;background:none;}
.tab.active{background:var(--bg2);color:var(--text);border:0.5px solid var(--border);}

/* ─── PROJECTS ─── */
.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}
.project-card{
  background:var(--bg2);border-radius:var(--r2);border:0.5px solid var(--border);
  overflow:hidden;cursor:pointer;transition:all 0.15s;
}
.project-card:hover{border-color:var(--border2);transform:translateY(-1px);}
.project-thumb{height:80px;display:flex;align-items:center;justify-content:center;font-size:32px;}
.project-body{padding:12px;}
.project-name{font-size:13px;font-weight:600;color:var(--text);margin-bottom:4px;}
.project-meta{font-size:11px;color:var(--text3);font-family:var(--mono);margin-bottom:10px;}
.project-progress{height:3px;background:var(--border);border-radius:2px;overflow:hidden;margin-bottom:8px;}
.progress-fill{height:100%;border-radius:2px;transition:width 0.5s;}
.project-footer{display:flex;justify-content:space-between;align-items:center;}
.project-time{font-size:10px;color:var(--text3);font-family:var(--mono);}
.badge{font-size:10px;padding:3px 8px;border-radius:20px;font-family:var(--mono);font-weight:500;}
.badge-teal{background:rgba(56,217,169,0.12);color:var(--teal);}
.badge-blue{background:rgba(78,168,255,0.12);color:var(--blue);}
.badge-amber{background:rgba(240,180,41,0.12);color:var(--amber);}
.badge-purple{background:rgba(167,139,250,0.12);color:var(--purple);}
.badge-coral{background:rgba(255,107,91,0.12);color:var(--coral);}
.badge-green{background:rgba(111,207,151,0.12);color:var(--green);}
.badge-gray{background:rgba(255,255,255,0.06);color:var(--text3);}

/* ─── MATERIALS ─── */
.material-list{display:flex;flex-direction:column;gap:10px;}
.material-item{display:flex;align-items:center;gap:12px;}
.mat-color{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.mat-info{flex:1;min-width:0;}
.mat-name{font-size:12px;font-weight:600;color:var(--text);}
.mat-type{font-size:10px;color:var(--text3);font-family:var(--mono);}
.mat-bar{height:4px;background:var(--border);border-radius:2px;overflow:hidden;width:70px;}
.mat-bar-fill{height:100%;border-radius:2px;}
.mat-grams{font-size:10px;color:var(--text2);font-family:var(--mono);text-align:right;min-width:52px;}

/* ─── QUEUE ─── */
.queue-list{display:flex;flex-direction:column;gap:8px;}
.queue-item{
  display:flex;align-items:center;gap:12px;background:var(--bg3);
  border-radius:var(--r);padding:10px 12px;border:0.5px solid var(--border);
}
.queue-num{font-size:11px;color:var(--text3);font-family:var(--mono);min-width:18px;}
.queue-name{flex:1;font-size:12px;font-weight:600;color:var(--text);}
.queue-meta{font-size:10px;color:var(--text3);font-family:var(--mono);}
.queue-time{font-size:11px;color:var(--text2);font-family:var(--mono);text-align:right;min-width:42px;}

/* ─── PRODUCTS ─── */
.product-card{
  background:var(--bg2);border-radius:var(--r2);border:0.5px solid var(--border);
  padding:14px;cursor:pointer;transition:all 0.15s;
}
.product-card:hover{border-color:var(--border2);transform:translateY(-1px);}
.prod-emoji{font-size:28px;margin-bottom:8px;}
.prod-name{font-size:12px;font-weight:600;color:var(--text);margin-bottom:3px;}
.prod-sku{font-size:10px;color:var(--text3);font-family:var(--mono);margin-bottom:8px;}
.prod-price{font-size:15px;font-weight:700;color:var(--ferrari);margin-bottom:4px;}
.prod-stock{font-size:10px;font-family:var(--mono);}
.stock-ok{color:var(--teal);}
.stock-low{color:var(--amber);}
.stock-out{color:var(--coral);}

/* ─── ACTIVITY ─── */
.activity-list{display:flex;flex-direction:column;}
.activity-item{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:0.5px solid var(--border);}
.activity-item:last-child{border-bottom:none;}
.act-dot{width:28px;height:28px;border-radius:8px;flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:1px;}
.act-dot svg{width:14px;height:14px;}
.act-body{flex:1;}
.act-text{font-size:12px;color:var(--text);line-height:1.4;}
.act-text strong{font-weight:600;}
.act-time{font-size:10px;color:var(--text3);font-family:var(--mono);margin-top:2px;}

/* ─── CHART BARS ─── */
.chart-area{display:flex;align-items:flex-end;gap:4px;height:56px;margin-top:12px;}
.chart-bar{flex:1;border-radius:3px 3px 0 0;transition:opacity 0.15s;cursor:pointer;}
.chart-bar:hover{opacity:0.7;}
.chart-labels{display:flex;justify-content:space-between;margin-top:5px;}
.chart-labels span{font-size:9px;color:var(--text3);font-family:var(--mono);}

/* ─── GAUGE ─── */
.gauge-row{display:flex;gap:10px;flex-wrap:wrap;}
.gauge-item{flex:1;min-width:80px;}
.gauge-label{font-size:10px;color:var(--text3);font-family:var(--mono);margin-bottom:5px;text-align:center;}
.gauge-circle-wrap{position:relative;width:56px;height:56px;margin:0 auto 4px;}
.gauge-circle-wrap svg{transform:rotate(-90deg);}
.gauge-pct{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;font-family:var(--mono);}

/* ─── PRINTERS PAGE ─── */
.printer-card{background:var(--bg2);border-radius:var(--r2);border:0.5px solid var(--border);padding:18px;}
.printer-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.printer-title{font-size:15px;font-weight:700;}
.printer-specs{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:14px;}
.spec-item{background:var(--bg3);border-radius:8px;padding:10px;}
.spec-label{font-size:10px;color:var(--text3);font-family:var(--mono);margin-bottom:3px;}
.spec-val{font-size:13px;font-weight:600;color:var(--text);}

/* ─── MODAL ─── */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,0.7);z-index:100;
  display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px);
}
.modal-overlay.open{display:flex;}
.modal{
  background:var(--bg2);border-radius:var(--r2);border:0.5px solid var(--border2);
  padding:24px;width:480px;max-width:95vw;max-height:90vh;overflow-y:auto;
}
.modal-title{font-size:16px;font-weight:700;margin-bottom:18px;color:var(--text);}
.modal-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:20px;padding-top:16px;border-top:0.5px solid var(--border);}

/* ─── FORM ─── */
.form-group{margin-bottom:14px;}
.form-label{font-size:11px;color:var(--text3);font-family:var(--mono);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:6px;display:block;}
.form-input{
  width:100%;background:var(--bg3);border:0.5px solid var(--border2);border-radius:8px;
  padding:9px 12px;color:var(--text);font-size:13px;outline:none;transition:border-color 0.15s;
}
.form-input:focus{border-color:var(--ferrari);}
.form-input::placeholder{color:var(--text3);}
select.form-input option{background:var(--bg3);color:var(--text);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}

/* ─── TABLE ─── */
.data-table{width:100%;border-collapse:collapse;}
.data-table th{font-size:10px;color:var(--text3);font-family:var(--mono);text-transform:uppercase;letter-spacing:0.5px;padding:8px 12px;text-align:left;border-bottom:0.5px solid var(--border);}
.data-table td{font-size:12px;padding:10px 12px;border-bottom:0.5px solid var(--border);color:var(--text);}
.data-table tr:last-child td{border-bottom:none;}
.data-table tr:hover td{background:rgba(255,255,255,0.02);}
.data-table .mono{font-family:var(--mono);color:var(--text2);}

/* ─── MAINTENANCE ─── */
.maint-card{background:var(--bg2);border-radius:var(--r2);border:0.5px solid var(--border);padding:16px;margin-bottom:10px;}
.maint-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.maint-title{font-size:13px;font-weight:600;}
.maint-meta{font-size:11px;color:var(--text3);font-family:var(--mono);}

/* ─── TOAST ─── */
.toast{
  position:fixed;bottom:24px;right:24px;background:var(--bg2);border:0.5px solid var(--border2);
  border-radius:var(--r);padding:12px 16px;font-size:13px;z-index:200;
  transform:translateY(80px);opacity:0;transition:all 0.3s;pointer-events:none;
  display:flex;align-items:center;gap:10px;
}
.toast.show{transform:translateY(0);opacity:1;}
.toast-icon{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;}

/* ─── EMPTY STATE ─── */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;color:var(--text3);gap:12px;}
.empty-state svg{width:40px;height:40px;opacity:0.3;}
.empty-state p{font-size:13px;font-family:var(--mono);}

/* ─── ADD CARD ─── */
.add-card{
  background:var(--bg2);border-radius:var(--r2);border:0.5px dashed var(--border2);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-height:120px;cursor:pointer;transition:all 0.15s;color:var(--text3);gap:8px;padding:14px;
}
.add-card:hover{border-color:var(--ferrari);color:var(--ferrari);background:rgba(232,255,71,0.03);}
.add-card svg{width:24px;height:24px;}
.add-card span{font-size:12px;font-family:var(--mono);}

/* ─── COST CALCULATOR ─── */
.calc-panel{background:var(--bg3);border-radius:var(--r);padding:14px;margin-top:10px;}
.calc-result{font-size:22px;font-weight:700;color:var(--ferrari);margin:10px 0 4px;}
.calc-breakdown{font-size:11px;color:var(--text3);font-family:var(--mono);}

/* ─── RESPONSIVE ─── */

/* ─── MOBILE NAV ─── */
.mobile-topbar{
  display:none;position:sticky;top:0;z-index:50;
  background:var(--bg2);border-bottom:0.5px solid var(--border);box-shadow:0 1px 0 var(--ferrari-dim);
  padding:12px 16px;align-items:center;justify-content:space-between;
}
.mobile-menu-btn{
  width:36px;height:36px;background:var(--bg3);border:0.5px solid var(--border2);
  border-radius:8px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;flex-direction:column;gap:4px;
}
.mobile-menu-btn span{
  display:block;width:16px;height:2px;background:var(--text2);border-radius:2px;
  transition:all 0.2s;
}
.mobile-overlay{
  display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);
  z-index:98;backdrop-filter:blur(2px);
}
.mobile-overlay.open{display:block;}

/* ─── DESKTOP ─── */
@media(min-width:901px){
  .mobile-topbar{display:none !important;}
  .mobile-overlay{display:none !important;}
}

/* ─── TABLET + MOBILE ─── */
@media(max-width:900px){
  .app{grid-template-columns:1fr;}
  .mobile-topbar{display:flex;}
  .sidebar{
    position:fixed;top:0;left:-260px;width:260px;height:100vh;
    z-index:99;transition:left 0.28s cubic-bezier(0.4,0,0.2,1);
    box-shadow:none;
  }
  .sidebar.open{
    left:0;
    box-shadow:4px 0 24px rgba(0,0,0,0.3);
  }
  .sidebar-footer{display:flex !important;flex-direction:column;}
  .main{padding-top:0;}
  .topbar{display:none;}
  .stats-row,.projects-grid,.grid-3,.grid-4{grid-template-columns:repeat(2,1fr);}
  .grid-2,.grid-2-1,.grid-1-2{grid-template-columns:1fr;}
  .section{padding:14px 14px 32px;}
}
@media(max-width:560px){
  .stats-row,.projects-grid,.grid-4{grid-template-columns:1fr 1fr;}
  .grid-3{grid-template-columns:1fr;}
  .grid-2{grid-template-columns:1fr;}
  #sec-costos > div:last-child{grid-template-columns:1fr;}
  /* Calculadora costos — columna derecha va abajo en mobile */
  #costos-main-grid{grid-template-columns:1fr !important;}
  /* Portal detail grid — 1 columna en mobile */
  .portal-detail-grid{grid-template-columns:1fr !important;}
  /* Tabs de materiales — wrappear */
  #sec-materiales [style*="width:fit-content"]{width:100% !important;}
}

/* ─── COST CALCULATOR ─── */
.calc-card{background:var(--bg2);border-radius:var(--r2);border:0.5px solid var(--border);padding:16px;}
.calc-card-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--text);margin-bottom:14px;}
.calc-currency-btn{padding:8px 18px;border-radius:8px;border:none;background:none;color:var(--text2);font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font);transition:all 0.15s;}
.calc-currency-btn.active{background:var(--navy);color:#fff;}
.calc-currency-btn:hover:not(.active){background:var(--bg4);color:var(--text);}
.calc-toggle-btn{flex:1;padding:9px 12px;border-radius:8px;border:none;background:var(--bg3);color:var(--text2);font-size:12px;font-weight:600;cursor:pointer;font-family:var(--font);transition:all 0.15s;}
.calc-toggle-btn.active{background:var(--navy);color:#fff;}
.calc-preset-btn{padding:9px 8px;border-radius:8px;border:0.5px solid var(--border2);background:var(--bg3);color:var(--text2);font-size:12px;font-weight:600;cursor:pointer;font-family:var(--font);transition:all 0.15s;text-align:center;}
.calc-preset-btn:hover{border-color:var(--blue);color:var(--blue);}
.calc-preset-btn.active{background:var(--navy);color:#fff;border-color:var(--navy);}
.calc-result-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:0.5px solid var(--border);font-size:13px;}
.calc-result-row:last-child{border-bottom:none;}
.calc-result-row .label{color:var(--text2);display:flex;align-items:center;gap:6px;}
.calc-result-row .val{font-family:var(--mono);color:var(--text);}
.calc-filamento-row{background:var(--bg3);border-radius:var(--r);padding:12px;border:0.5px solid var(--border);margin-bottom:8px;}

/* ─── MATERIAL MODAL ─── */
.mat-peso-btn{
  padding:7px 14px;border-radius:8px;font-size:12px;font-weight:600;
  background:var(--bg3);color:var(--text2);border:0.5px solid var(--border2);
  cursor:pointer;font-family:var(--font);transition:all 0.15s;
}
.mat-peso-btn:hover{background:var(--bg4);color:var(--text);}
.mat-peso-btn.active{background:var(--navy);color:#ffffff;border-color:var(--navy);}
.mat-dropdown-item{
  display:flex;align-items:center;gap:12px;padding:11px 16px;cursor:pointer;
  font-size:13px;color:var(--text);transition:background 0.1s;border-bottom:0.5px solid var(--border);
}
.mat-dropdown-item:last-child{border-bottom:none;}
.mat-dropdown-item:hover{background:rgba(255,255,255,0.05);}
.mat-dropdown-item.selected{background:rgba(232,255,71,0.08);color:var(--ferrari);}
.mat-dropdown-item .item-name{font-weight:600;}
.mat-dropdown-item .item-desc{font-size:11px;color:var(--text3);font-family:var(--mono);}
.mat-color-swatch-item{width:20px;height:20px;border-radius:50%;flex-shrink:0;border:0.5px solid var(--border2);}
.mat-checkmark{margin-left:auto;color:var(--ferrari);font-size:14px;}

.login-screen{position:fixed;inset:0;background:var(--bg);z-index:999;display:flex;align-items:center;justify-content:center;}
.login-screen.hidden{display:none;}
.login-card{background:var(--bg2);border:0.5px solid var(--border2);border-radius:20px;padding:48px 40px;text-align:center;width:380px;max-width:92vw;}
.login-logo{width:56px;height:56px;background:var(--accent);border-radius:14px;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;}
.login-logo svg{width:28px;height:28px;}
.login-title{font-size:22px;font-weight:700;color:var(--text);margin-bottom:6px;letter-spacing:-0.5px;}
.login-sub{font-size:13px;color:var(--text3);font-family:var(--mono);margin-bottom:32px;}
.btn-google{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:13px 20px;border-radius:10px;border:1.5px solid rgba(26,58,107,0.3);background:var(--bg3);color:var(--text);font-size:14px;font-weight:600;cursor:pointer;font-family:var(--font);transition:all 0.15s;}
.btn-google:hover{background:var(--bg4);border-color:var(--border3);}
.btn-google svg{width:20px;height:20px;flex-shrink:0;}
.login-footer{margin-top:20px;font-size:11px;color:var(--text3);font-family:var(--mono);}
.login-error{background:rgba(255,107,91,0.1);border:0.5px solid rgba(255,107,91,0.3);border-radius:8px;padding:10px 14px;font-size:12px;color:var(--coral);margin-bottom:16px;display:none;font-family:var(--mono);}

/* ─── THEME SYSTEM ─── */
/* Dark theme (default) */
:root, [data-theme="dark"] {
  --bg:#000000;--bg2:#0d0d0f;--bg3:#161618;--bg4:#1e1e22;
  --border:rgba(255,255,255,0.06);--border2:rgba(255,255,255,0.11);--border3:rgba(255,255,255,0.17);
  --text:#f2f2f2;--text2:#8a8a96;--text3:#505058;
  --accent:#f97316;--accent2:#1a3a6b;--blue:#f97316;
  --ferrari:#f97316;--ferrari-dim:rgba(249,115,22,0.35);
  --teal:#34d399;--coral:#f97316;--amber:#fbbf24;--purple:#a78bfa;--green:#34d399;
  --shadow:0 2px 20px rgba(0,0,0,0.7);
}
/* Light theme */
[data-theme="light"] {
  --bg:#f5f5f7;--bg2:#ffffff;--bg3:#ebebed;--bg4:#e0e0e4;
  --border:rgba(0,0,0,0.08);--border2:rgba(0,0,0,0.15);--border3:rgba(0,0,0,0.22);
  --text:#0d0d0f;--text2:#3a3a42;--text3:#6b6b78;
  --accent:#f97316;--accent2:#152f58;--blue:#1a3a6b;
  --ferrari:#cc2200;--ferrari-dim:rgba(204,34,0,0.2);
  --teal:#059669;--coral:#cc2200;--amber:#d97706;--purple:#7c3aed;--green:#059669;
  --shadow:0 2px 12px rgba(0,0,0,0.08);
}
/* Auto: follow system */
@media(prefers-color-scheme:light){
  [data-theme="auto"] {
    --bg:#f5f5f7;--bg2:#ffffff;--bg3:#ebebed;--bg4:#e0e0e4;
    --border:rgba(0,0,0,0.08);--border2:rgba(0,0,0,0.15);--border3:rgba(0,0,0,0.22);
    --text:#0d0d0f;--text2:#3a3a42;--text3:#6b6b78;
    --accent:#f97316;--accent2:#152f58;--blue:#1a3a6b;
    --ferrari:#cc2200;--ferrari-dim:rgba(204,34,0,0.2);
    --teal:#059669;--coral:#cc2200;--amber:#d97706;--purple:#7c3aed;--green:#059669;
    --shadow:0 2px 12px rgba(0,0,0,0.08);
  }
}

/* ─── THEME TOGGLE ─── */
.theme-toggle{
  display:flex;gap:4px;padding:3px;background:var(--bg3);
  border-radius:8px;border:0.5px solid var(--border);margin:10px 10px 0;
}
.theme-btn{
  flex:1;padding:5px 4px;border-radius:6px;font-size:10px;font-weight:600;
  cursor:pointer;text-align:center;color:var(--text3);transition:all 0.15s;
  font-family:var(--mono);border:none;background:none;
}
.theme-btn.active{background:var(--bg2);color:var(--text);border:0.5px solid var(--border);}

/* ─── PRINTER STATUS CARD IN SIDEBAR ─── */
.sidebar-printer-select{
  padding:10px;border-top:0.5px solid var(--border);
}
.printer-select-label{
  font-size:9px;color:var(--text3);font-family:var(--mono);
  text-transform:uppercase;letter-spacing:1px;margin-bottom:6px;padding:0 2px;
}
.printer-select-dropdown{
  width:100%;background:var(--bg3);border:0.5px solid var(--border2);
  border-radius:7px;padding:6px 8px;color:var(--text);font-size:11px;
  font-family:var(--mono);outline:none;cursor:pointer;
}

/* ─── PRINTER CARD REDESIGN ─── */
.printer-card-v2{
  background:var(--bg2);border-radius:var(--r2);border:0.5px solid var(--border);
  overflow:hidden;transition:border-color 0.15s;
}
.printer-card-v2:hover{border-color:var(--border2);}
.printer-card-v2-inner{display:grid;grid-template-columns:160px 1fr;}
.printer-card-v2-img{
  position:relative;background:var(--bg3);
  display:flex;align-items:center;justify-content:center;
  border-right:0.5px solid var(--border);min-height:180px;
}
.printer-card-v2-img img{width:100%;height:100%;object-fit:cover;display:block;}
.printer-card-v2-imginfo{
  position:absolute;bottom:0;left:0;right:0;
  padding:8px 10px;background:linear-gradient(transparent,rgba(0,0,0,0.7));
}
.printer-card-v2-body{padding:16px;}

/* Status badge improved */
.status-badge-large{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 12px;border-radius:20px;font-size:11px;font-weight:700;
  font-family:var(--mono);letter-spacing:0.3px;
}
