@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;700&family=IBM+Plex+Mono:wght@400;500&display=swap";:root{--bg: #f3eee5;--ink: #172026;--accent: #116466;--accent-2: #ff7a59;--card: #fff9ef;--line: #d4c8b5}*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:Space Grotesk,Segoe UI,sans-serif;color:var(--ink);background:radial-gradient(circle at 12% 20%,#f9cf7c 0%,transparent 32%),radial-gradient(circle at 87% 8%,#8fd3c7 0%,transparent 30%),linear-gradient(135deg,#f5eee2,#efe6d6 45%,#e9deca)}.page{position:relative;max-width:1120px;margin:0 auto;padding:3.5rem 1.25rem 4rem}.glow{position:absolute;z-index:0;border-radius:999px;filter:blur(40px);opacity:.34}.glow-a{right:0;top:1rem;width:190px;height:190px;background:#ff7a59}.glow-b{left:15%;top:13rem;width:220px;height:220px;background:#1cb89a}.hero,.grid,.status{position:relative;z-index:1}.hero{animation:rise .7s ease-out both}.tag{display:inline-block;margin:0;padding:.35rem .8rem;border:1px solid var(--line);border-radius:999px;background:#ffffff8c;font-family:IBM Plex Mono,monospace;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase}h1{margin:1rem 0 .9rem;max-width:14ch;font-size:clamp(2rem,5.4vw,4rem);line-height:1.03;letter-spacing:-.02em}.lead{max-width:60ch;font-size:1.1rem;line-height:1.55}.cta-row{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1.25rem}.btn{text-decoration:none;border-radius:12px;padding:.72rem 1.05rem;border:1px solid var(--line);font-weight:600;transition:transform .18s ease,box-shadow .18s ease}.btn:hover{transform:translateY(-1px)}.btn-primary{color:#fff;border-color:transparent;background:linear-gradient(140deg,var(--accent),#0a7f74);box-shadow:0 8px 24px #11646647}.btn-ghost{color:var(--ink);background:#fff9}.grid{margin-top:2.25rem;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.9rem}.card{border:1px solid var(--line);border-radius:16px;padding:1rem;background:var(--card);box-shadow:0 10px 28px #18202612;animation:rise .7s ease-out both}.card:nth-child(2){animation-delay:.11s}.card:nth-child(3){animation-delay:.2s}.card h2{margin:0 0 .45rem;font-size:1.06rem}.card p{margin:0;line-height:1.5}.status{margin-top:1.4rem;border:1px solid var(--line);border-radius:16px;padding:1rem;background:#ffffffb8;animation:rise .7s ease-out both;animation-delay:.23s}.status h3{margin:0 0 .4rem}.status ul{margin:0;padding-left:1.2rem}.status li{margin:.3rem 0}.live-board{margin-top:1.25rem;padding:1rem;border-radius:16px;border:1px solid var(--line);background:#ffffffa8}.live-board-header{display:flex;flex-wrap:wrap;justify-content:space-between;gap:.75rem;align-items:baseline}.live-board-header h3{margin:0}.live-board-header p{margin:0;font-size:.92rem;opacity:.9}.live-loading,.live-error{margin:.75rem 0 0}.live-error{color:#a51f17}.kpi-grid{margin-top:.9rem;display:grid;gap:.8rem;grid-template-columns:repeat(3,minmax(0,1fr))}.kpi-card{border-radius:12px;border:1px solid var(--line);background:#fff8ed;padding:.85rem}.kpi-card p{margin:0;font-size:.9rem}.kpi-card strong{display:block;margin-top:.3rem;font-size:1.3rem}.trend{display:inline-block;margin-top:.35rem;padding:.2rem .5rem;border-radius:999px;font-size:.74rem;font-weight:700}.trend-up{background:#15984f24;color:#0d7b3e}.trend-stable{background:#1620261a;color:#21313a}.trend-down{background:#c3342624;color:#9a281d}.alert-list{margin-top:.9rem;display:grid;gap:.7rem}.alert-card{border-radius:12px;border:1px solid var(--line);background:#fffdf9;padding:.8rem}.alert-meta{margin:0;font-family:IBM Plex Mono,monospace;font-size:.76rem;text-transform:uppercase;letter-spacing:.03em}.alert-card h4{margin:.3rem 0}.alert-card p{margin:0}.alert-critical{border-color:#da675a}.alert-high{border-color:#e3a45f}.alert-medium{border-color:#9cb7aa}@keyframes rise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.admin-toggle-row{margin-top:1.1rem;display:flex;justify-content:flex-end}.kpi-trends{margin-top:2.5rem;padding:1.5rem;border-radius:14px;background:#fafaf7;border:1px solid #e8e4d9}.kpi-trends h3{margin:0 0 .3rem;font-size:1.1rem}.section-hint{margin:0 0 1.2rem;font-size:.83rem;opacity:.65}.kpi-charts-grid{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.kpi-chart-container{background:#fff;border-radius:12px;border:1px solid #e8e4d9;padding:.9rem}.kpi-chart{display:flex;flex-direction:column}.kpi-chart-title{margin:0 0 .6rem;font-size:.95rem;font-weight:600;color:#1a1a1a}.kpi-chart-svg{width:100%;height:auto;max-height:150px;display:block}.kpi-chart-meta{margin:.4rem 0 0;font-size:.75rem;opacity:.6;font-family:IBM Plex Mono,monospace}.readings-grid{margin-top:.9rem;display:grid;gap:.7rem;grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.reading-card{border-radius:12px;border:1px solid var(--line);background:#fffdf9;padding:.75rem}.reading-arete{border-left:3px solid #116466}.reading-sensor{border-left:3px solid #ff7a59}.reading-meta{margin:0 0 .25rem;font-size:.8rem;display:flex;align-items:center;gap:.4rem}.reading-type-badge{display:inline-block;padding:.1rem .42rem;border-radius:999px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.reading-badge-arete{background:#11646624;color:#0a5052}.reading-badge-sensor{background:#ff7a5924;color:#a33d1e}.reading-metric{margin:0;font-size:.78rem;opacity:.7;text-transform:capitalize}.reading-value{display:block;font-size:1.25rem;margin:.15rem 0}.reading-time{margin:0;font-family:IBM Plex Mono,monospace;font-size:.7rem;opacity:.55}.admin-device-badge{display:inline-block;padding:.18rem .55rem;border-radius:999px;font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.admin-device-arete{background:#11646624;color:#0a5052}.admin-device-sensor{background:#ff7a5924;color:#a33d1e}.admin-token-reveal{margin-bottom:.9rem;padding:.75rem .9rem;border-radius:12px;background:#fff0c899;border:1px solid rgba(212,180,100,.5);display:flex;flex-wrap:wrap;gap:.5rem;align-items:flex-start}.admin-token-reveal p{margin:0;font-size:.88rem;flex:1 1 100%}.admin-token-code{flex:1;font-family:IBM Plex Mono,monospace;font-size:.8rem;word-break:break-all;background:#ffffffb3;padding:.3rem .6rem;border-radius:8px}.admin-panel{margin-top:1.5rem;border:1px solid var(--line);border-radius:16px;padding:1.25rem;background:#ffffffb8}.admin-heading{margin:0 0 1rem;font-size:1.1rem;font-family:IBM Plex Mono,monospace;text-transform:uppercase;letter-spacing:.07em;color:var(--accent)}.admin-feedback{margin:0 0 .9rem;padding:.55rem .9rem;border-radius:10px;font-size:.9rem;font-weight:500}.admin-feedback-ok{background:#15984f21;color:#0d7b3e;border:1px solid rgba(21,152,79,.3)}.admin-feedback-err{background:#c334261f;color:#9a281d;border:1px solid rgba(195,52,38,.3)}.admin-auth label{display:block;font-size:.88rem;font-weight:600;margin-bottom:.45rem}.admin-auth-hint{margin:0 0 .75rem;font-size:.9rem;opacity:.8}.admin-auth-fields,.admin-auth-row{display:flex;gap:.6rem;flex-wrap:wrap}.admin-input{flex:1;min-width:120px;padding:.55rem .75rem;border:1px solid var(--line);border-radius:10px;background:#fff;font-size:.9rem;font-family:Space Grotesk,sans-serif;color:var(--ink);outline:none;transition:border-color .16s}.admin-input:focus{border-color:var(--accent)}.admin-input[readonly]{background:#f5f0e8;cursor:default}.admin-input-narrow{max-width:80px;flex:0 0 80px}.admin-input-wide{flex:2}.admin-select{padding:.55rem .6rem;border:1px solid var(--line);border-radius:10px;background:#fff;font-size:.9rem;font-family:Space Grotesk,sans-serif;color:var(--ink);outline:none;transition:border-color .16s}.admin-select:focus{border-color:var(--accent)}.admin-btn{display:inline-flex;align-items:center;padding:.55rem 1rem;border-radius:10px;border:1px solid var(--line);font-weight:600;font-size:.9rem;font-family:Space Grotesk,sans-serif;cursor:pointer;transition:transform .14s,box-shadow .14s;white-space:nowrap}.admin-btn:hover{transform:translateY(-1px)}.admin-btn-sm{padding:.38rem .7rem;font-size:.82rem}.admin-btn-primary{background:linear-gradient(140deg,var(--accent),#0a7f74);color:#fff;border-color:transparent;box-shadow:0 6px 18px #11646638}.admin-btn-ghost{background:#ffffffb3;color:var(--ink)}.admin-btn-danger{background:#c334261a;color:#9a281d;border-color:#c334264d}.admin-btn-danger:hover{background:#c334262e}.admin-section{margin-top:1.4rem}.admin-section-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.75rem}.admin-section-header h4{margin:0;font-size:.97rem;font-weight:600}.admin-form{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.85rem}.admin-table{width:100%;border-collapse:collapse;font-size:.88rem}.admin-table th{text-align:left;padding:.45rem .6rem;border-bottom:1px solid var(--line);font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;opacity:.7}.admin-table td{padding:.55rem .6rem;border-bottom:1px solid rgba(212,200,181,.4);vertical-align:middle}.admin-row-editing td{background:#1164660f}.admin-actions{display:flex;gap:.4rem;justify-content:flex-end;white-space:nowrap}.admin-mono{font-family:IBM Plex Mono,monospace;font-size:.82rem}.admin-severity-badge{display:inline-block;padding:.18rem .55rem;border-radius:999px;font-size:.74rem;font-weight:700;border:none;background:transparent}.admin-footer{margin-top:1.25rem;display:flex;align-items:center;justify-content:space-between;gap:.75rem}.admin-logged-as{font-size:.84rem;opacity:.8}@media (max-width: 900px){.grid,.kpi-grid{grid-template-columns:1fr}.admin-table{font-size:.82rem}.admin-table th:nth-child(4),.admin-table td:nth-child(4){display:none}}.batches-board{margin-top:2.5rem;padding:1.5rem;border-radius:14px;background:#fafaf7;border:1px solid #e8e4d9}.batches-grid{display:grid;gap:.9rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-top:1.2rem}.batch-card-public{border-radius:12px;border-left:4px solid #ccc;background:#fff;padding:.9rem}.batch-status-produccion{border-left-color:#2e7d32}.batch-status-traslado{border-left-color:#f57c00}.batch-status-almacen{border-left-color:#1976d2}.batch-status-entrega{border-left-color:#c2185b}.batch-status-completado{border-left-color:#388e3c}.batch-id{margin:0 0 .2rem;font-size:.85rem;font-weight:700;font-family:IBM Plex Mono,monospace;opacity:.7}.batch-label{margin:0 0 .3rem;font-size:.95rem;font-weight:600}.batch-quantity{margin:.2rem 0;font-size:.82rem}.batch-route{margin:.2rem 0 .4rem;font-size:.78rem;opacity:.65}.batch-status-badge-public{display:inline-block;padding:.2rem .55rem;border-radius:999px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;background:#64646424;color:#404040}.batch-panel{margin-top:1.2rem;padding-top:1.2rem;border-top:1px solid #e8e4d9}.batch-panel h4{margin:0 0 .9rem;font-size:.98rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;opacity:.8}.batch-section{margin-bottom:1.5rem}.batch-section h5{margin:0 0 .6rem;font-size:.9rem;font-weight:600}.batch-form{display:grid;gap:.5rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:.9rem}.batches-list{display:grid;gap:.6rem;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));margin-top:.9rem}.batch-card{border-radius:10px;border:1px solid #d5d0c4;background:#f9f7f3;padding:.75rem;cursor:pointer;transition:all .2s}.batch-card:hover{border-color:#116466;background:#f0ebe5}.batch-card-selected{border-color:#116466;background:#efe8de;box-shadow:0 0 0 2px #1164661a}.batch-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.3rem}.batch-card-header strong{font-size:.85rem;font-family:IBM Plex Mono,monospace}.batch-card-label{margin:0 0 .2rem;font-size:.82rem;font-weight:600}.batch-card-meta{margin:0;font-size:.75rem;opacity:.6}.batch-detail{background:#1164660a;border-radius:10px;padding:.9rem}.batch-info{background:#fff;border-radius:8px;padding:.75rem;margin-bottom:.9rem}.batch-info p{margin:.25rem 0;font-size:.85rem}.batch-info strong{font-weight:700;min-width:90px;display:inline-block}.batch-update-form{background:#ffffff80;border-radius:8px;padding:.75rem;margin-bottom:.9rem}.batch-update-form h6{margin:0 0 .6rem;font-size:.8rem;font-weight:700;text-transform:uppercase;opacity:.7}.batch-update-form .admin-select,.batch-update-form .admin-input{margin-bottom:.5rem}.batch-events{margin-bottom:.9rem}.batch-events h6{margin:0 0 .6rem;font-size:.8rem;font-weight:700;text-transform:uppercase;opacity:.7}.batch-event{background:#fff;border-radius:8px;border-left:3px solid #116466;padding:.6rem;margin-bottom:.5rem}.batch-event-produccion{border-left-color:#2e7d32}.batch-event-traslado{border-left-color:#f57c00}.batch-event-almacen{border-left-color:#1976d2}.batch-event-entrega{border-left-color:#c2185b}.batch-event-completado{border-left-color:#388e3c}.batch-event-header{margin:0 0 .25rem;font-size:.8rem;font-weight:600}.batch-event-detail{margin:.15rem 0;font-size:.77rem;opacity:.7;font-style:italic}.batch-event-time{margin:0;font-size:.7rem;opacity:.5;font-family:IBM Plex Mono,monospace}.batch-actions{display:flex;gap:.5rem;margin-top:.9rem}.admin-table{width:100%;border-collapse:collapse;font-size:.83rem}.admin-table th{background:#f0ebe5;padding:.45rem .6rem;text-align:left;font-weight:700;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid #d5d0c4}.admin-table td{padding:.4rem .6rem;border-bottom:1px solid #ece8e0;vertical-align:middle}.admin-table tr:last-child td{border-bottom:none}.btn-primary{background:#116466;color:#fff;border:none;padding:.45rem 1rem;border-radius:6px;font-weight:700;cursor:pointer;font-size:.85rem}.btn-primary:hover{background:#0d4f50}.btn-secondary{background:#e8e4d9;color:#333;border:none;padding:.35rem .75rem;border-radius:6px;font-weight:600;cursor:pointer;font-size:.8rem}.btn-secondary:hover{background:#d5d0c4}.btn-danger{background:#fce8e8;color:#b71c1c;border:1px solid #f5c6c6;padding:.35rem .75rem;border-radius:6px;font-weight:600;cursor:pointer;font-size:.8rem}.btn-danger:hover{background:#f8d0d0}.btn-sm{padding:.25rem .55rem;font-size:.75rem}.form-row{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.5rem}.form-row input,.form-row select{flex:1;min-width:130px;padding:.4rem .55rem;border:1px solid #ccc;border-radius:6px;font-size:.85rem}.analytics-panel{padding:2.5rem 1.5rem;background:#fafaf8;border-top:1px solid #e8e4d9}.analytics-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}.analytics-window-selector{display:flex;align-items:center;gap:.4rem;font-size:.82rem;color:#555}.analytics-window-btn{background:#e8e4d9;border:none;padding:.3rem .65rem;border-radius:20px;font-size:.78rem;font-weight:600;cursor:pointer;transition:background .15s}.analytics-window-btn.active{background:#116466;color:#fff}.analytics-window-btn:hover:not(.active){background:#d5d0c4}.analytics-stats-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));margin-bottom:2rem}.analytics-stat-card{background:#fff;border:1px solid #e0dcd4;border-radius:10px;padding:1rem 1.1rem}.analytics-stat-title{margin:0 0 .3rem;font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;opacity:.6;font-weight:700}.analytics-stat-value{margin:0 0 .15rem;font-size:1.55rem;font-weight:800;color:#116466}.analytics-stat-sub{margin:0;font-size:.73rem;opacity:.55}.analytics-block{margin-bottom:2rem}.analytics-block-title{margin:0 0 .9rem;font-size:.88rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;opacity:.75;border-bottom:1px solid #e8e4d9;padding-bottom:.4rem}.analytics-kpi-row{display:flex;flex-wrap:wrap;gap:.75rem}.analytics-kpi-chip{background:#fff;border:1px solid #e0dcd4;border-radius:8px;padding:.6rem .9rem;display:flex;align-items:center;gap:.5rem}.analytics-kpi-label{font-size:.82rem;font-weight:600;color:#333}.analytics-kpi-val{font-size:.9rem;font-weight:800;color:#116466}.analytics-kpi-trend{font-size:1rem;font-weight:700}.analytics-kpi-pts{font-size:.7rem;opacity:.5}.analytics-production-bars{display:flex;align-items:flex-end;gap:.6rem;height:120px;padding:0 .2rem}.analytics-bar-item{display:flex;flex-direction:column;align-items:center;gap:.2rem;flex:1;height:100%}.analytics-bar-track{flex:1;width:100%;background:#f0ebe5;border-radius:4px 4px 0 0;display:flex;align-items:flex-end;overflow:hidden}.analytics-bar-fill{width:100%;background:linear-gradient(to top,#116466,#2d9b9e);border-radius:4px 4px 0 0;transition:height .4s ease;min-height:3px}.analytics-bar-val{font-size:.68rem;font-weight:700;color:#333}.analytics-bar-day{font-size:.65rem;opacity:.55;font-family:IBM Plex Mono,monospace}.analytics-metrics-table td code.metric-code{background:#11646614;color:#116466;padding:.1rem .35rem;border-radius:4px;font-size:.78rem}.analytics-loading{padding:2rem;text-align:center;color:#888}.analytics-empty{color:#888;font-size:.88rem;font-style:italic}.analytics-generated{margin-top:1rem;font-size:.7rem;opacity:.4;text-align:right;font-family:IBM Plex Mono,monospace}
