/* ═══════════════════════════════════════════════════════
   Eurorejas — Design System v8
   Modo oscuro (default) + Modo claro completo
   ═══════════════════════════════════════════════════════ */

/* ── VARIABLES MODO OSCURO (default) ─────────────────── */
:root {
  --bg0:#1C1C1A; --bg1:#1E1E1C; --bg2:#242422; --bg3:#2C2C2A; --bg4:#343432;
  --bdr:#3A3A38; --bdr2:#4A4A48;
  --text:#F0EFEC; --text2:#A8A8A4; --text3:#6E6E6A;
  --teal:#5DCAA5; --teal-d:#1D9E75; --teal-bg:rgba(93,202,165,.15);
  --blue:#85B7EB; --blue-d:#185FA5; --blue-bg:rgba(133,183,235,.15);
  --amber:#EF9F27; --amber-bg:rgba(239,159,39,.15);
  --red:#E24B4A; --red-bg:rgba(226,75,74,.12);
  --sem-green:#5DCAA5; --sem-yellow:#EF9F27; --sem-red:#E24B4A; --sem-gray:#6E6E6A;
  --pill-green-bg:rgba(93,202,165,.18); --pill-green-t:#5DCAA5;
  --pill-yellow-bg:rgba(239,159,39,.18); --pill-yellow-t:#EF9F27;
  --pill-red-bg:rgba(226,75,74,.15); --pill-red-t:#E24B4A;
  --pill-blue-bg:rgba(133,183,235,.18); --pill-blue-t:#85B7EB;
  --pill-gray-bg:#343432; --pill-gray-t:#A8A8A4;
  --sidebar:#1E1E1C; --sidebar-item:rgba(255,255,255,.07); --sidebar-active:rgba(93,202,165,.15);
  --topbar-bg:var(--bg3);
  --input-bg:var(--bg3); --input-border:var(--bdr2);
  --shadow:0 2px 12px rgba(0,0,0,.4); --shadow-lg:0 8px 32px rgba(0,0,0,.5);
  --thead-bg:var(--bg3); --row-hover:var(--bg3);
  --kwh-bg:#1A1A18; --kwh-bdr:#3A3A38;
  --radius:10px; --radius-lg:14px; --radius-xl:20px;
  /* ── Aliases de compatibilidad ─────────────────── */
  --card:var(--bg2); --card-border:var(--bdr); --sep:var(--bdr);
  --navy:var(--bg3); --blue-soft:var(--blue-bg); --bg:var(--bg0);
}

/* ── VARIABLES MODO CLARO ─────────────────────────────── */
[data-theme="light"] {
  --bg0:#F4F6F8; --bg1:#EAEEF2; --bg2:#FFFFFF; --bg3:#F0F3F6; --bg4:#E4E9EE;
  --bdr:#D1D9E0; --bdr2:#B8C4CE;
  --text:#1A2332; --text2:#4A6070; --text3:#7A93A6;
  --teal:#0F8A6A; --teal-d:#0A6B52; --teal-bg:rgba(15,138,106,.1);
  --blue:#1A6FA5; --blue-d:#0F5280; --blue-bg:rgba(26,111,165,.1);
  --amber:#C07010; --amber-bg:rgba(192,112,16,.1);
  --red:#C02828; --red-bg:rgba(192,40,40,.08);
  --sem-green:#0F8A6A; --sem-yellow:#C07010; --sem-red:#C02828; --sem-gray:#7A93A6;
  --pill-green-bg:rgba(15,138,106,.12); --pill-green-t:#0A6B52;
  --pill-yellow-bg:rgba(192,112,16,.12); --pill-yellow-t:#8A5800;
  --pill-red-bg:rgba(192,40,40,.08); --pill-red-t:#7A1515;
  --pill-blue-bg:rgba(26,111,165,.1); --pill-blue-t:#0F5280;
  --pill-gray-bg:#E4E9EE; --pill-gray-t:#4A6070;
  --sidebar:#232B35; --sidebar-item:rgba(255,255,255,.08); --sidebar-active:rgba(15,138,106,.18);
  --topbar-bg:#FFFFFF;
  --input-bg:#FFFFFF; --input-border:var(--bdr2);
  --shadow:0 2px 8px rgba(0,0,0,.08); --shadow-lg:0 8px 24px rgba(0,0,0,.12);
  --thead-bg:#EEF2F6; --row-hover:#F4F7FA;
  --kwh-bg:#1A2332; --kwh-bdr:#2A3A4A;
  /* ── Aliases de compatibilidad ─────────────────── */
  --card:#FFFFFF; --card-border:var(--bdr); --sep:var(--bdr);
  --navy:var(--bg3); --blue-soft:var(--blue-bg); --bg:var(--bg0);
}

/* ── RESET ───────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px}
body{font-family:-apple-system,BlinkMacSystemFont,"Inter","Segoe UI",sans-serif;
  background:var(--bg0);color:var(--text);min-height:100vh;line-height:1.5;
  -webkit-font-smoothing:antialiased;transition:background .2s,color .2s}
a{color:var(--teal);text-decoration:none}
a:hover{text-decoration:underline}

/* ── APP SHELL ───────────────────────────────────────── */
.app-shell{display:flex;min-height:100vh}

/* ── SIDEBAR ─────────────────────────────────────────── */
.sidebar{width:224px;flex-shrink:0;background:var(--sidebar);border-right:1px solid var(--bdr);
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;z-index:100;
  transition:background .2s,border-color .2s}
.brand-area{padding:1rem 1.1rem;border-bottom:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:3px}
.brand-area img{max-height:30px;max-width:140px;object-fit:contain;filter:brightness(1.15)}
.brand-subtitle{font-size:10px;color:rgba(255,255,255,.55);letter-spacing:.04em}
.nav-section{padding:.75rem .75rem .5rem;flex:1}
.nav-section-label{font-size:10px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;
  color:rgba(255,255,255,.5);padding:.4rem .5rem .3rem;margin-bottom:2px}
.nav-link{display:flex;align-items:center;gap:9px;padding:7px 10px;border-radius:8px;font-size:13px;
  font-weight:500;color:rgba(255,255,255,.75);cursor:pointer;transition:background .12s,color .12s;
  margin-bottom:1px;text-decoration:none}
.nav-link:hover{background:rgba(255,255,255,.1);color:#fff;text-decoration:none}
.nav-link.active{background:rgba(93,202,165,.2);color:var(--teal);font-weight:600}
.nav-link .nav-icon{font-size:15px;flex-shrink:0;opacity:.85}
.sidebar-foot{padding:.75rem;border-top:rgba(255,255,255,.08) 1px solid}
.user-chip{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:8px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);margin-bottom:6px}
.user-chip-info strong{display:block;font-size:12px;font-weight:600;color:#fff}
.user-chip-info span{font-size:10px;color:rgba(255,255,255,.6)}
.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--teal-bg);
  border:1px solid rgba(93,202,165,.4);display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;color:var(--teal);flex-shrink:0;object-fit:cover}

/* ── MAIN PANEL ──────────────────────────────────────── */
.main-panel{flex:1;min-width:0;display:flex;flex-direction:column}

/* ── TOPBAR ──────────────────────────────────────────── */
.topbar{background:var(--topbar-bg);border-bottom:1px solid var(--bdr);padding:.7rem 1.5rem;
  display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;
  min-height:56px;transition:background .2s,border-color .2s;box-shadow:var(--shadow)}
.topbar-left .eyebrow{font-size:10px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;
  color:var(--text3);margin-bottom:1px}
.topbar-left h1{font-size:17px;font-weight:700;color:var(--text);line-height:1.2}
.topbar-right{display:flex;align-items:center;gap:8px}
.topbar-user{display:flex;align-items:center;gap:8px}
.topbar-user-info strong{font-size:13px;font-weight:600;color:var(--text)}
.topbar-user-info span{font-size:11px;color:var(--text3);display:block}
.theme-toggle-btn{background:var(--bg4);border:1px solid var(--bdr2);border-radius:7px;
  padding:5px 10px;font-size:12px;cursor:pointer;color:var(--text2);transition:background .12s;
  white-space:nowrap;font-family:inherit}
.theme-toggle-btn:hover{background:var(--bg3);color:var(--text)}
.notif-btn{background:var(--bg4);border:1px solid var(--bdr2);border-radius:7px;
  padding:5px 10px;font-size:14px;cursor:pointer;position:relative;transition:background .12s}
.notif-btn:hover{background:var(--bg3)}
.notif-badge{position:absolute;top:-4px;right:-4px;background:var(--red);color:#fff;font-size:9px;
  font-weight:700;min-width:16px;height:16px;border-radius:999px;display:flex;
  align-items:center;justify-content:center;padding:0 3px}
.sidebar-toggle{display:none;background:none;border:none;color:var(--text2);font-size:22px;
  cursor:pointer;margin-right:8px;padding:2px 6px;border-radius:6px}
.sidebar-toggle:hover{background:var(--bg4)}
@media(max-width:768px){.sidebar-toggle{display:inline-flex;align-items:center}}

/* ── PAGE CONTENT ────────────────────────────────────── */
.page-content{padding:1.5rem;flex:1}
@media(max-width:640px){.page-content{padding:1rem}}

/* ── CARDS ───────────────────────────────────────────── */
.card{background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--radius-lg);
  padding:1.1rem 1.25rem;margin-bottom:1rem;transition:background .2s,border-color .2s}
.card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:.85rem}
.card-head h2,.card-head h3{font-size:15px;font-weight:700;color:var(--text);line-height:1.3}
.eyebrow{font-size:10px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--text3);margin-bottom:2px}

/* ── METRICS ─────────────────────────────────────────── */
.metrics-grid{display:grid;gap:10px;margin-bottom:1rem}
.metrics-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.metrics-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.metrics-grid.cols-4{grid-template-columns:repeat(2,1fr)}
@media(min-width:720px){.metrics-grid.cols-4{grid-template-columns:repeat(4,1fr)}.metrics-grid.cols-3{grid-template-columns:repeat(3,1fr)}}
.metric-card{background:var(--bg3);border:1px solid var(--bdr);border-radius:var(--radius);padding:.85rem 1rem;transition:background .2s}
.m-label{font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text3);margin-bottom:5px}
.m-value{font-size:26px;font-weight:700;color:var(--text);line-height:1;margin-bottom:4px;font-variant-numeric:tabular-nums}
.m-sub{font-size:11px;color:var(--text3);display:flex;align-items:center;gap:4px;flex-wrap:wrap}

/* ── TWO COL ─────────────────────────────────────────── */
.two-col{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:1rem}
@media(min-width:900px){.two-col{grid-template-columns:1fr 1fr}}

/* ── BUTTONS ─────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:8px;font-size:13px;
  font-weight:500;font-family:inherit;cursor:pointer;border:1px solid var(--bdr2);background:transparent;
  color:var(--text);transition:background .12s,border-color .12s;text-decoration:none;white-space:nowrap}
.btn:hover{background:var(--bg4);text-decoration:none}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--teal);color:#fff;border-color:var(--teal);font-weight:600}
.btn-primary:hover{background:var(--teal-d);border-color:var(--teal-d)}
.btn-ghost{background:transparent;border-color:var(--bdr2);color:var(--text2)}
.btn-ghost:hover{background:var(--bg4);color:var(--text)}
.btn-danger{background:var(--red-bg);border-color:rgba(192,40,40,.35);color:var(--red)}
.btn-danger:hover{opacity:.8}
.btn-warning{background:var(--amber-bg);border-color:rgba(192,112,16,.35);color:var(--amber)}
.btn-success{background:var(--teal-bg);border:1px solid rgba(15,138,106,.4);color:var(--teal);font-weight:600}
.btn-success:hover{opacity:.85}
.btn-sm{padding:5px 10px;font-size:12px}
.btn-lg{padding:10px 20px;font-size:14px}
.btn-full{width:100%;justify-content:center}

/* ── FORMS ───────────────────────────────────────────── */
.form-group{margin-bottom:1rem}
.form-label{display:block;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:5px;letter-spacing:.02em}
.form-control{width:100%;padding:8px 12px;border-radius:8px;border:1px solid var(--bdr2);
  background:var(--input-bg);color:var(--text);font-size:13px;font-family:inherit;transition:border-color .15s}
.form-control:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-bg)}
.form-control::placeholder{color:var(--text3)}
textarea.form-control{resize:vertical;min-height:80px;line-height:1.6}
select.form-control{appearance:none;cursor:pointer;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='%236E6E6A' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px}
.form-hint{font-size:11px;color:var(--text3);margin-top:4px}
.form-row{display:grid;gap:12px}
@media(min-width:600px){.form-row.cols-2{grid-template-columns:1fr 1fr}}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
@media(max-width:600px){.form-grid-2,.form-grid-3{grid-template-columns:1fr}}
.form-section-title{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--text3);border-bottom:1px solid var(--bdr);padding-bottom:6px;margin-bottom:12px;margin-top:1.2rem}

/* ── PILLS ───────────────────────────────────────────── */
.pill{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:600;white-space:nowrap}
.pill-green{background:var(--pill-green-bg);color:var(--pill-green-t)}
.pill-yellow{background:var(--pill-yellow-bg);color:var(--pill-yellow-t)}
.pill-red{background:var(--pill-red-bg);color:var(--pill-red-t)}
.pill-blue{background:var(--pill-blue-bg);color:var(--pill-blue-t)}
.pill-gray{background:var(--pill-gray-bg);color:var(--pill-gray-t)}

/* ── LIVE DOTS ───────────────────────────────────────── */
.live-dot,.busy-dot{display:inline-block;width:7px;height:7px;border-radius:50%;flex-shrink:0}
.live-dot{background:var(--teal);box-shadow:0 0 5px rgba(93,202,165,.7);animation:pulse 2s infinite}
.busy-dot{background:var(--amber);box-shadow:0 0 5px rgba(239,159,39,.7);animation:pulse 1.2s infinite}
.sem{display:inline-block;width:7px;height:7px;border-radius:50%;flex-shrink:0}
.sem-green{background:var(--teal)}.sem-yellow{background:var(--amber)}.sem-red{background:var(--red)}.sem-gray{background:var(--text3)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* ── TABLES ──────────────────────────────────────────── */
.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--bdr)}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{background:var(--thead-bg);padding:9px 12px;text-align:left;font-size:10px;font-weight:700;
  letter-spacing:.07em;text-transform:uppercase;color:var(--text3);white-space:nowrap;border-bottom:1px solid var(--bdr)}
tbody tr{border-bottom:1px solid var(--bdr);transition:background .1s}
tbody tr:last-child{border-bottom:none}
tbody tr:hover{background:var(--row-hover)}
td{padding:9px 12px;vertical-align:middle;color:var(--text)}
th[data-sortable]{cursor:pointer;user-select:none}
th[data-sortable]:hover{color:var(--teal)}
th[data-sortable]::after{content:' ↕';opacity:.4;font-size:10px}
th[data-sortable].asc::after{content:' ↑';opacity:1;color:var(--teal)}
th[data-sortable].desc::after{content:' ↓';opacity:1;color:var(--teal)}

/* ── NOTICES ─────────────────────────────────────────── */
.notice{display:flex;align-items:flex-start;gap:10px;padding:.75rem 1rem;border-radius:var(--radius);border:1px solid;font-size:13px;margin-bottom:.5rem;color:var(--text)}
.notice-info   {background:var(--blue-bg);border-color:rgba(133,183,235,.5)}
.notice-info   .notice-title{color:var(--blue-d)}
.notice-info   .notice-sub  {color:var(--text2)}
.notice-warn   {background:var(--red-bg);border-color:rgba(226,75,74,.45)}
.notice-warn   .notice-title{color:var(--red)}
.notice-warn   .notice-sub  {color:var(--text2)}
.notice-success{background:var(--teal-bg);border-color:rgba(93,202,165,.5)}
.notice-success .notice-title{color:var(--teal)}
.notice-success .notice-sub  {color:var(--text2)}
.notice-amber  {background:var(--amber-bg);border-color:rgba(239,159,39,.5)}
.notice-amber  .notice-title{color:var(--amber)}
.notice-amber  .notice-sub  {color:var(--text2)}
.notice-title{font-weight:600;margin-bottom:2px;font-size:13px}
.notice-sub{font-size:12px;line-height:1.5}

/* ── FLASH MESSAGES ──────────────────────────────────── */
.flash-stack{padding:.75rem 1.5rem 0;display:flex;flex-direction:column;gap:6px}
@media(max-width:640px){.flash-stack{padding:.6rem 1rem 0}}
.flash-success{background:var(--teal-bg);border:1px solid var(--teal);color:var(--teal);border-radius:var(--radius);padding:.7rem 1rem;margin-bottom:.75rem;font-size:13px;font-weight:500}
.flash-danger{background:var(--red-bg);border:1px solid rgba(226,75,74,.45);border-left:3px solid var(--red);color:var(--red);border-radius:var(--radius);padding:.65rem 1rem;margin-bottom:.75rem;font-size:13px;font-weight:500}
.flash-danger strong,.flash-danger b{color:var(--red)}
.flash-danger span,.flash-danger p{color:var(--text2)}
.flash-warning{background:var(--amber-bg);border:1px solid rgba(239,159,39,.45);border-left:3px solid var(--amber);color:var(--amber);border-radius:var(--radius);padding:.65rem 1rem;margin-bottom:.75rem;font-size:13px;font-weight:500}
.flash-warning strong,.flash-warning b{color:var(--amber)}
.flash-warning span,.flash-warning p{color:var(--text2)}
.flash-info{background:var(--blue-bg);border:1px solid var(--blue);color:var(--blue);border-radius:var(--radius);padding:.7rem 1rem;margin-bottom:.75rem;font-size:13px;font-weight:500}

/* ── LIST ROWS ───────────────────────────────────────── */
.list-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--bdr)}
.list-row:last-child{border-bottom:none}
.list-row-name{font-size:13px;font-weight:600;color:var(--text)}
.list-row-sub{font-size:11px;color:var(--text3);margin-top:1px}
.person-av{width:36px;height:36px;border-radius:50%;background:var(--bg4);border:1px solid var(--bdr2);
  display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--text2);flex-shrink:0}

/* ── MACHINE CARDS ───────────────────────────────────── */
.machine-card{background:var(--bg3);border:1px solid var(--bdr);border-radius:var(--radius);padding:9px 11px;font-size:12px;transition:background .2s,border-color .15s}
.machine-card.busy{border-color:var(--amber);background:var(--amber-bg)}
.machine-card.free{border-color:var(--teal);background:var(--teal-bg)}
.machine-card.maintenance{border-color:var(--red);background:var(--red-bg)}
.mc-name{font-weight:600;color:var(--text);margin-bottom:3px}
.mc-status{font-size:11px;display:flex;align-items:center;gap:4px}
.mc-status.busy{color:var(--amber)}.mc-status.free{color:var(--teal)}.mc-status.blocked{color:var(--red)}

/* ── PROGRESS BAR ────────────────────────────────────── */
.bar-wrap{height:5px;background:var(--bg4);border-radius:999px;overflow:hidden}
.bar-fill{height:100%;border-radius:999px;background:var(--teal);transition:width .3s}
.prog-mini{height:3px;background:var(--bg4);border-radius:999px;overflow:hidden;margin-top:3px}
.prog-mini-f{height:100%;border-radius:999px;background:var(--teal)}

/* ── STAGE CARDS ─────────────────────────────────────── */
.stage-card{background:var(--bg3);border:1.5px solid var(--bdr);border-radius:var(--radius);overflow:hidden;margin-bottom:.75rem;transition:border-color .2s}
/* Active/paused get coloured border AND subtle bg tint */
.stage-active,.stage-card.stage-active{border-color:var(--teal)!important;background:rgba(93,202,165,.05)}
.stage-paused,.stage-card.stage-paused{border-color:var(--amber)!important;background:rgba(239,159,39,.04)}
.stage-done,.stage-card.stage-done{opacity:.8}
.stage-pending,.stage-card.stage-pending{border-color:var(--bdr)}
/* ── Stage header ── */
.stage-header{display:flex;align-items:center;gap:12px;padding:14px 16px;cursor:pointer;user-select:none;transition:background .1s}
.stage-header:hover{background:rgba(255,255,255,.03)}
.stage-info{flex:1;min-width:0}
.stage-name{font-size:14px;font-weight:600;color:var(--text);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.stage-meta{display:flex;flex-wrap:wrap;gap:6px;font-size:11px;color:var(--text2);align-items:center}
/* ── Stage body ── */
.stage-body{padding:14px 16px 16px;border-top:1.5px solid var(--bdr);display:flex;flex-direction:column;gap:12px}
.stage-body.hidden{display:none}
/* ── Stage status indicator circles ── */
.stage-num{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;background:var(--bg4);color:var(--text2);border:1.5px solid var(--bdr2);transition:all .2s}
.stage-num.active{background:var(--teal-bg);color:var(--teal);border-color:var(--teal)}
.stage-num.done{background:var(--teal-bg);color:var(--teal);border-color:var(--teal);font-size:15px}
.stage-num.paused-num{background:var(--amber-bg);color:var(--amber);border-color:var(--amber)}
.stage-head{display:flex;align-items:center;gap:10px;padding:10px 13px;cursor:pointer;background:var(--bg3);user-select:none}
.stage-head:hover{background:var(--bg4)}
.stage-body{padding:12px 14px;border-top:1px solid var(--bdr);display:flex;flex-direction:column;gap:10px}
.stage-body.hidden{display:none}

/* ── DATA ROWS ───────────────────────────────────────── */
.data-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--bdr);font-size:13px}
.data-row:last-child{border-bottom:none}
.data-row .label{color:var(--text3);font-size:12px}
.data-row .value{font-weight:600;color:var(--text)}

/* ── MODAL ───────────────────────────────────────────── */
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:200;display:flex;align-items:center;justify-content:center;padding:1rem}
.modal-box{background:var(--bg2);border:1px solid var(--bdr2);border-radius:var(--radius-xl);width:100%;max-width:460px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}
.modal-head{padding:1.2rem 1.4rem .5rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--bdr)}
.modal-head h3{font-size:15px;font-weight:700;color:var(--text)}
.modal-close{background:var(--bg3);border:none;border-radius:50%;width:28px;height:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--text3);transition:background .15s}
.modal-close:hover{background:var(--bg4);color:var(--text)}
.modal-body{padding:1.2rem 1.4rem}
.modal-footer{padding:.75rem 1.4rem 1.2rem;display:flex;gap:8px;border-top:1px solid var(--bdr)}

/* ── LOGIN PAGE ──────────────────────────────────────── */
.login-bg-grid{position:fixed;inset:0;z-index:0;
  background-image:linear-gradient(rgba(93,202,165,.04) 1px,transparent 1px),
  linear-gradient(90deg,rgba(93,202,165,.04) 1px,transparent 1px);background-size:44px 44px}
.login-glow{position:fixed;top:-120px;right:-120px;width:500px;height:500px;border-radius:50%;z-index:0;
  background:radial-gradient(circle,rgba(93,202,165,.12) 0%,transparent 70%)}
.login-glow2{position:fixed;bottom:-100px;left:-100px;width:400px;height:400px;border-radius:50%;z-index:0;
  background:radial-gradient(circle,rgba(26,26,24,.8) 0%,transparent 70%)}
.login-card{position:relative;z-index:1;background:var(--bg2);border:1px solid var(--bdr2);
  border-radius:20px;padding:2.5rem 2rem;width:100%;max-width:400px;box-shadow:var(--shadow-lg)}
.login-logo{text-align:center;margin-bottom:1.5rem}
.login-logo img{height:44px;width:auto;margin-bottom:10px}
.login-logo h1{font-size:20px;font-weight:800;color:var(--text)}
.login-logo h1 span{color:var(--teal)}
.login-logo p{font-size:12px;color:var(--text3);margin-top:3px}

/* ── MISC ────────────────────────────────────────────── */
.divider{height:1px;background:var(--bdr);margin:1rem 0}
.text-muted{color:var(--text3);font-size:12px}
.text-teal{color:var(--teal)}.text-amber{color:var(--amber)}.text-red{color:var(--red)}.text-blue{color:var(--blue)}
.empty-state{text-align:center;padding:3rem 1rem;color:var(--text3)}
.empty-state .empty-icon{font-size:40px;margin-bottom:.75rem}
.empty-state h3{font-size:15px;color:var(--text2);margin-bottom:.35rem}
.empty-state p{font-size:13px}

/* kWh display */
.kwh-hero{background:var(--kwh-bg);border-radius:10px;padding:14px 18px;border:1px solid var(--kwh-bdr);display:flex;align-items:baseline;gap:10px}
.kwh-hero-val{font-family:'Courier New',monospace;font-size:36px;font-weight:500;color:var(--teal);letter-spacing:.05em;line-height:1}
.kwh-hero-unit{font-size:14px;color:var(--teal);opacity:.7}

/* Alert rows */
.alert-row{display:flex;align-items:flex-start;gap:10px;padding:9px 0;border-bottom:1px solid var(--bdr)}
.alert-row:last-child{border-bottom:none}
.alert-icon{font-size:16px;flex-shrink:0;margin-top:1px}
.alert-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:1px}
.alert-sub{font-size:12px;color:var(--text3)}

/* Profile avatar */
.profile-av{width:80px;height:80px;border-radius:50%;background:var(--teal-bg);border:2px solid var(--teal);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;color:var(--teal);flex-shrink:0;object-fit:cover}
.user-av{width:32px;height:32px;border-radius:50%;background:var(--teal-bg);border:1px solid var(--teal);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--teal);flex-shrink:0}

/* Step dots */
.step-dots{display:flex;align-items:center;gap:6px;margin-bottom:10px}
.step-dot{width:8px;height:8px;border-radius:50%;background:var(--bdr2);transition:background .2s}
.step-dot.on{background:var(--teal)}
.step-dot.done{background:var(--teal-d)}

/* Confirm boxes */
.confirm-box{background:var(--bg3);border:1px solid var(--bdr2);border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;gap:8px}
.confirm-row{display:flex;justify-content:space-between;font-size:13px}
.confirm-label{color:var(--text3)}
.confirm-val{font-weight:600;color:var(--text);font-family:'Courier New',monospace}

/* Drag & drop */
.wcard{background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--radius-lg);overflow:hidden;transition:border-color .2s,background .2s}
.wcard.fw{grid-column:1/-1}
.wcard.dragging{opacity:.55;border-color:var(--teal)}
.wcard.drag-over{border-color:var(--teal);background:var(--teal-bg)}
.wcard.wh{display:none}
.whead{display:flex;align-items:center;gap:8px;padding:11px 14px 0}
.whead-drag{cursor:grab;flex-shrink:0;display:flex;flex-direction:column;gap:3px;opacity:.3}
.whead-drag:active{cursor:grabbing}
.whead-drag span{display:flex;gap:3px}
.whead-drag span i{display:block;width:3px;height:3px;border-radius:50%;background:var(--text2)}
.whead-info{flex:1;min-width:0}
.w-ey{font-size:9px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--text3)}
.w-title{font-size:14px;font-weight:700;color:var(--text);line-height:1.2}
.whead-acts{display:flex;align-items:center;gap:4px;flex-shrink:0}
.wact{background:none;border:none;color:var(--text3);cursor:pointer;font-size:12px;padding:3px 6px;border-radius:5px;transition:background .1s;font-family:inherit}
.wact:hover{background:var(--bg4);color:var(--text)}
.wbody{padding:11px 14px 14px}

/* KPI strip */
.kpi-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:1rem}
@media(max-width:640px){.kpi-strip{grid-template-columns:repeat(2,1fr)}}
.kpi{background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--radius);padding:12px 14px;position:relative;overflow:hidden;transition:background .2s}
.kpi::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:var(--kpi-accent,var(--bdr2))}
.kpi.at{--kpi-accent:var(--teal)}.kpi.ab{--kpi-accent:var(--blue)}.kpi.aa{--kpi-accent:var(--amber)}.kpi.ar{--kpi-accent:var(--red)}
.kpi-label{font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text3);margin-bottom:5px}
.kpi-val{font-size:28px;font-weight:700;color:var(--text);line-height:1;font-variant-numeric:tabular-nums;margin-bottom:4px}
.kpi-sub{font-size:11px;color:var(--text3);display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.kpi-badge{font-size:10px;font-weight:600;padding:1px 7px;border-radius:999px;white-space:nowrap}
.kb-teal{background:var(--teal-bg);color:var(--teal)}.kb-amber{background:var(--amber-bg);color:var(--amber)}.kb-red{background:var(--red-bg);color:var(--red)}

/* Prio dot */
.prio-dot{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0}

/* Maquinas en dashboard */
.mach-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px}
.mt{background:var(--bg3);border:1px solid var(--bdr);border-radius:8px;padding:9px 11px;transition:background .2s,border-color .15s}
.mt.busy{border-color:var(--amber);background:var(--amber-bg)}
.mt.maint{border-color:var(--red);background:var(--red-bg)}
.mt.free{border-color:var(--teal);background:var(--teal-bg)}
.mt-name{font-size:12px;font-weight:600;color:var(--text);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mt-st{font-size:11px;display:flex;align-items:center;gap:4px}
.mt-st.busy{color:var(--amber)}.mt-st.free{color:var(--teal)}.mt-st.maint{color:var(--red)}

/* OT table inside dash */
.ot-tbl{width:100%;border-collapse:collapse;font-size:13px}
.ot-tbl th{background:var(--thead-bg);padding:7px 10px;text-align:left;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text3);white-space:nowrap;border-bottom:1px solid var(--bdr)}
.ot-tbl td{padding:8px 10px;border-bottom:1px solid var(--bdr);vertical-align:middle;color:var(--text)}
.ot-tbl tbody tr:last-child td{border-bottom:none}
.ot-tbl tbody tr:hover{background:var(--row-hover)}

/* Tabs */
.tab-bar{display:grid;gap:3px;background:var(--bg3);border-radius:var(--radius);padding:3px;margin-bottom:1rem}
.tab-bar.cols-2{grid-template-columns:1fr 1fr}
.tab-bar.cols-3{grid-template-columns:1fr 1fr 1fr}
.tab-btn{padding:8px;font-size:13px;font-weight:500;border:none;background:transparent;cursor:pointer;color:var(--text3);font-family:inherit;border-radius:8px;transition:all .15s;text-align:center}
.tab-btn:hover{color:var(--text)}
.tab-btn.active{background:var(--bg2);color:var(--text);border:1px solid var(--bdr);box-shadow:var(--shadow)}

/* Breadcrumb */
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text3);margin-bottom:.75rem;flex-wrap:wrap}
.breadcrumb a{color:var(--text3);text-decoration:none}
.breadcrumb a:hover{color:var(--teal)}
.breadcrumb .current{color:var(--text2);font-weight:500}

/* Toast */
#toast-container{position:fixed;bottom:1.2rem;right:1.2rem;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{padding:.65rem 1rem;border-radius:10px;font-size:13px;font-weight:500;box-shadow:var(--shadow-lg);animation:toastIn .25s ease;max-width:320px;border:1px solid}
.toast.success{background:var(--teal-bg);border-color:var(--teal);color:var(--teal)}
.toast.error{background:var(--red-bg);border-color:var(--red);color:var(--red)}
.toast.info{background:var(--blue-bg);border-color:var(--blue);color:var(--blue)}
@keyframes toastIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* Scrollbar */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--bg0)}
::-webkit-scrollbar-thumb{background:var(--bdr2);border-radius:999px}
::-webkit-scrollbar-thumb:hover{background:var(--text3)}

/* Responsive */
@media(max-width:768px){
  .sidebar{position:fixed;top:0;left:0;bottom:0;transform:translateX(-100%);transition:transform .2s ease;z-index:300;box-shadow:4px 0 24px rgba(0,0,0,.5)}
  .sidebar.open{transform:translateX(0)}
  .main-panel{width:100%}
  .topbar{padding:.6rem 1rem}
  .topbar-user-info{display:none}
}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:299}
.sidebar-overlay.open{display:block}

/* Print */
@media print{
  .sidebar,.topbar,.no-print,.flash-stack,.whead-acts{display:none!important}
  .main-panel,.page-content{margin:0!important;padding:0!important}
  .card{break-inside:avoid;border:1px solid #ccc;background:#fff!important}
  body{background:#fff!important;color:#000!important;font-size:11pt}
  .pill{border:1px solid currentColor}
  .table-wrap{overflow:visible}
  th{background:#f0f0f0!important;color:#000!important}
}

/* Operator catalog - product cards */
.fam-pill{padding:6px 14px;border-radius:999px;font-size:12px;font-weight:500;cursor:pointer;
  border:1px solid var(--bdr2);background:transparent;color:var(--text2);font-family:inherit;transition:all .12s}
.fam-pill:hover{background:var(--bg3)}
.fam-pill.on{background:var(--bg3);color:var(--text);border-color:var(--bdr2)}
.prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px}
.prod-card{background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--radius-lg);
  padding:12px 14px;cursor:pointer;transition:border-color .12s,box-shadow .12s;
  display:flex;align-items:center;gap:12px}
.prod-card:hover{border-color:var(--teal);box-shadow:0 2px 12px var(--teal-bg)}
.icon-box{border-radius:8px;flex-shrink:0;overflow:hidden}

/* Detail sheet */
.detail-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:600;align-items:flex-end;justify-content:center}
.detail-overlay.open{display:flex}
.detail-sheet{background:var(--bg2);border-radius:20px 20px 0 0;width:100%;max-width:560px;max-height:85vh;overflow-y:auto;padding:1.4rem;animation:slideUp .25s cubic-bezier(.34,1.56,.64,1);border:1px solid var(--bdr)}
@keyframes slideUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.spec-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:10px}
.spec-box{background:var(--bg3);border-radius:8px;padding:9px 12px;border:1px solid var(--bdr)}
.spec-l{font-size:9px;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);margin-bottom:2px}
.spec-v{font-size:14px;font-weight:600;color:var(--text);line-height:1.2}

/* Misc helpers */
.prio-badge{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}
.quick-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:13px 8px;border-radius:9px;background:var(--bg3);border:1px solid var(--bdr);color:var(--text2);font-size:12px;font-weight:500;text-decoration:none;text-align:center;transition:all .12s}
.quick-btn:hover{background:var(--bg4);color:var(--text);border-color:var(--bdr2);text-decoration:none}

/* ── Worker chips in active stage ── */
.worker-chip-live{display:flex;align-items:center;gap:10px;padding:10px 13px;background:var(--bg2);border:1.5px solid var(--bdr);border-radius:10px;transition:border-color .15s;cursor:pointer}
.worker-chip-live:hover{border-color:var(--bdr2)}
.worker-chip-live.assigned{border-color:var(--teal);background:rgba(93,202,165,.08)}
.worker-chip-live.assigned .worker-name-sm{color:var(--teal)}
.worker-chip-live.assigned .worker-timer{color:var(--teal)}
.worker-av-sm{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.worker-info{flex:1;min-width:0}
.worker-name-sm{font-size:13px;font-weight:600;color:var(--text);line-height:1.2}
.worker-role-sm{font-size:11px;color:var(--text3);margin-top:1px}
.worker-timer{font-size:14px;font-weight:700;font-family:'Courier New',monospace;color:var(--blue);letter-spacing:.02em;min-width:64px;text-align:right;white-space:nowrap}
.timer-display{font-size:22px;font-weight:700;font-family:'Courier New',monospace;color:var(--teal);letter-spacing:.04em;line-height:1}
