/* ═══════════════════════════════════════════════════════════════════════════
   Jafona — Hoja de estilos global

   Antes vivía embebido en <style> de index.html. Externalizado en fase 8.1
   sin modificar reglas (byte-a-byte). El orden de las reglas se preserva
   EXACTAMENTE — algunas dependencias del sistema vienen del cascade
   (ej. dark mode tokens definidos después de la base light).

   Las migraciones inline → clases ocurren a partir de la fase 8.2. NO
   reorganizar/optimizar reglas en este PR — son trabajos separados.

   Navegación: Cmd+F sobre los headers entre cajas dobles.
   ═══════════════════════════════════════════════════════════════════════════ */

/* ╔═════════════════════════════════════════════════════════════════════════╗
   ║  DESIGN TOKENS (light) + RESET + APP SHELL                              ║
   ╚═════════════════════════════════════════════════════════════════════════╝ */
:root {
  --bg:#f7f6f3; --surface:#ffffff; --surface2:#f0efe9;
  --border:#e2e0d8; --border2:#ccc9be;
  /* Hover de fila en tablas — diferenciado por modo. En light el ojo necesita
     ~10% de diferencia para ser claramente perceptible (Weber-Fechner). En
     dark, var(--surface2) ya da contraste suficiente "elevando" la celda. */
  --row-hover:#e6e4da;
  --text:#1a1916; --text2:#6b6860; --text3:#a09e98;
  --accent:#65a30d; --accent-l:#ecfccb;
  --green:#16a34a; --green-l:#dcfce7;
  --amber:#d97706; --amber-l:#fef3c7;
  --red:#dc2626; --red-l:#fee2e2;
  --gray-l:#f3f2ee;
  --r:8px; --rlg:12px; --sidebar:220px;
  --shadow:0 1px 3px rgba(0,0,0,.08);
  /* Tokens semánticos extendidos (fase 0 — disponibles, aún sin uso global) */
  --warn:#b45309; --warn-bg:rgba(180,83,9,.08); --warn-border:rgba(180,83,9,.22); --warn-bg-hover:rgba(180,83,9,.16);
  --error:#b91c1c; --error-bg:rgba(220,38,38,.07); --error-border:rgba(220,38,38,.18); --error-bg-hover:rgba(220,38,38,.14);
  --info:#2563eb; --info-bg:rgba(37,99,235,.07); --info-border:rgba(37,99,235,.18); --info-bg-hover:rgba(37,99,235,.14);
  --violet:#7c3aed; --violet-bg:rgba(124,58,237,.07); --violet-border:rgba(124,58,237,.18);
  --accent-2:#4d7c0f;
  --accent-glow:rgba(101,163,13,.18); --accent-glow-soft:rgba(101,163,13,.08);
  /* Fase 1: gradient + foreground del botón primary (alineado al login) */
  --btn-primary-top:#84cc16; --btn-primary-fg:#ffffff;
  /* Fase 4: tipos de paso BPM — los 4 principales son alias semánticos; el resto
     mantiene sus colores de marca distintivos (preservan reconocibilidad
     visual establecida). */
  --bpm-inicio:var(--accent); --bpm-fin:var(--error);
  --bpm-tarea:var(--info); --bpm-decision:var(--warn);
  --bpm-servicio:#a78bfa; --bpm-bitacora:#94a3b8; --bpm-modulo:#2dd4bf;
  --bpm-fork:#475569; --bpm-join:#475569;
  --bpm-notificacion:#f97316; --bpm-notif-email:#6366f1; --bpm-notif-telegram:#0ea5e9;
  --bpm-timer:#0891b2;
  /* Canvas SVG del editor BPM (background + color de grid) */
  --canvas-bg:#f8fafc; --canvas-grid:#cbd5e1;
}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);font-size:14px;height:100dvh;overflow:hidden;}
*{-webkit-tap-highlight-color:transparent;}
button,a,.btn,.sb-item{touch-action:manipulation;cursor:pointer;}
input,select,textarea{font-size:16px!important;-webkit-appearance:none;appearance:none;touch-action:manipulation;}
input[type=checkbox],input[type=radio]{appearance:auto;-webkit-appearance:auto;width:auto;padding:0;border:initial;border-radius:initial;background:initial;accent-color:var(--accent);}
.app{display:flex;position:fixed;inset:0;overflow:hidden;}
.sidebar{width:var(--sidebar);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;min-height:0;overflow:hidden;}
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;}
.topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:0 20px;height:52px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.content{flex:1;min-height:0;overflow:hidden;position:relative;}

/* ╔═════════════════════════════════════════════════════════════════════════╗
   ║  SIDEBAR (nav + footer + user menu)                                     ║
   ╚═════════════════════════════════════════════════════════════════════════╝ */
.sb-header{flex-shrink:0;border-bottom:1px solid var(--border);}
.sb-nav{flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--border2) transparent;}
.sb-nav::-webkit-scrollbar{width:6px;}
.sb-nav::-webkit-scrollbar-track{background:transparent;}
.sb-nav::-webkit-scrollbar-thumb{background:var(--border2);border-radius:8px;border:2px solid var(--surface);background-clip:padding-box;}
.sb-nav::-webkit-scrollbar-thumb:hover{background:var(--text3);background-clip:padding-box;}
.sb-logo{padding:18px 16px 12px;}
.sb-logo .brand{font-size:16px;font-weight:600;letter-spacing:-.3px;}
.sb-logo .brand span{color:var(--accent);}
.sb-logo .sub{font-size:11px;color:var(--text3);margin-top:2px;}
#sb-company-logo{display:none;max-height:64px;max-width:176px;width:auto;height:auto;margin-bottom:2px;cursor:pointer;}
.sb-section{font-size:10px;color:var(--text3);padding:12px 16px 4px;text-transform:uppercase;letter-spacing:.08em;font-weight:500;}
.sb-item{display:flex;align-items:center;gap:8px;padding:9px 16px;font-size:13px;color:var(--text2);cursor:pointer;border-left:2px solid transparent;transition:all .12s;user-select:none;min-height:44px;}
.sb-item:hover{background:var(--bg);color:var(--text);}
.sb-item.active{background:var(--accent-l);color:var(--accent);border-left-color:var(--accent);font-weight:500;}
.sb-item svg{width:15px;height:15px;flex-shrink:0;}
.sb-badge{display:inline-block;border-radius:10px;padding:1px 6px;font-size:10px;font-weight:600;color:#fff;margin-left:auto;line-height:1.4;}
.sb-badge-red{background:var(--red);}
.sb-badge-accent{background:var(--accent);}
.sb-footer{flex-shrink:0;padding:8px;border-top:1px solid var(--border);background:var(--surface);position:relative;}
.sb-user-trigger{display:flex;align-items:center;gap:9px;width:100%;padding:6px 8px;border:0;background:transparent;cursor:pointer;border-radius:8px;font-family:inherit;text-align:left;color:var(--text);min-height:44px;transition:background .12s;touch-action:manipulation;}
.sb-user-trigger:hover{background:var(--bg);}
.sb-user-trigger[aria-expanded="true"]{background:var(--bg);}
.sb-avatar{width:30px;height:30px;flex-shrink:0;border-radius:50%;background:var(--accent-l);color:var(--accent);display:inline-flex;align-items:center;justify-content:center;font-size:11.5px;font-weight:600;letter-spacing:.02em;text-transform:uppercase;user-select:none;}
.sb-user-meta{min-width:0;flex:1;}
.sb-greeting{font-size:12.5px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3;}
.sb-greeting span{font-weight:600;}
.sb-user-chevron{width:14px;height:14px;color:var(--text3);flex-shrink:0;margin-left:auto;transition:transform .15s;}
.sb-user-trigger[aria-expanded="true"] .sb-user-chevron{transform:rotate(180deg);}
.sb-user-menu{position:absolute;left:8px;right:8px;bottom:calc(100% - 8px);background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.12),0 2px 4px rgba(0,0,0,.06);padding:4px;z-index:201;animation:sb-menu-in .14s ease-out;}
.sb-user-menu[hidden]{display:none;}
.sb-user-menu-sep{height:1px;background:var(--border);margin:3px 6px;}
@keyframes sb-menu-in{from{opacity:0;transform:translateY(4px);}to{opacity:1;transform:translateY(0);}}
.sb-user-action{display:flex;align-items:center;gap:9px;padding:7px 10px;border:0;background:transparent;color:var(--text2);font-size:12.5px;font-family:inherit;cursor:pointer;border-radius:5px;width:100%;text-align:left;min-height:32px;transition:background .12s,color .12s;touch-action:manipulation;}
.sb-user-action:hover,.sb-user-action:focus-visible{background:var(--accent-glow);color:var(--accent);outline:none;}
.sb-user-action svg{width:14px;height:14px;flex-shrink:0;}
.sb-user-action-danger{color:var(--red);}
.sb-user-action-danger:hover,.sb-user-action-danger:focus-visible{background:var(--red-l);color:var(--red);}

/* ╔═════════════════════════════════════════════════════════════════════════╗
   ║  PAGE TITLE + BUTTONS (.btn family)                                     ║
   ╚═════════════════════════════════════════════════════════════════════════╝ */
.page-title{font-size:15px;font-weight:600;}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:8px 14px;border-radius:10px;border:1px solid var(--border2);background:var(--surface);color:var(--text);font-size:13px;font-weight:500;letter-spacing:-.01em;cursor:pointer;font-family:'DM Sans',sans-serif;transition:background-color .15s,border-color .15s,color .15s,box-shadow .15s,filter .15s,transform .05s,opacity .15s;white-space:nowrap;min-height:36px;touch-action:manipulation;}
.btn:hover{background:var(--accent-glow);border-color:var(--accent);color:var(--accent);}
.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px;}
.btn:active{transform:translateY(1px);}
.btn + .btn{margin-left:4px;}
.btn-primary{background:linear-gradient(180deg,var(--btn-primary-top) 0%,var(--accent) 100%);color:var(--btn-primary-fg);border-color:transparent;font-weight:700;box-shadow:0 8px 22px var(--accent-glow),0 0 0 1px var(--accent-glow-soft);}
.btn-primary:hover{filter:brightness(1.04);box-shadow:0 12px 28px var(--accent-glow),0 0 0 1px var(--accent-glow-soft);background:linear-gradient(180deg,var(--btn-primary-top) 0%,var(--accent) 100%);}
.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none;}
@keyframes ia-spin{to{transform:rotate(360deg)}}
.ia-spinner{width:40px;height:40px;border:3px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:ia-spin .75s linear infinite;margin:0 auto;}
.ia-modal-box{background:var(--surface);border-radius:var(--rlg);padding:32px 28px;max-width:320px;width:90%;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,.25);}
.btn-sm{padding:5px 10px;font-size:12px;min-height:32px;border-radius:8px;gap:6px;}
.btn-ghost{border-color:transparent;background:transparent;color:var(--text2);}
.btn-ghost:hover{background:var(--accent-glow-soft);color:var(--accent);border-color:transparent;}
.btn-danger{background:var(--error-bg);color:var(--error);border-color:var(--error-border);font-weight:600;}
.btn-danger:hover{background:var(--error-bg-hover);border-color:var(--error);color:var(--error);}
.btn-warn{background:var(--warn-bg);color:var(--warn);border-color:var(--warn-border);font-weight:600;}
.btn-warn:hover{background:var(--warn-bg-hover);border-color:var(--warn);color:var(--warn);}
.btn-info{background:var(--info-bg);color:var(--info);border-color:var(--info-border);font-weight:600;}
.btn-info:hover{background:var(--info-bg-hover);border-color:var(--info);color:var(--info);}
.btn-neutral{background:transparent;color:var(--text2);border-color:var(--border2);}
.btn-neutral:hover{background:var(--surface2);color:var(--text);border-color:var(--border2);}

/* ╔═════════════════════════════════════════════════════════════════════════╗
   ║  APP ROOT + STATS + CARDS + FILTERS + DATE INPUTS                       ║
   ╚═════════════════════════════════════════════════════════════════════════╝ */
#app-root{position:absolute;inset:0;overflow-y:auto;padding:20px;-webkit-overflow-scrolling:touch;background:var(--bg);}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rlg);padding:16px;}
.stat-card .num{font-size:28px;font-weight:600;line-height:1;font-family:'DM Mono',monospace;}
.stat-card .lbl{font-size:12px;color:var(--text2);margin-top:4px;}
.stat-card .sub{font-size:11px;color:var(--text3);margin-top:2px;}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rlg);padding:18px;margin-bottom:16px;}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.card-title{font-size:12px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.05em;}
.filters{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap;align-items:center;}
.filter-input{padding:7px 10px;border:1px solid var(--border);border-radius:var(--r);font-size:14px;background:var(--surface);color:var(--text);font-family:'DM Sans',sans-serif;}
/* Dark mode: el ícono del calendario por defecto es negro (chrome user-agent),
   queda invisible sobre el background oscuro de los inputs. filter:invert
   lo blanquea sin afectar el resto del input. Aplica a todos los date /
   datetime-local pickers de la app (date input no soporta currentColor). */
[data-theme="dark"] input[type="date"]::-webkit-calendar-picker-indicator,
[data-theme="dark"] input[type="datetime-local"]::-webkit-calendar-picker-indicator,
[data-theme="dark"] input[type="time"]::-webkit-calendar-picker-indicator,
[data-theme="dark"] input[type="month"]::-webkit-calendar-picker-indicator{filter:invert(1) brightness(.85);}

/* ╔═════════════════════════════════════════════════════════════════════════╗
   ║  TABLES (.tbl-wrap, table, th, td) + BADGES                             ║
   ╚═════════════════════════════════════════════════════════════════════════╝ */
.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
table{width:100%;border-collapse:collapse;font-size:13px;}
th{text-align:left;padding:8px 10px;border-bottom:1px solid var(--border);color:var(--text3);font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;}
td{padding:10px;border-bottom:1px solid var(--border);vertical-align:middle;}
tr:last-child td{border-bottom:none;}
/* Hover de fila — token dedicado --row-hover, tuneado por modo:
   Light: #e6e4da contra --surface #ffffff → ~10% diff, claramente perceptible
          (Weber-Fechner: en valores claros el ojo necesita más delta).
   Dark:  #2d2c29 contra --surface #1c1c1a → ~7% más claro, efecto "elevación". */
tr:hover td{background:var(--row-hover);}
.report tr:hover td{background:#f0f0ee;}
.report table tr:last-child td{border-bottom:1px solid #ddd;}
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:500;white-space:nowrap;}
.badge::before{content:'';width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0;}
.b-open{background:var(--amber-l);color:var(--amber);}
.b-closed{background:var(--green-l);color:var(--green);}
.b-void{background:var(--gray-l);color:var(--text3);}
.b-admin{background:var(--accent-l);color:var(--accent);}
.b-jefatura{background:#fff7ed;color:#c2410c;}
.b-inspector{background:#fdf4ff;color:#7e22ce;}
.b-coord{background:#ecfdf5;color:#065f46;}
.b-client{background:var(--gray-l);color:var(--text2);}

/* ╔═════════════════════════════════════════════════════════════════════════╗
   ║  FORM GROUPS (.fg) + MODALS                                             ║
   ╚═════════════════════════════════════════════════════════════════════════╝ */
.fg{margin-bottom:13px;}
.fg label{display:block;font-size:11px;font-weight:600;color:var(--text2);margin-bottom:5px;text-transform:uppercase;letter-spacing:.05em;}
.fg input,.fg select,.fg textarea{width:100%;padding:9px 10px;border:1px solid var(--border2);border-radius:var(--r);font-size:16px;color:var(--text);background:var(--surface);font-family:'DM Sans',sans-serif;transition:border-color .12s;}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:2px solid var(--accent);border-color:transparent;}
.fg textarea{resize:vertical;min-height:72px;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;z-index:100;opacity:0;pointer-events:none;transition:opacity .15s;padding:16px;}
.modal-bg.open{opacity:1;pointer-events:all;}
.modal{background:var(--surface);border-radius:var(--rlg);width:100%;max-width:580px;max-height:88dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;box-shadow:0 20px 60px rgba(0,0,0,.25);transform:scale(.96);transition:transform .15s;}
.modal-bg.open .modal{transform:scale(1);}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--border);}
.modal-head h3{font-size:15px;font-weight:600;}
.modal-close{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background:none;border:0;border-radius:8px;cursor:pointer;color:var(--text3);padding:0;transition:background-color .15s,color .15s;touch-action:manipulation;}
.modal-close:hover{background:var(--surface2);color:var(--text);}
.modal-close:focus-visible{outline:2px solid var(--accent);outline-offset:2px;}
.modal-close svg{width:16px;height:16px;display:block;}
.modal-body{padding:20px;}
.modal-foot{display:flex;justify-content:flex-end;gap:8px;padding:14px 20px;border-top:1px solid var(--border);}
.detail-back{cursor:pointer;font-size:13px;color:var(--accent);display:inline-flex;align-items:center;gap:4px;margin-bottom:12px;touch-action:manipulation;}
.detail-back:hover{text-decoration:underline;}
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px;}
.info-item .lbl{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);font-weight:500;margin-bottom:2px;}
.info-item .val{font-size:13px;color:var(--text);}
.timeline{border-left:2px solid var(--border);padding-left:16px;margin-top:10px;}
.tl-item{position:relative;margin-bottom:14px;}
.tl-item::before{content:'';position:absolute;left:-21px;top:4px;width:8px;height:8px;border-radius:50%;background:var(--border2);border:2px solid var(--surface);}
.tl-item.current::before{background:var(--accent);}
.tl-date{font-size:11px;color:var(--text3);font-family:'DM Mono',monospace;}
.tl-text{font-size:13px;color:var(--text);margin-top:2px;}
.photo-editor{border:1px solid var(--border);border-radius:var(--r);overflow:hidden;background:#e8e8e8;cursor:crosshair;}
.photo-editor canvas{display:block;width:100%;}

/* ╔═════════════════════════════════════════════════════════════════════════╗
   ║  CANVAS TOOLBAR (inspecciones / novedades) + EVIDENCIA HEADER           ║
   ╚═════════════════════════════════════════════════════════════════════════╝ */
/* Canvas toolbar (icon-only system) — usada por inspecciones y novedades */
.tool-bar{display:flex;align-items:center;gap:6px;padding:6px;background:var(--surface2);border:1px solid var(--border);border-radius:10px;margin-bottom:8px;flex-wrap:wrap;}
.tool-group{display:inline-flex;border:1px solid var(--border);border-radius:8px;overflow:hidden;background:var(--surface);}
.tool-group .tool-btn{border:none;border-radius:0;border-right:1px solid var(--border);}
.tool-group .tool-btn:last-child{border-right:none;}
.tool-btn{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid var(--border);border-radius:8px;cursor:pointer;color:var(--text2);padding:0;transition:background .12s,color .12s,border-color .12s;font-family:inherit;touch-action:manipulation;}
.tool-btn:hover{background:var(--bg);color:var(--text);}
.tool-btn--active{background:var(--accent)!important;color:var(--btn-primary-fg)!important;border-color:var(--accent)!important;}
.tool-btn--primary{border-color:var(--border);color:var(--accent);}
.tool-btn--primary:hover{background:var(--accent-glow);color:var(--accent);border-color:var(--accent);}
.tool-btn--cta{background:var(--accent);border-color:var(--accent);color:var(--btn-primary-fg);}
.tool-btn--cta:hover{filter:brightness(1.08);color:var(--btn-primary-fg);}
.tool-btn--danger{border-color:var(--border);color:var(--error);}
.tool-btn--danger:hover{background:var(--error-bg);border-color:var(--error);color:var(--error);}
.tool-btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none;}
.tool-btn svg{width:16px;height:16px;display:block;}
.tool-spacer{flex:1 1 auto;}
.tool-btn .lock-icon-pencil{display:none;}
.tool-btn .lock-icon-lock{display:block;}
.tool-btn[data-locked="true"] .lock-icon-pencil{display:block;}
.tool-btn[data-locked="true"] .lock-icon-lock{display:none;}

/* Evidencia header con [+] camera-plus */
.evidencia-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;gap:12px;}
.evidencia-label{font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.05em;display:inline-flex;align-items:baseline;gap:8px;flex:1;}
.evidencia-counter{font-size:10px;color:var(--text3);font-weight:400;text-transform:none;letter-spacing:0;}
.evidencia-add-btn{width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--accent);background:var(--accent-l);color:var(--accent);border-radius:7px;cursor:pointer;padding:0;flex-shrink:0;transition:background .15s,color .15s,border-color .15s;}
.evidencia-add-btn:hover{background:var(--accent);color:var(--btn-primary-fg);}
.evidencia-add-btn:disabled{opacity:.4;cursor:not-allowed;background:transparent;pointer-events:none;}
.evidencia-add-btn svg{width:15px;height:15px;display:block;}

@media(max-width:640px){
  .tool-btn{width:36px;height:36px;}
  .tool-btn svg{width:17px;height:17px;}
  .evidencia-add-btn{width:34px;height:34px;}
  .evidencia-add-btn svg{width:16px;height:16px;}
}

/* ╔═════════════════════════════════════════════════════════════════════════╗
   ║  REPORT (PDF) + TOAST + LIGHTBOX                                        ║
   ╚═════════════════════════════════════════════════════════════════════════╝ */
.report{font-family:'DM Mono',monospace;font-size:11px;background:#fff;border:1px solid #ccc;border-radius:var(--r);padding:20px;color:#000;width:100%;box-sizing:border-box;}
@media(max-width:768px){.report{padding:12px;border-radius:0;border-left:none;border-right:none;}}
.report-brand{font-size:20px;font-weight:700;color:#cc1f1f;font-family:'DM Sans',sans-serif;}
.report table{width:100%;border-collapse:collapse;margin-top:10px;}
.report th{background:#1e3a5f;color:#fff;padding:6px 7px;border:1px solid #1e3a5f;font-size:10px;font-weight:700;text-align:center;letter-spacing:.4px;}
.report td{padding:6px 7px;border:1px solid #ddd;vertical-align:top;color:#000;}
.photo-thumb{width:72px;height:52px;background:#e0e0e0;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:10px;color:#888;}
/* Toast — banner inferior derecho con ícono + título + descripción opcional.
   Variantes (success/error) cambian border-left + color del ícono. El JS en
   shared/toast.js inyecta la estructura. Usa --red (no --error) para el rojo
   encendido en ambos modos: --error tiene un fade dark a #fca5a5 (pensado para
   fondos pale) que queda muy apagado como color de ícono/borde. */
.toast{position:fixed;bottom:20px;right:20px;display:inline-flex;align-items:flex-start;gap:10px;background:var(--surface);color:var(--text);border:1px solid var(--border);border-left:3px solid transparent;border-radius:10px;padding:10px 12px;max-width:380px;font-size:13px;z-index:500;opacity:0;transform:translateY(10px);transition:all .2s;pointer-events:none;box-shadow:0 6px 20px rgba(0,0,0,.10),0 2px 6px rgba(0,0,0,.06);}
[data-theme="dark"] .toast{box-shadow:0 6px 20px rgba(0,0,0,.45),0 2px 6px rgba(0,0,0,.30);}
.toast.show{opacity:1;transform:translateY(0);}
.toast--success{border-left-color:var(--accent);}
.toast--error{border-left-color:var(--red);}
.toast__icon{flex-shrink:0;margin-top:1px;color:var(--text2);}
.toast--success .toast__icon{color:var(--accent);}
.toast--error .toast__icon{color:var(--red);}
.toast__content{flex:1;min-width:0;}
.toast__title{font-size:13px;font-weight:600;color:var(--text);line-height:1.3;}
.toast__desc{font-size:12px;color:var(--text2);margin-top:2px;line-height:1.35;}
.lightbox{position:fixed;inset:0;z-index:400;background:rgba(0,0,0,.92);display:none;align-items:center;justify-content:center;padding:16px;}
.lightbox.open{display:flex;}
.lightbox img{max-width:100%;max-height:90dvh;border-radius:var(--r);object-fit:contain;}
.lb-close{position:fixed;top:16px;right:16px;background:rgba(255,255,255,.15);border:none;color:#fff;width:44px;height:44px;border-radius:50%;font-size:20px;cursor:pointer;touch-action:manipulation;}

/* ╔═════════════════════════════════════════════════════════════════════════╗
   ║  DARK MODE OVERRIDES (must come after light tokens)                     ║
   ╚═════════════════════════════════════════════════════════════════════════╝ */
[data-theme="dark"] {
  --bg:#111110; --surface:#1c1c1a; --surface2:#252523;
  --border:#2e2d2a; --border2:#3d3c38;
  --row-hover:#2d2c29;
  --text:#f0efe9; --text2:#a09e98; --text3:#6b6860;
  --accent:#a3e635; --accent-l:#1a2e05;
  --green:#22c55e; --green-l:#052e16;
  --amber:#f59e0b; --amber-l:#2d1a00;
  --red:#ef4444; --red-l:#2d0a0a;
  --gray-l:#1c1c1a;
  /* Tokens semánticos extendidos (fase 0 — pares dark) */
  --warn:#fcd34d; --warn-bg:rgba(251,191,36,.14); --warn-border:rgba(251,191,36,.32); --warn-bg-hover:rgba(251,191,36,.24);
  --error:#fca5a5; --error-bg:rgba(248,113,113,.08); --error-border:rgba(248,113,113,.28); --error-bg-hover:rgba(248,113,113,.16);
  --info:#93c5fd; --info-bg:rgba(147,197,253,.10); --info-border:rgba(147,197,253,.28); --info-bg-hover:rgba(147,197,253,.20);
  --violet:#c4b5fd; --violet-bg:rgba(196,181,253,.10); --violet-border:rgba(196,181,253,.28);
  --accent-2:#84cc16;
  --accent-glow:rgba(163,230,53,.28); --accent-glow-soft:rgba(163,230,53,.10);
  /* Fase 1: gradient + foreground del botón primary (pares dark) */
  --btn-primary-top:#b7f34a; --btn-primary-fg:#0a0a0c;
  /* Fase 4: BPM tipos de paso — los 4 principales heredan de tokens dark,
     el resto mantiene su color de marca (mismo hex en dark+light por consistencia
     de reconocimiento; el fondo del canvas sí cambia, los nodos no). */
  --bpm-inicio:var(--accent); --bpm-fin:var(--error);
  --bpm-tarea:var(--info); --bpm-decision:var(--warn);
  --bpm-servicio:#a78bfa; --bpm-bitacora:#94a3b8; --bpm-modulo:#2dd4bf;
  --bpm-fork:#475569; --bpm-join:#475569;
  --bpm-notificacion:#f97316; --bpm-notif-email:#6366f1; --bpm-notif-telegram:#0ea5e9;
  --bpm-timer:#0891b2;
  /* Canvas BPM en dark */
  --canvas-bg:#1c1c1a; --canvas-grid:#3f3f3c;
}

/* ╔═════════════════════════════════════════════════════════════════════════╗
   ║  SCROLLBAR + HAMBURGER + RESPONSIVE MOBILE                              ║
   ╚═════════════════════════════════════════════════════════════════════════╝ */
::-webkit-scrollbar{width:4px;height:4px;}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:10px;}
.hamburger{display:none;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--border);border-radius:var(--r);background:var(--surface);color:var(--text2);font-size:18px;cursor:pointer;flex-shrink:0;touch-action:manipulation;}
.sb-overlay{display:none;position:fixed;inset:0;z-index:199;background:rgba(0,0,0,.4);}
.sb-overlay.open{display:block;}
@media(max-width:640px){
  .hamburger{display:flex;}
  .sidebar{width:220px;position:fixed;left:0;top:0;bottom:0;z-index:200;transform:translateX(-100%);transition:transform .2s;box-shadow:4px 0 24px rgba(0,0,0,.15);}
  .sidebar.open{transform:translateX(0);}
  .stats-row{grid-template-columns:1fr 1fr;}
  .form-grid{grid-template-columns:1fr;}
  .dn-foto-card{order:1;}
  .dn-main{order:2;}
}
/* Landscape mobile: keep hamburger + sliding sidebar */
@media(orientation:landscape) and (max-height:500px){
  .hamburger{display:flex;}
  .sidebar{width:220px;position:fixed;left:0;top:0;bottom:0;z-index:200;transform:translateX(-100%);transition:transform .2s;box-shadow:4px 0 24px rgba(0,0,0,.15);}
  .sidebar.open{transform:translateX(0);}
}
/* Mobile calendar: dots instead of pills; compact cells; day panel visible */
@media(max-width:640px),(orientation:landscape) and (max-height:500px){
  .fer-cell-pills{display:none!important;}
  .fer-cell-dots{display:flex!important;}
  .fer-day-cell{min-height:44px!important;padding:4px 5px!important;}
  .fer-day-panel{display:block!important;}
}
.fer-day-selected{background:var(--accent-l)!important;border-color:var(--accent)!important;}

/* ╔═════════════════════════════════════════════════════════════════════════╗
   ║  LOGO ZOOM MODAL + PRINT STYLES                                         ║
   ╚═════════════════════════════════════════════════════════════════════════╝ */
#logo-zoom{position:fixed;inset:0;z-index:401;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.35);cursor:pointer;}
#logo-zoom.open{display:flex;}
#logo-zoom-box{background:var(--bg);border-radius:14px;padding:28px 36px;box-shadow:0 24px 80px rgba(0,0,0,.4);max-width:80vw;max-height:80vh;display:flex;align-items:center;justify-content:center;cursor:default;}
#logo-zoom-box img{max-width:60vw;max-height:60vh;width:auto;height:auto;display:block;}
@media print{
  html,body{height:auto!important;overflow:visible!important;min-height:0!important;}
  .sidebar,.topbar,.detail-back,.toast,.lightbox,.modal-bg,.sb-overlay,.no-print{display:none!important;}
  .app{display:block!important;position:static!important;overflow:visible!important;inset:auto!important;}
  .main{display:block!important;overflow:visible!important;}
  .content{overflow:visible!important;padding:0!important;position:static!important;height:auto!important;}
  #app-root{position:static!important;overflow:visible!important;height:auto!important;padding:0!important;}
  .report{border:none!important;padding:0!important;box-shadow:none!important;}
  .report,#report-content,#report-content td,#report-content td *{color:#000!important;}
  .report table,.report th,.report td{border-color:#999!important;}
  #report-content th{background-color:#1e3a5f!important;color:#fff!important;-webkit-print-color-adjust:exact;print-color-adjust:exact;text-align:center!important;}
  .report thead{display:table-header-group;}
  .report tbody tr{page-break-inside:avoid;}
  #report-content img{max-width:100%!important;-webkit-print-color-adjust:exact;print-color-adjust:exact;}
  #report-content img.firma-overlay{max-width:none!important;}
}

/* ╔═════════════════════════════════════════════════════════════════════════╗
   ║  LOGIN SCREEN (gigante — modern design con tokens propios --lg-*)       ║
   ╚═════════════════════════════════════════════════════════════════════════╝ */
/* ── Login screen (modern design) ─────────────────────────────── */
#login-screen{
  position:fixed;inset:0;z-index:999;overflow-y:auto;-webkit-overflow-scrolling:touch;
  font-family:'Geist',system-ui,sans-serif;color:var(--lg-text);
  --lg-bg:#0a0a0c;--lg-bg-2:#050507;--lg-grid:#2e2e33;
  --lg-surface:rgba(16,16,20,.78);--lg-surface-solid:#101013;
  --lg-border:rgba(255,255,255,.09);--lg-border-strong:rgba(255,255,255,.14);
  --lg-text:#fafafa;--lg-text-dim:#b3b3b3;--lg-text-mute:#777;
  --lg-accent:#a3e635;--lg-accent-2:#84cc16;
  --lg-accent-glow:rgba(163,230,53,.28);--lg-accent-glow-soft:rgba(163,230,53,.10);
  --lg-tri-left:rgba(250,250,250,.88);--lg-tri-right:rgba(163,230,53,.72);
  --lg-tri-wire:#3f3f46;--lg-input-bg:rgba(18,18,22,.84);--lg-error:#fca5a5;
  --lg-warn:#fcd34d;--lg-warn-bg:rgba(251,191,36,.18);--lg-warn-border:rgba(251,191,36,.42);
  background:var(--lg-bg);
  transition:background-color .25s,color .25s;
}
html[data-theme="light"] #login-screen{
  --lg-bg:#fafaf9;--lg-bg-2:#f0f0ec;--lg-grid:#d4d4d2;
  --lg-surface:rgba(255,255,255,.84);--lg-surface-solid:#fff;
  --lg-border:rgba(10,10,12,.10);--lg-border-strong:rgba(10,10,12,.16);
  --lg-text:#0a0a0c;--lg-text-dim:#4f4f4f;--lg-text-mute:#737373;
  --lg-accent:#65a30d;--lg-accent-2:#4d7c0f;
  --lg-accent-glow:rgba(101,163,13,.18);--lg-accent-glow-soft:rgba(101,163,13,.08);
  --lg-tri-left:rgba(10,10,12,.82);--lg-tri-right:rgba(101,163,13,.62);
  --lg-tri-wire:#a3a3a3;--lg-input-bg:rgba(255,255,255,.9);--lg-error:#b91c1c;
  --lg-warn:#92400e;--lg-warn-bg:rgba(180,83,9,.16);--lg-warn-border:rgba(180,83,9,.42);
}
#login-screen .lg-stage{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden;
  background:radial-gradient(circle at 50% 44%,var(--lg-accent-glow) 0,transparent 34%),
             radial-gradient(circle at 50% 95%,var(--lg-accent-glow-soft) 0,transparent 34%),
             linear-gradient(180deg,#0d0d10 0%,var(--lg-bg) 46%,var(--lg-bg-2) 100%);}
html[data-theme="light"] #login-screen .lg-stage{
  background:radial-gradient(circle at 50% 44%,var(--lg-accent-glow) 0,transparent 34%),
             radial-gradient(circle at 50% 95%,var(--lg-accent-glow-soft) 0,transparent 34%),
             linear-gradient(180deg,#fff 0%,var(--lg-bg) 46%,var(--lg-bg-2) 100%);}
#login-screen .lg-stage-grid{position:absolute;inset:0;
  background-image:radial-gradient(circle,var(--lg-grid) 1.25px,transparent 1.25px);
  background-size:24px 24px;opacity:.46;
  -webkit-mask-image:radial-gradient(circle at center,#000 0%,#000 48%,transparent 88%);
  mask-image:radial-gradient(circle at center,#000 0%,#000 48%,transparent 88%);}
#login-screen .lg-stage-glow{position:absolute;width:900px;height:900px;left:50%;top:50%;
  transform:translate(-50%,-50%);
  background:radial-gradient(circle,var(--lg-accent-glow) 0%,transparent 60%);
  filter:blur(78px);opacity:.46;animation:lg-pulseGlow 10s ease-in-out infinite;}
@keyframes lg-pulseGlow{0%,100%{opacity:.42;transform:translate(-50%,-50%) scale(1);}50%{opacity:.66;transform:translate(-50%,-50%) scale(1.05);}}
#login-screen .lg-stage-tris{position:absolute;left:50%;top:52%;transform:translate(-50%,-50%);
  width:min(880px,92vw);height:min(880px,92vw);max-height:86vh;opacity:.68;
  filter:blur(.15px) drop-shadow(0 20px 48px rgba(0,0,0,.34));}
html[data-theme="light"] #login-screen .lg-stage-tris{filter:blur(.15px) drop-shadow(0 18px 44px rgba(10,10,12,.14));}
#login-screen .lg-stage-tris svg{width:100%;height:100%;overflow:visible;}
#login-screen #lg-tri-left,#login-screen #lg-tri-right,#login-screen #lg-tri-wire{
  transition:transform .8s cubic-bezier(.2,.8,.25,1),opacity .4s;
  transform-box:fill-box;will-change:transform,opacity;}
#login-screen #lg-tri-left{transform-origin:50% 14%;}
#login-screen #lg-tri-right{transform-origin:50% 86%;}
#login-screen #lg-tri-wire{transform-origin:center;}
#login-screen.submitting #lg-tri-left{animation:lg-slamLeft 1.05s cubic-bezier(.16,1,.3,1) forwards;}
#login-screen.submitting #lg-tri-right{animation:lg-slamRight 1.05s cubic-bezier(.16,1,.3,1) forwards;}
#login-screen.submitting #lg-tri-wire{animation:lg-wireZap 1.05s cubic-bezier(.16,1,.3,1) forwards;}
#login-screen.submitting .lg-stage-glow{animation:lg-glowBurst 1.05s cubic-bezier(.16,1,.3,1) forwards;}
@keyframes lg-slamLeft{0%{transform:translate3d(0,0,0) rotate(0);opacity:1;}34%{transform:translate3d(-36px,-2px,0) rotate(-3deg);opacity:.88;}58%{transform:translate3d(18px,1px,0) rotate(1.2deg);opacity:1;}78%{transform:translate3d(-4px,0,0) rotate(-.4deg);}100%{transform:translate3d(0,0,0) rotate(0);opacity:1;}}
@keyframes lg-slamRight{0%{transform:translate3d(0,0,0) rotate(0);opacity:1;}34%{transform:translate3d(36px,2px,0) rotate(3deg);opacity:.88;}58%{transform:translate3d(-18px,-1px,0) rotate(-1.2deg);opacity:1;}78%{transform:translate3d(4px,0,0) rotate(.4deg);}100%{transform:translate3d(0,0,0) rotate(0);opacity:1;}}
@keyframes lg-wireZap{0%{stroke-dashoffset:0;opacity:.42;stroke-width:8;}38%{stroke-dashoffset:-24;opacity:.72;stroke-width:8;}58%{stroke-dashoffset:-52;opacity:1;stroke-width:10;filter:drop-shadow(0 0 10px var(--lg-accent));}100%{stroke-dashoffset:-76;opacity:.42;stroke-width:8;}}
@keyframes lg-glowBurst{0%{opacity:.42;transform:translate(-50%,-50%) scale(1);}52%{opacity:.76;transform:translate(-50%,-50%) scale(1.18);}100%{opacity:.42;transform:translate(-50%,-50%) scale(1);}}
#login-screen .lg-stage-tris.idle #lg-tri-left{animation:lg-bobLeft 6s ease-in-out infinite;}
#login-screen .lg-stage-tris.idle #lg-tri-right{animation:lg-bobRight 6s ease-in-out infinite;}
@keyframes lg-bobLeft{0%,100%{transform:translateY(0);}50%{transform:translateY(-1.2%);}}
@keyframes lg-bobRight{0%,100%{transform:translateY(0);}50%{transform:translateY(1.2%);}}

#login-screen .lg-topbar{position:relative;z-index:5;display:flex;align-items:center;
  justify-content:space-between;padding:22px 28px;}
#login-screen .lg-brand-mini{color:var(--lg-text);text-decoration:none;display:inline-flex;
  align-items:center;gap:.43em;font-weight:700;letter-spacing:-.04em;font-size:28px;
  filter:drop-shadow(0 0 18px rgba(163,230,53,.10));animation:lg-brandBreath 7s ease-in-out infinite;}
@keyframes lg-brandBreath{0%,100%{opacity:.92;transform:translateY(0);}50%{opacity:1;transform:translateY(-1px);}}
#login-screen .lg-brand-mark{display:inline-flex;align-items:center;}
#login-screen .lg-brand-mark svg{display:block;width:1.629em;height:.72em;}
#login-screen .lg-brand-mark .lg-tri-outline{fill:none;stroke:var(--lg-text);}
#login-screen .lg-brand-mark .lg-tri-wire{stroke:var(--lg-tri-wire);}
#login-screen .lg-brand-mark .lg-tri-fill{fill:var(--lg-accent);stroke:var(--lg-accent);}
#login-screen.submitting .lg-brand-mark .lg-tri-wire{
  stroke:var(--lg-accent);
  animation:lg-wireZapMini 1.05s cubic-bezier(.16,1,.3,1) forwards;}
@keyframes lg-wireZapMini{
  0%{opacity:.85;}50%{opacity:1;filter:drop-shadow(0 0 4px var(--lg-accent));}100%{opacity:.85;}
}

#login-screen .lg-center{position:relative;z-index:4;display:flex;align-items:center;
  justify-content:center;min-height:calc(100vh - 80px - 44px);padding:12px 20px 24px;}
#login-screen .lg-card{width:100%;max-width:420px;background:var(--lg-surface);
  backdrop-filter:blur(26px) saturate(135%);-webkit-backdrop-filter:blur(26px) saturate(135%);
  border:1px solid var(--lg-border);border-radius:22px;padding:40px 36px 34px;
  box-shadow:0 1px 0 rgba(255,255,255,.05) inset,0 28px 80px rgba(0,0,0,.52),0 0 0 1px var(--lg-accent-glow-soft);}
html[data-theme="light"] #login-screen .lg-card{
  box-shadow:0 1px 0 rgba(255,255,255,.7) inset,0 16px 48px rgba(10,10,12,.10),0 0 0 1px var(--lg-accent-glow-soft);}

#login-screen .lg-title{font-family:'Instrument Serif',serif;font-size:40px;font-weight:400;
  letter-spacing:-.02em;line-height:1.08;margin:0 0 10px;color:var(--lg-text);}
#login-screen .lg-title em{font-style:italic;color:var(--lg-accent);}
#login-screen .lg-subtitle{color:var(--lg-accent);font-size:14px;font-weight:500;
  line-height:1.5;margin:2px 0 28px;letter-spacing:-.01em;opacity:.92;}
html[data-theme="light"] #login-screen .lg-subtitle{color:var(--lg-accent-2);opacity:.88;}

#login-screen .lg-field{margin-bottom:14px;}
#login-screen .lg-field label{display:block;font-size:12px;font-weight:500;
  color:var(--lg-text-dim);margin-bottom:7px;letter-spacing:0;text-transform:none;}
#login-screen .lg-input{width:100%;height:48px;background:var(--lg-input-bg);
  border:1px solid var(--lg-border);border-radius:10px;color:var(--lg-text);
  font-size:16px!important;padding:0 14px;font-family:inherit;
  transition:border-color .15s,box-shadow .15s,background .15s;outline:none;}
#login-screen .lg-input:hover{border-color:var(--lg-border-strong);}
#login-screen .lg-input:focus{border-color:var(--lg-accent);
  box-shadow:0 0 0 4px var(--lg-accent-glow-soft);}
#login-screen .lg-input::placeholder{color:var(--lg-text-mute);}

#login-screen .lg-input-wrap{position:relative;display:block;}
#login-screen .lg-input-wrap > .lg-input-pass{padding-right:108px;}
#login-screen .lg-pass-toggle{
  position:absolute;top:50%;right:6px;transform:translateY(-50%);
  width:36px;height:36px;border:0;background:transparent;
  color:var(--lg-text-mute);
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:8px;cursor:pointer;user-select:none;
  -webkit-tap-highlight-color:transparent;
  transition:color .15s,background .15s;
  font-family:inherit;
}
#login-screen .lg-pass-toggle:hover{color:var(--lg-accent);background:var(--lg-accent-glow-soft);}
#login-screen .lg-pass-toggle:focus-visible{outline:2px solid var(--lg-accent);outline-offset:2px;}
#login-screen .lg-pass-toggle svg{width:18px;height:18px;pointer-events:none;}
#login-screen .lg-pass-toggle .lg-eye-hide{display:none;}
#login-screen .lg-pass-toggle[aria-pressed="true"] .lg-eye-show{display:none;}
#login-screen .lg-pass-toggle[aria-pressed="true"] .lg-eye-hide{display:inline-block;color:var(--lg-accent);}

#login-screen .lg-caps-warn{
  position:absolute;top:50%;right:50px;transform:translateY(-50%);
  display:inline-flex;align-items:center;gap:4px;
  font-size:10.5px;font-weight:600;letter-spacing:.04em;line-height:1;
  color:var(--lg-warn);background:var(--lg-warn-bg);
  border:1px solid var(--lg-warn-border);
  padding:3px 7px;border-radius:6px;
  pointer-events:none;white-space:nowrap;
  font-family:inherit;
  animation:lg-fadeIn .18s ease-out;
}
#login-screen .lg-caps-warn[hidden]{display:none;}
#login-screen .lg-caps-warn svg{display:block;}
@keyframes lg-fadeIn{from{opacity:0;}to{opacity:1;}}

#login-screen .lg-form-error{display:none;margin:-2px 0 16px;padding:10px 12px;
  border:1px solid rgba(248,113,113,.28);border-radius:10px;
  background:rgba(248,113,113,.08);color:var(--lg-error);font-size:13px;line-height:1.45;text-align:left;}
html[data-theme="light"] #login-screen .lg-form-error{
  background:rgba(220,38,38,.07);border-color:rgba(220,38,38,.18);}
#login-screen .has-error .lg-form-error,
#login-screen .lg-form.has-error .lg-form-error{display:block;
  animation:lg-errorIn .18s ease-out,lg-errorShake .34s ease-out .08s;}
#login-screen .lg-form.has-error .lg-input{border-color:rgba(248,113,113,.72);}
#login-screen .lg-form.has-error .lg-input:focus{border-color:#f87171;
  box-shadow:0 0 0 4px rgba(248,113,113,.12);}
@keyframes lg-errorIn{from{opacity:0;transform:translateY(-4px);}to{opacity:1;transform:translateY(0);}}
@keyframes lg-errorShake{0%,100%{transform:translateX(0);}25%{transform:translateX(-4px);}50%{transform:translateX(4px);}75%{transform:translateX(-2px);}}

#login-screen .lg-btn-primary{width:100%;height:52px;margin-top:22px;
  background:linear-gradient(180deg,#b7f34a 0%,var(--lg-accent) 100%);color:#0a0a0c;
  border:0;border-radius:12px;font-family:inherit;font-size:15px;font-weight:700;
  letter-spacing:-.01em;cursor:pointer;
  transition:filter .15s,transform .05s,box-shadow .25s,opacity .15s;
  box-shadow:0 12px 34px rgba(163,230,53,.24),0 0 0 1px var(--lg-accent-glow-soft);
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  position:relative;overflow:hidden;}
#login-screen .lg-btn-primary:hover{filter:brightness(1.04);
  box-shadow:0 16px 42px rgba(163,230,53,.30);}
#login-screen .lg-btn-primary:active{transform:translateY(1px);}
#login-screen .lg-btn-primary[disabled]{cursor:not-allowed;opacity:.6;}
#login-screen .lg-btn-primary .lg-spinner{width:16px;height:16px;border-radius:50%;
  border:2px solid currentColor;border-right-color:transparent;
  animation:lg-spin .7s linear infinite;display:none;}
#login-screen.submitting .lg-btn-primary .lg-spinner{display:inline-block;}
#login-screen.submitting .lg-btn-primary .lg-arrow{opacity:.42;}
#login-screen.submitting .lg-btn-primary .lg-label{opacity:.82;}
@keyframes lg-spin{to{transform:rotate(360deg);}}

@media(prefers-reduced-motion:reduce){
  /* Idle: kill looping background motion */
  #login-screen .lg-stage-glow,
  #login-screen .lg-stage-tris.idle #lg-tri-left,
  #login-screen .lg-stage-tris.idle #lg-tri-right,
  #login-screen .lg-brand-mini{animation:none;}
  /* Submit: skip the oscillating slam — the spinner already conveys progress */
  #login-screen.submitting #lg-tri-left,
  #login-screen.submitting #lg-tri-right,
  #login-screen.submitting #lg-tri-wire,
  #login-screen.submitting .lg-stage-glow,
  #login-screen.submitting .lg-brand-mark .lg-tri-wire{animation:none;}
  /* Error: keep the fade-in but drop the shake */
  #login-screen .has-error .lg-form-error,
  #login-screen .lg-form.has-error .lg-form-error{animation:lg-errorIn .18s ease-out;}
}

@media(max-width:520px){
  #login-screen .lg-topbar{padding:18px 18px 10px;}
  #login-screen .lg-brand-mini{font-size:24px;}
  #login-screen .lg-center{min-height:calc(100svh - 74px);padding:14px 16px 22px;}
  #login-screen .lg-card{max-width:100%;padding:30px 22px 24px;border-radius:18px;}
  #login-screen .lg-title{font-size:34px;line-height:1.05;}
  #login-screen .lg-subtitle{font-size:14px;margin-bottom:24px;}
  #login-screen .lg-input{height:48px;}
  #login-screen .lg-input-wrap > .lg-input-pass{padding-right:78px;}
  #login-screen .lg-caps-warn span{display:none;}
  #login-screen .lg-caps-warn{padding:4px;}
  #login-screen .lg-btn-primary{height:52px;font-size:15px;}
  #login-screen .lg-stage-grid{opacity:.34;background-size:22px 22px;}
  #login-screen .lg-stage-glow{width:680px;height:680px;top:48%;opacity:.38;}
  #login-screen .lg-stage-tris{width:118vw;height:118vw;top:48%;opacity:.42;}
}
@media(max-width:360px){
  #login-screen .lg-topbar{padding:14px 14px 8px;}
  #login-screen .lg-brand-mini{font-size:22px;}
  #login-screen .lg-card{padding:26px 18px 22px;}
  #login-screen .lg-title{font-size:31px;}
}

/* ╔═════════════════════════════════════════════════════════════════════════╗
   ║  DETALLE NOVEDAD (.dn-*)                                                ║
   ╚═════════════════════════════════════════════════════════════════════════╝ */
.dn-grid{display:flex;flex-direction:column;gap:16px;}
.dn-foto-wrap{background:var(--surface2);border-radius:var(--r);min-height:300px;display:flex;align-items:center;justify-content:center;color:var(--text3);font-size:13px;overflow:hidden;}
.dn-foto-wrap img{width:100%;height:300px;object-fit:cover;display:block;cursor:zoom-in;}
.dn-detail-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;}
.dn-detail-header .detail-back{margin-bottom:0;}
.dn-action-kebab-wrap{position:relative;}
.dn-action-kebab-wrap[hidden]{display:none;}
.dn-action-kebab{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--border);background:var(--surface);color:var(--text3);border-radius:8px;cursor:pointer;padding:0;transition:background .12s,color .12s,border-color .12s;}
.dn-action-kebab:hover,.dn-action-kebab[aria-expanded="true"]{background:var(--bg);color:var(--text);border-color:var(--border2);}
.dn-action-kebab svg{width:16px;height:16px;display:block;}
.dn-action-menu{position:absolute;top:calc(100% + 4px);right:0;min-width:200px;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.12),0 2px 4px rgba(0,0,0,.06);padding:4px;z-index:150;animation:dn-menu-in .14s ease-out;}
.dn-action-menu[hidden]{display:none;}
@keyframes dn-menu-in{from{opacity:0;transform:translateY(-4px);}to{opacity:1;transform:translateY(0);}}
.dn-menu-item{display:flex;align-items:center;gap:9px;padding:7px 10px;border:0;background:transparent;color:var(--text2);font-size:13px;font-family:inherit;cursor:pointer;border-radius:5px;width:100%;text-align:left;min-height:34px;transition:background .12s,color .12s;touch-action:manipulation;}
.dn-menu-item[hidden]{display:none;}
.dn-menu-item:hover,.dn-menu-item:focus-visible{background:var(--accent-glow);color:var(--accent);outline:none;}
.dn-menu-item:hover svg,.dn-menu-item:focus-visible svg{color:var(--accent);}
.dn-menu-item svg{width:14px;height:14px;flex-shrink:0;}
.dn-menu-item-danger{color:var(--error);}
.dn-menu-item-danger:hover,.dn-menu-item-danger:focus-visible{background:var(--error-bg-hover);color:var(--error);}
.dn-menu-item-danger:hover svg,.dn-menu-item-danger:focus-visible svg{color:var(--error);}
.dn-menu-sep{height:1px;background:var(--border);margin:3px 6px;}
.dn-menu-sep[hidden]{display:none;}
@media(min-width:769px){
  .dn-grid{display:grid;grid-template-columns:1fr 420px;grid-template-rows:auto;}
  .dn-foto-card{grid-column:2;grid-row:1;}
  .dn-main{grid-column:1;grid-row:1;}
}

/* ╔═════════════════════════════════════════════════════════════════════════╗
   ║  UTILITIES — Fase 8 (extracción de inline styles)                       ║
   ║                                                                         ║
   ║  Reglas pensadas para reemplazar los 1209 style="..." inline detectados ║
   ║  por arch:inline-style. Cada clase cubre un patrón recurrente con valor ║
   ║  semántico (.label, .mono, .subtitle) o estructural (.row, .stack).     ║
   ║                                                                         ║
   ║  Reglas para esta sección:                                              ║
   ║  - Sólo agregar utilidades que aparecen ≥10 veces en código real        ║
   ║  - Evitar atajos tipo Tailwind con un solo prop (.pt-4, .text-12)       ║
   ║  - Las utilidades MAYBE-rompen-cascade no llevan !important; si chocan  ║
   ║    con un componente, el componente gana (lo cual suele ser correcto)   ║
   ╚═════════════════════════════════════════════════════════════════════════╝ */

/* Spacing scale — usar en lugar de px ad-hoc. gap y space son escalas
   independientes porque cumplen funciones distintas (gap entre items de un
   flex/grid vs. margen interno entre secciones). */
:root {
  --gap-xs: 4px;  --gap-sm: 6px;  --gap-md: 8px;  --gap-lg: 12px;
  --space-xs: 6px; --space-sm: 10px; --space-md: 16px; --space-lg: 24px;
}

/* ── Layout (flex / grid) ─────────────────────────────────────────────── */
.row              { display:flex; align-items:center; gap:var(--gap-md); }
.row-sm           { display:flex; align-items:center; gap:var(--gap-sm); }
.row-lg           { display:flex; align-items:center; gap:var(--gap-lg); }
.row-between      { display:flex; align-items:center; justify-content:space-between; }
.row-center       { display:flex; align-items:center; justify-content:center; }
.stack            { display:flex; flex-direction:column; gap:var(--gap-lg); }
.stack-sm         { display:flex; flex-direction:column; gap:var(--gap-md); }
.grid-2           { display:grid; grid-template-columns:1fr 1fr; gap:var(--space-sm) var(--space-md); }

/* ── Typography ───────────────────────────────────────────────────────── */
.label            { font-size:11px; color:var(--text3); text-transform:uppercase; letter-spacing:.05em; }
.subtitle         { font-size:12px; color:var(--text3); line-height:1.5; }
.heading-sm       { font-size:13px; font-weight:600; color:var(--text); }
.mono             { font-family:'DM Mono',monospace; font-size:11px; }
.mono-muted       { font-family:'DM Mono',monospace; font-size:11px; color:var(--text3); }
.text-muted       { color:var(--text3); }
.text-center      { text-align:center; }
/* Texto pequeño muted sin uppercase — para captions, helps text, metadata
   secundaria. La diferencia con .label: .label es para titular un campo
   y por convención va en uppercase; .caption es para texto descriptivo. */
.caption          { font-size:11px; color:var(--text3); }
/* Label de form compacta (usada en cfg-panels, paneles de configuración).
   Diferente de .fg label (más grande, uppercase): esta es para forms densos
   de configuración donde el espacio es premium. font-weight no se establece
   — los call sites que lo necesitan en bold lo declaran inline. */
.field-label      { display:block; font-size:11px; color:var(--text3); margin-bottom:4px; }

/* ── Containers ───────────────────────────────────────────────────────── */
/* .panel-inset: sub-panel dentro de un .card (fondo --bg, borde sutil,
   padding uniforme). 14px elegido empíricamente desde uso real en
   empresa-perfil; si en el futuro hace falta variante más comprimida,
   agregar .panel-inset-tight con padding:10px 14px. */
.panel-inset      { padding:14px; background:var(--bg); border:1px solid var(--border); border-radius:8px; }

/* ── Spacing (margin-bottom escala) ───────────────────────────────────── */
.mb-sm            { margin-bottom:var(--gap-md); }
.mb-md            { margin-bottom:var(--gap-lg); }
.mb-lg            { margin-bottom:var(--space-md); }

/* ── Layout helpers de uso muy frecuente ──────────────────────────────── */
.flex-1           { flex:1; }
.nowrap           { white-space:nowrap; }

/* ── Atomic shortcuts ──────────────────────────────────────────────────
   La regla original era evitar atomic-utilities tipo Tailwind. Excepto:
   propiedades mecánicas (cursor, text-align, font-weight) que aparecen
   ≥5 veces como single-prop puro en código real. Su uso no es decisión
   semántica — es ajuste micro. Listadas aquí para cerrarlas en lote. */
.fs-11            { font-size:11px; }
.fs-12            { font-size:12px; }
.fs-13            { font-size:13px; }
.fw-500           { font-weight:500; }
.fw-600           { font-weight:600; }
.fw-700           { font-weight:700; }
.clickable        { cursor:pointer; }
.text-right       { text-align:right; }
.m-0              { margin:0; }
.mt-xs            { margin-top:var(--gap-xs); }  /* 4px */
.mt-sm            { margin-top:var(--gap-sm); }  /* 6px */
.mt-md            { margin-top:var(--gap-md); }  /* 8px */
.mt-lg            { margin-top:var(--gap-lg); }  /* 12px */
.mb-xs            { margin-bottom:var(--gap-xs); } /* 4px */
.w-full           { width:100%; }
.mw-0             { min-width:0; }
.v-top            { vertical-align:top; }
.p-20             { padding:20px; }
.p-12             { padding:12px; }
.p-30             { padding:30px; }
.fs-10            { font-size:10px; }
.fs-14            { font-size:14px; }
.fs-16            { font-size:16px; }
.flex-wrap        { flex-wrap:wrap; }
.fs-15            { font-size:15px; }
.text-2nd         { color:var(--text2); }
.text-accent      { color:var(--accent); }
.no-select        { user-select:none; }
.font-mono        { font-family:'DM Mono',monospace; }
.truncate         { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.ellipsis         { overflow:hidden; text-overflow:ellipsis; }
.mb-0             { margin-bottom:0; }
.text-error       { color:var(--red); }
/* Variantes flex sin align-items:center (para cuando los items son del mismo
   tamaño o querés stretch default). El .row-* tradicional setea
   align-items:center, lo cual a veces no es lo que querés. */
.flex-row         { display:flex; gap:var(--gap-md); }
.flex-row-sm      { display:flex; gap:var(--gap-sm); }
.flex-row-lg      { display:flex; gap:var(--space-md); }    /* gap:16 */
.flex-end         { display:flex; gap:var(--gap-md); justify-content:flex-end; }
.ml-xs            { margin-left:4px; }
.ml-sm            { margin-left:6px; }
.text-1st         { color:var(--text); }
/* Color highlights — combos frecuentes color+weight */
.accent-bold      { color:var(--accent); font-weight:600; }
/* Info-grid key-value — auto 1fr 2-col grid usado para listas tipo
   "Etiqueta: valor" en empresa-perfil, bpm-canvas, etc. */
.info-grid-kv     { display:grid; grid-template-columns:auto 1fr; gap:4px 16px; font-size:13px; }
.info-grid-kv-base{ display:grid; grid-template-columns:auto 1fr; gap:4px 16px; }
/* Alert: notificación inline warn con background+border (cfg-panels usa esto
   para mensajes "ya hay X tareas en curso" en paneles SLA editor). */
.alert-warn       { color:var(--warn); background:var(--warn-bg); border:1px solid var(--warn-border); border-radius:6px; padding:6px 8px; }
.alert-error      { color:var(--error); background:var(--error-bg); border:1px solid var(--error-border); border-radius:6px; padding:6px 8px; }
/* Dot indicator: marker pequeño circular con color dinámico. Usado para
   tipos de paso BPM, estados activo/inactivo, etc. */
.dot              { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
/* Checkbox/radio wrapper: contenedor de 16x16 con flex-shrink para icons
   custom dentro de filas. */
.icon-16          { width:16px; height:16px; flex-shrink:0; }
/* List row con border-bottom — patrón de tablas/listas custom (telegram-picker,
   trusted-issuers, cfg-panels). */
.list-row         { gap:8px; padding:10px 12px; border-bottom:1px solid var(--border); }
/* Radio button 15x15 con accent-color — usado en cfg-panels para opciones
   de scope (todas las tareas / solo nuevas). */
.radio-15         { width:15px; height:15px; accent-color:var(--accent); }
/* Background+border accent — combo para botones/cards "activos" */
.bg-accent-bordered { background:var(--accent); border-color:var(--accent); }
.break-all        { word-break:break-all; }
.break-word       { word-break:break-word; }
.overflow-visible { overflow:visible; }
.pre-wrap         { white-space:pre-wrap; }
/* Input mini: campo de texto compacto con borde + radius + fondo claro,
   usado en bpm-canvas para inputs inline de SLA/asignación. */
.input-mini       { box-sizing:border-box; padding:5px 6px; border:1px solid var(--border); border-radius:6px; background:var(--bg); }

/* ── Empty/error states (patrón "Sin datos…" centrado) ──────────────────
   Aparece 40+ veces con leves variaciones de padding (12px / 20px / 24px /
   32px / 40px). Unificamos a 20px como default y permitimos override con
   .empty-state-sm (12px) y .empty-state-lg (32px). */
.empty-state      { padding:20px; text-align:center; color:var(--text3); font-size:12px; }
.empty-state-sm   { padding:12px; text-align:center; color:var(--text3); font-size:12px; }
.empty-state-lg   { padding:32px 0; text-align:center; color:var(--text3); font-size:12px; }
.error-state      { padding:20px; color:var(--red); font-size:13px; }
