/* ═══════════════════════════════════════════════
   TALI · CONDUCTOR CSS
═══════════════════════════════════════════════ */
:root {
  --cyan:#0099cc; --green:#16a34a; --orange:#ea6c00; --red:#dc2626;
  --bg:#f0f2f5; --surface:#ffffff; --surface2:#e8ecf2;
  --border:rgba(0,100,160,.15); --border2:rgba(0,0,0,.10);
  --white:#111118; --gray:#555570; --gray2:#888899;
  --app-h: 100vh;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;background:var(--bg);color:var(--white);font-family:'DM Sans',sans-serif;overflow:hidden}
#app{height:var(--app-h);display:flex;flex-direction:column;overflow:hidden}

/* ── Header ── */
header{
  background:linear-gradient(135deg,rgba(0,100,180,.06),rgba(240,242,245,.98));
  border-bottom:1px solid var(--border);
  padding:env(safe-area-inset-top,14px) 16px 14px;
  display:flex;align-items:center;justify-content:space-between;flex-shrink:0;
}
.hdr-left{display:flex;align-items:center;gap:10px}
.hdr-logo{font-family:'Bebas Neue',sans-serif;font-size:28px;letter-spacing:3px;color:var(--cyan)}
.hdr-sub{font-size:10px;letter-spacing:2px;color:var(--gray);text-transform:uppercase}
.hdr-dot{width:10px;height:10px;border-radius:50%;background:var(--gray2);flex-shrink:0;
  box-shadow:0 0 0 3px rgba(90,112,128,.15);transition:background .3s,box-shadow .3s}
.hdr-dot.online{background:var(--green);box-shadow:0 0 0 4px rgba(0,230,118,.2),0 0 12px rgba(0,230,118,.5)}
.hdr-dot.gps-err{background:var(--orange)}

/* ── Scroll area ── */
#scroll{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:14px}

/* ── Cards ── */
.card{background:var(--surface);border:1px solid var(--border2);border-radius:14px;padding:16px;display:flex;flex-direction:column;gap:12px}
.card-title{font-size:10px;letter-spacing:2px;color:var(--cyan);text-transform:uppercase;font-weight:600}

/* ── Status toggle ── */
#status-btn{
  width:100%;padding:18px;border-radius:12px;border:2px solid;
  font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:3px;
  cursor:pointer;transition:all .25s;display:flex;align-items:center;justify-content:center;gap:10px;
}
#status-btn.vacante{background:rgba(0,230,118,.1);border-color:var(--green);color:var(--green)}
#status-btn.ocupado{background:rgba(255,61,87,.1);border-color:var(--red);color:var(--red)}
#status-btn:disabled,#status-btn.trip-locked{opacity:.4 !important;cursor:not-allowed !important;pointer-events:none !important;filter:grayscale(.6)}

/* ── Inputs ── */
.inp-row{display:flex;flex-direction:column;gap:5px}
.inp-label{font-size:11px;color:var(--gray);letter-spacing:.5px}
.inp{background:var(--surface2);border:1px solid var(--border2);border-radius:9px;
  padding:11px 13px;color:var(--white);font-family:'DM Sans',sans-serif;font-size:15px;
  width:100%;outline:none;transition:border-color .2s}
.inp:focus{border-color:var(--cyan)}
.inp::placeholder{color:var(--gray2)}

/* ── GPS info ── */
.gps-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.gps-val{background:var(--surface2);border-radius:9px;padding:10px 12px;text-align:center}
.gps-val .label{font-size:10px;color:var(--gray);margin-bottom:3px}
.gps-val .val{font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--white)}

/* ── Demand bar ── */
.demand-bar{height:6px;border-radius:3px;background:var(--border2);overflow:hidden;margin-top:4px}
.demand-fill{height:100%;border-radius:3px;background:var(--green);transition:width .4s,background .4s}

/* ── Trip card (incoming) ── */
.trip-card{background:rgba(0,100,180,.04);border:1px solid rgba(0,100,180,.18);border-radius:12px;padding:14px;display:none;flex-direction:column;gap:10px}
.trip-card.visible{display:flex}
.trip-row{display:flex;gap:8px;align-items:flex-start}
.trip-ico{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.trip-ico.origin{background:rgba(0,0,0,.07)}
.trip-ico.dest{background:rgba(22,163,74,.12)}
.trip-text{display:flex;flex-direction:column;gap:2px}
.trip-name{font-size:13px;font-weight:600;color:var(--white)}
.trip-sub{font-size:11px;color:var(--gray)}
.trip-price{font-family:'Bebas Neue',sans-serif;font-size:32px;color:var(--green);line-height:1}

/* ── Bottom bar ── */
#bottom{
  background:var(--surface);border-top:1px solid var(--border2);
  padding:10px 16px env(safe-area-inset-bottom,10px);flex-shrink:0;
  display:flex;align-items:center;justify-content:space-between;gap:10px
}
.sync-txt{font-size:11px;color:var(--gray);display:flex;align-items:center;gap:5px}
.sync-txt i{font-size:10px}
.btn-wa{background:rgba(37,211,102,.12);border:1px solid rgba(37,211,102,.3);border-radius:9px;
  padding:10px 14px;color:#25d366;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;
  cursor:pointer;display:flex;align-items:center;gap:6px;display:none}

/* ── Trip overlay (incoming) — FULLSCREEN ── */
.trip-overlay{
  position:fixed;inset:0;z-index:9999;
  background:var(--bg);
  display:flex;flex-direction:column;
  pointer-events:none;opacity:0;
  transform:scale(.97);
  transition:opacity .3s ease, transform .3s ease
}
.trip-overlay.show{opacity:1;pointer-events:all;transform:scale(1)}
/* trip-sheet ya no se usa como sheet, se convierte en el contenedor flex */
.trip-sheet{
  flex:1;display:flex;flex-direction:column;gap:0;
  overflow:hidden;transform:none!important
}
/* ── Trip overlay fullscreen — componentes ── */
.to-topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 18px 10px;
  padding-top:calc(16px + env(safe-area-inset-top));
  background:var(--surface);
  border-bottom:1px solid var(--border);
}
.to-new-badge{
  font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:4px;
  color:var(--green);
}
.to-countdown-wrap{position:relative;width:44px;height:44px;flex-shrink:0}
.cr-svg{display:block}
.cr-txt{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:'Bebas Neue',sans-serif;font-size:17px;color:var(--white);
}

.to-info-block{
  padding:14px 18px 10px;background:var(--surface);
  border-bottom:1px solid var(--border);
  display:flex;flex-direction:column;gap:8px;
}
.to-point{display:flex;align-items:flex-start;gap:12px}
.to-point-dot{width:11px;height:11px;border-radius:50%;flex-shrink:0;margin-top:4px}
.to-dot-o{background:var(--white);border:2px solid var(--border2)}
.to-dot-d{background:var(--green)}
.to-point-text{display:flex;flex-direction:column;gap:1px}
.to-point-label{font-size:9px;letter-spacing:2px;color:var(--gray);text-transform:uppercase}
.to-point-name{font-size:14px;font-weight:600;color:var(--white);line-height:1.35}
.to-line-connector{
  width:2px;height:14px;background:var(--border2);
  border-radius:2px;margin-left:4px;
}
.to-stats{
  display:flex;align-items:center;justify-content:space-around;
  background:var(--surface2);border-radius:12px;padding:10px 12px;margin-top:4px;
}
.to-stat{display:flex;flex-direction:column;align-items:center;gap:2px}
.to-stat-val{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:1px;color:var(--white)}
.to-stat-key{font-size:8px;letter-spacing:2px;color:var(--gray);text-transform:uppercase}
.to-stat-divider{width:1px;height:28px;background:var(--border2)}
.to-dist-label{font-size:11px;color:var(--gray);text-align:center;padding-top:2px}

#trip-map{flex:1;min-height:0}

.to-actions{
  display:flex;gap:10px;padding:14px 18px;
  padding-bottom:calc(14px + env(safe-area-inset-bottom));
  background:var(--surface);border-top:1px solid var(--border);
}
.to-btn-accept{
  flex:1;background:var(--green);color:#fff;border:none;border-radius:14px;
  padding:16px;font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:3px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;
  box-shadow:0 4px 18px rgba(34,197,94,.35);
}
.to-btn-reject{
  background:var(--surface2);border:2px solid var(--border2);border-radius:14px;
  padding:16px 20px;color:var(--gray);font-size:18px;cursor:pointer;flex-shrink:0;
  transition:border-color .2s,color .2s;
}
.to-btn-reject:hover{border-color:var(--red);color:var(--red)}

/* ── Active trip card ── */
.active-trip-card{background:rgba(0,100,180,.06);border:1px solid rgba(0,100,180,.2);
  border-radius:12px;padding:14px;display:none;flex-direction:column;gap:10px}
.active-trip-card.visible{display:flex}

/* ── Phase steps (progress) ── */
.phase-tabs{display:flex;border-bottom:1px solid var(--border2);flex-shrink:0}
.phase-step{flex:1;padding:8px 4px;text-align:center;font-size:9px;letter-spacing:1px;
  color:var(--gray);border-bottom:2px solid transparent;transition:all .2s}
.phase-step.active{color:var(--cyan);border-color:var(--cyan);font-weight:600}
.phase-step.done{color:var(--green);border-color:transparent}

/* Phase buttons */
.phase-btns{display:flex;flex-direction:column;gap:8px}
.phase-btn{width:100%;padding:15px;border:none;border-radius:12px;font-family:'DM Sans',sans-serif;
  font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;
  justify-content:center;gap:8px;transition:transform .12s;-webkit-appearance:none}
.phase-btn:active{transform:scale(.97)}
.phase-btn.nav-btn{background:#e8f0fe;color:#1a73e8}
.phase-btn.waze-btn{background:#06c;color:#fff}
.phase-btn.next-btn{background:var(--green);color:#fff}
.phase-btn.finish-btn{background:var(--red);color:#fff}
.phase-btn.back-map{background:var(--surface2);color:var(--gray);font-size:13px}

/* ── Driver nav bar ── */
#nav-bar{display:none;background:rgba(240,242,245,.97);backdrop-filter:blur(8px);
  border-bottom:2px solid rgba(0,150,200,.2);padding:10px 12px;
  align-items:center;gap:10px;flex-shrink:0}
#nav-bar.show{display:flex}
#nav-icon{font-size:26px;flex-shrink:0}
#nav-dist{font-family:'Bebas Neue',sans-serif;font-size:22px;color:#111118;letter-spacing:1px;flex-shrink:0;min-width:60px}
#nav-instr{flex:1;font-size:12px;font-weight:600;color:#333355;line-height:1.3}
#nav-eta{font-size:11px;color:#888899;flex-shrink:0}
.nav-stop-btn{background:rgba(255,61,87,.12);border:1px solid rgba(255,61,87,.3);
  border-radius:8px;padding:7px 10px;color:var(--red);font-size:11px;
  font-family:'DM Sans',sans-serif;cursor:pointer;flex-shrink:0;white-space:nowrap}

/* ── Driver map wrap ── */
#drv-map-wrap{display:none;position:fixed;inset:0;z-index:600;background:var(--bg)}
#drv-map-wrap.show{display:block}
#drv-map{width:100%;height:100%}

/* ── Setup screen ── */
#setup{position:fixed;inset:0;background:var(--bg);z-index:9000;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:24px;gap:0}
.setup-logo{font-family:'Bebas Neue',sans-serif;font-size:56px;letter-spacing:8px;color:var(--white);margin-bottom:4px}
.setup-sub{font-size:11px;color:var(--gray);letter-spacing:3px;margin-bottom:32px;text-transform:uppercase}
.setup-card{background:var(--surface);border:1px solid var(--border2);border-radius:16px;
  padding:22px;width:100%;max-width:360px;display:flex;flex-direction:column;gap:14px}
.setup-title{font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:3px;color:var(--cyan)}
.setup-btn{width:100%;padding:16px;border:none;border-radius:12px;
  background:linear-gradient(135deg,#0088bb,#0055aa);color:#fff;
  font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:3px;
  cursor:pointer;margin-top:4px;display:flex;align-items:center;justify-content:center;gap:8px}
.setup-btn:active{opacity:.85}

/* ── Toast ── */
#toast{position:fixed;bottom:calc(20px + env(safe-area-inset-bottom));left:50%;
  transform:translateX(-50%) translateY(10px);background:#1a1a28;border:1px solid rgba(255,255,255,.12);
  border-radius:20px;padding:9px 18px;font-size:13px;color:#fff;z-index:99999;
  opacity:0;transition:opacity .3s,transform .3s;pointer-events:none;white-space:nowrap;
  box-shadow:0 4px 20px rgba(0,0,0,.3)}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── PWA banner ── */
#pwa-banner{display:none;position:fixed;bottom:0;left:0;right:0;z-index:9999;
  background:var(--bg);border-top:1px solid var(--border2);
  padding:14px 16px calc(16px + env(safe-area-inset-bottom));
  flex-direction:column;gap:12px;
  transform:translateY(100%);transition:transform .4s cubic-bezier(.34,1.2,.64,1);
  box-shadow:0 -4px 24px rgba(0,0,0,.08)}
#pwa-banner.show{transform:translateY(0)}
.pwa-row{display:flex;align-items:center;gap:12px}
.pwa-icon{width:48px;height:48px;border-radius:12px;background:#e8f4fb;
  border:1.5px solid rgba(0,100,160,.2);display:flex;align-items:center;justify-content:center;
  font-family:'Bebas Neue',sans-serif;font-size:26px;color:#0077aa}
.pwa-text{flex:1}
.pwa-title{font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:2px;color:var(--white)}
.pwa-sub{font-size:11px;color:var(--gray);margin-top:2px}
.pwa-btns{display:flex;gap:8px}
.pwa-install{flex:1;padding:12px;background:#0088bb;color:#fff;border:none;border-radius:10px;
  font-family:'DM Sans',sans-serif;font-size:13px;font-weight:700;cursor:pointer}
.pwa-dismiss{padding:12px 14px;background:var(--surface2);color:var(--gray);border:1px solid var(--border2);
  border-radius:10px;font-family:'DM Sans',sans-serif;font-size:12px;cursor:pointer}

/* ── iOS install sheet ── */
#pwa-ios{display:none;position:fixed;bottom:0;left:0;right:0;z-index:9999;
  background:var(--bg);border-radius:16px 16px 0 0;border-top:1px solid var(--border2);
  padding:18px 18px calc(20px + env(safe-area-inset-bottom));
  flex-direction:column;gap:12px;box-shadow:0 -4px 24px rgba(0,0,0,.08)}
#pwa-ios.show{display:flex}
.ios-title{font-family:'Bebas Neue',sans-serif;font-size:16px;letter-spacing:2px;color:var(--white);text-align:center}
.ios-step{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--gray)}
.ios-step strong{color:var(--white)}
.ios-step-num{width:22px;height:22px;border-radius:50%;background:rgba(0,100,160,.1);
  display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--cyan);flex-shrink:0}
.ios-close{align-self:center;background:var(--surface2);border:1px solid var(--border2);
  border-radius:8px;padding:8px 24px;color:var(--gray);font-size:12px;cursor:pointer;
  font-family:'DM Sans',sans-serif;margin-top:4px}

/* ── Profile tab ── */
.prof-section{border-top:1px solid var(--border2);padding-top:14px;margin-top:2px}
.prof-save-btn{width:100%;padding:13px;border:none;border-radius:10px;background:var(--cyan);color:#fff;
  font-family:'Bebas Neue',sans-serif;font-size:16px;letter-spacing:2px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:8px;margin-top:4px}
.prof-save-btn:active{opacity:.85}

/* ══════════════════════════════════════
   DEBUG PANEL
══════════════════════════════════════ */
#dbg-panel {
  position: fixed;
  bottom: 80px; right: 12px;
  z-index: 9998;
  background: rgba(10,10,20,.92);
  border: 1px solid rgba(0,212,255,.3);
  border-radius: 14px;
  padding: 10px;
  display: flex; flex-direction: column; gap: 8px;
  backdrop-filter: blur(10px);
  min-width: 140px;
  box-shadow: 0 4px 24px rgba(0,0,0,.5);
}
.dbg-title {
  font-size: 9px; letter-spacing: 3px; color: var(--cyan);
  text-align: center; font-family: 'JetBrains Mono', monospace;
}
.dbg-coords {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px; color: rgba(255,255,255,.5);
  text-align: center; line-height: 1.4;
}
.dbg-joystick {
  display: grid; grid-template-columns: repeat(3, 36px);
  grid-template-rows: repeat(3, 36px);
  gap: 3px; justify-content: center;
}
.dbg-btn {
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 8px; color: #fff;
  font-size: 14px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  user-select: none; -webkit-user-select: none;
  touch-action: none;
  transition: background .1s;
}
.dbg-btn:active, .dbg-btn:hover { background: rgba(0,212,255,.25); border-color: var(--cyan); }
.dbg-center { background: rgba(0,212,255,.12); border-color: rgba(0,212,255,.3); }
.dbg-actions {
  display: flex; gap: 5px;
}
.dbg-act {
  flex: 1; background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px; color: rgba(255,255,255,.7);
  font-size: 10px; padding: 6px 4px;
  cursor: pointer; font-family: 'DM Sans', sans-serif;
  text-align: center;
}
.dbg-act:hover { background: rgba(0,212,255,.15); color: #fff; }