/* screens.css — Estilos específicos por pantalla */

/* ── LOGIN ── */
.login-wrap{width:100%;max-width:380px;padding:40px 28px 60px;display:flex;flex-direction:column;align-items:center;gap:24px;position:relative;z-index:1}
.login-logo{width:72px;height:72px;background:var(--gold);border-radius:22px;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px rgba(245,200,66,.35)}
.login-logo svg{width:40px;height:40px;fill:var(--night)}
.login-h1{font-family:var(--fh);font-size:32px;font-weight:800;color:#fff;letter-spacing:-.8px;text-align:center}
.login-sub{font-size:14px;color:rgba(255,255,255,.4);text-align:center}
.login-card{width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:24px;display:flex;flex-direction:column;gap:14px}
.role-tabs{display:flex;background:rgba(255,255,255,.05);border-radius:12px;padding:4px}
.role-btn{flex:1;padding:10px;border:none;background:transparent;font-family:var(--fh);font-size:13px;font-weight:700;color:rgba(255,255,255,.4);border-radius:9px;cursor:pointer;transition:all .2s}
.role-btn.on{background:var(--gold);color:var(--night)}
.li{background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.1);border-radius:12px;padding:14px 16px;font-family:var(--fb);font-size:15px;color:#fff;outline:none;width:100%;transition:border-color .15s}
.li::placeholder{color:rgba(255,255,255,.3)}
.li:focus{border-color:var(--gold)}
.login-btn{background:var(--gold);color:var(--night);border:none;border-radius:12px;padding:15px;font-family:var(--fh);font-size:15px;font-weight:700;cursor:pointer;width:100%}
.login-err{font-size:13px;color:#fca5a5;text-align:center;display:none}
.login-toggle{font-size:13px;color:rgba(255,255,255,.4);cursor:pointer;text-align:center}
.login-toggle span{color:var(--gold);font-weight:600}
.forgot{font-size:12px;color:var(--gold);text-align:right;cursor:pointer;opacity:.7;width:100%}
.demo-btn{background:rgba(245,200,66,.08);border:1px solid rgba(245,200,66,.2);border-radius:12px;padding:12px 28px;font-family:var(--fh);font-size:14px;font-weight:700;color:rgba(245,200,66,.7);cursor:pointer}

/* ── HOME CLIENTE ── */
.hero{margin:16px 20px 0;background:linear-gradient(135deg,#1e1e38,#2a2a4e);border-radius:20px;padding:22px;border:1px solid rgba(245,200,66,.2);position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;right:-30px;top:-30px;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,rgba(245,200,66,.15),transparent 70%)}
.hero-greet{font-size:13px;opacity:.6;margin-bottom:4px}
.hero-name{font-family:var(--fh);font-size:24px;font-weight:800;letter-spacing:-.5px;margin-bottom:14px}
.hero-row{display:flex;align-items:center;gap:12px}
.city-tag{background:rgba(245,200,66,.15);border:1px solid rgba(245,200,66,.3);border-radius:8px;padding:6px 12px;font-size:12px;font-weight:600;color:var(--gold);display:flex;align-items:center;gap:6px}
.city-tag svg{width:13px;height:13px;stroke:var(--gold);stroke-width:2;fill:none}
.hero-viajes{font-size:12px;color:rgba(255,255,255,.4)}
.req-wrap{padding:16px 20px 0}
.req-btn{width:100%;background:var(--gold);color:var(--night);border:none;border-radius:var(--r);padding:18px;font-family:var(--fh);font-size:17px;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:box-shadow .2s}
.req-btn:hover{box-shadow:0 8px 24px rgba(245,200,66,.35)}
.req-btn svg{width:22px;height:22px;stroke:var(--night);stroke-width:2.2;fill:none}
.cancel-btn{margin:8px 20px 0;width:calc(100% - 40px);background:rgba(239,68,68,.08);color:var(--red);border:1px solid rgba(239,68,68,.25);border-radius:var(--rs);padding:12px;font-family:var(--fh);font-size:13px;font-weight:700;cursor:pointer;display:none;align-items:center;justify-content:center;gap:7px}
.cancel-btn.on{display:flex}
.cancel-btn svg{width:15px;height:15px;stroke:var(--red);stroke-width:2;fill:none}
.status-banner{margin:12px 20px 0;border-radius:var(--r);padding:14px 16px;display:none;align-items:center;gap:12px;border:1px solid}
.status-banner.on{display:flex}
.sb-pending{background:rgba(245,158,11,.08);border-color:rgba(245,158,11,.3)}
.sb-confirmed{background:rgba(96,165,250,.08);border-color:rgba(96,165,250,.3)}
.sb-enroute{background:rgba(245,200,66,.08);border-color:rgba(245,200,66,.3)}
.sb-delivered{background:rgba(34,197,94,.08);border-color:rgba(34,197,94,.3)}
.sb-icon{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sb-pending .sb-icon{background:rgba(245,158,11,.15)}
.sb-confirmed .sb-icon,.sb-enroute .sb-icon{background:rgba(96,165,250,.1)}
.sb-delivered .sb-icon{background:rgba(34,197,94,.15)}
.sb-text{font-size:14px;font-weight:600;color:var(--text)}
.sb-sub{font-size:12px;color:var(--text2);margin-top:2px}
.track-card{margin:8px 20px 0;border-radius:var(--r);overflow:hidden;border:1px solid var(--border);background:var(--card2);display:none}
.track-card.on{display:block}
.track-hdr{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--card);border-bottom:1px solid var(--border)}
.track-title{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:700;color:var(--gold);font-family:var(--fh)}
.track-title svg{width:14px;height:14px;stroke:var(--gold);stroke-width:2;fill:none}
.track-eta{font-family:var(--fm);font-size:13px;color:var(--text2);background:var(--card2);padding:4px 10px;border-radius:7px;border:1px solid var(--border)}
.track-eta.arr{color:var(--green);border-color:rgba(34,197,94,.3);background:rgba(34,197,94,.08)}
.track-chofer{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border)}
.chof-av{width:38px;height:38px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-weight:800;font-size:13px;color:var(--night);flex-shrink:0}
.chof-name{font-size:13px;font-weight:700;color:var(--text);font-family:var(--fh)}
.chof-auto{font-size:11px;color:var(--text3)}
.chof-call{background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.3);border-radius:9px;padding:7px 13px;font-size:11px;font-weight:700;color:var(--green);text-decoration:none;font-family:var(--fh);display:flex;align-items:center;gap:5px;margin-left:auto}
.chof-call svg{width:13px;height:13px;stroke:var(--green);stroke-width:2;fill:none}
.track-maps-btn{width:100%;background:var(--card);border:none;border-top:1px solid var(--border);padding:11px 16px;font-family:var(--fh);font-size:12px;font-weight:700;color:var(--text2);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px}
.track-maps-btn svg{width:14px;height:14px;stroke:var(--gold);stroke-width:2;fill:none}
.cli-row{padding:12px 20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}
.cli-row:hover{background:var(--card2)}
.cli-av{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0;font-family:var(--fh)}
.cli-name{font-size:14px;font-weight:600;font-family:var(--fh)}
.cli-addr{font-size:12px;color:var(--text3);margin-top:1px}

/* ── HOME CHOFER ── */
.vact-card{margin:10px 20px 0;background:linear-gradient(135deg,#1e1e38,#2a2a4e);border-radius:var(--r);border:1px solid rgba(245,200,66,.3);padding:16px;display:none;flex-direction:column;gap:12px}
.vact-card.on{display:flex}
.vact-hdr{display:flex;align-items:center;justify-content:space-between}
.vact-title{font-family:var(--fh);font-size:14px;font-weight:800;color:var(--gold);display:flex;align-items:center;gap:7px}
.vact-title svg{width:15px;height:15px;stroke:var(--gold);stroke-width:2;fill:none}
.stats-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:16px 20px 0}
.stat-card{background:var(--card2);border-radius:var(--r);padding:14px 16px;border:1px solid var(--border)}
.stat-card.gold{background:var(--gold);border-color:var(--gold)}
.stat-card.gold .sv,.stat-card.gold .sl{color:var(--night)}
.sv{font-family:var(--fh);font-size:26px;font-weight:800;letter-spacing:-1px;line-height:1}
.sl{font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;margin-top:5px;font-family:var(--fh)}
.loc-bar{margin:12px 20px 0;background:var(--card2);border-radius:var(--rs);padding:12px 14px;display:flex;align-items:center;gap:10px;border:1px solid var(--border)}
.loc-bar svg{width:18px;height:18px;stroke:var(--gold);stroke-width:2;fill:none;flex-shrink:0}
.loc-info{flex:1}
.loc-info strong{font-size:13px;font-weight:700;display:block;font-family:var(--fh)}
.loc-info span{font-size:11px;color:var(--text3)}
.loc-toggle{width:44px;height:26px;background:var(--text3);border-radius:13px;border:none;cursor:pointer;position:relative;transition:background .2s;flex-shrink:0}
.loc-toggle::after{content:'';position:absolute;width:20px;height:20px;background:#fff;border-radius:50%;top:3px;left:3px;transition:transform .2s;box-shadow:0 1px 4px rgba(0,0,0,.3)}
.loc-toggle.on{background:var(--green)}
.loc-toggle.on::after{transform:translateX(18px)}

/* ── TURNO ── */
#screen-turno{background:var(--bg);align-items:center;justify-content:center;padding:32px 28px}
.turno-wrap{width:100%;display:flex;flex-direction:column;align-items:center;gap:24px}
.turno-logo{width:72px;height:72px;background:var(--gold);border-radius:22px;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px rgba(245,200,66,.35)}
.turno-logo svg{width:40px;height:40px;fill:var(--night)}
.turno-greeting{text-align:center}
.turno-greeting h2{font-family:var(--fh);font-size:26px;font-weight:800;color:var(--text);letter-spacing:-.5px}
.turno-greeting p{font-size:14px;color:var(--text3);margin-top:6px}
.turno-auto-card{width:100%;background:var(--card2);border:1px solid var(--border);border-radius:var(--r);padding:16px;display:flex;flex-direction:column;gap:12px}
.turno-auto-label{font-size:12px;font-weight:700;color:var(--text3);font-family:var(--fh);text-transform:uppercase;letter-spacing:.5px}
.turno-auto-num{font-family:var(--fm);font-size:28px;font-weight:500;color:var(--gold);letter-spacing:-1px}
.turno-auto-nombre{font-size:14px;color:var(--text2);margin-top:-8px}
.turno-estado-row{display:flex;align-items:center;gap:8px}
.turno-estado-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.turno-estado-txt{font-size:13px;font-weight:600;color:var(--text2)}
.turno-checklist{width:100%;display:flex;flex-direction:column;gap:8px}
.turno-check-item{display:flex;align-items:center;gap:12px;background:var(--card2);border:1.5px solid var(--border);border-radius:var(--rs);padding:12px 14px;cursor:pointer;transition:border-color .15s}
.turno-check-item.checked{border-color:var(--green);background:rgba(34,197,94,.06)}
.turno-check-box{width:22px;height:22px;border-radius:6px;border:2px solid var(--border2);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s}
.turno-check-item.checked .turno-check-box{background:var(--green);border-color:var(--green)}
.turno-check-box svg{width:13px;height:13px;stroke:#fff;stroke-width:2.5;fill:none;display:none}
.turno-check-item.checked .turno-check-box svg{display:block}
.turno-check-txt{font-size:14px;color:var(--text);font-weight:500}
.turno-check-item.checked .turno-check-txt{color:var(--text2);text-decoration:line-through}
.turno-iniciar-btn{width:100%;background:var(--gold);color:var(--night);border:none;border-radius:var(--r);padding:18px;font-family:var(--fh);font-size:17px;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:box-shadow .2s,opacity .15s;letter-spacing:-.3px}
.turno-iniciar-btn:disabled{opacity:.4;cursor:not-allowed}
.turno-iniciar-btn svg{width:22px;height:22px;stroke:var(--night);stroke-width:2.2;fill:none}
.turno-active-banner{width:100%;background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.3);border-radius:var(--r);padding:14px 16px;display:flex;align-items:center;gap:12px}
.turno-active-icon{width:38px;height:38px;border-radius:11px;background:rgba(34,197,94,.15);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.turno-active-icon svg{width:18px;height:18px;stroke:var(--green);stroke-width:2;fill:none}
.turno-active-txt{font-size:14px;font-weight:700;color:var(--text)}
.turno-active-sub{font-size:12px;color:var(--text2);margin-top:2px}
.turno-fin-btn{width:100%;background:rgba(239,68,68,.08);color:var(--red);border:1px solid rgba(239,68,68,.25);border-radius:var(--r);padding:14px;font-family:var(--fh);font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}
.turno-fin-btn svg{width:16px;height:16px;stroke:var(--red);stroke-width:2;fill:none}
.turno-tiempo{font-family:var(--fm);font-size:13px;color:var(--text3)}

/* ── OPERADOR: FLOTA ── */
.flota-hdr{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--card);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:2}
.flota-title-txt{font-family:var(--fh);font-size:13px;font-weight:700;color:var(--blue);display:flex;align-items:center;gap:6px}
.flota-title-txt svg{width:14px;height:14px;stroke:var(--blue);stroke-width:2;fill:none}
.flota-counters{display:flex;gap:8px;flex-wrap:wrap}
.fcnt{font-size:11px;font-weight:700;padding:3px 8px;border-radius:6px;font-family:var(--fh)}
.fcnt-l{background:rgba(34,197,94,.12);color:var(--green)}
.fcnt-o{background:rgba(245,200,66,.12);color:var(--gold)}
.fcnt-f{background:rgba(71,85,105,.2);color:var(--text3)}
.auto-row{display:flex;align-items:center;gap:8px;padding:10px 16px;border-bottom:1px solid var(--border)}
.auto-row:last-child{border-bottom:none}
.auto-num{font-family:var(--fm);font-size:13px;font-weight:500;min-width:50px;flex-shrink:0}
.auto-chofer{font-size:12px;color:var(--text2);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.auto-estado{display:flex;align-items:center;gap:5px;flex-shrink:0}
.edot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.elabel{font-size:10px;font-weight:700;font-family:var(--fh);white-space:nowrap}
.tbtn{padding:4px 10px;border-radius:7px;font-size:10px;font-weight:700;font-family:var(--fh);border:none;cursor:pointer;white-space:nowrap;flex-shrink:0}
.tbtn-act{background:rgba(34,197,94,.12);color:var(--green);border:1px solid rgba(34,197,94,.3)}
.tbtn-des{background:rgba(71,85,105,.15);color:var(--text3);border:1px solid var(--border)}
.tbtn:disabled{opacity:.4;cursor:not-allowed}
.abtn{padding:4px 10px;border-radius:7px;font-size:10px;font-weight:700;font-family:var(--fh);background:rgba(96,165,250,.1);color:var(--blue);border:1px solid rgba(96,165,250,.3);cursor:pointer;white-space:nowrap;flex-shrink:0}
.abtn:disabled{opacity:.3;cursor:not-allowed}

/* ── OPERADOR: MAPA ── */
#op-mapa-wrap{margin:0 20px;border-radius:var(--r);overflow:hidden;border:1px solid var(--border);background:var(--card2)}
#op-mapa-hdr{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--card);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:2}
#op-mapa-hdr-title{font-family:var(--fh);font-size:13px;font-weight:700;color:var(--blue);display:flex;align-items:center;gap:6px}
#op-mapa-hdr-title svg{width:14px;height:14px;stroke:var(--blue);stroke-width:2;fill:none}
#op-map{height:260px;width:100%}
.leaflet-container{background:#0f0f1e !important}
.leaflet-tile-pane{filter:brightness(.85) saturate(.7) hue-rotate(200deg)}
.auto-marker-libre{background:#22c55e;border:2px solid #fff;border-radius:50%;width:14px;height:14px;box-shadow:0 0 8px rgba(34,197,94,.7)}
.auto-marker-ocupado{background:#f5c842;border:2px solid #fff;border-radius:50%;width:14px;height:14px;box-shadow:0 0 8px rgba(245,200,66,.7)}
.auto-marker-fuera{background:#475569;border:2px solid #fff;border-radius:50%;width:14px;height:14px}
#mapa-leyenda{display:flex;gap:12px;padding:8px 14px;border-top:1px solid var(--border);background:var(--card);flex-wrap:wrap}
.mapa-ley-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text2);font-weight:600;font-family:var(--fh)}
.mapa-ley-dot{width:10px;height:10px;border-radius:50%}
#mapa-last-update{font-size:10px;color:var(--text3);font-family:var(--fm)}
.mapa-toggle-btn{background:var(--card2);border:1px solid var(--border);border-radius:8px;padding:5px 10px;font-size:11px;font-weight:700;font-family:var(--fh);color:var(--text2);cursor:pointer}
.mapa-toggle-btn.on{background:rgba(96,165,250,.12);color:var(--blue);border-color:rgba(96,165,250,.3)}

/* ── OPERADOR: PEDIDOS ── */
.op-card{background:var(--card2);border-radius:var(--r);border:1px solid var(--border);margin:0 20px 10px;padding:14px 16px;display:flex;flex-direction:column;gap:10px}
.op-card-top{display:flex;align-items:flex-start;justify-content:space-between}
.op-card-client{font-size:15px;font-weight:700;font-family:var(--fh)}
.op-card-time{font-size:11px;color:var(--text3);margin-top:2px}
.op-assign{display:flex;align-items:center;gap:8px}
.op-sel{flex:1;background:var(--card);border:1.5px solid var(--border);border-radius:9px;padding:8px 12px;font-family:var(--fb);font-size:13px;color:var(--text);outline:none}
.op-sel:focus{border-color:var(--blue)}
.op-go{background:var(--blue);color:var(--night);border:none;border-radius:9px;padding:9px 14px;font-family:var(--fh);font-size:12px;font-weight:700;cursor:pointer}
.op-go:disabled{opacity:.35;cursor:not-allowed}

/* ── OPERADOR: CHOFERES ── */
.chof-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border)}
.chof-av2{width:38px;height:38px;border-radius:50%;background:rgba(96,165,250,.15);color:var(--blue);display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-weight:800;font-size:13px;flex-shrink:0}
.chof-name2{font-size:14px;font-weight:700;font-family:var(--fh)}
.chof-sub{font-size:11px;color:var(--text3);margin-top:1px}
.online-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.online-dot.on{background:var(--green);box-shadow:0 0 6px rgba(34,197,94,.5)}
.online-dot.off{background:var(--text3)}

/* ── OPERADOR: REPORTES ── */
.rep-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 20px;margin-bottom:10px}
.rep-card{background:var(--card2);border-radius:12px;padding:14px;border:1px solid var(--border)}
.rep-val{font-family:var(--fh);font-size:24px;font-weight:800;letter-spacing:-.8px}
.rep-lbl{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;margin-top:4px;font-family:var(--fh)}

/* ── MODAL: TIPO VIAJE ── */
.dest-opts{padding:0 20px 16px;display:flex;flex-direction:column;gap:10px}
.dopt{background:var(--card2);border:1.5px solid var(--border);border-radius:var(--rs);padding:13px 14px;font-family:var(--fb);font-size:15px;color:var(--text);outline:none;width:100%}
.dopt:focus{border-color:var(--gold)}
.dopt::placeholder{color:var(--text3)}
.tipo-row{display:flex;gap:8px;padding:0 20px 8px}
.tipo-btn{flex:1;padding:10px;border:1.5px solid var(--border);background:var(--card2);border-radius:var(--rs);font-family:var(--fh);font-size:12px;font-weight:700;color:var(--text3);cursor:pointer;text-align:center;transition:all .15s;text-transform:uppercase}
.tipo-btn.on{border-color:var(--gold);background:rgba(245,200,66,.1);color:var(--gold)}
