*{margin:0;padding:0;box-sizing:border-box}
:root{
  --dark:#0B1420;--dark2:#121E2E;--orange:#1A7A5C;--orange2:#2BA67A;
  --orange-pale:#D4EDE4;--green-pale:#D4EDE4;--green-dark:#14614A;
  --light:#F3F6F8;--white:#FFFFFF;--border:rgba(255,255,255,.08);
  --text:#f0f0f0;--muted:rgba(255,255,255,.45);--danger:#c84a20;
  --accent:#2563EB;--accent2:#3B82F6;
  --radius:12px;
  --safe-bottom:env(safe-area-inset-bottom, 0px);
}
html{-webkit-text-size-adjust:100%;height:100%}
body{font-family:'DM Sans',sans-serif;background:var(--dark);color:var(--text);min-height:100vh;min-height:100dvh;padding-bottom:calc(68px + var(--safe-bottom));font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;overscroll-behavior-y:none;transition:background .3s,color .3s}

/* ── LIGHT MODE ─────────────────────────────────────────── */
body.light{
  --dark:#FFFFFF;--dark2:#F3F6F8;--orange:#1A7A5C;--orange2:#158A64;
  --border:rgba(0,0,0,.1);--text:#1a2030;--muted:rgba(0,0,0,.5);
  --accent:#2563EB;--accent2:#3B82F6;
  background:#F5F7FA;color:var(--text);
}

body.light .app-greeting{color:#1a2030}
body.light .login-logo h1{color:#1a2030}
body.light .page-header h2{color:#1a2030}
body.light .modal-title{color:#1a2030}
body.light .area-name{color:#1a2030}
body.light .dash-card-body h3{color:#1a2030}
body.light .verif-title{color:var(--orange)}
body.light .hist-card-head strong{color:#1a2030}
body.light .form-group input,body.light .form-group select,body.light .form-group textarea,body.light .app-textarea,body.light .app-input{background:#fff;border-color:rgba(0,0,0,.12);color:#1a2030}
body.light .form-group input::placeholder,body.light .app-textarea::placeholder,body.light .app-input::placeholder{color:rgba(0,0,0,.3)}
body.light .form-group input:focus,body.light .app-textarea:focus,body.light .app-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
body.light select.app-input,body.light .form-group select{color:#1a2030}
body.light select.app-input option,body.light .form-group select option{background:#fff;color:#1a2030}
body.light .dash-card{background:#fff;border-color:rgba(0,0,0,.08);box-shadow:0 1px 4px rgba(0,0,0,.04)}
body.light .area-item{background:#fff;border-color:rgba(0,0,0,.08)}
body.light .verif-section{background:#fff;border-color:rgba(0,0,0,.08)}
body.light .hist-card{background:#fff;border-color:rgba(0,0,0,.08)}
body.light .desp-item{background:#fff;border-color:rgba(0,0,0,.08);color:#1a2030}
body.light .modal-box{background:#fff;border-top-color:var(--accent)}
body.light .modal-area{color:var(--orange)}
body.light .bottom-nav{background:rgba(255,255,255,.95);border-top-color:rgba(0,0,0,.08)}
body.light .nav-item svg{fill:rgba(0,0,0,.3)}
body.light .nav-item span{color:rgba(0,0,0,.3)}
body.light .nav-item.active svg{fill:var(--accent)}
body.light .nav-item.active span{color:var(--accent)}
body.light .btn-logout{background:rgba(0,0,0,.04);border-color:rgba(0,0,0,.1)}
body.light .btn-logout svg{fill:rgba(0,0,0,.4)}
body.light .login-page{background:#F5F7FA;background-image:radial-gradient(ellipse at 50% 0%,rgba(37,99,235,.06) 0%,transparent 60%)}
body.light .login-icon{background:#fff;border-color:rgba(26,122,92,.25);box-shadow:0 4px 24px rgba(0,0,0,.06)}
body.light .login-icon svg{fill:var(--orange)}
body.light .login-logo p{color:rgba(0,0,0,.45)}
body.light .login-help{color:rgba(0,0,0,.4)}
body.light .alert-error{background:rgba(200,74,32,.06);border-color:rgba(200,74,32,.2);color:#c84a20}
body.light .alert-success{background:rgba(26,122,92,.06);border-color:rgba(26,122,92,.2);color:#14614A}
body.light .hist-tabs{border-color:rgba(0,0,0,.1)}
body.light .hist-tab{background:rgba(0,0,0,.03);color:rgba(0,0,0,.4)}
body.light .hist-tab.active{background:var(--accent);color:#fff}
body.light .abtn.si{background:rgba(26,122,92,.08);border-color:rgba(26,122,92,.2);color:#14614A}
body.light .abtn.no{background:rgba(200,74,32,.06);border-color:rgba(200,74,32,.15);color:#c84a20}
body.light .ebtn.ok{background:rgba(26,122,92,.08);border-color:rgba(26,122,92,.2);color:#14614A}
body.light .ebtn.ko{background:rgba(200,74,32,.06);border-color:rgba(200,74,32,.15);color:#c84a20}
body.light .btn-cancel{border-color:rgba(0,0,0,.12);color:rgba(0,0,0,.5)}
body.light .btn-add-desp{border-color:rgba(0,0,0,.12);color:rgba(0,0,0,.4)}
body.light .app-code{color:rgba(0,0,0,.4)}
body.light .page-week,body.light .page-sub{color:rgba(0,0,0,.45)}
body.light .dash-card-body p{color:rgba(0,0,0,.45)}
body.light .dash-card-arrow{color:rgba(0,0,0,.2)}
body.light .dash-card-icon{background:rgba(26,122,92,.08)}
body.light .dash-alert{background:rgba(200,74,32,.06);border-color:rgba(200,74,32,.15)}

/* AUTOSAVE INDICATOR */
.save-toast{position:fixed;top:16px;left:50%;transform:translateX(-50%);background:#16a34a;color:#fff;padding:10px 22px;border-radius:24px;font-size:14px;font-weight:600;z-index:300;opacity:0;transition:opacity .25s,transform .25s;pointer-events:none;font-family:'DM Sans',sans-serif;box-shadow:0 8px 24px rgba(22,163,74,.4);transform:translateX(-50%) translateY(-8px)}
.save-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
body.light .save-toast{background:#16a34a}

/* SAVE BAR (sticky bottom save area) */
.save-bar{position:sticky;bottom:calc(76px + var(--safe-bottom));margin:24px -20px 0;padding:12px 20px 14px;background:linear-gradient(180deg,transparent 0%,rgba(14,19,12,.85) 28%,rgba(14,19,12,.96) 100%);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:50;display:flex;flex-direction:column;gap:6px;border-top:1px solid rgba(255,255,255,.04)}
body.light .save-bar{background:linear-gradient(180deg,transparent 0%,rgba(248,249,250,.85) 28%,rgba(248,249,250,.98) 100%);border-top-color:rgba(0,0,0,.04)}
.save-bar .btn-primary-app{margin:0}
.save-status{font-size:12px;color:var(--muted);text-align:center;letter-spacing:.02em;transition:color .25s}
.save-status.saving{color:var(--orange2)}
.save-status.saved{color:#16a34a;font-weight:600}
.save-status.error{color:#ef4444;font-weight:600}
.btn-primary-app.saved-state{background:#16a34a;box-shadow:0 4px 16px rgba(22,163,74,.35)}
.btn-primary-app.saved-state:hover{background:#15803d}

/* THEME TOGGLE */
.theme-toggle{width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all .2s}
.theme-toggle:active{transform:scale(.9)}
.theme-toggle svg{width:18px;height:18px;fill:rgba(255,255,255,.45);transition:fill .2s}
body.light .theme-toggle{background:rgba(0,0,0,.04);border-color:rgba(0,0,0,.1)}
body.light .theme-toggle svg{fill:rgba(0,0,0,.5)}
.theme-toggle .icon-sun{display:none}
.theme-toggle .icon-moon{display:block}
body.light .theme-toggle .icon-sun{display:block}
body.light .theme-toggle .icon-moon{display:none}

@keyframes fadeIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}

/* ── APP CONTAINER ─────────────────────────────────────── */
.app-container{max-width:520px;margin:0 auto;padding:20px 20px 28px;animation:fadeIn .4s ease both}

/* ── LOGIN ──────────────────────────────────────────────── */
.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:24px;background:var(--dark);background-image:radial-gradient(ellipse at 50% 0%,rgba(37,99,235,.08) 0%,transparent 60%)}
.login-container{width:100%;max-width:360px;animation:fadeIn .5s ease both}
.login-logo{text-align:center;margin-bottom:36px}
.login-icon{width:64px;height:64px;background:var(--dark2);border:2px solid rgba(26,122,92,.4);border-radius:18px;display:inline-flex;align-items:center;justify-content:center;margin-bottom:16px;box-shadow:0 4px 24px rgba(26,122,92,.15)}
.login-icon svg{width:30px;height:30px;fill:var(--orange2)}
.login-logo h1{font-family:'Playfair Display',serif;font-size:26px;color:var(--white);letter-spacing:-.01em}
.login-logo h1 em{font-style:normal;color:var(--orange)}
.login-logo p{font-size:13px;color:var(--muted);margin-top:6px}
.login-help{text-align:center;font-size:12px;color:var(--muted);margin-top:24px;line-height:1.6}
.login-help a{color:var(--orange2);text-decoration:none}

/* ── FORMS ──────────────────────────────────────────────── */
.app-form,.form-group{display:flex;flex-direction:column;gap:14px}
.form-group{gap:6px}
.form-group label,.form-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;font-weight:600}
.form-group input,.form-group select,.form-group textarea,.app-textarea{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:14px 16px;font-size:16px;color:var(--white);font-family:'DM Sans',sans-serif;outline:none;width:100%;transition:all .25s;-webkit-appearance:none}
.form-group input:focus,.form-group select:focus,.app-textarea:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(26,122,92,.15);background:rgba(255,255,255,.07)}
.form-group input::placeholder,.app-textarea::placeholder{color:rgba(255,255,255,.25)}
.app-textarea{min-height:88px;resize:none}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* ── BUTTONS ────────────────────────────────────────────── */
.btn-primary-app{background:var(--accent);color:#fff;border:none;padding:15px;border-radius:var(--radius);font-size:15px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;width:100%;transition:all .25s;-webkit-tap-highlight-color:transparent;box-shadow:0 2px 12px rgba(37,99,235,.25)}
.btn-primary-app:hover,.btn-primary-app:active{background:var(--accent2);transform:translateY(-1px);box-shadow:0 4px 20px rgba(37,99,235,.35)}
.btn-primary-app:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}
.btn-cancel{background:transparent;color:var(--muted);border:1px solid var(--border);padding:13px 20px;border-radius:var(--radius);font-size:14px;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .2s}
.btn-cancel:active{background:rgba(255,255,255,.05)}
.btn-logout{width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:rgba(255,255,255,.05);border:1px solid var(--border);transition:all .2s}
.btn-logout:active{background:rgba(200,74,32,.15)}
.btn-logout svg{width:18px;height:18px;fill:var(--muted)}

/* ── ALERTS ─────────────────────────────────────────────── */
.alert-error{background:rgba(200,74,32,.12);border:1px solid rgba(200,74,32,.3);border-radius:var(--radius);padding:14px 18px;font-size:14px;color:var(--orange2);margin-bottom:14px}
.alert-success{background:rgba(42,106,26,.12);border:1px solid rgba(74,154,48,.3);border-radius:var(--radius);padding:16px 18px;font-size:14px;color:#a8d5a0;text-align:center;margin-bottom:16px}

/* ── TOP BAR ────────────────────────────────────────────── */
.app-top-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}
.app-greeting{font-family:'Playfair Display',serif;font-size:22px;color:var(--white);line-height:1.3;letter-spacing:-.01em}
.app-code{font-size:12px;color:var(--muted);margin-top:3px}

/* ── DASHBOARD CARDS ────────────────────────────────────── */
.dashboard-cards{display:flex;flex-direction:column;gap:12px}
.dash-card{display:flex;align-items:center;gap:16px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:14px;padding:18px;text-decoration:none;transition:all .25s;-webkit-tap-highlight-color:transparent}
.dash-card:active{transform:scale(.98);background:rgba(255,255,255,.06)}
.dash-card.pending{border-left:3px solid var(--orange)}
.dash-card.done{border-left:3px solid #4a9a30}
.dash-card-icon{width:44px;height:44px;background:rgba(26,122,92,.12);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.dash-card-icon svg{width:22px;height:22px;fill:var(--orange2)}
.dash-card-body{flex:1}
.dash-card-body h3{font-size:15px;font-weight:600;color:var(--white);margin-bottom:3px}
.dash-card-body p{font-size:12px;color:var(--muted);line-height:1.4}
.dash-card-status{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}
.status-ok{background:#2a6a1a;color:#fff}
.status-pending{background:var(--accent);color:#fff;animation:pulse 2s infinite}
.dash-card-arrow{font-size:22px;color:rgba(255,255,255,.2);flex-shrink:0}
.dash-alert{background:rgba(200,74,32,.1);border:1px solid rgba(200,74,32,.25);border-radius:12px;padding:12px 16px;font-size:13px;color:#c84a20;margin-bottom:10px}
.dash-alert-info{background:rgba(37,99,235,.08);border:1px solid rgba(37,99,235,.15);border-radius:12px;padding:12px 16px;font-size:13px;color:var(--accent);margin-bottom:10px}

/* DASH SECTIONS */
.dash-section{margin-top:20px}
.dash-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:10px}
.dash-section-muted{font-size:13px;color:var(--muted)}

/* TEMPERATURAS DASHBOARD */
.dash-temps{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:8px}
.dash-temp{display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 8px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--radius);text-align:center}
body.light .dash-temp{background:#fff;border-color:rgba(0,0,0,.08)}
.dash-temp-val{font-size:22px;font-weight:700;font-family:'DM Sans',sans-serif}
.dash-temp.temp-ok .dash-temp-val{color:var(--orange2)}
.dash-temp.temp-danger .dash-temp-val{color:#c84a20}
.dash-temp.temp-danger{border-color:rgba(200,74,32,.3);background:rgba(200,74,32,.06)}
.dash-temp-name{font-size:10px;color:var(--muted);line-height:1.3;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* QUICK STATS */
.dash-quick{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.dash-quick-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 8px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;transition:all .2s;-webkit-tap-highlight-color:transparent}
body.light .dash-quick-item{background:#fff;border-color:rgba(0,0,0,.08)}
.dash-quick-item:active{transform:scale(.97)}
.dash-quick-num{font-size:24px;font-weight:700;color:var(--accent);font-family:'DM Sans',sans-serif}
.dash-quick-label{font-size:11px;color:var(--muted);text-align:center;line-height:1.3}

/* ── PAGE HEADERS ───────────────────────────────────────── */
.page-header{margin-bottom:24px}
.page-header h2{font-family:'Playfair Display',serif;font-size:24px;color:var(--white);letter-spacing:-.01em}
.page-week,.page-sub{font-size:13px;color:var(--muted);margin-top:6px}

/* ── AREA LIST (REGISTRO) ───────────────────────────────── */
.area-list{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}
.area-item{display:flex;align-items:center;justify-content:space-between;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:14px;padding:16px 18px;gap:14px;transition:all .2s}
.area-info{display:flex;align-items:center;gap:12px;flex:1}
.area-num{font-size:13px;font-weight:700;color:var(--orange2);min-width:28px;letter-spacing:.02em}
.area-name{font-size:17px;color:var(--white);font-weight:700;font-family:'Playfair Display',serif;letter-spacing:.02em;text-transform:uppercase}
body.light .area-name{color:#0B1420}
.area-sub{font-size:12px;color:var(--muted);font-weight:400;margin-top:2px;font-family:'DM Sans',sans-serif;text-transform:none;letter-spacing:0}

/* Resaltado con borde izquierdo naranja en todas las areas principales */
.area-item{border-left:3px solid var(--orange)}

/* Headers de seccion (Limpieza, Temperaturas, Contaminacion...) con fondo degradado */
.area-item-header{background:linear-gradient(90deg,rgba(26,122,92,.14) 0%,rgba(26,122,92,.04) 100%);border-color:rgba(26,122,92,.25)}
body.light .area-item-header{background:linear-gradient(90deg,rgba(26,122,92,.08) 0%,rgba(26,122,92,.02) 100%);border-color:rgba(26,122,92,.2)}
.area-btns{display:flex;gap:8px;flex-shrink:0}
.abtn{padding:10px 20px;border-radius:10px;border:1px solid transparent;font-size:13px;font-weight:700;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .2s;-webkit-tap-highlight-color:transparent}
.abtn.si{background:rgba(42,106,26,.15);border-color:rgba(42,106,26,.3);color:#a8d5a0}
.abtn.no{background:rgba(200,74,32,.12);border-color:rgba(200,74,32,.25);color:var(--orange2)}
.abtn:active{transform:scale(.95)}
.abtn.sel-si{background:#2a6a1a;border-color:#4a9a30;color:#fff;box-shadow:0 2px 8px rgba(42,106,26,.3)}
.abtn.sel-no{background:#8a2a10;border-color:#c84a20;color:#fff;box-shadow:0 2px 8px rgba(200,74,32,.3)}

/* ── LIMPIEZA POR ZONAS ────────────────────────────────── */
.limp-zonas{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:10px}
.limp-zona{display:flex;align-items:center;gap:10px;padding:14px 16px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent}
body.light .limp-zona{background:#fff;border-color:rgba(0,0,0,.08)}
.limp-zona:active{transform:scale(.97)}
.limp-zona input{width:20px;height:20px;accent-color:var(--orange);flex-shrink:0}
.limp-zona span{font-size:14px;color:var(--text);font-weight:500}
body.light .limp-zona span{color:#1a2030}
.limp-zona:has(input:checked){border-color:var(--orange);background:rgba(26,122,92,.06)}
body.light .limp-zona:has(input:checked){background:rgba(26,122,92,.04)}
.btn-toggle-all{background:rgba(26,122,92,.18);border:1px solid rgba(26,122,92,.4);color:var(--brand,#2BA67A);padding:6px 12px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent;white-space:nowrap}
.btn-toggle-all:hover{background:rgba(26,122,92,.28)}
.btn-toggle-all:active{transform:scale(.95)}
body.light .btn-toggle-all{background:rgba(26,122,92,.1);border-color:rgba(26,122,92,.3);color:#1A7A5C}

/* FAB Incidencia: rojo, flotante, encima de bottom-nav */
.fab-incidencia{position:fixed;bottom:calc(78px + var(--safe-bottom));right:14px;background:linear-gradient(135deg,#c53030,#ef4444);color:#fff;border:0;border-radius:24px;padding:11px 18px;display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;box-shadow:0 6px 18px rgba(220,38,38,.42);cursor:pointer;z-index:99;font-family:inherit;-webkit-tap-highlight-color:transparent;letter-spacing:.2px}
.fab-incidencia svg{width:18px;height:18px;flex-shrink:0}
.fab-incidencia:active{transform:scale(.96)}
@media(max-width:380px){.fab-incidencia span{display:none}.fab-incidencia{padding:14px;border-radius:50%}}

/* ── DICTADO POR VOZ (Web Speech API) ─────────────────────────
   Botón circular reutilizable que se asocia a un textarea/input via
   attachVoiceInput() en js/voice-input.js. Se usa en:
     · Asistente IA (input del chat)
     · Modal incidencia (qué pasó / acción correctora)
   Estados: idle (gris) · listening (rojo pulsando) · no-support (oculto).
*/
.voice-mic{background:rgba(255,255,255,.05);border:1px solid var(--border,rgba(255,255,255,.12));color:var(--muted,#8B96A6);width:36px;height:36px;border-radius:50%;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .18s,color .18s,transform .12s;padding:0;font-family:inherit}
.voice-mic svg{width:18px;height:18px}
.voice-mic:hover{background:rgba(255,255,255,.12);color:#fff}
.voice-mic:active{transform:scale(.94)}
.voice-mic.listening{background:#ef4444;color:#fff;border-color:#ef4444;animation:voicePulse 1.2s infinite}
.voice-mic.no-support{display:none}
@keyframes voicePulse{0%{box-shadow:0 0 0 0 rgba(239,68,68,.55)}70%{box-shadow:0 0 0 10px rgba(239,68,68,0)}100%{box-shadow:0 0 0 0 rgba(239,68,68,0)}}
body.light .voice-mic{background:rgba(0,0,0,.04);border-color:rgba(0,0,0,.1);color:#6b7280}
body.light .voice-mic:hover{background:rgba(0,0,0,.08);color:#1a2030}
body.light .voice-mic.listening{background:#ef4444;color:#fff;border-color:#ef4444}

/* Etiqueta del campo con mic alineado a la derecha */
.label-with-mic{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}
.label-with-mic label{margin:0}

/* ── TEMPERATURAS POR CAMARA ────────────────────────────── */
.area-item-header{border-bottom:none;padding-bottom:6px}
.area-item-header .area-info{flex:1}
.temp-camara{display:flex;align-items:center;justify-content:space-between;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;gap:14px;margin-bottom:6px}
body.light .temp-camara{background:#fff;border-color:rgba(0,0,0,.08)}
.temp-camara-info{flex:1;display:flex;flex-direction:column;gap:2px}
.temp-camara-name{font-size:14px;font-weight:500;color:var(--white)}
body.light .temp-camara-name{color:#1a2030}
.temp-camara-rango{font-size:11px;color:var(--muted)}
.temp-camara-input{width:80px;flex-shrink:0}
.temp-camara-input .app-input{text-align:center;padding:12px 8px;font-size:18px;font-weight:700}
.temp-camara.fuera-rango{border-color:#c84a20;background:rgba(200,74,32,.08)}
.temp-camara.fuera-rango .temp-camara-input .app-input{color:#c84a20;border-color:#c84a20}
.temp-camara.en-rango .temp-camara-input .app-input{color:var(--orange2);border-color:var(--orange)}
.temp-empty{text-align:center;padding:20px;font-size:13px;color:var(--muted)}
.temp-empty a{color:var(--accent);text-decoration:none}
.abtn-sm{padding:6px 14px;font-size:12px}
.temp-coccion-wrap{padding:0 4px 10px}
.temp-block{background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px}
body.light .temp-block{background:#fff;border-color:rgba(0,0,0,.08)}
.temp-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.temp-label{font-size:13px;font-weight:500;color:var(--text);flex:1}
body.light .temp-label{color:#1a2030}

/* ── FOTO ATTACH ───────────────────────────────────────── */
.foto-attach{padding:0 16px 10px}
.foto-btn{display:flex;align-items:center;gap:8px;padding:12px 16px;border:1px dashed rgba(255,255,255,.15);border-radius:var(--radius);color:var(--muted);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;font-family:'DM Sans',sans-serif}
.foto-btn:active{background:rgba(255,255,255,.04)}
.foto-btn svg{width:18px;height:18px;fill:var(--orange2)}
body.light .foto-btn{border-color:rgba(0,0,0,.12);color:rgba(0,0,0,.45)}
body.light .foto-btn svg{fill:var(--orange)}
.foto-btn.uploading{opacity:.5;pointer-events:none}
.foto-preview{margin-top:8px}
.foto-thumb{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px}
body.light .foto-thumb{background:#fff;border-color:rgba(0,0,0,.08)}
.foto-thumb img{width:56px;height:56px;object-fit:cover;border-radius:8px;flex-shrink:0}
.foto-thumb-info{flex:1;font-size:12px;color:var(--muted);line-height:1.5}
.foto-thumb-info .foto-ok{color:var(--orange2);font-weight:600;display:block;margin-bottom:2px}
body.light .foto-thumb-info .foto-ok{color:var(--orange)}
.foto-thumb-info .foto-ocr{font-size:11px;color:rgba(255,255,255,.35)}
body.light .foto-thumb-info .foto-ocr{color:rgba(0,0,0,.35)}

/* ── DESPERDICIO ────────────────────────────────────────── */
.desp-item{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:10px;padding:12px 16px;font-size:13px;color:rgba(255,255,255,.7);margin-top:8px;line-height:1.5}
.desp-item strong{color:var(--orange2);font-weight:600}
.btn-add-desp{background:rgba(26,122,92,.08);border:1px dashed rgba(26,122,92,.4);border-radius:10px;padding:12px;width:100%;color:var(--orange2);font-size:13px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;margin-top:8px;transition:all .2s}
.btn-add-desp:hover{background:rgba(26,122,92,.15);border-color:var(--orange);color:var(--orange)}
.btn-add-desp:active{transform:scale(.98)}
.app-input{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:14px 16px;font-size:16px;color:var(--white);font-family:'DM Sans',sans-serif;outline:none;width:100%;transition:all .25s;-webkit-appearance:none}
.app-input:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(26,122,92,.15)}
.app-input::placeholder{color:rgba(255,255,255,.25)}
select.app-input,.form-group select{color:rgba(255,255,255,.7)}
select.app-input option,.form-group select option{background:var(--dark2);color:var(--white)}

/* ── ALBARAN ────────────────────────────────────────────── */
.albaran-result{font-size:14px}
.albaran-header{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:12px;gap:12px}
.albaran-header strong{color:var(--white)}
.albaran-table{width:100%;border-collapse:collapse;font-size:13px;margin-bottom:12px}
.albaran-table th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:8px;border-bottom:1px solid rgba(255,255,255,.08);font-weight:600}
.albaran-table td{padding:8px;border-bottom:1px solid rgba(255,255,255,.04);color:var(--text,#e8e8e8)}
.albaran-totals{display:flex;flex-direction:column;gap:4px;padding-top:8px;border-top:1px solid rgba(255,255,255,.08)}
.albaran-totals > div{display:flex;justify-content:space-between;font-size:13px;color:var(--muted)}
.albaran-total-row{font-size:16px!important;font-weight:700;color:var(--white)!important;padding-top:6px;border-top:1px solid rgba(255,255,255,.12)}
.spinner-sm{width:28px;height:28px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--orange);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto}
body.light .albaran-header{border-color:rgba(0,0,0,.08)}
body.light .albaran-header strong{color:#1a2030}
body.light .albaran-table th{border-color:rgba(0,0,0,.08);color:#5a6570}
body.light .albaran-table td{border-color:rgba(0,0,0,.04);color:#1a2030}
body.light .albaran-totals{border-color:rgba(0,0,0,.08)}
body.light .albaran-total-row{color:#1a2030!important;border-color:rgba(0,0,0,.12)}
body.light .spinner-sm{border-color:rgba(0,0,0,.1);border-top-color:var(--accent)}

/* ── VERIFICACIONES ─────────────────────────────────────── */
.verif-section{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:14px;padding:20px;margin-bottom:14px}
.verif-title{font-size:13px;font-weight:700;color:var(--orange2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:16px}
.estado-btns{display:flex;gap:8px;margin-top:6px}
.ebtn{padding:10px 18px;border-radius:10px;border:1px solid transparent;font-size:12px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .2s;-webkit-tap-highlight-color:transparent}
.ebtn.ok{background:rgba(42,106,26,.15);border-color:rgba(42,106,26,.3);color:#a8d5a0}
.ebtn.ko{background:rgba(200,74,32,.12);border-color:rgba(200,74,32,.25);color:var(--orange2)}
.ebtn:active{transform:scale(.95)}
.ebtn.sel-ok{background:#2a6a1a;border-color:#4a9a30;color:#fff}
.ebtn.sel-ko{background:#8a2a10;border-color:#c84a20;color:#fff}

/* ── INFORME MENSUAL (historial) ─────────────────────────── */
.informe-mes-box{background:linear-gradient(135deg,rgba(26,122,92,.12) 0%,rgba(26,122,92,.04) 100%);border:1px solid rgba(26,122,92,.3);border-left:3px solid var(--orange);border-radius:12px;padding:16px;margin-bottom:18px}
body.light .informe-mes-box{background:linear-gradient(135deg,rgba(26,122,92,.06) 0%,rgba(26,122,92,.02) 100%);border-color:rgba(26,122,92,.25)}
.informe-mes-head{margin-bottom:12px}
.informe-mes-title{font-family:'Playfair Display',serif;font-size:15px;font-weight:700;color:var(--white);text-transform:uppercase;letter-spacing:.02em}
body.light .informe-mes-title{color:#0B1420}
.informe-mes-sub{font-size:12px;color:var(--muted);margin-top:2px;line-height:1.5}
.informe-mes-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:stretch}
.informe-mes-actions .btn-primary-app{padding:10px 14px;font-size:13px;flex:1;min-width:140px;text-decoration:none;justify-content:center}
.informe-mes-actions select{min-height:42px}
@media(max-width:480px){.informe-mes-actions{flex-direction:column}.informe-mes-actions select{width:100%}.informe-mes-actions .btn-primary-app{width:100%;min-width:0}}

/* ── HISTORIAL ──────────────────────────────────────────── */
.hist-tabs{display:flex;gap:0;border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:18px}
.hist-tab{flex:1;min-width:0;padding:12px 4px;background:rgba(255,255,255,.03);color:var(--muted);font-size:13px;font-weight:600;cursor:pointer;border:none;font-family:'DM Sans',sans-serif;text-align:center;transition:all .2s;-webkit-tap-highlight-color:transparent;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media(max-width:480px){.hist-tab{font-size:11px;padding:10px 2px}}
.hist-tab.active{background:var(--orange);color:#fff}
.hist-tab:active{background:rgba(255,255,255,.08)}
.hist-tab.active:active{background:var(--orange2)}
.hist-panel{display:none}
.hist-panel.active{display:flex;flex-direction:column;gap:10px}
.hist-card{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:12px;padding:16px 18px;transition:all .2s}
.hist-card.open{border-left:3px solid var(--orange)}
.hist-card.resolved{border-left:3px solid #4a9a30}
.hist-card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.hist-card-head strong{font-size:14px;color:var(--white)}
.hist-date{font-size:11px;color:var(--muted)}
/* Botones de resolver / reabrir incidencia en el historial */
.btn-resolver-inc{background:rgba(34,197,94,.14);border:1px solid rgba(34,197,94,.4);color:#22c55e;padding:6px 12px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap;transition:background .15s,transform .12s;-webkit-tap-highlight-color:transparent}
.btn-resolver-inc:hover{background:rgba(34,197,94,.22)}
.btn-resolver-inc:active{transform:scale(.96)}
.btn-resolver-inc:disabled{opacity:.6;cursor:wait}
.btn-reabrir-inc{background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--muted);padding:6px 12px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap;transition:background .15s;-webkit-tap-highlight-color:transparent}
.btn-reabrir-inc:hover{background:rgba(255,255,255,.08);color:var(--text)}
body.light .btn-reabrir-inc{background:rgba(0,0,0,.03)}
body.light .btn-reabrir-inc:hover{background:rgba(0,0,0,.06)}
.hist-areas{display:flex;flex-wrap:wrap;gap:5px}
.hist-tag{font-size:11px;padding:3px 10px;border-radius:20px;font-weight:500}
.tag-ok{background:rgba(42,106,26,.15);color:#a8d5a0}
.tag-ko{background:rgba(200,74,32,.15);color:var(--orange2)}
.tag-na{background:rgba(255,255,255,.05);color:var(--muted)}
.hist-obs{font-size:13px;color:rgba(255,255,255,.5);margin-top:8px;line-height:1.5}
.hist-correctora{font-size:12px;color:rgba(255,255,255,.3);margin-top:4px}
.hist-details{display:flex;flex-wrap:wrap;gap:10px;font-size:12px;color:var(--muted)}
.hist-badge{font-size:11px;padding:3px 10px;border-radius:20px;font-weight:600}
.badge-ok{background:#2a6a1a;color:#fff}
.badge-open{background:var(--accent);color:#fff}
.empty-msg{text-align:center;color:var(--muted);font-size:14px;padding:40px 0}

/* ── MODAL ──────────────────────────────────────────────── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.85);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:500;align-items:flex-end;justify-content:center;padding:0}
.modal-overlay.open{display:flex}
.modal-box{background:var(--dark);border-top:3px solid var(--orange);border-radius:24px 24px 0 0;padding:28px 24px calc(32px + var(--safe-bottom));width:100%;max-width:520px;display:flex;flex-direction:column;gap:16px;animation:fadeIn .3s ease both}
.modal-title{font-family:'Playfair Display',serif;font-size:20px;color:var(--white)}
.modal-area{font-size:12px;color:var(--orange2);text-transform:uppercase;letter-spacing:.06em;font-weight:700;margin-top:-8px}
.modal-actions{display:flex;gap:10px;margin-top:8px}
.modal-actions .btn-primary-app{flex:1}

/* ── BOTTOM NAV ─────────────────────────────────────────── */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:rgba(14,19,12,.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(255,255,255,.06);display:flex;padding:8px 0 calc(8px + var(--safe-bottom));z-index:100}
.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;text-decoration:none;padding:6px 0;-webkit-tap-highlight-color:transparent;transition:all .2s}
.nav-item svg{width:22px;height:22px;fill:rgba(255,255,255,.3);transition:fill .2s}
.nav-item span{font-size:10px;color:rgba(255,255,255,.3);font-weight:600;transition:color .2s}
.nav-item.active svg{fill:var(--orange2)}
.nav-item.active span{color:var(--orange2)}
.nav-item:active svg{fill:var(--orange)}

/* ── CARTA / ALERGENOS ──────────────────────────────────── */
.carta-tipo{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin:20px 0 8px;padding-left:2px}
.carta-tipo:first-of-type{margin-top:0}
.carta-plato{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-bottom:6px}
body.light .carta-plato{background:#fff;border-color:rgba(0,0,0,.08)}
.carta-plato-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.carta-plato-nombre{font-size:15px;font-weight:600;color:var(--white)}
body.light .carta-plato-nombre{color:#1a2030}
.carta-alergenos{display:flex;flex-wrap:wrap;gap:4px}
.carta-ale{font-size:18px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.06);border-radius:8px}
body.light .carta-ale{background:rgba(0,0,0,.04)}
.carta-sin-ale{font-size:12px;color:var(--muted);font-style:italic}
.ale-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.ale-check{display:flex;align-items:center;gap:8px;padding:10px 12px;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent}
body.light .ale-check{background:#fff;border-color:rgba(0,0,0,.08)}
.ale-check:active{transform:scale(.97)}
.ale-check input{width:18px;height:18px;accent-color:var(--accent);flex-shrink:0}
.ale-icon{font-size:18px;flex-shrink:0}
.ale-name{font-size:13px;color:var(--text);font-weight:500}
body.light .ale-name{color:#1a2030}
.ale-check:has(input:checked){border-color:var(--accent);background:rgba(37,99,235,.06)}
body.light .ale-check:has(input:checked){background:rgba(37,99,235,.04)}

.btn-skip{background:none;border:none;color:var(--muted);font-size:13px;cursor:pointer;font-family:'DM Sans',sans-serif;padding:8px 0;-webkit-tap-highlight-color:transparent}
.btn-skip:active{color:var(--accent)}
body.light .btn-skip{color:rgba(0,0,0,.4)}

/* ── WIZARD ─────────────────────────────────────────────── */
.wizard-container{max-width:560px;margin:0 auto;padding:20px 20px 100px;animation:fadeIn .4s ease both}
.wizard-progress{margin-bottom:28px}
.wizard-bar{height:4px;background:rgba(255,255,255,.08);border-radius:2px;overflow:hidden}
body.light .wizard-bar{background:rgba(0,0,0,.08)}
.wizard-bar-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .4s ease;width:20%}
.wizard-steps-label{font-size:12px;color:var(--muted);margin-top:8px;text-align:center}
.wizard-title{font-family:'Playfair Display',serif;font-size:24px;color:var(--white);margin-bottom:6px;letter-spacing:-.01em}
body.light .wizard-title{color:#1a2030}
.wizard-sub{font-size:14px;color:var(--muted);margin-bottom:24px;line-height:1.6}
.wizard-step{display:none;flex-direction:column;gap:14px}
.wizard-step.active{display:flex}
.wizard-nav{position:fixed;bottom:0;left:0;right:0;background:var(--dark);border-top:1px solid rgba(255,255,255,.06);padding:14px 20px calc(14px + var(--safe-bottom));display:flex;justify-content:space-between;align-items:center;z-index:90;max-width:560px;margin:0 auto}
body.light .wizard-nav{background:#fff;border-top-color:rgba(0,0,0,.08)}
.wizard-tip{background:rgba(37,99,235,.08);border:1px solid rgba(37,99,235,.15);border-radius:var(--radius);padding:14px 16px;font-size:13px;color:var(--accent);line-height:1.6;margin-top:8px}
body.light .wizard-tip{background:rgba(37,99,235,.04)}

/* Dynamic cards (camaras, proveedores) */
.dynamic-card{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:10px}
body.light .dynamic-card{background:#fff;border-color:rgba(0,0,0,.08)}
.dynamic-card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.dynamic-card-head strong{font-size:13px;color:var(--orange2)}
.btn-remove{background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .2s}
.btn-remove:active{background:rgba(200,74,32,.15);color:#c84a20}

/* Chips */
.chip-group{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.chip{display:flex;cursor:pointer;-webkit-tap-highlight-color:transparent}
.chip input{display:none}
.chip span{padding:8px 16px;border-radius:20px;font-size:13px;font-weight:500;border:1px solid rgba(255,255,255,.1);color:var(--muted);transition:all .2s;font-family:'DM Sans',sans-serif}
body.light .chip span{border-color:rgba(0,0,0,.1);color:rgba(0,0,0,.4)}
.chip input:checked + span{background:var(--accent);border-color:var(--accent);color:#fff}

/* Check list */
.check-list{display:flex;flex-direction:column;gap:6px}
.check-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent}
body.light .check-item{background:#fff;border-color:rgba(0,0,0,.08)}
.check-item:active{transform:scale(.98)}
.check-item input[type=checkbox]{width:20px;height:20px;accent-color:var(--accent);flex-shrink:0}
.check-item span{font-size:14px;color:var(--text);line-height:1.4}

/* ── RESPONSIVE ─────────────────────────────────────────── */
@media(min-width:520px){
  .modal-overlay{align-items:center;padding:24px}
  .modal-box{border-radius:20px;border-top:3px solid var(--orange);padding-bottom:32px}
}
@media(min-width:768px){
  .app-container{padding:28px 32px 36px}
  .form-row{gap:16px}
}

/* SIDEBAR DESKTOP del dashboard (PDF v3 Luis C4).
   En móvil el aside queda oculto; en >= 1024px se muestra a la derecha junto
   al app-container, sin afectar al resto de páginas que mantienen su
   layout vertical centrado. */
.dashboard-sidebar{display:none}

@media(min-width:1024px){
  .dashboard-layout{display:flex;justify-content:center;align-items:flex-start;gap:24px;max-width:840px;margin:0 auto;padding:0 16px}
  .dashboard-layout .app-container{margin:0;flex:0 0 520px}
  .dashboard-sidebar{display:flex;flex-direction:column;gap:14px;flex:0 0 260px;padding:24px 0;position:sticky;top:20px}
  .ds-card{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:14px;padding:16px}
  .ds-card-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:8px}
  .ds-card-value{font-size:22px;font-weight:700;color:var(--text,#fff);font-family:'Playfair Display',serif}
  .ds-card-sub{font-size:12px;color:var(--orange2);font-family:monospace;margin-top:4px}
  .ds-action{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;background:rgba(0,0,0,.18);border-radius:8px;border-left:3px solid #6b7280;margin-top:8px;font-size:12px}
  .ds-action strong{font-weight:600;color:var(--text,#fff)}
  .ds-action span{color:var(--muted);font-size:11px;text-align:right}
  .ds-contact{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:#25D366;color:#fff;border-radius:10px;text-decoration:none;font-weight:600;font-size:14px;transition:filter .15s}
  .ds-contact:hover{filter:brightness(1.1)}
  body.light .ds-card{background:rgba(0,0,0,.03)}
  body.light .ds-action{background:rgba(0,0,0,.04)}
}