/* style.css — Taxi Zone Tracker · todos los estilos de la aplicación */

:root{
  --primary:#1e3a8a;--primary-light:#3b82f6;
  --green:#16a34a;--green-light:#22c55e;
  --red:#dc2626;--accent:#f59e0b;
  --bg:#0f172a;--bg2:#1e293b;--bg3:#334155;
  --surface:#1e293b;--border:#334155;
  --text:#f1f5f9;--text2:#94a3b8;--text3:#64748b;
  --radius:16px;--radius-sm:10px;
  --shadow:0 4px 24px rgba(0,0,0,.4);
  --safe-top:env(safe-area-inset-top,0px);
  --safe-bottom:env(safe-area-inset-bottom,0px);
}
[data-theme="light"]{
  --bg:#f0f4ff;--bg2:#e8edf8;--bg3:#d1daf0;
  --surface:#fff;--border:#d1daf0;
  --text:#0f172a;--text2:#475569;--text3:#94a3b8;
  --shadow:0 4px 24px rgba(30,58,138,.12);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;overflow:hidden;background:var(--bg);color:var(--text);
  font-family:-apple-system,'Helvetica Neue',sans-serif;
  -webkit-text-size-adjust:100%;}
#app{display:flex;flex-direction:column;height:100%;height:100dvh}

/* HEADER */
#header{
  background:var(--surface);border-bottom:1px solid var(--border);
  padding:calc(var(--safe-top) + 10px) 16px 10px;
  display:flex;align-items:center;justify-content:space-between;z-index:10;flex-shrink:0;
}
#header h1{font-size:17px;font-weight:700;letter-spacing:-.3px}
.status-pill{font-size:11px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;
  padding:4px 10px;border-radius:20px;background:var(--bg3);color:var(--text2);transition:all .3s}
.status-pill.libre{background:rgba(22,163,74,.2);color:var(--green-light)}
.status-pill.ocupado{background:rgba(220,38,38,.2);color:#f87171}
#content{flex:1;overflow:hidden;position:relative;min-height:0}

/* TABS */
.tab-pane{position:absolute;inset:0;overflow-y:auto;overflow-x:hidden;
  -webkit-overflow-scrolling:touch;display:none}
.tab-pane.active{display:block}
#pane-servicio.active{display:flex}
#pane-servicio{flex-direction:column;align-items:center;justify-content:center;
  padding:12px 20px calc(12px + var(--safe-bottom));gap:12px}

/* CLOCK */
#wall-clock{font-size:54px;font-weight:200;letter-spacing:-2px;
  font-variant-numeric:tabular-nums;color:var(--text);line-height:1;text-align:center}
#wall-date{font-size:12px;color:var(--text3);text-align:center;text-transform:capitalize}

/* MAIN BTN */
#main-btn-wrap{position:relative}
#pulse-ring{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:190px;height:190px;border-radius:50%;background:rgba(34,197,94,.15);
  z-index:1;animation:pulseRing 2s ease-out infinite}
#pulse-ring.hidden{display:none}
@keyframes pulseRing{0%{transform:translate(-50%,-50%) scale(1);opacity:.8}
  100%{transform:translate(-50%,-50%) scale(1.5);opacity:0}}
#main-btn{width:190px;height:190px;border-radius:50%;border:none;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-size:40px;gap:6px;transition:all .4s cubic-bezier(.34,1.56,.64,1);
  position:relative;z-index:2;box-shadow:0 8px 40px rgba(0,0,0,.5);
  -webkit-user-select:none;user-select:none;touch-action:manipulation}
#main-btn .btn-label{font-size:13px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}
#main-btn.libre{background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff}
#main-btn.ocupado{background:linear-gradient(135deg,#dc2626,#ef4444);color:#fff}
#main-btn:active{transform:scale(.95)}

#timer-display{font-size:48px;font-weight:200;letter-spacing:-1px;
  font-variant-numeric:tabular-nums;color:var(--text);
  opacity:0;transform:translateY(8px);transition:all .4s;pointer-events:none}
#timer-display.visible{opacity:1;transform:translateY(0)}
#service-info{background:var(--surface);border-radius:var(--radius);
  padding:12px 16px;width:100%;max-width:320px;border:1px solid var(--border);
  opacity:0;transform:translateY(8px);transition:all .4s}
#service-info.visible{opacity:1;transform:translateY(0)}
.info-row{display:flex;align-items:center;gap:10px;padding:4px 0}
.info-row+.info-row{border-top:1px solid var(--border)}
.info-label{font-size:11px;color:var(--text3);font-weight:600;
  text-transform:uppercase;letter-spacing:.5px;min-width:64px}
.info-val{font-size:13px;color:var(--text);font-weight:500}
#gps-status{font-size:12px;color:var(--text3);display:flex;align-items:center;gap:6px;min-height:18px}
.spinner{width:13px;height:13px;border:2px solid var(--border);
  border-top-color:var(--primary-light);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}

/* BOTTOM NAV */
#bottom-nav{background:var(--surface);border-top:1px solid var(--border);
  display:flex;padding-bottom:var(--safe-bottom);z-index:10;flex-shrink:0}
.nav-btn{flex:1;border:none;background:none;cursor:pointer;
  padding:8px 2px;display:flex;flex-direction:column;
  align-items:center;gap:2px;color:var(--text3);
  transition:color .2s;position:relative;touch-action:manipulation;min-width:0}
.nav-btn.active{color:var(--primary-light)}
.nav-btn .nav-icon{font-size:20px;line-height:1}
.nav-btn .nav-label{font-size:9px;font-weight:500;letter-spacing:.2px;white-space:nowrap}
.nav-btn.active::after{content:'';position:absolute;bottom:0;left:50%;
  transform:translateX(-50%);width:20px;height:3px;
  background:var(--primary-light);border-radius:3px 3px 0 0}

/* HISTORIAL */
.month-tabs{display:flex;gap:6px;overflow-x:auto;padding-bottom:10px;scrollbar-width:none}
.month-tabs::-webkit-scrollbar{display:none}
.month-tab{padding:5px 14px;border-radius:20px;border:1px solid var(--border);
  font-size:13px;font-weight:500;white-space:nowrap;cursor:pointer;
  background:var(--surface);color:var(--text2);transition:all .2s;touch-action:manipulation}
.month-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.historial-list{display:flex;flex-direction:column;gap:8px}
.historial-card{background:var(--surface);border-radius:var(--radius-sm);
  padding:12px 14px;border:1px solid var(--border);display:flex;align-items:flex-start;gap:10px}
.hcard-time{font-size:13px;font-weight:700;color:var(--text2);min-width:44px;padding-top:1px}
.hcard-star{font-size:13px;padding-top:1px}
.hcard-body{flex:1;min-width:0}
.hcard-route{font-size:14px;font-weight:500;color:var(--text);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hcard-meta{font-size:11px;color:var(--text3);margin-top:3px;display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.hcard-nota{font-size:11px;color:var(--text3);margin-top:4px;font-style:italic;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.btn-icon{background:none;border:none;cursor:pointer;color:var(--text3);
  padding:6px;border-radius:8px;font-size:16px;transition:color .2s;touch-action:manipulation;flex-shrink:0}
.badge{font-size:11px;font-weight:600;padding:2px 7px;border-radius:10px}
.badge-dur{background:rgba(59,130,246,.15);color:var(--primary-light)}
.badge-importe{background:rgba(245,158,11,.15);color:var(--accent)}
.badge-propina{background:rgba(251,191,36,.15);color:#fbbf24}
.empty-state{text-align:center;padding:50px 20px;color:var(--text3)}
.empty-state .empty-icon{font-size:44px;margin-bottom:10px}
.empty-state p{font-size:14px}

/* ZONAS */
.filter-row{display:flex;gap:6px;margin-bottom:14px;overflow-x:auto;scrollbar-width:none}
.filter-row::-webkit-scrollbar{display:none}
.filter-chip{padding:5px 12px;border-radius:20px;border:1px solid var(--border);
  font-size:12px;font-weight:600;white-space:nowrap;cursor:pointer;
  background:var(--surface);color:var(--text2);transition:all .2s;touch-action:manipulation}
.filter-chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.zona-card{background:var(--surface);border-radius:var(--radius);
  padding:14px;margin-bottom:8px;border:1px solid var(--border)}
.zona-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.zona-name{font-size:15px;font-weight:700}
.zona-rank{font-size:13px;font-weight:700;color:var(--accent)}
.zona-stats{display:flex;gap:12px;margin-bottom:8px}
.zona-stat{flex:1}
.zs-val{font-size:17px;font-weight:700}
.zs-label{font-size:10px;color:var(--text3);margin-top:1px}
.zona-bar-bg{height:4px;background:var(--bg3);border-radius:3px;overflow:hidden}
.zona-bar{height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-light));
  border-radius:3px;transition:width .8s ease}
.zona-dests{margin-top:6px;font-size:11px;color:var(--text3)}
.zona-dests strong{color:var(--text2)}

/* HORARIOS */
.turno-cards{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.turno-card{background:var(--surface);border-radius:var(--radius-sm);
  padding:12px 14px;border:1px solid var(--border);display:flex;align-items:center;gap:12px}
.turno-icon{font-size:26px}
.turno-info{flex:1}
.turno-name{font-size:14px;font-weight:600}
.turno-range{font-size:11px;color:var(--text3)}
.turno-nums{text-align:right}
.turno-count{font-size:17px;font-weight:700}
.turno-dur{font-size:11px;color:var(--text3)}
.heatmap-section h3{font-size:14px;font-weight:600;margin-bottom:10px;color:var(--text2)}
.heatmap-grid{overflow-x:auto;-webkit-overflow-scrolling:touch}
.hm-row{display:flex;align-items:center;gap:2px;margin-bottom:2px}
.hm-label{font-size:9px;color:var(--text3);width:26px;text-align:right;flex-shrink:0;margin-right:3px}
.hm-cell{flex:1;height:24px;border-radius:3px;background:var(--bg3);cursor:pointer;
  min-width:30px;display:flex;align-items:center;justify-content:center;
  font-size:9px;font-weight:600;color:transparent;touch-action:manipulation}
.hm-cell:active{opacity:.7}
.hm-cell.has-data{color:rgba(255,255,255,.8)}
.hm-day-labels{display:flex;padding-left:29px;gap:2px;margin-bottom:3px}
.hm-day-lbl{flex:1;text-align:center;font-size:9px;color:var(--text3);min-width:30px}

/* CONFIG */
.config-section{margin-bottom:20px}
.config-section h3{font-size:12px;font-weight:600;color:var(--text3);
  text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding:0 4px}
.config-list{background:var(--surface);border-radius:var(--radius);
  overflow:hidden;border:1px solid var(--border)}
.config-row{display:flex;align-items:center;justify-content:space-between;
  padding:13px 15px;gap:12px}
.config-row+.config-row{border-top:1px solid var(--border)}
.cr-label{font-size:14px;font-weight:500}
.cr-desc{font-size:11px;color:var(--text3);margin-top:1px}
.toggle{width:48px;height:26px;background:var(--bg3);border-radius:13px;
  position:relative;cursor:pointer;transition:background .3s;flex-shrink:0;touch-action:manipulation}
.toggle.on{background:var(--green)}
.toggle::after{content:'';position:absolute;top:3px;left:3px;width:20px;height:20px;
  border-radius:50%;background:#fff;transition:transform .3s;box-shadow:0 1px 4px rgba(0,0,0,.3)}
.toggle.on::after{transform:translateX(22px)}
.btn-config{background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);
  padding:12px 16px;font-size:14px;font-weight:600;cursor:pointer;
  display:flex;align-items:center;gap:8px;transition:all .2s;width:100%;touch-action:manipulation}
.btn-config:active{opacity:.8}
.btn-config.danger{background:rgba(220,38,38,.15);color:var(--red)}
.btn-config.sample{background:rgba(245,158,11,.15);color:var(--accent)}
.stats-row{display:flex;gap:8px;margin-bottom:18px}
.stat-box{flex:1;background:var(--surface);border-radius:var(--radius-sm);
  padding:12px 10px;border:1px solid var(--border);text-align:center}
.stat-big{font-size:26px;font-weight:700}
.stat-label{font-size:11px;color:var(--text3)}
input[type="text"],input[type="number"],textarea{
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);
  color:var(--text);font-size:16px;padding:10px 12px;outline:none;
  -webkit-appearance:none;font-family:inherit}
input[type="text"]:focus,input[type="number"]:focus,textarea:focus{border-color:var(--primary-light)}

/* MAP */
#pane-mapa.active{display:flex}
#pane-mapa{flex-direction:column;overflow:hidden}
#map-controls{flex-shrink:0;padding:8px 12px;background:var(--surface);
  border-bottom:1px solid var(--border);display:flex;gap:6px;align-items:center;flex-wrap:wrap}
#map-container{flex:1;min-height:0;width:100%;position:relative}
#leaflet-map{position:absolute;inset:0;width:100%;height:100%;background:#1a2535}
#map-no-tiles{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);
  background:rgba(0,0,0,.6);color:#94a3b8;font-size:11px;padding:4px 10px;
  border-radius:10px;z-index:500;pointer-events:none;white-space:nowrap;display:none}
.leaflet-container{background:#1a2535 !important}
.map-layer-btn{padding:6px 12px;border-radius:20px;border:1px solid var(--border);
  font-size:12px;font-weight:600;cursor:pointer;background:var(--bg3);
  color:var(--text2);transition:all .2s;white-space:nowrap;touch-action:manipulation}
.map-layer-btn.active-recogidas{background:rgba(34,197,94,.25);color:#4ade80;border-color:#22c55e}
.map-layer-btn.active-destinos{background:rgba(239,68,68,.25);color:#f87171;border-color:#ef4444}
#map-count{font-size:11px;color:var(--text3);margin-left:auto}

/* MODAL */
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:100;
  display:flex;align-items:flex-end;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .25s}
.modal-backdrop.open{opacity:1;pointer-events:all}
.modal-sheet{background:var(--surface);border-radius:20px 20px 0 0;
  padding:16px 16px calc(16px + var(--safe-bottom));
  width:100%;max-width:480px;
  transform:translateY(100%);transition:transform .35s cubic-bezier(.34,1.2,.64,1)}
.modal-backdrop.open .modal-sheet{transform:translateY(0)}
.modal-handle{width:36px;height:4px;background:var(--border);border-radius:2px;margin:0 auto 14px}
.modal-title{font-size:17px;font-weight:700;margin-bottom:14px}
.modal-actions{display:flex;gap:8px;margin-top:14px}
.btn-modal{flex:1;padding:13px;border-radius:var(--radius-sm);border:none;
  font-size:15px;font-weight:600;cursor:pointer;transition:opacity .2s;touch-action:manipulation}
.btn-modal:active{opacity:.75}
.btn-modal.primary{background:var(--primary);color:#fff}
.btn-modal.secondary{background:var(--bg3);color:var(--text)}
.modal-label{display:block;font-size:11px;font-weight:600;color:var(--text3);
  text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.modal-field{margin-bottom:12px}
.hm-tooltip{background:var(--bg2);border-radius:var(--radius-sm);padding:12px;margin-top:10px}
.hm-tooltip h4{font-size:13px;font-weight:600;margin-bottom:6px}
.hm-tooltip-list{font-size:13px;color:var(--text2);display:flex;flex-direction:column;gap:3px}

/* COIN BUTTONS */
.coin-grid{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}
.coin-btn{
  padding:8px 10px;border-radius:10px;border:1.5px solid var(--border);
  background:var(--bg3);color:var(--text);font-size:13px;font-weight:600;
  cursor:pointer;transition:all .15s;touch-action:manipulation;min-width:52px;text-align:center;
}
.coin-btn:active{transform:scale(.92);background:var(--primary);border-color:var(--primary);color:#fff}
.coin-display{
  display:flex;align-items:center;justify-content:space-between;
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:10px 12px;margin-bottom:8px;
}
.coin-display-val{font-size:22px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--accent)}
.coin-reset{background:none;border:none;color:var(--text3);font-size:13px;cursor:pointer;
  padding:4px 8px;touch-action:manipulation}

/* TOAST */
#toast{position:fixed;bottom:calc(52px + var(--safe-bottom) + 10px);left:50%;
  transform:translateX(-50%) translateY(16px);
  background:var(--bg3);color:var(--text);padding:9px 18px;border-radius:20px;
  font-size:13px;font-weight:500;z-index:200;opacity:0;
  transition:all .25s;pointer-events:none;white-space:nowrap;box-shadow:var(--shadow)}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

.section-title{font-size:16px;font-weight:700;margin-bottom:12px}
::-webkit-scrollbar{width:3px;height:3px}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
