@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

:root {
  --bg: #f6f6f3;
  --surface: rgba(255,255,255,.94);
  --surface-strong: #ffffff;
  --text: #111111;
  --muted: #6b6b70;
  --line: #e9e9ec;
  --soft: #f3f3f5;
  --black: #111111;
  --green: #0f8a4a;
  --accent: #111111;
  --accent-soft: #f1f1f3;
  --warn: #555555;
  --danger: #a52929;
  --shadow: 0 18px 50px rgba(17,17,17,.08);
  --radius: 26px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Inter',system-ui,sans-serif;background:linear-gradient(180deg,#fafaf8 0%,#f3f3f5 100%);color:var(--text)}
a{text-decoration:none;color:inherit}
button,input,select{font:inherit}
button{cursor:pointer}
.page{max-width:1220px;margin:0 auto;padding:22px 18px 46px}
.topbar{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:18px}
.brand{display:flex;align-items:center;gap:12px;font-weight:900;font-size:1.05rem;letter-spacing:-.03em}
.brand-mark{width:42px;height:42px;border-radius:15px;background:var(--accent);color:#fff;display:grid;place-items:center;font-size:1.15rem;box-shadow:var(--shadow)}
.nav{display:flex;gap:10px;flex-wrap:wrap}
.nav a,.nav button{border:1px solid rgba(17,17,17,.08);background:rgba(255,255,255,.86);padding:12px 16px;border-radius:999px;font-weight:800;color:#111;transition:.2s ease}
.nav a:hover,.nav button:hover{transform:translateY(-1px);background:#fff}
.page-shell{display:grid;gap:18px}
.hero,.layout-2,.split{display:grid;gap:18px}
.hero{grid-template-columns:1.1fr .9fr;align-items:stretch}
.layout-2,.split{grid-template-columns:1fr 1fr}
.hero-panel,.card,.glass,.section,.hero-mini{background:var(--surface);border:1px solid rgba(255,255,255,.78);backdrop-filter:blur(14px);border-radius:var(--radius);box-shadow:var(--shadow)}
.hero-panel,.hero-side,.card,.section,.hero-mini{padding:24px}
.hero-side{display:flex;flex-direction:column;justify-content:space-between;gap:16px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;padding:9px 13px;border-radius:999px;background:#fff;border:1px solid var(--line);font-size:.82rem;font-weight:800;color:#111}
.eyebrow::before{content:"";width:8px;height:8px;border-radius:50%;background:#111}
.display{font-size:clamp(2.2rem,5vw,4.6rem);line-height:.95;letter-spacing:-.08em;font-weight:900;margin:14px 0 10px;max-width:760px}
.display-sm{font-size:clamp(1.8rem,4vw,3rem)}
.lead{font-size:1rem;line-height:1.65;color:var(--muted);max-width:640px}
.hero-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.btn,.btn-secondary,.btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:10px;border:none;border-radius:20px;padding:15px 18px;font-weight:800;transition:.2s ease}
.btn{background:var(--accent);color:#fff;box-shadow:0 14px 30px rgba(17,17,17,.18)}
.btn-secondary{background:#fff;color:#111;border:1px solid var(--line)}
.btn-ghost{background:transparent;color:#111;border:1px solid rgba(17,17,17,.1)}
.btn:hover,.btn-secondary:hover,.btn-ghost:hover{transform:translateY(-1px)}
.section-title,.card-title h3{font-size:1.2rem;font-weight:900;letter-spacing:-.05em;margin:0}
.section-sub,.small{font-size:.92rem;color:var(--muted);line-height:1.5}
.stack{display:grid;gap:14px}
.card-title{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:14px}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.form-grid.single{grid-template-columns:1fr}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-size:.9rem;color:var(--muted);font-weight:700}
.field input,.field select,.search-shell input{width:100%;padding:15px 16px;border-radius:18px;border:1px solid var(--line);background:#fff;color:#111;outline:none}
.field input:focus,.field select:focus,.search-shell input:focus{border-color:#bdbdc3;box-shadow:0 0 0 4px rgba(17,17,17,.04)}
.search-shell{position:relative;display:grid;gap:8px}
.search-results{position:absolute;left:0;right:0;top:calc(100% + 6px);z-index:200;display:grid;gap:8px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:10px;box-shadow:var(--shadow);max-height:280px;overflow-y:auto;-webkit-overflow-scrolling:touch}
.search-results button{display:grid;gap:4px;text-align:left;padding:12px;border:none;border-radius:14px;background:#f7f7f8}
.search-results button:hover{background:#f0f0f2}
.inline-card{padding:16px 18px;border-radius:22px;background:#fff;border:1px solid var(--line)}
.notice{padding:14px 16px;border-radius:18px;border:1px solid var(--line);background:#fff}
.notice-muted{background:#f5f5f7;color:#222}.notice-success{background:#eef8f1;color:var(--green)}.notice-warn{background:#fff5e7;color:var(--warn)}.notice-danger{background:#fff0f0;color:var(--danger)}
.chips{display:flex;gap:8px;flex-wrap:wrap}.chip{padding:10px 14px;border-radius:999px;background:#fff;border:1px solid var(--line);font-weight:700}.chip-more{background:var(--accent-soft);border-color:rgba(17,17,17,.08)}
.metric-grid,.role-grid,.kpi-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.metric,.role-option,.kpi{padding:16px;border-radius:22px;background:#fff;border:1px solid var(--line)}
.metric strong,.kpi strong{display:block;font-size:1.6rem;font-weight:900;letter-spacing:-.06em}.metric span,.role-option span,.kpi span{display:block;margin-top:8px;color:var(--muted);line-height:1.45}
.role-option strong{display:block;font-size:1rem}.role-option.active{border-color:#111;background:#111;color:#fff}.role-option.active span{color:rgba(255,255,255,.7)}
.map-shell{overflow:hidden;border-radius:24px;border:1px solid var(--line)}
.map{height:430px;width:100%;background:#ececef}
.status-pill{display:inline-flex;align-items:center;gap:8px;padding:9px 12px;border-radius:999px;font-size:.85rem;font-weight:800;background:#fff;border:1px solid var(--line);white-space:nowrap}
.status-pill::before{content:"";width:8px;height:8px;border-radius:50%;background:#666}
.status-waiting_price{background:#f6f6f7;color:#555}.status-waiting_price::before{background:#777}
.status-price_sent{background:#eef5ff;color:#184f90}.status-price_sent::before{background:#1d63b8}
.status-confirmed,.status-driver_en_route,.status-driver_arrived,.status-passenger_onboard,.status-completed{background:#eef8f1;color:var(--green)}
.status-confirmed::before,.status-driver_en_route::before,.status-driver_arrived::before,.status-passenger_onboard::before,.status-completed::before{background:var(--green)}
.status-cancelled{background:#fff0f0;color:var(--danger)}.status-cancelled::before{background:var(--danger)}
.list{display:grid;gap:12px}
.item{padding:16px 18px;border-radius:22px;background:#fff;border:1px solid var(--line);display:grid;gap:10px}
.item-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.item-route{font-size:1rem;font-weight:900;letter-spacing:-.04em}
.item-meta{display:flex;gap:10px;flex-wrap:wrap;color:var(--muted);font-size:.9rem}
.price{font-size:1.35rem;font-weight:900;letter-spacing:-.06em}
.history-list{display:grid;gap:10px}.history-item{padding:14px 16px;border-radius:18px;background:#fff;border:1px solid var(--line)}
.table{width:100%;border-collapse:separate;border-spacing:0 10px}.table tr{background:#fff}.table td,.table th{padding:15px 14px;text-align:left}.table th{font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.table tbody tr td:first-child{border-top-left-radius:18px;border-bottom-left-radius:18px}.table tbody tr td:last-child{border-top-right-radius:18px;border-bottom-right-radius:18px}
.empty{padding:16px;border-radius:18px;background:#fff;border:1px dashed var(--line);color:var(--muted);text-align:center}
.footer-note{display:none}
.taxi-marker,.pickup-marker,.dropoff-marker{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-size:18px;box-shadow:0 10px 22px rgba(17,17,17,.16)}
.taxi-marker{background:#111;color:#fff;border:2px solid #fff}
.pickup-marker{background:#fff;color:#111;border:2px solid #111}
.dropoff-marker{background:#111;color:#fff;border:2px solid #fff}
.slide-wrap{display:grid;gap:8px}
.slide-wrap input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:58px;border-radius:999px;background:linear-gradient(90deg,#111 0%,#1f1f22 100%);padding:8px}
.slide-wrap input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:42px;height:42px;border-radius:50%;background:#fff;border:none;box-shadow:0 8px 20px rgba(17,17,17,.25)}

/* Driver dashboard */
.driver-shell{position:relative;min-height:100vh;background:#f4f4f2;overflow:hidden}
.driver-ambient-map{position:fixed;inset:0;z-index:0}
.driver-ambient-overlay{position:fixed;inset:0;z-index:1;pointer-events:none;background:linear-gradient(180deg,rgba(255,255,255,.28) 0%,rgba(255,255,255,.46) 45%,rgba(246,246,243,.92) 100%)}
.driver-dashboard-page{position:relative;z-index:2;min-height:100vh;padding-top:18px}
.driver-dashboard-page .topbar{background:rgba(255,255,255,.82);border:1px solid rgba(255,255,255,.8);padding:10px 12px;border-radius:24px;backdrop-filter:blur(12px)}
.driver-topbar-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.driver-status-pill{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;background:#fff;border:1px solid var(--line);font-weight:800}
.driver-live-dot{width:10px;height:10px;border-radius:50%;background:#14a44d;box-shadow:0 0 0 0 rgba(20,164,77,.4);animation:livePulse 1.8s infinite}
@keyframes livePulse{0%{box-shadow:0 0 0 0 rgba(20,164,77,.4)}70%{box-shadow:0 0 0 14px rgba(20,164,77,0)}100%{box-shadow:0 0 0 0 rgba(20,164,77,0)}}
.driver-hero{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 190px);transition:opacity .35s ease, transform .35s ease}
.driver-hero.hidden{opacity:0;transform:translateY(-16px);pointer-events:none;height:0;min-height:0;overflow:hidden;margin:0}
.driver-hero-card{background:rgba(255,255,255,.88);border:1px solid rgba(255,255,255,.85);backdrop-filter:blur(14px);border-radius:32px;box-shadow:var(--shadow);padding:28px 34px;display:grid;gap:16px;min-width:min(92vw,640px)}
.driver-hero-copy{display:grid;gap:8px;justify-items:center;text-align:center}
.driver-hero-copy h1{font-size:clamp(2rem,4vw,3.6rem);letter-spacing:-.08em;margin:0}
.driver-radar{position:relative;width:126px;height:126px;display:grid;place-items:center;justify-self:center}
.driver-radar span{position:absolute;border-radius:50%}
.driver-radar span:nth-child(1){width:24px;height:24px;background:#111}
.driver-radar span:nth-child(2),.driver-radar span:nth-child(3),.driver-radar span:nth-child(4){border:1px solid rgba(17,17,17,.18);animation:radarWave 3.2s infinite}
.driver-radar span:nth-child(2){width:56px;height:56px}
.driver-radar span:nth-child(3){width:90px;height:90px;animation-delay:.35s}
.driver-radar span:nth-child(4){width:126px;height:126px;animation-delay:.7s}
@keyframes radarWave{0%{transform:scale(.88);opacity:.4}70%{opacity:.9}100%{transform:scale(1.04);opacity:.22}}
.driver-dashboard-sheet{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr .9fr;gap:18px;align-items:start;margin-top:auto}
.driver-dashboard-sheet.compact{margin-top:-14px}
.driver-dashboard-sheet .section{box-shadow:0 12px 34px rgba(17,17,17,.07)}
.driver-sheet-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}
.driver-sheet-map{display:none}
.driver-card-quiet .item-meta span:last-child,.driver-card-quiet .detail-quiet,.driver-long-copy,.hero-copy-hide,.hero-panel-hide,.hero-side-hide{display:none}

.customer-ride-layout{display:grid;grid-template-columns:.95fr 1.05fr;gap:18px;align-items:start}
.customer-ride-layout .map-shell{order:-1}
.compact-card{padding:18px 20px}
.route-mini{display:grid;gap:8px}
.route-line{display:flex;align-items:center;gap:10px;font-weight:800}.route-line small{display:block;font-weight:600;color:var(--muted)}
.truncate{max-width:100%;display:inline-block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;vertical-align:bottom}
.driver-bottom-sheet{position:fixed;left:18px;right:18px;bottom:18px;z-index:3;display:none}
.driver-bottom-sheet.show{display:grid}
.driver-bottom-sheet .section{max-height:48vh;overflow:auto}
.driver-floating-kpis{display:flex;gap:10px;flex-wrap:wrap}
.driver-kpi-chip{padding:10px 14px;border-radius:999px;background:#fff;border:1px solid var(--line);font-weight:800}

@media (max-width: 980px){
  .hero,.layout-2,.split,.customer-ride-layout,.driver-dashboard-sheet{grid-template-columns:1fr}
  .metric-grid,.role-grid,.kpi-row,.form-grid{grid-template-columns:1fr}
  .driver-bottom-sheet{left:14px;right:14px;bottom:14px}
}
@media (max-width: 640px){
  .page{padding:16px 12px 34px}
  .hero-panel,.hero-side,.card,.section,.hero-mini{padding:18px}
  .display{font-size:2.25rem}
  .nav{width:100%}.nav a,.nav button{flex:1;justify-content:center}
  .map{height:360px}
  .driver-hero-card{padding:22px}
}


/* v3.2.1 fixes */
.topbar-floating{position:relative;z-index:4;background:transparent;backdrop-filter:none;box-shadow:none;padding-inline:0;margin-bottom:12px}
.driver-shell-minimal .page{max-width:none;padding:18px;min-height:100vh}
.driver-dashboard-page.minimal{position:relative;display:grid;grid-template-rows:auto 1fr}
.driver-ambient-overlay.light{background:linear-gradient(180deg,rgba(255,255,255,.12) 0%,rgba(255,255,255,.03) 28%,rgba(255,255,255,.30) 100%)}
.driver-floating-state{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:4px 0 0;transition:all .28s ease}
.driver-floating-state.hidden{display:none}
.driver-floating-dot{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:#111;color:#fff;position:relative;overflow:hidden;flex:0 0 auto}
.driver-floating-dot span,.driver-mini-pulse{width:14px;height:14px;border-radius:50%;background:#fff;display:block;animation:driverPulse 1.8s infinite}
.driver-mini-pulse{background:#111;width:12px;height:12px}
@keyframes driverPulse{0%{box-shadow:0 0 0 0 rgba(17,17,17,.25)}70%{box-shadow:0 0 0 12px rgba(17,17,17,0)}100%{box-shadow:0 0 0 0 rgba(17,17,17,0)}}
.driver-status-pill.white{background:rgba(255,255,255,.88);color:#111;border:1px solid rgba(17,17,17,.08)}
.driver-bottom-sheet.only-sheet{display:grid;position:fixed;left:18px;right:18px;bottom:18px;z-index:4}
.bottom-card-clean{background:rgba(255,255,255,.96)!important;border:1px solid rgba(17,17,17,.08)!important;backdrop-filter:blur(18px);box-shadow:0 18px 40px rgba(17,17,17,.14)}
.item-tight{padding:14px 0;border-top:1px solid rgba(17,17,17,.08)}
.item-tight:first-child{border-top:none;padding-top:0}
.inline-form{display:grid;grid-template-columns:1fr 1fr auto;gap:10px;margin-top:10px}
.inline-form input{width:100%;border:1px solid rgba(17,17,17,.12);border-radius:14px;padding:12px 14px;background:#fff;font:inherit}
.driver-waiting-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0}
.driver-sheet-head.compact{margin-bottom:0}
.theme-switch{display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border:1px solid rgba(17,17,17,.08);background:rgba(255,255,255,.86);border-radius:999px;font-weight:700}
.theme-switch select{border:none;background:transparent;font:inherit;color:#111;outline:none}
.route-auth-note{margin-top:10px}
.link-row{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:12px}
.text-link{font-weight:800;color:#111;opacity:.78}
.text-link:hover{opacity:1}
@media (max-width:720px){.inline-form{grid-template-columns:1fr 1fr}.inline-form .btn{grid-column:1/-1}.driver-floating-state{align-items:flex-start}.theme-switch{width:100%;justify-content:center}}

/* v3.2.4 ux polish */
*{scroll-behavior:smooth}
body,.card,.section,.bottom-card-clean,.notice,.status-pill,.btn,.btn-secondary,.item,.topbar,.price-dock,.modal-card{transition:all .28s ease}
.transition-page{animation:fadePage .35s ease}
.transition-card{animation:fadeUp .35s ease}
@keyframes fadePage{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.driver-floating-state.inline-inside{padding:0;gap:10px;align-items:center}
.driver-floating-dot.pulse,.driver-live-dot{position:relative}
.driver-floating-dot.pulse span{animation:driverBlink 1.25s infinite ease-in-out}
.driver-floating-dot.pulse::after,.driver-live-dot::after{content:'';position:absolute;inset:0;border-radius:50%;border:1px solid rgba(17,17,17,.16);animation:ring 1.8s infinite}
@keyframes driverBlink{0%,100%{transform:scale(.9);opacity:.85}50%{transform:scale(1.1);opacity:1}}
@keyframes ring{0%{transform:scale(.9);opacity:.8}100%{transform:scale(1.8);opacity:0}}
.merged-driver-card .item-route.mute{font-size:.92rem;color:var(--muted);font-weight:600;margin:.35rem 0 .6rem}
.page-ride-minimal .topbar{margin-bottom:14px}.single-column{grid-template-columns:1fr!important}.ride-map-tall{height:52vh;min-height:420px}.map-first-card{padding:12px}.ride-summary-card{display:grid;gap:14px}.ride-compact-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start}.route-mini.compact{gap:10px}.summary-stack{display:flex;gap:10px;flex-wrap:wrap}.notice.compact{display:flex;gap:8px;align-items:center;padding:12px 14px;border-radius:16px}
.price-dock{position:fixed;left:18px;right:18px;bottom:18px;z-index:20;background:rgba(255,255,255,.96);border:1px solid rgba(17,17,17,.08);box-shadow:0 18px 50px rgba(17,17,17,.14);border-radius:24px;padding:16px 18px;backdrop-filter:blur(18px)}
.price-dock.hidden{display:none}.price-dock-inner{display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center}.price-dock-label{font-size:.82rem;color:var(--muted);font-weight:700}.price-dock-value{font-size:2rem;font-weight:900;letter-spacing:-.06em}.price-dock-meta{font-weight:700}.price-dock-actions{display:flex;gap:10px;align-items:center}.dock-select{border:1px solid rgba(17,17,17,.12);border-radius:14px;padding:12px 14px;background:#fff;font:inherit}
.btn-secondary.full{width:100%}.inline-card.slim{padding:12px 14px}.modal{position:fixed;inset:0;z-index:30;display:grid;place-items:center}.modal.hidden{display:none}.modal-backdrop{position:absolute;inset:0;background:rgba(17,17,17,.28);backdrop-filter:blur(4px)}.modal-card{position:relative;z-index:1;background:#fff;border-radius:28px;padding:28px;min-width:min(92vw,360px);box-shadow:0 28px 70px rgba(17,17,17,.2);display:grid;gap:14px;text-align:center}.rating-stars{display:flex;justify-content:center;gap:8px}.rating-stars button{font-size:2rem;background:none;border:none;cursor:pointer;opacity:.28;transition:all .2s ease}.rating-stars button.active,.rating-stars button:hover,.rating-stars button:hover~button{opacity:1}.taxi-emoji{font-size:18px;display:block}
@media (max-width:720px){.price-dock{left:12px;right:12px;bottom:12px}.price-dock-inner{grid-template-columns:1fr;gap:12px}.price-dock-value{font-size:1.7rem}.price-dock-actions{width:100%;display:grid;grid-template-columns:1fr 1fr}.dock-select{grid-column:1/-1}.ride-map-tall{height:46vh;min-height:320px}}


/* v3.2.5 mobile cleanup */
.topbar-mobile-clean{position:sticky;top:0;z-index:25;padding:8px 0 10px;background:linear-gradient(180deg,rgba(246,246,243,.96),rgba(246,246,243,.82));backdrop-filter:blur(14px)}
.brand-logo-only{padding:0;border:none;background:transparent;box-shadow:none}.brand-logo-only:hover{transform:none}
.nav-emoji a,.nav-emoji button,.theme-switch-icon{width:44px;height:44px;padding:0;display:grid;place-items:center;border-radius:999px;font-size:1.15rem;line-height:1}.theme-switch-icon{grid-template-columns:1fr;position:relative;overflow:hidden}.theme-switch-icon span{pointer-events:none}.theme-switch-icon select{position:absolute;inset:0;opacity:0;cursor:pointer}
.compact-nav{gap:8px;align-items:center;flex-wrap:nowrap}
.status-navbar{position:sticky;top:64px;z-index:20;padding:10px 14px;margin-bottom:12px;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:flex-start}
.status-navbar #statusBadge{display:flex}.status-navbar .status-pill{font-size:.96rem;padding:10px 14px;border-radius:999px}
.page-ride-minimal{padding-bottom:150px}.ride-summary-card{min-width:0;overflow:hidden}.ride-summary-card .route-mini,.ride-summary-card .route-line,.ride-summary-card .summary-stack,.ride-summary-card .notice,.ride-summary-card .ride-compact-head{min-width:0}.ride-summary-card .route-line span:last-child,.ride-summary-card .notice{overflow:hidden;text-overflow:ellipsis}.map-shell,.ride-map-tall,#map{max-width:100%}.summary-stack{align-items:stretch}.customer-ride-layout{min-width:0}.route-line{display:grid;grid-template-columns:18px minmax(0,1fr);gap:8px;align-items:center}.route-line .truncate{min-width:0;display:block}.nav-emoji button{border:1px solid rgba(17,17,17,.08);background:rgba(255,255,255,.86);font-weight:800;color:#111}.compact-card{overflow:hidden}
.customer-dashboard-page .compact-card{overflow:visible}
@media (max-width:720px){
  .page{padding:12px 12px 112px}
  .topbar{gap:10px;align-items:center;margin-bottom:12px}
  .brand-mark{width:40px;height:40px;border-radius:14px}
  .nav{gap:8px}
  .theme-switch{padding:0}
  .page-shell,.layout-2,.split,.hero,.customer-ride-layout{grid-template-columns:1fr!important;gap:12px}
  .card,.section,.hero-panel,.hero-side,.hero-mini{padding:16px;border-radius:22px}
  .section-title{font-size:1rem;margin-bottom:4px}
  .field label{margin-bottom:6px}
  .map{height:300px}
  .ride-map-tall{height:40vh;min-height:280px}
  .map-first-card{padding:10px}
  .ride-summary-card{position:relative;margin-top:0;padding:14px 14px 16px}
  .ride-compact-head{display:block}
  .route-mini.compact{margin-bottom:10px}
  .summary-stack{display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .summary-stack > *{min-width:0}
  .notice.compact{padding:10px 12px;border-radius:14px;font-size:.88rem}
  .notice.compact strong,.notice.compact span{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .status-navbar{top:60px;padding:8px 10px;border-radius:18px;margin-bottom:10px}
  .status-navbar .status-pill{width:100%;justify-content:center;text-align:center}
  .price-dock{left:10px;right:10px;bottom:10px;padding:14px;border-radius:22px}
  .price-dock-inner{grid-template-columns:1fr;gap:10px}
  .price-dock-meta{font-size:.9rem}
  .price-dock-actions{grid-template-columns:1fr 1fr}
  .dock-select{grid-column:1/-1}
  .topbar .nav a,.topbar .nav button,.theme-switch-icon{flex:0 0 44px}
}
@media (max-width:420px){
  .page{padding-inline:10px}
  .topbar{gap:8px}
  .compact-nav{gap:6px}
  .nav-emoji a,.nav-emoji button,.theme-switch-icon{width:40px;height:40px;font-size:1rem}
  .summary-stack{grid-template-columns:1fr}
  .route-line{grid-template-columns:16px minmax(0,1fr)}
  .status-navbar{top:56px}
}


/* v3.2.6 interaction polish */
.topbar-mobile-clean .nav{margin-left:auto;justify-content:flex-end}
.topbar-mobile-clean .brand-logo-only{margin-right:auto}
.driver-dashboard-page .topbar .nav{margin-left:auto;justify-content:flex-end}
.driver-task-dock{position:fixed;left:10px;right:10px;bottom:10px;z-index:26;background:rgba(255,255,255,.96);border:1px solid rgba(17,17,17,.08);box-shadow:0 18px 50px rgba(17,17,17,.14);border-radius:24px;padding:12px 14px;backdrop-filter:blur(18px);display:grid;gap:10px}
.driver-task-dock.hidden{display:none}
.driver-task-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;align-items:center}
.driver-task-row.single{grid-template-columns:1fr}
.driver-task-slide{display:grid;gap:8px}
.driver-task-slide input[type="range"]{width:100%}
.driver-task-dock .btn,.driver-task-dock .btn-secondary{width:100%;padding:13px 14px;border-radius:16px}
.driver-task-dock .small{text-align:center}
.driver-task-page{padding-bottom:146px}
.driver-task-card{display:grid;gap:12px}
.driver-task-route{display:grid;gap:8px}
.driver-task-meta{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.driver-task-meta .notice{min-width:0}
.driver-task-meta .notice strong,.driver-task-meta .notice span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media (max-width:720px){
  .driver-task-page{padding-bottom:160px}
  .driver-task-meta{grid-template-columns:1fr}
  .driver-task-dock{left:8px;right:8px;bottom:8px;padding:10px 12px;border-radius:22px}
  .driver-task-row{grid-template-columns:1fr 1fr}
}


/* v3.2.7 polish */
body{overflow-x:hidden}
.page-ride-minimal{overflow-x:hidden;-webkit-overflow-scrolling:touch}
.page-ride-minimal .map-shell{overflow:hidden}
.ride-route-copy{display:grid;gap:8px;margin-bottom:12px;padding:14px 14px 10px;border-bottom:1px solid rgba(17,17,17,.08)}
.route-copy-line{display:grid;gap:4px}
.route-copy-line span{font-size:.78rem;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.08em}
.route-copy-line strong{font-size:.96rem;line-height:1.35}
.price-dock.confirming{background:linear-gradient(180deg,#18a957,#129047);color:#fff;border-color:rgba(0,0,0,.04)}
.price-confirmed{display:flex;align-items:center;gap:14px;padding:6px 2px}
.confirm-check{width:48px;height:48px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.18);font-size:1.4rem;font-weight:900;animation:popCheck .45s ease}
.price-confirmed strong{display:block;font-size:1.1rem}.price-confirmed span{display:block;opacity:.92}
@keyframes popCheck{0%{transform:scale(.55);opacity:0}100%{transform:scale(1);opacity:1}}
.btn-danger{background:#d92d20;color:#fff;border:none;font-weight:800;border-radius:16px;padding:13px 14px}
.btn-danger:hover{filter:brightness(.96)}
.driver-map-only .map-first-card{padding:0;overflow:hidden;position:relative}
.driver-full-map{height:calc(100vh - 170px);min-height:560px}
.driver-map-overlay{position:absolute;left:12px;right:12px;top:12px;z-index:5;background:rgba(255,255,255,.92);backdrop-filter:blur(16px);display:grid;gap:10px}
.driver-task-card,.driver-task-route{gap:10px}
.dropoff-callout{font-weight:900;font-size:1rem;letter-spacing:-.02em;text-align:center}
.active-ride-bubble{position:fixed;right:14px;bottom:92px;z-index:24;display:grid;gap:3px;padding:14px 16px;background:#111;color:#fff;border-radius:18px;box-shadow:0 18px 46px rgba(17,17,17,.26)}
.active-ride-bubble.hidden{display:none}.active-ride-bubble span{font-size:.74rem;opacity:.72}.active-ride-bubble strong{font-size:.92rem;max-width:180px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.auth-choice-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.auth-choice-card{display:grid;gap:8px;place-items:center;text-align:center;padding:14px;border:1px solid rgba(17,17,17,.08);border-radius:20px;background:rgba(255,255,255,.86)}
.auth-choice-icon{font-size:1.45rem}
.nav-right{margin-left:auto;justify-content:flex-end}
@media (max-width:720px){
  .driver-full-map{height:calc(100vh - 156px);min-height:500px}
  .driver-map-overlay{left:10px;right:10px;top:10px;padding:12px 14px;border-radius:20px}
  .active-ride-bubble{left:12px;right:12px;bottom:86px;padding:13px 15px}
  .active-ride-bubble strong{max-width:none}
  .page-ride-minimal .ride-map-tall{height:37vh;min-height:250px}
  .ride-summary-card{overflow:visible}
  .status-navbar{position:sticky}
}

.status-navbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.status-eta{display:inline-flex;align-items:center;justify-content:center;padding:10px 12px;border-radius:999px;background:#f3f4f6;border:1px solid rgba(17,17,17,.12);font-weight:800;color:#111;font-size:.9rem}
.driver-task-dock.confirming{background:linear-gradient(180deg,#18a957,#129047);color:#fff;border-color:rgba(0,0,0,.04)}
.dropoff-time{font-size:1.2rem;font-weight:900;letter-spacing:-.04em}
.leaflet-container{touch-action:pan-y pinch-zoom;}
.payment-dock .price-dock-meta{font-size:1rem;font-weight:800}
.auth-choice-label{margin-top:14px;margin-bottom:8px;font-weight:800}

/* v3.2.9 premium navbar flow */
:root{--accent:#111;--accent-soft:#f3f4f6;--accent-ink:#fff}
.btn,.btn-accent{background:var(--accent);color:var(--accent-ink);border:none;font-weight:900;border-radius:16px;padding:13px 16px}
.btn:hover,.btn-accent:hover{filter:brightness(.98)}
.btn-secondary{background:#fff;color:#111;border:1px solid rgba(17,17,17,.1);font-weight:800;border-radius:16px;padding:13px 16px}
.btn-danger{background:#d92d20;color:#fff;border:none;font-weight:900}
.btn-danger-small{padding:10px 14px;border-radius:999px}
.active-navbar{background:rgba(255,255,255,.94);backdrop-filter:blur(18px);display:flex;align-items:center;justify-content:flex-start;gap:8px}
.status-navbar #statusBadge{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.status-eta-pay{background:#dff5e7;border-color:#bce6ca}
.page-full-map{padding-bottom:140px}
.full-map-shell{position:relative;width:100%;height:calc(100vh - 128px);border-radius:28px;overflow:hidden}
.customer-full-map,.driver-full-map{width:100%;height:100%}
.customer-bottom-nav,.driver-task-dock{position:fixed;left:12px;right:12px;bottom:12px;z-index:26;background:rgba(255,255,255,.96);border:1px solid rgba(17,17,17,.08);box-shadow:0 18px 50px rgba(17,17,17,.14);border-radius:24px;padding:14px 16px;backdrop-filter:blur(18px);display:grid;gap:12px}
.customer-dock-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}
.customer-dock-head strong{display:block;font-size:1rem;letter-spacing:-.03em}
.customer-dock-head span{display:block;color:var(--muted);font-weight:700;margin-top:3px}
.customer-dock-head b{font-size:1.1rem;white-space:nowrap}
.customer-dock-state{display:flex;align-items:center;gap:12px;padding:2px 0}
.map-radar-inline{position:relative;width:40px;height:40px;display:grid;place-items:center;flex:0 0 auto}
.map-radar-inline span{position:absolute;inset:6px;border-radius:50%;border:1px solid rgba(17,17,17,.18);animation:taxiRadar 2.6s infinite}
.map-radar-inline span:nth-child(2){animation-delay:.45s}.map-radar-inline span:nth-child(3){animation-delay:.9s}
.map-radar-inline i{position:relative;z-index:2;font-style:normal;font-size:1.05rem}
.price-bar.offer-bar{display:grid;gap:12px}
.offer-price-block{display:flex;align-items:flex-end;justify-content:space-between;gap:12px}
.offer-price-block span{font-size:.82rem;color:var(--muted);font-weight:800}
.offer-price-block strong{font-size:2rem;letter-spacing:-.06em}
.offer-meta{font-weight:800}
.offer-actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.offer-actions .dock-select{grid-column:1/-1}
.customer-dock-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.dock-chip{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:999px;background:#fff;border:1px solid rgba(17,17,17,.08);font-weight:800}
.payment-green-card{display:flex;align-items:center;gap:14px;padding:16px 18px;border-radius:20px;background:linear-gradient(180deg,#19b35f,#149b50);color:#fff}
.payment-green-card>div:first-child{display:grid;gap:4px}.payment-green-card span{opacity:.9;font-size:.84rem;font-weight:800}.payment-green-card strong{font-size:1.5rem;letter-spacing:-.05em}
.payment-green-note{font-weight:800;line-height:1.3}.payment-green-card.is-done strong{font-size:1.12rem}
.pay-slide{margin-top:4px}
.driver-overlay-card{position:fixed;top:92px;left:12px;right:12px;z-index:20;background:rgba(255,255,255,.92);backdrop-filter:blur(18px);display:grid;gap:8px;border:1px solid rgba(17,17,17,.08);box-shadow:0 8px 24px rgba(17,17,17,.10);padding:12px 14px;border-radius:18px;max-height:76px;overflow:hidden}
.driver-task-meta.compact-grid{grid-template-columns:1fr 1fr}
.strong-callout{font-size:1.08rem;font-weight:900;letter-spacing:-.03em}
.fare-entry-card{display:grid;gap:12px}.fare-entry-card span{font-size:.82rem;color:var(--muted);font-weight:800}.fare-entry-card strong{font-size:1.4rem;letter-spacing:-.05em}
.fare-entry-row{display:grid;grid-template-columns:1fr auto;gap:10px}.fare-input{border:1px solid rgba(17,17,17,.12);border-radius:16px;padding:14px 16px;font:inherit;font-weight:800}
.driver-ambient-map .taxi-radar-marker,.taxi-radar-marker{background:transparent;border:none}
.map-radar{position:relative;width:84px;height:84px;display:grid;place-items:center}
.map-radar span{position:absolute;border-radius:50%;border:1px solid rgba(17,17,17,.18);animation:taxiRadar 2.8s infinite}
.map-radar span:nth-child(1){inset:22px}.map-radar span:nth-child(2){inset:12px;animation-delay:.45s}.map-radar span:nth-child(3){inset:0;animation-delay:.9s}.map-radar i{position:relative;z-index:2;font-style:normal;font-size:1.25rem;width:38px;height:38px;border-radius:50%;display:grid;place-items:center;background:#111;border:2px solid #fff;box-shadow:0 10px 24px rgba(17,17,17,.18)}
@keyframes taxiRadar{0%{transform:scale(.82);opacity:.85}100%{transform:scale(1.12);opacity:0}}
.customer-radar-marker,.taxi-radar-marker{background:transparent;border:none}
.driver-floating-dot.pulse span{background:#fff;animation:driverPulse 1.3s infinite}
.driver-full-map-shell{height:calc(100vh - 128px)}
.customer-full-map-shell{height:calc(100vh - 128px)}
.compact-nav.nav-right{margin-left:auto;justify-content:flex-end}
@media (max-width:720px){
  .full-map-shell,.customer-full-map-shell,.driver-full-map-shell{height:calc(100vh - 120px);border-radius:22px}
  .customer-bottom-nav,.driver-task-dock{left:10px;right:10px;bottom:10px;padding:12px 14px;border-radius:22px}
  .customer-dock-head{display:grid;gap:6px}
  .offer-actions{grid-template-columns:1fr 1fr}
  .offer-actions .dock-select{grid-column:1/-1}
  .driver-overlay-card{top:86px;left:10px;right:10px;padding:12px 14px;border-radius:20px}
  .driver-task-meta.compact-grid{grid-template-columns:1fr}
}


/* v3.2.10 layout fixes */
html,body{max-width:100%;overflow-x:hidden;background:#f5f5f5}
.ride-root,.driver-task-root,.driver-shell{background:#f5f5f5}
.leaflet-pane,.leaflet-top,.leaflet-bottom{z-index:1}
.leaflet-control-container{z-index:2}
.customer-ride-page,.driver-task-page,.driver-dashboard-page{min-height:100vh;overflow:hidden}
.topbar,.status-navbar,.customer-bottom-nav,.driver-task-dock,.driver-overlay-card,.driver-bottom-sheet.only-sheet{z-index:40}
.topbar-mobile-clean,.topbar-floating{position:fixed;top:10px;left:10px;right:10px;background:rgba(255,255,255,.92);backdrop-filter:blur(18px);border:1px solid rgba(17,17,17,.08);box-shadow:0 10px 30px rgba(17,17,17,.08);border-radius:22px;padding:10px 12px}
.customer-ride-page .status-navbar,.driver-task-page .status-navbar{position:fixed;top:76px;left:10px;right:10px;margin:0;box-shadow:0 10px 22px rgba(17,17,17,.08)}
.customer-full-map-shell{position:fixed;top:132px;bottom:118px;left:0;right:0;height:auto;border-radius:0;z-index:1}
.driver-full-map-shell{position:fixed;top:132px;bottom:146px;left:0;right:0;height:auto;border-radius:0;z-index:1}
.customer-full-map,.driver-full-map,.driver-ambient-map{width:100%;height:100%}
.customer-bottom-nav,.driver-task-dock{box-shadow:0 18px 50px rgba(17,17,17,.16),0 0 0 1px rgba(17,17,17,.04);border:1px solid rgba(17,17,17,.06)}
.customer-bottom-nav{min-height:96px}
.driver-overlay-card{top:132px;left:10px;right:10px;box-shadow:0 18px 40px rgba(17,17,17,.1);background:rgba(255,255,255,.9)}
.driver-bottom-sheet.only-sheet{left:10px;right:10px;bottom:12px;box-shadow:0 18px 50px rgba(17,17,17,.12),0 0 0 1px rgba(17,17,17,.04)}
.merged-driver-card{box-shadow:0 18px 42px rgba(17,17,17,.16),0 0 0 1px rgba(17,17,17,.05)}
.full-map-shell,.customer-full-map-shell,.driver-full-map-shell{overflow:hidden}
.map-radar{position:relative;width:124px;height:124px;display:grid;place-items:center}
.map-radar span{position:absolute;border-radius:50%;border:2px solid rgba(17,17,17,.18);animation:taxiRadar 2.4s infinite}
.map-radar span:nth-child(1){inset:44px}
.map-radar span:nth-child(2){inset:24px;animation-delay:.4s}
.map-radar span:nth-child(3){inset:0;animation-delay:.8s}
.map-radar i{position:relative;z-index:2;font-style:normal;font-size:1rem;width:28px;height:28px;border-radius:50%;display:grid;place-items:center;background:#111;border:2px solid #fff;box-shadow:0 10px 24px rgba(17,17,17,.18)}
.radar-center-icon{font-size:.95rem}
.customer-radar-marker,.taxi-radar-marker,.taxi-marker{background:transparent;border:none}
.customer-radar-marker .map-radar i{background:#111;color:#fff;border-color:#fff}
.driver-floating-dot{width:34px;height:34px;box-shadow:0 6px 18px rgba(17,17,17,.14)}
.driver-floating-dot.pulse::after,.driver-live-dot::after{border:1px solid rgba(17,17,17,.18)}
.strong-callout{font-size:1.16rem;font-weight:950;letter-spacing:-.03em}
.offer-price-block strong{font-size:2.35rem}
.payment-green-card{box-shadow:0 20px 40px rgba(25,179,95,.22)}
.confirm-check{width:42px;height:42px;border-radius:50%;background:#fff;color:#19b35f;display:grid;place-items:center;font-weight:1000;font-size:1.35rem;animation:popIn .45s ease}
.customer-bottom-nav.confirming,.driver-task-dock.confirming{background:linear-gradient(180deg,#19b35f,#149b50);color:#fff;transform:translateY(-2px);transition:all .25s ease}
.customer-bottom-nav.confirming *,.driver-task-dock.confirming *{color:#fff}
@keyframes popIn{0%{transform:scale(.6);opacity:0}70%{transform:scale(1.08);opacity:1}100%{transform:scale(1)}}
@media (max-width:720px){
  .topbar-mobile-clean,.topbar-floating{top:8px;left:8px;right:8px;padding:9px 10px;border-radius:18px}
  .customer-ride-page .status-navbar,.driver-task-page .status-navbar{top:68px;left:8px;right:8px;padding:8px 10px}
  .customer-full-map-shell{top:118px;bottom:108px}
  .driver-full-map-shell{top:118px;bottom:132px}
  .driver-overlay-card{top:118px;left:8px;right:8px}
  .customer-bottom-nav,.driver-task-dock,.driver-bottom-sheet.only-sheet{left:8px;right:8px;bottom:8px}
}

/* 3.2.11 stability and monochrome */
.driver-overlay-card .route-line{font-weight:800}
.driver-task-minirow{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:.92rem;color:var(--muted);font-weight:700}
.driver-task-minirow strong{color:#111;font-size:.96rem}
.driver-overlay-card #geoMessage .notice{padding:8px 10px;border-radius:12px;margin-top:6px}
.driver-overlay-card .route-line .truncate{font-weight:800}
.driver-overlay-card.compact-card{padding:10px 12px}
.driver-task-dock .btn{background:#111;color:#fff;box-shadow:0 10px 24px rgba(17,17,17,.18)}
.driver-task-dock .btn-secondary{background:#fff;color:#111;border:1px solid rgba(17,17,17,.10)}
.fare-entry-card{display:grid;gap:12px}
.fare-entry-row{display:grid;grid-template-columns:1fr auto;gap:10px}
.fare-input{width:100%;border:1px solid rgba(17,17,17,.12);border-radius:16px;padding:14px 16px;background:#fff;color:#111}
.taxi-radar .map-radar span,.map-radar-inline span,.map-radar span{border-color:rgba(17,17,17,.18)!important}
.driver-dashboard-page .inline-form .btn{background:#111;color:#fff}
.driver-dashboard-page .driver-floating-dot{background:#111;color:#fff}
@media (max-width:720px){
  .driver-overlay-card{top:84px;left:10px;right:10px;max-height:70px;padding:10px 12px}
  .driver-task-dock{padding:12px 12px 14px}
}

/* v3.2.12 monochrome home / uber-like refresh */
:root{
  --bg:#f5f5f5;
  --surface:rgba(255,255,255,.96);
  --surface-strong:#ffffff;
  --text:#111111;
  --muted:#6f6f73;
  --line:#e6e6e8;
  --soft:#f2f2f3;
  --accent:#111111;
  --accent-soft:#f4f4f5;
  --green:#111111;
  --warn:#6b6b6b;
  --shadow:0 18px 50px rgba(17,17,17,.08);
}
body{background:linear-gradient(180deg,#f7f7f7 0%,#efefef 100%)}
.brand-mark,.btn-home-primary,.journey-continue,.nav-home .nav-cta,.journey-filter.active{background:#111!important;color:#fff!important}
.notice-success,.payment-green-card,.customer-bottom-nav.confirming,.driver-task-dock.confirming,.price-dock.confirming{background:#111!important;color:#fff!important;border-color:#111!important;box-shadow:0 18px 40px rgba(17,17,17,.18)}
.payment-green-card span,.payment-green-card strong,.customer-bottom-nav.confirming *,.driver-task-dock.confirming *,.price-dock.confirming *{color:#fff!important}
.status-pill,.status-eta-pay{background:#111!important;color:#fff!important;border-color:#111!important}
.taxi-marker,.pickup-marker,.dropoff-marker,.mono-marker{filter:none}
.topbar-home{position:sticky;top:0;z-index:45;padding:12px 0 14px;margin-bottom:16px;background:linear-gradient(180deg,rgba(245,245,245,.96),rgba(245,245,245,.82));backdrop-filter:blur(16px)}
.brand-home{min-width:0;gap:12px}
.brand-copy{display:grid;min-width:0}
.brand-copy strong{font-size:1rem;line-height:1.1;letter-spacing:-.03em}
.brand-copy span{font-size:.78rem;color:var(--muted);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nav-home{margin-left:auto;align-items:center;gap:8px;flex-wrap:nowrap}
.nav-home a,.nav-home button,.nav-home .theme-switch{height:44px;display:inline-flex;align-items:center;justify-content:center;padding:0 15px;border-radius:999px}
.nav-home .nav-admin{background:#fff}
.home-shell{display:grid;grid-template-columns:minmax(340px,460px) minmax(0,1fr);gap:18px;align-items:stretch}
.home-booking-card,.home-map-card{padding:20px}
.home-booking-card{display:grid;gap:10px;align-content:start}
.home-booking-head{display:grid;gap:8px}
.eyebrow.mono{background:#111;color:#fff;border-color:#111}.eyebrow.mono::before{background:#fff}
.home-title{margin:0;letter-spacing:-.05em}
.home-lead{margin:0;max-width:none;font-size:.95rem}
.home-search-stack{gap:12px}
.field-dark label{font-weight:800;color:#111}
.field-dark input{background:#f7f7f7;border-color:#dedee2;font-weight:600}
.home-map-card{position:relative;overflow:hidden}
.home-map-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.home-map-shell{margin-top:0!important;border-radius:24px;overflow:hidden;border:1px solid rgba(17,17,17,.08)}
.home-map{height:min(68vh,760px)}
.chips-home .chip{background:#fff;border-color:#d9d9dd;padding:11px 14px;font-weight:800}
.chips-home .chip-more{min-width:42px;padding-inline:0;text-align:center;background:#111;color:#fff;border-color:#111}
.notice-home-route{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;align-items:center;text-align:center;border-radius:18px;padding:14px 16px}
.notice-home-route span,.notice-home-route strong{display:block}
.journey-sheet{position:fixed;left:50%;bottom:14px;transform:translate(-50%,24px);width:min(720px,calc(100vw - 24px));z-index:55;background:rgba(255,255,255,.99);border:1px solid rgba(17,17,17,.08);border-radius:28px;box-shadow:0 28px 80px rgba(17,17,17,.22),0 8px 24px rgba(17,17,17,.12);padding:14px 14px 16px;display:grid;gap:14px;backdrop-filter:blur(18px);opacity:0;pointer-events:none;transition:transform .28s ease,opacity .28s ease,box-shadow .28s ease}
.journey-sheet:not(.hidden){transform:translate(-50%,0);opacity:1;pointer-events:auto}
.journey-sheet.hidden{display:grid;opacity:0;pointer-events:none}
.journey-sheet-handle{width:52px;height:5px;border-radius:999px;background:#d2d2d7;margin:0 auto}
.journey-sheet-head h2{margin:0;font-size:1.8rem;letter-spacing:-.05em}
.journey-sheet-head p{margin:4px 0 0;color:var(--muted);font-weight:600}
.journey-filters{display:flex;gap:10px;flex-wrap:wrap}
.journey-filter{border:none;background:#f3f3f4;color:#111;border-radius:999px;padding:12px 16px;font-weight:800}
.vehicle-card{border:1px solid rgba(17,17,17,.1);background:#fff;border-radius:24px;padding:16px;display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:center;text-align:left}
.vehicle-card.active{box-shadow:inset 0 0 0 2px #111}
.vehicle-card-media{width:62px;height:62px;border-radius:18px;background:#f3f3f4;display:grid;place-items:center;font-size:2rem;filter:none;font-family:"Apple Color Emoji","Segoe UI Emoji","Noto Color Emoji",sans-serif}
.vehicle-card-top{display:flex;justify-content:space-between;gap:10px;align-items:center;font-size:1.05rem}
.vehicle-card-top strong{font-size:1.15rem;letter-spacing:-.03em}
.vehicle-card-top span{font-weight:900}
.vehicle-card-meta{display:flex;gap:12px;flex-wrap:wrap;margin:6px 0 4px;color:var(--muted);font-weight:700}
.vehicle-card-copy p{margin:0;color:var(--muted);line-height:1.45;font-weight:600}
.journey-payment-row{display:grid}
.payment-tile{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:18px;background:#f6f6f7;border:1px solid rgba(17,17,17,.06)}
.payment-icon{width:38px;height:38px;border-radius:12px;background:#eef5ff;color:#111;display:grid;place-items:center;font-weight:900;font-size:1.15rem;line-height:1;filter:none;font-family:"Apple Color Emoji","Segoe UI Emoji","Noto Color Emoji",sans-serif}
.payment-tile strong{display:block;font-size:1rem}
.payment-tile span:last-child{display:block;color:var(--muted);font-size:.88rem}
.journey-sheet .color-emoji,.journey-sheet .vehicle-card-media,.journey-sheet .payment-icon{filter:none!important;font-family:"Apple Color Emoji","Segoe UI Emoji","Noto Color Emoji",sans-serif;font-variant-emoji:emoji}
.journey-continue{width:100%;min-height:54px;border-radius:18px;font-size:1rem}
.active-ride-bubble{z-index:60}
.customer-bottom-nav,.driver-task-dock,.price-dock,.status-navbar,.topbar-mobile-clean,.topbar-floating{background:rgba(255,255,255,.94)}

@media (max-width:900px){
  .home-shell{grid-template-columns:1fr;gap:14px}
  .home-map{height:42vh;min-height:300px}
}
@media (max-width:720px){
  .topbar-home{padding:8px 0 10px}
  .topbar-home .brand-copy span{display:none}
  .topbar-home .brand-copy strong{font-size:.95rem}
  .nav-home{gap:6px;flex-wrap:nowrap}
  .nav-home a,.nav-home button,.nav-home .theme-switch{height:40px;padding:0 12px;font-size:.92rem}
  .nav-home .nav-admin{display:none}
  .home-booking-card,.home-map-card{padding:16px}
  .home-title{font-size:1.9rem}
  .journey-sheet{left:8px;right:8px;bottom:8px;transform:translateY(24px);width:auto;border-radius:24px;padding:12px 12px 14px}
  .journey-sheet:not(.hidden){transform:translateY(0)}
  .journey-sheet-head h2{font-size:1.45rem}
  .vehicle-card{grid-template-columns:54px 1fr;padding:14px}
  .vehicle-card-media{width:54px;height:54px;border-radius:16px}
  .notice-home-route{grid-template-columns:1fr}
}
@media (max-width:420px){
  .topbar-home{gap:8px}
  .brand-home{gap:10px}
  .brand-copy strong{font-size:.9rem}
  .nav-home a,.nav-home button,.nav-home .theme-switch{padding:0 10px;font-size:.86rem}
  .nav-home .nav-cta{min-width:72px}
}

/* v3.2.12 monochrome overrides */
.map-radar i,.customer-radar-marker .map-radar i{background:#111!important;color:#fff!important}
.confirm-check{color:#111!important}
:root{--accent:#111!important;--accent-soft:#f4f4f5!important;--accent-ink:#fff!important}


/* v3.2.14 button contrast fix */
.btn,.btn-accent,button.btn,.btn[type=submit]{color:#fff!important;background:#111!important}
.btn .muted,.btn-accent .muted{color:rgba(255,255,255,.78)!important}


/* v3.2.15 dashboard + dock polish */
.customer-dashboard-page{padding-top:96px;padding-bottom:36px}
.customer-dashboard-page .page-shell{display:grid;grid-template-columns:minmax(0,420px) minmax(0,1fr);gap:18px;align-items:start}
.customer-dashboard-page .compact-card{padding:20px}
.customer-dashboard-page .section-title{font-size:1.05rem;letter-spacing:-.04em}
.customer-dashboard-page .search-shell label{font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:#8a8a90}
.customer-dashboard-page .search-shell input{min-height:56px;background:#f7f7f8;border-color:#e2e2e5;font-weight:700;border-radius:18px}
.customer-dashboard-page .chips{margin:4px 0 12px!important}
.customer-dashboard-page .chip{padding:12px 16px;background:#f8f8f8;border-color:#d8d8dc;font-weight:800}
.customer-dashboard-page .chip-more{min-width:44px;justify-content:center;padding-inline:0;background:#efeff1;color:#111}
.customer-dashboard-page .map-shell{border-radius:28px;border:1px solid rgba(17,17,17,.08);overflow:hidden;min-height:calc(100vh - 150px)}
.customer-dashboard-page .map{height:calc(100vh - 150px);min-height:520px}
.brand-logo-only{display:inline-flex;align-items:center;gap:0}
.topbar-mobile-clean{display:flex;align-items:center;justify-content:space-between;gap:14px;min-height:72px}
.compact-nav{display:flex;align-items:center;gap:10px;flex-wrap:nowrap}
.compact-nav a,.compact-nav button,.compact-nav .theme-switch{width:48px;height:48px;padding:0;border-radius:999px;display:grid;place-items:center;background:#fff;border:1px solid rgba(17,17,17,.08);box-shadow:none;font-size:1.1rem;flex:0 0 auto}
.compact-nav .theme-switch{position:relative;overflow:hidden}
.compact-nav .theme-switch span{display:grid;place-items:center}
.compact-nav .theme-switch select{position:absolute;inset:0;opacity:0;cursor:pointer}
.compact-nav a:hover,.compact-nav button:hover,.compact-nav .theme-switch:hover{background:#f6f6f7;transform:none}

.customer-bottom-nav{padding:18px 18px 16px;border-radius:28px;gap:14px}
.customer-bottom-nav::before{content:"";width:44px;height:5px;border-radius:999px;background:#d5d5d8;margin:0 auto 2px}
.customer-dock-head{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:start}
.customer-dock-title{display:grid;gap:6px;min-width:0}
.customer-dock-title strong{font-size:1.08rem;line-height:1.1}
.customer-dock-sub{display:flex;gap:8px;align-items:center;flex-wrap:wrap;color:var(--muted);font-weight:700}
.customer-dock-eta{display:grid;gap:2px;align-items:end;text-align:right}
.customer-dock-eta b{font-size:1.4rem;line-height:1;letter-spacing:-.05em}
.customer-dock-eta span{font-size:.8rem;color:var(--muted);font-weight:800}
.customer-route-card{display:grid;gap:10px;padding:14px;border-radius:20px;background:#f7f7f8;border:1px solid rgba(17,17,17,.06)}
.customer-route-stop{display:grid;grid-template-columns:14px minmax(0,1fr);gap:10px;align-items:start}
.customer-route-stop i{display:block;width:14px;height:14px;border-radius:50%;border:3px solid #111;margin-top:3px}
.customer-route-stop.dropoff i{background:#111}
.customer-route-stop label{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:#8a8a90;font-weight:800;margin-bottom:3px}
.customer-route-stop strong{display:block;font-size:.98rem;line-height:1.35;letter-spacing:-.02em}
.customer-dock-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.dock-stat{padding:12px 12px 13px;border-radius:18px;background:#fff;border:1px solid rgba(17,17,17,.08);display:grid;gap:4px}
.dock-stat label{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:#8a8a90;font-weight:800}
.dock-stat strong{font-size:.98rem;line-height:1.2}
.dock-stat span{color:var(--muted);font-size:.86rem;font-weight:700}
.customer-dock-state{align-items:center;gap:14px;padding:0}
.customer-dock-state>div:last-child{display:grid;gap:4px}
.customer-dock-state strong{font-size:1rem}
.customer-dock-actions{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}
.customer-dock-actions .btn,.customer-dock-actions .btn-danger{min-height:52px;border-radius:18px}
.customer-dock-actions .btn-danger{padding-inline:18px}
.customer-dock-actions.split{grid-template-columns:1fr 1fr}
.price-bar.offer-bar{gap:14px}
.offer-price-block{align-items:flex-start;padding:2px 0}
.offer-price-block span{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em}
.offer-price-block strong{font-size:2.2rem;line-height:1}
.offer-meta{color:var(--muted);font-weight:700}
.offer-actions{grid-template-columns:1fr 1fr;align-items:stretch}
.offer-actions .dock-select{grid-column:1/-1;min-height:52px;border-radius:18px;background:#f7f7f8}
.dock-chip{padding:11px 14px;border-radius:16px;background:#f7f7f8;border:1px solid rgba(17,17,17,.08);font-weight:800}
.payment-green-card{border-radius:22px;padding:18px}

@media (max-width:980px){
  .customer-dashboard-page .page-shell{grid-template-columns:1fr}
  .customer-dashboard-page .map-shell{min-height:340px}
  .customer-dashboard-page .map{height:44vh;min-height:340px}
}
@media (max-width:720px){
  .customer-dashboard-page{padding-top:88px;padding-bottom:24px}
  .topbar-mobile-clean{min-height:60px;padding:8px 10px}
  .compact-nav{gap:8px}
  .compact-nav a,.compact-nav button,.compact-nav .theme-switch{width:44px;height:44px;font-size:1rem}
  .customer-dashboard-page .page-shell{gap:14px}
  .customer-dashboard-page .compact-card{padding:16px}
  .customer-bottom-nav{left:8px;right:8px;bottom:8px;padding:16px 14px 14px;border-radius:24px}
  .customer-dock-head{grid-template-columns:1fr}
  .customer-dock-eta{text-align:left}
  .customer-dock-grid{grid-template-columns:1fr 1fr}
  .customer-dock-actions,.customer-dock-actions.split{grid-template-columns:1fr}
}
@media (max-width:420px){
  .customer-dashboard-page .map{min-height:300px}
  .customer-dock-grid{grid-template-columns:1fr}
}

.quote-waiting-card{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:18px;background:#111!important;color:#fff!important}.quote-waiting-card strong,.quote-waiting-card span{color:#fff!important}.quote-waiting-card span{opacity:.84}


/* v3.2.18 driver ui polish + nav follow */
.driver-task-page .topbar-mobile-clean,.driver-task-page .status-navbar{left:12px;right:12px}
.driver-task-page .topbar-mobile-clean{display:flex;align-items:center;justify-content:space-between;min-height:58px;padding:10px 12px;border-radius:20px}
.driver-task-page .status-navbar{top:78px;padding:10px 12px;border-radius:18px;background:rgba(255,255,255,.9);backdrop-filter:blur(16px)}
.driver-task-page .status-navbar #taskBadge{display:flex;gap:8px;align-items:center;flex-wrap:wrap;width:100%;justify-content:space-between}
.driver-task-page .status-navbar .status-pill{padding:8px 12px;font-size:.88rem}
.driver-status-inline{display:flex;align-items:center;gap:8px;color:#111;font-weight:900}
.driver-status-inline small{color:var(--muted);font-weight:800}
.driver-nav-action{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:999px;background:#111;color:#fff;font-weight:900;text-decoration:none;border:none}
.driver-overlay-card{top:auto;bottom:128px;left:12px;right:12px;max-height:none;padding:14px 16px;border-radius:24px;background:rgba(255,255,255,.94);box-shadow:0 16px 44px rgba(17,17,17,.12);display:grid;gap:12px}
.driver-overlay-card.compact-card{padding:14px 16px}
.driver-overlay-hero{display:grid;gap:10px}
.driver-overlay-title{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.driver-overlay-title strong{font-size:1.08rem;letter-spacing:-.03em}
.driver-overlay-sub{color:var(--muted);font-size:.9rem;font-weight:800}
.driver-overlay-route{display:grid;gap:8px;padding:12px 14px;border-radius:18px;background:#f7f7f7;border:1px solid rgba(17,17,17,.06)}
.driver-overlay-route .route-line{grid-template-columns:14px minmax(0,1fr);font-size:.95rem}
.driver-overlay-meta{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.driver-meta-pill{padding:10px 12px;border-radius:16px;background:#fff;border:1px solid rgba(17,17,17,.08);display:grid;gap:2px}
.driver-meta-pill span{font-size:.74rem;color:var(--muted);font-weight:800}
.driver-meta-pill strong{font-size:.96rem;letter-spacing:-.02em}
.driver-follow-pill{display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border-radius:999px;background:#111;color:#fff;font-weight:900;box-shadow:0 8px 22px rgba(17,17,17,.18)}
.driver-follow-pill small{color:rgba(255,255,255,.78);font-weight:700}
.driver-task-dock{padding:14px 16px 18px;border-radius:26px;gap:12px}
.driver-task-dock .driver-task-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.driver-task-dock .driver-task-row.single{grid-template-columns:1fr}
.driver-task-slide{display:grid;gap:8px;padding:12px 14px;border:1px solid rgba(17,17,17,.08);border-radius:18px;background:#fafafa}
.driver-task-slide .small{font-weight:800;color:var(--muted)}
.driver-task-dock .btn,.driver-task-dock .btn-secondary,.driver-task-dock .btn-danger{min-height:52px;border-radius:18px}
.driver-sheet-head.compact{align-items:center}
.driver-dashboard-page #openRequests .item{padding:16px 0}
.driver-dashboard-page #openRequests .item-head{align-items:center}
.driver-dashboard-page .request-card-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.driver-dashboard-page .request-card-actions .btn,.driver-dashboard-page .request-card-actions .btn-secondary{flex:1 1 0;min-width:0;text-align:center;justify-content:center;display:inline-flex;align-items:center}
.driver-dashboard-page .inline-form{display:grid;grid-template-columns:1fr 1fr auto;gap:10px;margin-top:12px}
.driver-dashboard-page .inline-form input{border:1px solid rgba(17,17,17,.1);border-radius:16px;padding:12px 14px;background:#fff;font:inherit;font-weight:800;color:#111;min-width:0}
.driver-dashboard-page .request-task-chip{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;background:#111;color:#fff;font-weight:900;text-decoration:none}
.driver-dashboard-page .request-task-chip small{color:rgba(255,255,255,.78);font-weight:700}
.driver-dashboard-page .driver-nav-link{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:50%;border:1px solid rgba(17,17,17,.08);background:rgba(255,255,255,.92);color:#111;text-decoration:none;font-size:1.05rem}
.driver-dashboard-page .driver-nav-link.cta{width:auto;padding:0 16px;border-radius:999px;background:#111;color:#fff;font-weight:900}
@media (max-width:720px){
  .driver-task-page .topbar-mobile-clean{left:8px;right:8px;min-height:54px;padding:8px 10px}
  .driver-task-page .status-navbar{left:8px;right:8px;top:66px;padding:8px 10px}
  .driver-full-map-shell{top:112px;bottom:150px}
  .driver-overlay-card{left:8px;right:8px;bottom:126px;padding:12px 14px;border-radius:22px}
  .driver-overlay-card.compact-card{padding:12px 14px}
  .driver-overlay-meta{grid-template-columns:1fr 1fr 1fr}
  .driver-task-dock{left:8px;right:8px;bottom:8px;padding:12px 12px 14px;border-radius:22px}
  .driver-dashboard-page .inline-form{grid-template-columns:1fr 1fr;}
  .driver-dashboard-page .inline-form .btn{grid-column:1/-1}
}


/* v3.2.19 layout cleanup */
.steady-card{animation:none!important;transition:none!important}
.driver-dashboard-page #openRequests{min-height:56px}
.driver-dashboard-page .item-tight{padding:16px 0}
.driver-dashboard-page .request-task-chip{background:#f4f4f5;color:#111;border:1px solid rgba(17,17,17,.08)}
.driver-dashboard-page .request-task-chip small{display:none}
.customer-ride-page .status-navbar{padding:8px 10px;min-height:auto}
.customer-ride-page .status-navbar #statusBadge{gap:6px}
.customer-ride-page .status-pill,.customer-ride-page .status-eta{padding:8px 12px;font-size:.84rem}
.customer-dock-sub span,.dock-stat span,.customer-dock-eta span{display:none}
.customer-dock-eta b{font-size:1.16rem}
.customer-dock-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.dock-stat{gap:2px;min-height:72px;align-content:start}
.dock-stat label{font-size:.68rem}
.dock-stat strong{font-size:.92rem}
.driver-task-topbar{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:center}
.driver-task-topbar .compact-nav a,.driver-task-topbar .compact-nav button,.driver-task-topbar .compact-nav .theme-switch{width:42px;height:42px}
.driver-task-page .full-map-shell{top:82px;bottom:118px}
.driver-task-page .status-navbar{display:none!important}
.driver-task-navstate{display:flex;align-items:center;justify-content:flex-end;gap:8px;min-width:0;flex-wrap:wrap}
.driver-task-navstate .driver-status-inline{min-width:0}
.driver-task-navstate .driver-status-inline .status-pill{white-space:nowrap}
.driver-task-navstate .driver-status-inline small{display:none}
.driver-task-navstate .driver-nav-action{padding:9px 12px;min-height:40px}
.driver-nav-action.subtle{background:#f4f4f5;color:#111}
.driver-overlay-card{bottom:10px;left:12px;right:12px;padding:12px 14px;border-radius:20px;background:rgba(255,255,255,.9);backdrop-filter:blur(14px);box-shadow:0 10px 28px rgba(17,17,17,.10)}
.driver-overlay-card.compact-card{padding:12px 14px}
.driver-overlay-hero.slim{gap:8px}
.driver-overlay-title.slim{align-items:center}
.driver-overlay-title.slim strong{font-size:1rem}
.driver-overlay-title.slim .driver-overlay-sub{font-size:.82rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:52vw}
.driver-follow-pill.compact{padding:8px 12px;box-shadow:none;background:#111;color:#fff;font-size:.88rem}
.driver-overlay-meta.compact{grid-template-columns:1fr 1fr;gap:8px}
.driver-overlay-meta.compact .driver-meta-pill{padding:10px 12px;border-radius:14px}
.driver-overlay-meta.compact .driver-meta-pill strong{font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media (max-width:720px){
  .customer-dock-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .dock-stat{min-height:68px;padding:10px}
  .driver-task-page .full-map-shell{top:74px;bottom:108px}
  .driver-overlay-card{left:8px;right:8px;bottom:8px;border-radius:18px;padding:10px 12px}
  .driver-task-topbar{left:8px;right:8px;padding:8px 10px}
  .driver-overlay-title.slim .driver-overlay-sub{max-width:44vw}
}


.driver-topbar-row-live{gap:12px;min-width:0;flex:1}
.driver-topbar-meta{display:grid;gap:2px;min-width:0}
.driver-topbar-meta strong,.driver-topbar-meta span{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.driver-topbar-meta strong{font-size:.96rem;font-weight:900;color:#111}
.driver-topbar-meta span{font-size:.74rem;color:#5f5f5f}
.task-inline-card{display:grid;gap:12px;padding:2px 0}
.task-inline-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.task-inline-price{font-weight:900;font-size:1rem;white-space:nowrap}
.task-inline-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.task-inline-grid label{display:block;font-size:.72rem;color:#6a6a6a;margin-bottom:3px}
.task-inline-grid strong{display:block;font-size:.86rem;line-height:1.25}
.task-inline-actions{display:flex;gap:8px;flex-wrap:wrap}
.task-inline-actions .btn,.task-inline-actions .btn-secondary,.task-inline-actions .btn-danger{flex:1 1 120px}
.task-inline-foot{font-size:.78rem;color:#666;font-weight:700}
.compact-searching{margin-top:12px}
.customer-dock-grid .dock-stat label{font-size:.7rem}
.customer-dock-grid .dock-stat strong{font-size:.94rem}
@media (max-width: 640px){
  .driver-topbar-meta strong{font-size:.9rem}
  .driver-topbar-meta span{font-size:.7rem}
  .task-inline-grid{grid-template-columns:1fr}
  .task-inline-actions{display:grid;grid-template-columns:1fr 1fr}
}


/* v3.2.21 driver topbar slim + inline task */
.driver-dashboard-page .topbar-floating{min-height:58px;padding:8px 10px;border-radius:18px}
.driver-dashboard-page .driver-bottom-sheet.only-sheet{top:104px;bottom:10px;display:block}
.driver-dashboard-page .driver-bottom-sheet.only-sheet .section{max-height:calc(100vh - 114px);display:grid;align-content:start;gap:10px}
.driver-route-strip{position:fixed;top:76px;left:10px;right:10px;z-index:39;padding:0}
.driver-route-strip.hidden{display:none}
.driver-route-strip-inner{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr) auto;gap:8px;align-items:center;background:rgba(255,255,255,.94);backdrop-filter:blur(16px);border:1px solid rgba(17,17,17,.08);box-shadow:0 10px 24px rgba(17,17,17,.08);border-radius:18px;padding:10px 12px}
.driver-route-strip-line{display:flex;align-items:center;gap:8px;min-width:0}
.driver-route-strip-line strong{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.86rem}
.driver-route-dot{width:10px;height:10px;border-radius:50%;flex:0 0 auto;border:2px solid #111}
.driver-route-dot.dropoff{background:#111}
.driver-route-strip-arrow{color:#7a7a7a;font-weight:900}
.driver-route-strip-stat{padding:8px 10px;border-radius:999px;background:#111;color:#fff;font-weight:900;font-size:.8rem;white-space:nowrap}
.driver-dashboard-page #driverTaskInline{display:grid;gap:0}
.driver-dashboard-page #driverTaskInline .task-inline-card{padding:0;border-bottom:1px solid rgba(17,17,17,.06);padding-bottom:12px;margin-bottom:2px}
.driver-dashboard-page #openRequests:empty{display:none}
.customer-ride-page .customer-dock-head{grid-template-columns:1fr}
.customer-ride-page .customer-dock-sub{gap:6px}
.customer-ride-page .customer-dock-eta{display:none!important}
@media (max-width:720px){
  .driver-dashboard-page .topbar-floating{top:8px;left:8px;right:8px;min-height:54px;padding:8px 10px}
  .driver-route-strip{top:68px;left:8px;right:8px}
  .driver-route-strip-inner{grid-template-columns:minmax(0,1fr) auto;gap:8px}
  .driver-route-strip-arrow{display:none}
  .driver-route-strip-line:last-of-type{grid-column:1/2}
  .driver-route-strip-stat{grid-column:2/3;grid-row:1/3;align-self:center}
  .driver-dashboard-page .driver-bottom-sheet.only-sheet{top:118px;bottom:8px;left:8px;right:8px}
  .driver-dashboard-page .driver-bottom-sheet.only-sheet .section{max-height:calc(100vh - 126px)}
}

/* v3.2.22 customer sheet + cleaner driver chrome */
.customer-bottom-nav{
  gap:14px;
  padding:10px 12px 16px;
  border-radius:28px 28px 0 0;
  background:#f6f6f6;
  max-height:72vh;
  overflow:auto;
}
.customer-sheet-handle{
  width:46px;height:5px;border-radius:999px;background:#d2d2d2;margin:0 auto 6px;
}
.customer-hero-time{
  text-align:center;font-size:1.1rem;font-weight:950;letter-spacing:-.04em;color:#111;padding:4px 8px 2px;
}
.customer-panel-card{
  background:#fff;border:1px solid rgba(17,17,17,.08);border-radius:24px;padding:18px 16px;display:grid;gap:14px;box-shadow:0 4px 16px rgba(17,17,17,.04);
}
.customer-panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.customer-panel-head span{display:block;font-size:.86rem;color:#666;font-weight:700;margin-bottom:4px}
.customer-panel-head strong{display:block;font-size:1rem;line-height:1.35;letter-spacing:-.03em}
.mini-icon-btn{width:60px;height:58px;border-radius:16px;border:1px solid rgba(17,17,17,.08);background:#f2f2f2;color:#111;font-size:1.45rem;font-weight:900}
.customer-route-stack.compact{display:grid;gap:12px}
.customer-route-stop{display:grid;grid-template-columns:16px 1fr;gap:12px;align-items:start}
.customer-route-stop i{width:12px;height:12px;border-radius:50%;margin-top:6px}
.customer-route-stop.pickup i{background:#111}
.customer-route-stop.dropoff i{background:#111;box-shadow:0 0 0 3px #fff inset;border:2px solid #111}
.customer-route-stop label{display:block;font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:#777;font-weight:800;margin-bottom:4px}
.customer-route-stop strong{font-size:.98rem;line-height:1.34}
.customer-search-card{background:#fff}
.driver-card-uber-top{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center}
.driver-card-identity{position:relative;width:68px;height:68px}
.driver-avatar{width:56px;height:56px;border-radius:50%;background:#111;color:#fff;display:grid;place-items:center;font-size:1.25rem;font-weight:900}
.driver-rating-chip{position:absolute;left:20px;bottom:-2px;background:#fff;border:1px solid rgba(17,17,17,.1);border-radius:999px;padding:4px 8px;font-size:.78rem;font-weight:800;box-shadow:0 4px 12px rgba(17,17,17,.08)}
.driver-car-hero{font-size:3rem;line-height:1;filter:grayscale(1)}
.driver-card-copy{text-align:right;display:grid;gap:3px}
.driver-card-copy strong{font-size:1.1rem;letter-spacing:-.03em}
.driver-card-copy span{font-size:.92rem;color:#444}
.driver-card-actions-inline{display:grid;grid-template-columns:1fr auto;gap:10px}
.message-pill,.icon-action-pill{border:1px solid rgba(17,17,17,.08);background:#f5f5f5;color:#111;border-radius:16px;min-height:56px;font:inherit;font-weight:800}
.message-pill{display:flex;align-items:center;justify-content:center;gap:10px}
.icon-action-pill{width:70px}
.customer-action-grid-uber{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.customer-action-tile{background:#efefef;border-radius:18px;min-height:96px;display:grid;place-items:center;gap:8px;padding:14px 12px;text-align:center;border:1px solid rgba(17,17,17,.04)}
.customer-action-tile strong{font-size:.98rem}
.tile-icon{font-size:1.8rem;filter:grayscale(1)}
.customer-dock-actions.single-line{display:block}
.subtle-danger{background:#f3f3f3;color:#d92d20;border-radius:16px;width:100%;min-height:58px}
.offer-bar-clean{gap:10px}
.stacked-actions{grid-template-columns:1fr}
.offer-meta{font-size:.92rem;color:#555}
.status-navbar.active-navbar{padding:8px 12px;border-radius:18px;min-height:auto;width:max-content;max-width:calc(100vw - 20px)}
.status-navbar #statusBadge{flex-wrap:nowrap}
.status-navbar .status-pill,.status-navbar .status-eta{white-space:nowrap}
.driver-dashboard-page .topbar{padding:8px 10px;border-radius:18px;background:rgba(255,255,255,.94)}
.driver-topbar-row-live{gap:8px;flex-wrap:nowrap}
.driver-topbar-meta{min-width:0;display:grid;gap:1px}
.driver-topbar-meta strong{font-size:.95rem;line-height:1.1;letter-spacing:-.03em}
.driver-topbar-meta span{font-size:.78rem;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:42vw}
.driver-dashboard-page .nav a,.driver-dashboard-page .nav button,.driver-dashboard-page .theme-switch{min-height:42px;padding:8px 10px}
.driver-route-strip{position:fixed;top:72px;left:10px;right:10px;z-index:39}
.driver-route-strip-inner.minimal{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto;gap:8px;align-items:center;background:rgba(255,255,255,.96);border:1px solid rgba(17,17,17,.08);box-shadow:0 10px 22px rgba(17,17,17,.08);border-radius:16px;padding:10px 12px}
.driver-route-strip-line{display:flex;align-items:center;gap:8px;min-width:0}
.driver-route-strip-line strong{font-size:.79rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.driver-route-dot{width:8px;height:8px;border-radius:50%;flex:0 0 auto;background:#111}
.driver-route-dot.dropoff{background:#fff;border:2px solid #111;width:10px;height:10px}
.driver-route-strip-stat{font-size:.84rem;font-weight:900;background:#111;color:#fff;padding:8px 10px;border-radius:999px}
.driver-bottom-sheet.only-sheet{bottom:10px;left:10px;right:10px}
.driver-sheet-head.compact{align-items:flex-start}
.inline-inside{padding-top:0;gap:10px}
.driver-floating-state strong{font-size:.84rem}
.driver-floating-dot{width:28px;height:28px}
.task-inline-card-clean{padding-top:12px}
.task-inline-top.clean .item-route:first-child{font-size:1.02rem}
.task-inline-top.clean .item-route.mute{font-size:.86rem;margin-top:2px}
.task-inline-grid.compact{grid-template-columns:1fr 1fr;gap:10px;margin-top:8px}
.task-inline-grid.compact label{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:#777;font-weight:800;margin-bottom:4px}
.task-inline-grid.compact strong{display:block;font-size:.88rem;line-height:1.3}
.task-inline-foot{font-size:.84rem;color:#666;font-weight:700;margin-top:10px}
@media (max-width:720px){
  .customer-bottom-nav{left:0;right:0;bottom:0;border-radius:28px 28px 0 0;padding:10px 10px 16px;max-height:74vh}
  .customer-panel-card{padding:16px 14px;border-radius:22px}
  .driver-card-uber-top{grid-template-columns:auto 1fr auto;gap:8px}
  .driver-car-hero{font-size:2.6rem}
  .driver-card-copy strong{font-size:1rem}
  .driver-card-copy span{font-size:.88rem}
  .driver-route-strip{top:66px;left:8px;right:8px}
  .driver-route-strip-inner.minimal{padding:9px 10px;grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto}
  .driver-route-strip-stat{padding:7px 9px;font-size:.8rem}
  .driver-topbar-meta span{max-width:38vw}
}


/* v3.2.23 cleanup */
.customer-ride-page .status-navbar{display:none!important}
.customer-bottom-nav::before{display:none!important}
.customer-bottom-nav{left:8px;right:8px;bottom:8px;border-radius:28px;max-height:min(48vh,420px);overflow:auto;padding:14px 14px 16px;gap:12px}
.customer-sheet-handle{margin:0 auto 2px;width:44px;height:5px;border-radius:999px;background:#d5d5d8}
.customer-hero-time{font-size:1.05rem;line-height:1.2;text-align:center;font-weight:900}
.customer-inline-status{text-align:center;font-size:.82rem;color:#6f6f73;margin-top:-4px}
.customer-panel-card{border-radius:22px}
.customer-panel-head strong{font-size:1.35rem;line-height:1.2}
.customer-route-stack.compact{gap:10px}
.customer-action-grid-uber{grid-template-columns:1fr 1fr}
.customer-search-card .offer-actions.stacked-actions{grid-template-columns:1fr;gap:10px}
.customer-search-card .offer-meta{font-size:.88rem;color:#666}
.customer-bottom-nav.confirming{overflow:hidden}
.driver-dashboard-page .topbar-floating{display:flex;align-items:center;justify-content:space-between;min-height:54px;padding:8px 10px;border-radius:18px}
.driver-topbar-meta strong{font-size:1rem;line-height:1.1}
.driver-topbar-meta span{font-size:.78rem;color:#666}
.driver-route-strip{top:70px;left:8px;right:8px}
.driver-route-strip-inner.minimal{grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto;gap:8px;padding:8px 10px;border-radius:16px}
.driver-route-strip-line strong{font-size:.8rem}
.driver-route-strip-stat{padding:7px 9px;font-size:.78rem}
.driver-dashboard-page .driver-bottom-sheet.only-sheet{top:auto;bottom:8px;left:8px;right:8px}
.driver-dashboard-page .driver-bottom-sheet.only-sheet .section{max-height:min(36vh,300px);border-radius:24px;padding:14px}
.driver-sheet-head.compact{align-items:center;margin-bottom:8px}
.driver-sheet-head.compact .section-title{font-size:1rem}
.driver-floating-state.inline-inside{gap:8px;padding:0;background:transparent;border:none}
#driverTaskInline .task-inline-card-clean{border:1px solid rgba(17,17,17,.08);border-radius:20px;padding:14px;background:#fff;box-shadow:none}
#driverTaskInline .task-inline-grid.compact{grid-template-columns:1fr;gap:8px;margin-top:10px}
#driverTaskInline .task-inline-actions{grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}
#driverTaskInline .task-inline-actions .btn-danger{grid-column:1/-1}
#openRequests .item.steady-card{padding:14px 0}
.driver-ambient-map{transition:none!important}
.driver-task-page .status-navbar,.active-navbar,.status-navbar.card.compact-card.active-navbar{display:none!important}
.driver-task-page .topbar-mobile-clean{min-height:52px;padding:8px 10px;border-radius:18px}
.driver-task-page .driver-task-navstate{display:flex;align-items:center;justify-content:center;flex:1;text-align:center;font-weight:900;font-size:.95rem}
.driver-task-page .full-map-shell{top:70px;bottom:122px}
.driver-overlay-card{left:8px;right:8px;bottom:8px;top:auto;max-height:none;padding:12px 14px;border-radius:22px;background:rgba(255,255,255,.96);box-shadow:0 12px 28px rgba(17,17,17,.12)}
.driver-overlay-card.compact-card{padding:12px 14px}
.driver-overlay-hero.slim{gap:10px}
.driver-overlay-title.slim{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.driver-overlay-sub{font-size:.8rem;color:#666;line-height:1.3;margin-top:3px}
.driver-overlay-meta.compact{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.driver-meta-pill{background:#f5f5f5;border-radius:14px;padding:10px}
.driver-meta-pill span{display:block;font-size:.72rem;color:#777;margin-bottom:3px}
.driver-meta-pill strong{display:block;font-size:.84rem;line-height:1.25}
.driver-follow-pill.compact{padding:8px 10px;border-radius:999px;background:#111;color:#fff;font-weight:900;font-size:.82rem;white-space:nowrap}
.driver-task-dock{left:8px;right:8px;bottom:8px;border-radius:22px;padding:12px 14px;max-height:36vh;overflow:auto}
@media (max-width:640px){
  .customer-bottom-nav{max-height:min(44vh,380px)}
  .driver-route-strip{top:66px}
  .driver-dashboard-page .driver-bottom-sheet.only-sheet .section{max-height:min(34vh,270px)}
}

/* v3.2.24 compact driver/customer refresh */
.driver-topbar-compact{padding:8px 10px;min-height:56px;border-radius:18px;background:rgba(255,255,255,.94);box-shadow:0 10px 24px rgba(17,17,17,.1)}
.driver-topbar-compact.is-request,.driver-topbar-compact.is-task{background:#2f80ed;color:#fff}
.driver-topbar-compact.is-request .driver-topbar-meta strong,.driver-topbar-compact.is-request .driver-topbar-meta span,.driver-topbar-compact.is-request .driver-nav-link,.driver-topbar-compact.is-request .theme-switch-icon span{color:#fff!important}
.driver-topbar-compact.is-request .driver-nav-link,.driver-topbar-compact.is-request .theme-switch-icon{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.18)}
.driver-topbar-compact.is-task .driver-topbar-meta strong,.driver-topbar-compact.is-task .driver-topbar-meta span,.driver-topbar-compact.is-task .driver-nav-link,.driver-topbar-compact.is-task .theme-switch-icon span{color:#fff!important}
.driver-topbar-compact.is-task .driver-nav-link,.driver-topbar-compact.is-task .theme-switch-icon{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.18)}
.driver-route-strip.slim{position:fixed;top:70px;left:12px;right:12px;z-index:35;padding:7px 10px;border-radius:16px;background:rgba(255,255,255,.92);box-shadow:0 10px 24px rgba(17,17,17,.08);pointer-events:none}
.driver-route-strip-inner.single-line{display:grid;grid-template-columns:1fr 1fr;gap:8px;align-items:center}
.driver-sheet-compact{bottom:10px;padding:0 10px 10px;background:transparent;pointer-events:none}
.driver-sheet-card{padding:10px;border-radius:24px;background:rgba(255,255,255,.86);backdrop-filter:blur(16px);box-shadow:0 18px 40px rgba(17,17,17,.12);pointer-events:auto;max-height:min(24vh,220px);overflow:auto}
.driver-request-list{display:grid;gap:10px}
.ride-request-card{padding:14px 16px;border-radius:22px;background:#fff;border:1px solid rgba(17,17,17,.08);box-shadow:0 8px 20px rgba(17,17,17,.06);display:grid;gap:10px}
.ride-request-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.ride-request-head strong{display:block;font-size:1rem}.ride-request-head span{display:block;color:var(--muted);font-size:.86rem;font-weight:700}
.ride-request-badge{padding:8px 12px;border-radius:999px;background:#f3f7ff;color:#2f80ed;font-weight:900;white-space:nowrap}
.ride-request-route{font-weight:800;line-height:1.35}
.compact-slide-wrap{gap:6px}.compact-slide-wrap .small{text-align:center}
.accept-slider{width:100%}
.driver-live-card{padding:12px 14px;border-radius:22px;background:#fff;border:1px solid rgba(17,17,17,.08);box-shadow:0 10px 24px rgba(17,17,17,.08);display:grid;gap:8px;margin-bottom:8px}
.driver-live-card-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.driver-live-card-top strong{display:block;font-size:1rem}.driver-live-card-top span{display:block;color:var(--muted);font-weight:700}.driver-live-chip{padding:8px 12px;border-radius:999px;background:#f4f5f6;font-weight:900;white-space:nowrap}
.driver-live-sub{font-weight:800;color:#2f80ed}.driver-live-actions{display:flex;gap:8px}.driver-live-actions .btn-danger{min-height:48px}
.customer-bottom-nav-compact{left:10px;right:10px;bottom:10px;padding:10px 10px 12px;border-radius:28px;max-height:min(32vh,280px);overflow:auto;background:rgba(255,255,255,.96);box-shadow:0 18px 44px rgba(17,17,17,.14)}
.customer-bottom-nav-compact .customer-sheet-handle{margin:0 auto 6px}
.customer-hero-time.compact{font-size:1rem;font-weight:900;text-align:center;margin:2px 0 6px}
.compact-search-card,.compact-driver-card,.compact-route-card{padding:12px 14px;border-radius:20px}
.compact-route-card{margin-bottom:8px}
.customer-route-stack.only-two{gap:10px}
.offer-price-inline{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 0 0;font-weight:800}.offer-price-inline strong{font-size:1.1rem}.muted-inline{color:var(--muted)}
.colorful-avatar{background:linear-gradient(135deg,#ffd29b,#ff8b6a);color:#111}.color-chip{background:#fff3d6;color:#6b4a00}.color-emoji{filter:none!important}
.compact-actions{margin-top:6px}.compact-actions .message-pill,.compact-actions .icon-action-pill{min-height:44px}
.driver-car-hero.color-emoji,.tile-icon,.driver-car-hero,.message-pill,.icon-action-pill{filter:none!important}
.customer-action-tile .tile-icon{filter:none!important}
.color-marker{filter:none!important}
.taxi-marker.color-marker,.pickup-marker,.dropoff-marker{filter:none}
.status-navbar,.active-navbar,.status-navbar.card.compact-card.active-navbar{display:none!important}
@media (max-width:720px){
  .driver-topbar-compact{padding:8px 10px;min-height:58px}
  .driver-route-strip.slim{top:64px;left:8px;right:8px;padding:7px 9px}
  .driver-route-strip-inner.single-line{grid-template-columns:1fr;gap:6px}
  .driver-sheet-card{max-height:min(22vh,190px);padding:8px}
  .customer-bottom-nav-compact{left:8px;right:8px;bottom:8px;max-height:min(34vh,300px);padding:10px}
  .driver-live-actions{display:grid;grid-template-columns:1fr}
}


/* v3.2.26 driver cleanup */
.driver-dashboard-page.driver-task-page{padding-bottom:0!important;overflow:visible!important}
.driver-ambient-map,.driver-shell{position:fixed;inset:0}
.driver-dashboard-page .topbar-floating{top:8px;left:8px;right:8px;position:fixed;z-index:50}
.driver-topbar-compact{min-height:52px!important;padding:8px 10px!important;display:flex;align-items:center;justify-content:space-between;gap:10px}
.driver-topbar-compact .driver-topbar-meta{display:grid;gap:2px;min-width:0}
.driver-topbar-compact .driver-topbar-meta strong{font-size:.98rem;line-height:1.05}
.driver-topbar-compact .driver-topbar-meta span{font-size:.78rem;line-height:1.05;opacity:.9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:42vw}
.driver-topbar-compact.is-ready{background:linear-gradient(135deg,#13a94c,#0f8f41);color:#fff;animation:readyGlow 2.2s ease-in-out infinite}
.driver-topbar-compact.is-ready .driver-nav-link,.driver-topbar-compact.is-ready .theme-switch-icon{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.2)}
.driver-topbar-compact.is-ready .driver-nav-link,.driver-topbar-compact.is-ready .theme-switch-icon span,.driver-topbar-compact.is-ready .driver-topbar-meta strong,.driver-topbar-compact.is-ready .driver-topbar-meta span{color:#fff!important}
.driver-topbar-compact.is-request,.driver-topbar-compact.is-task{background:linear-gradient(135deg,#2f80ed,#1f5fd1)!important;color:#fff;animation:requestGlow 2s ease-in-out infinite}
.driver-route-strip.slim{top:68px!important;padding:6px 10px!important;background:rgba(255,255,255,.9)!important;border-radius:14px!important}
.driver-route-strip-line strong{font-size:.76rem!important}
.driver-sheet-compact{pointer-events:none;left:8px;right:8px;bottom:8px;position:fixed;z-index:48}
.driver-sheet-card{pointer-events:auto;max-height:min(22vh,190px)!important;overflow:auto;border-radius:22px!important;background:rgba(255,255,255,.92)!important}
.driver-live-card,.ride-request-card{border-radius:18px!important}
.driver-live-card-top span,.ride-request-head span{font-size:.8rem!important}
.driver-live-chip{background:#eef4ff!important;color:#1f5fd1}
.driver-ready-state{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:18px;background:linear-gradient(135deg,#13a94c,#0f8f41);color:#fff;box-shadow:0 10px 28px rgba(19,169,76,.24)}
.driver-ready-state strong{display:block;font-size:1rem;line-height:1.1}.driver-ready-state span{display:block;font-size:.8rem;opacity:.95}
.driver-ready-dot{width:12px;height:12px;border-radius:50%;background:#fff;box-shadow:0 0 0 0 rgba(255,255,255,.65);animation:driverPulse 1.8s infinite}
.driver-radar-marker .map-radar-driver i{background:#111!important}
.driver-radar-marker .map-radar-driver span{border-color:rgba(47,128,237,.42)!important}
.customer-bottom-nav-compact{resize:vertical;overflow:auto;min-height:138px;max-height:min(40vh,360px)!important;padding-top:8px!important}
.customer-bottom-nav-compact .customer-sheet-handle{margin:0 auto 8px!important}
.customer-bottom-nav-compact .customer-panel-card:last-child{margin-bottom:0}
.customer-hero-time.compact{margin:0 0 8px!important}
.colorful-avatar{background:linear-gradient(135deg,#ffc46a,#ff8a65)!important;color:#111!important}
.driver-car-hero.color-emoji,.message-pill,.icon-action-pill,.driver-rating-chip.color-chip{filter:none!important}
.driver-rating-chip.color-chip{background:#fff4cf!important;color:#5f4700!important}
@keyframes readyGlow{0%,100%{box-shadow:0 10px 24px rgba(19,169,76,.18)}50%{box-shadow:0 14px 32px rgba(19,169,76,.32)}}
@keyframes requestGlow{0%,100%{box-shadow:0 10px 24px rgba(47,128,237,.18)}50%{box-shadow:0 14px 32px rgba(47,128,237,.3)}}
@media (max-width:720px){
  .driver-topbar-compact .driver-topbar-meta span{max-width:48vw}
  .driver-route-strip.slim{top:64px!important}
  .driver-sheet-card{max-height:min(24vh,200px)!important}
}

.search-results button strong{display:block;font-size:.97rem;line-height:1.35}
.search-results button span{display:block;margin-top:4px;color:var(--muted);font-size:.84rem;line-height:1.35}


/* v3.2.27 driver dashboard unlock */
.driver-dashboard-page.driver-task-page{
  position:fixed!important;
  inset:0!important;
  min-height:100dvh!important;
  width:100%!important;
  height:100dvh!important;
  padding:0!important;
  margin:0!important;
  overflow:visible!important;
  background:transparent!important;
  pointer-events:none!important;
  z-index:40!important;
}
.driver-dashboard-page.driver-task-page > *{pointer-events:none}
.driver-dashboard-page.driver-task-page .topbar-floating,
.driver-dashboard-page.driver-task-page .topbar-floating *,
.driver-dashboard-page.driver-task-page #driverRouteStrip,
.driver-dashboard-page.driver-task-page #driverRouteStrip *,
.driver-dashboard-page.driver-task-page #driverSheet,
.driver-dashboard-page.driver-task-page #driverSheet *,
.driver-dashboard-page.driver-task-page .driver-sheet-card,
.driver-dashboard-page.driver-task-page .driver-sheet-card *,
.driver-dashboard-page.driver-task-page button,
.driver-dashboard-page.driver-task-page a,
.driver-dashboard-page.driver-task-page input,
.driver-dashboard-page.driver-task-page select,
.driver-dashboard-page.driver-task-page label{
  pointer-events:auto!important;
}
.driver-dashboard-page.driver-task-page #driverSheet{background:transparent!important}
.driver-dashboard-page.driver-task-page .driver-sheet-compact{pointer-events:none!important}
.driver-dashboard-page.driver-task-page .driver-sheet-card{pointer-events:auto!important}
.driver-dashboard-page.driver-task-page .driver-route-strip.slim{pointer-events:none!important}


/* v3.3 ride compact emphasis */
.customer-bottom-nav-compact{padding:12px 12px 14px!important;max-height:min(42vh,380px)!important}
.customer-hero-time.compact,.customer-hero-time.compact.hero-time-strong{font-size:1.22rem!important;line-height:1.15!important;font-weight:950!important;letter-spacing:-.01em!important;margin:2px 0 10px!important}
.fare-highlight{display:grid!important;grid-template-columns:1fr auto;align-items:center;gap:10px 14px;padding:12px 14px!important;margin-top:4px;border-radius:18px;background:linear-gradient(135deg,#111,#262626)!important;color:#fff!important;box-shadow:0 12px 30px rgba(17,17,17,.22)!important;border:1px solid rgba(255,255,255,.08)!important}
.fare-highlight .fare-label{display:block;font-size:.82rem;font-weight:800;letter-spacing:.02em;text-transform:uppercase;opacity:.82;color:#f1f1f1!important}
.fare-highlight strong{display:block;font-size:1.6rem!important;line-height:1;font-weight:950;color:#fff!important;white-space:nowrap}
@media (max-width:720px){
  .customer-hero-time.compact,.customer-hero-time.compact.hero-time-strong{font-size:1.28rem!important}
  .fare-highlight{padding:13px 14px!important}
  .fare-highlight strong{font-size:1.72rem!important}
}


/* Liman61 yellow theme overrides */
:root{--bg:#ffffff;--surface:#ffffff;--surface-strong:#ffffff;--text:#111111;--muted:#5d5d5d;--line:#ece7d5;--soft:#fff8d9;--green:#0f8a4a;--accent:#f7c600;--accent-soft:#fff4b8;--warn:#8a6100;--shadow:0 16px 40px rgba(17,17,17,.08)}
body{background:#fff}
.btn,.btn-home-primary,.nav-cta{background:var(--accent)!important;color:#111!important;box-shadow:0 14px 30px rgba(247,198,0,.28)!important}
.btn-secondary,.btn-ghost,.nav a,.nav button,.theme-switch,.chip,.payment-tile,.vehicle-card,.card,.section,.hero-mini,.hero-panel,.notice,.status-pill{border-color:#eee2a8!important}
.eyebrow,.chip-more,.notice-success{background:#fff8d9!important;color:#111!important}
.theme-switch,.nav a,.nav button{background:#fffdf5!important;color:#111!important}
.topbar-mobile-clean{background:rgba(255,255,255,.92)!important}
.brand-logo-image img{height:44px;width:auto;display:block}
.brand-logo-only{padding:0!important;background:transparent!important;border:none!important;box-shadow:none!important}
.brand-mark,.brand-copy,.nav-admin{display:none!important}
.topbar-liman .nav{margin-left:auto}
.topbar-liman .nav a,.topbar-liman .nav button,.topbar-liman .theme-switch-icon{width:46px;height:46px;display:grid;place-items:center;padding:0;border-radius:999px}
.journey-sheet{position:fixed;left:12px;right:12px;bottom:12px;z-index:40;background:rgba(255,255,255,.98);border:1px solid #eee2a8;border-radius:28px;box-shadow:0 18px 46px rgba(17,17,17,.16);padding:18px;display:grid;gap:14px;transform:translateY(130%) scale(.985);transform-origin:bottom center;opacity:0;filter:blur(8px);pointer-events:none;will-change:transform,opacity,filter;transition:transform .82s cubic-bezier(.18,.84,.18,1),opacity .52s ease,filter .62s ease}
.journey-sheet:not(.hidden){transform:translateY(0) scale(1);opacity:1;filter:blur(0);pointer-events:auto}
.journey-sheet.hidden{display:grid!important}
.journey-payment-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.payment-option{display:flex;align-items:center;gap:10px;text-align:left;background:#fff;border:1px solid var(--line)}
.payment-option.active{border-color:#f7c600!important;background:#fff8d9!important;box-shadow:0 0 0 3px rgba(247,198,0,.14)}
.vehicle-card-top span{font-weight:900;color:#111}
.vehicle-card-meta span::before{margin-right:6px}
.vehicle-card-meta span:first-child::before{content:'👤'}
.vehicle-card-meta span:last-child::before{content:'⏱️'}
.customer-radar-marker .map-radar,.customer-radar-blue{width:132px;height:132px}
.customer-radar-marker .map-radar i,.customer-radar-blue i{width:64px;height:64px;border-radius:50%;background:#2f80ed!important;color:#fff!important;font-size:1.7rem;display:grid;place-items:center;box-shadow:0 10px 28px rgba(47,128,237,.35)}
.customer-radar-marker .map-radar span,.customer-radar-blue span{border-color:rgba(47,128,237,.42)!important;animation:taxiRadar 2.3s infinite}
.customer-radar-marker .map-radar span:nth-child(1),.customer-radar-blue span:nth-child(1){inset:20px}
.customer-radar-marker .map-radar span:nth-child(2),.customer-radar-blue span:nth-child(2){inset:6px;animation-delay:.4s}
.customer-radar-marker .map-radar span:nth-child(3),.customer-radar-blue span:nth-child(3){inset:-8px;animation-delay:.8s}
@keyframes taxiRadar{0%{transform:scale(.72);opacity:.88}100%{transform:scale(1.2);opacity:0}}
.waiting-dots::after{content:'...';display:inline-block;animation:dots 1.4s steps(4,end) infinite}
@keyframes dots{0%{content:''}25%{content:'.'}50%{content:'..'}75%,100%{content:'...'}}
.wallet-card{background:#fff8d9;border:1px solid #f1dc79!important}
.wallet-card .price{color:#111}


/* part2 fixes */
.customer-hero-time.compact.hero-time-strong{font-size:1rem!important;line-height:1.12!important;margin:0 0 8px!important;letter-spacing:-.01em!important}
.customer-search-card .offer-price-inline.fare-highlight{padding:10px 12px!important;border-radius:16px;background:#fff8d9!important;color:#111!important;box-shadow:none!important;border:1px solid #eee2a8!important}
.customer-search-card .fare-highlight .fare-label{color:#6a6a6a!important;opacity:1!important;font-size:.76rem!important}
.customer-search-card .fare-highlight strong{font-size:1rem!important;color:#111!important;font-weight:900!important;white-space:normal!important}
.customer-search-card .payment-method-inline{margin-top:10px;padding:10px 12px;border-radius:14px;background:#fff;border:1px solid #eee2a8;font-weight:800;color:#111;display:flex;align-items:center;justify-content:space-between;gap:12px}
.customer-search-card .payment-method-inline span{color:#6a6a6a;font-size:.82rem;font-weight:700}
.waiting-dots::after{animation:dots 2.4s steps(4,end) infinite}
.btn,.btn-home-primary,.nav-cta{box-shadow:none!important}
.driver-quote-form{display:grid;gap:12px}
.driver-quote-actions{display:flex;gap:10px;align-items:center}
.driver-quote-send{min-width:140px}
.ride-request-form{display:grid;gap:10px;margin-top:10px}
.ride-request-inline{display:grid;grid-template-columns:1fr 1fr auto;gap:8px;align-items:end}
.ride-request-inline .field{margin:0}
.ride-request-inline .btn{height:48px}
.ride-request-help{font-size:.84rem;color:#666;font-weight:700}
@media (max-width:720px){.ride-request-inline{grid-template-columns:1fr}.customer-hero-time.compact.hero-time-strong{font-size:.98rem!important}}


/* part 3 cleanup overrides */
.page{padding-top:108px!important}
.customer-dashboard-page{padding-top:108px!important}
.page-ride-minimal{padding-top:108px!important}
.driver-dashboard-page{padding-top:88px!important}
.topbar-mobile-clean,.topbar-floating{top:10px;left:10px;right:10px;box-shadow:0 8px 22px rgba(17,17,17,.06)!important}
.topbar-mobile-clean + .page-shell,.topbar + .page-shell{margin-top:6px}
.home-booking-card,.compact-card{scroll-margin-top:120px}
:root{--accent:#f7c600!important;--accent-soft:#fff6c9!important;--accent-ink:#111!important;--line:#ece7d5!important}
.btn,.btn-home-primary,.btn-accent,.nav-cta,button.btn,.btn[type=submit]{background:#f7c600!important;color:#111!important;box-shadow:none!important;border:1px solid #e3b700!important}
.btn:hover,.btn-home-primary:hover,.btn-accent:hover,.nav-cta:hover{filter:none!important;background:#efbe00!important}
.eyebrow,.chip-more,.notice-success,.payment-option.active,.vehicle-card.active,.wallet-card,.customer-search-card .offer-price-inline.fare-highlight{background:#fff!important;color:#111!important;box-shadow:none!important}
.payment-option.active,.vehicle-card.active,.wallet-card,.customer-search-card .offer-price-inline.fare-highlight,.notice-success{border-color:#e3b700!important}
.journey-filter.active{background:#f7c600!important;color:#111!important;border-color:#e3b700!important}
.theme-switch,.nav a,.nav button{background:#fff!important}
@media (max-width:720px){.page,.customer-dashboard-page,.page-ride-minimal{padding-top:96px!important}.driver-dashboard-page{padding-top:76px!important}.topbar-mobile-clean,.topbar-floating{top:8px;left:8px;right:8px}}

.map-image-marker{filter:none!important}
.taxi-png-marker{filter:none!important}
.customer-png-marker{filter:none!important}


/* part6 driver dashboard visibility fix */
.driver-dashboard-page #driverTaskInline,
.driver-dashboard-page #openRequests{display:block!important;visibility:visible!important;opacity:1!important}
.driver-dashboard-page .driver-sheet-card{max-height:min(42vh,420px)!important;overflow:auto!important}
.driver-dashboard-page #driverTaskInline:empty{display:none!important}
.driver-inline-hint{display:grid;gap:4px;padding:12px 4px 2px;color:#555;font-size:.95rem}
.driver-inline-hint strong{color:#111;font-size:.96rem}
.driver-inline-hint span{color:#666}

.driver-wallet-card{display:grid;gap:14px;padding:18px;border-radius:24px;margin-bottom:14px}
.wallet-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.wallet-card-head strong{display:block;font-size:1.08rem;line-height:1.15}
.wallet-chip{display:inline-flex;align-items:center;padding:10px 14px;border-radius:999px;background:#111;color:#fff;font-weight:800;font-size:.86rem}
.wallet-balance-row{display:grid;grid-template-columns:minmax(0,180px) minmax(0,1fr);gap:16px;align-items:start}
.wallet-balance-row small{display:block;color:#666;font-weight:800;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.wallet-meta-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.wallet-meta-grid div{padding:12px 14px;border-radius:18px;background:#fff;border:1px solid rgba(17,17,17,.08);display:grid;gap:4px}
.wallet-meta-grid label{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:#777;font-weight:800}
.wallet-meta-grid strong{font-size:.98rem;line-height:1.2}
.wallet-footnote{font-size:.84rem;color:#666;font-weight:700}
@media (max-width:720px){.wallet-card-head,.wallet-balance-row{grid-template-columns:1fr}.wallet-chip{justify-content:center}.wallet-meta-grid{grid-template-columns:1fr 1fr}}
