/* Autoriders Booking — Public Styles */
:root{
  --red:#E0301E; --red-deep:#B41E0F; --red-tint:#FBEAE7;
  --ink:#14161B; --slate:#5A626E; --slate-2:#8B92A0;
  --mist:#F6F7F9; --panel:#FFFFFF; --line:#E6E9EF; --line-2:#EFF1F5;
  --ok:#15994A; --ok-tint:#E6F4EC; --gold:#B8923F;
  --shadow:0 1px 2px rgba(20,22,27,.04),0 12px 34px -14px rgba(20,22,27,.18);
  --shadow-lg:0 30px 70px -30px rgba(20,22,27,.45);
  --r:14px; --r-sm:10px;
  --disp:"Bricolage Grotesque",ui-sans-serif,system-ui,sans-serif;
  --body:"Inter",ui-sans-serif,system-ui,sans-serif;
  --mono:"Space Mono",ui-monospace,monospace;
}
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:var(--body);color:var(--ink);background:var(--mist);-webkit-font-smoothing:antialiased;line-height:1.5}
.wrap{max-width:1180px;margin:0 auto;padding:0 20px}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input{font-family:inherit}

/* ── Topbar ──────────────────────────────────────────────── */
.topbar{background:#fff;border-bottom:1px solid var(--line)}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:70px;gap:16px}
.logo{display:flex;align-items:center;flex:0 0 auto;text-decoration:none}
.logo img{height:50px;width:auto;display:block}
.sitenav{display:flex;align-items:center;gap:2px;flex:1;justify-content:center}
.sitenav a{font-size:13.5px;font-weight:500;color:var(--ink);padding:7px 12px;border-radius:8px;text-decoration:none;transition:.16s;white-space:nowrap}
.sitenav a:hover{color:var(--red);background:var(--red-tint)}
.sitenav a.current{color:var(--red);font-weight:600}
.contact-btn{display:inline-flex;align-items:center;gap:7px;background:var(--red);color:#fff;font-weight:600;font-size:13.5px;border-radius:999px;padding:10px 20px;text-decoration:none;transition:.16s;white-space:nowrap;flex:0 0 auto;box-shadow:0 8px 20px -8px var(--red)}
.contact-btn:hover{background:var(--red-deep)}
.contact-btn svg{width:14px;height:14px;flex:0 0 auto}
@media(max-width:960px){.sitenav{display:none}}
@media(max-width:560px){.contact-btn span{display:none}}

/* ── Hero ────────────────────────────────────────────────── */
.hero{padding:40px 0 0}
.hero h1{font-family:var(--disp);font-weight:800;letter-spacing:-.03em;line-height:1.02;font-size:clamp(30px,5vw,52px);margin:0 0 10px}
.hero h1 em{font-style:normal;color:var(--red)}
.hero p{margin:0;color:var(--slate);font-size:15.5px;max-width:560px}
.trustrow{display:flex;gap:22px;flex-wrap:wrap;margin-top:18px}
.trust{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--slate);font-weight:500}
.trust svg{color:var(--red)}

/* ── Console grid ────────────────────────────────────────── */
.console{margin:26px 0 60px;display:grid;grid-template-columns:1fr 348px;gap:22px;align-items:start}
@media(max-width:920px){.console{grid-template-columns:1fr}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow)}

/* ── Steps ───────────────────────────────────────────────── */
.steps{display:flex;align-items:center;gap:6px;padding:16px 22px;border-bottom:1px solid var(--line-2);overflow:auto}
.step{display:flex;align-items:center;gap:9px;color:var(--slate-2);font-size:13px;font-weight:600;white-space:nowrap}
.step .dot{width:24px;height:24px;border-radius:50%;border:1.5px solid var(--line);display:grid;place-items:center;font-size:12px;background:#fff;transition:.25s}
.step.active{color:var(--ink)}.step.active .dot{background:var(--ink);border-color:var(--ink);color:#fff}
.step.done .dot{background:var(--ok);border-color:var(--ok);color:#fff}.step.done{color:var(--ink)}
.step .bar{width:22px;height:1.5px;background:var(--line)}
@media(max-width:680px){.step .lbl{display:none}.step .bar{width:14px}}

/* ── Panes ───────────────────────────────────────────────── */
.pane{padding:24px 22px 26px;display:none;animation:rise .35s cubic-bezier(.2,.7,.2,1)}
.pane.on{display:block}
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.pane h2{font-family:var(--disp);font-weight:700;letter-spacing:-.02em;font-size:21px;margin:0 0 3px}
.pane .sub{color:var(--slate);font-size:13.5px;margin:0 0 18px}

/* ── Trip tabs ───────────────────────────────────────────── */
.triptabs{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;background:var(--mist);padding:5px;border-radius:12px;margin-bottom:18px}
.triptab{padding:11px 6px;border-radius:9px;font-weight:600;font-size:13.5px;color:var(--slate);display:flex;align-items:center;justify-content:center;gap:8px;transition:.18s}
.triptab svg{width:18px;height:18px}
.triptab.on{background:var(--red);color:#fff;box-shadow:0 8px 20px -8px var(--red)}
@media(max-width:560px){.triptab{flex-direction:column;gap:4px}.triptab .t{font-size:11.5px}}
.subtabs{display:inline-flex;gap:4px;background:var(--mist);padding:4px;border-radius:10px;margin:-6px 0 16px}
.subtab{padding:8px 18px;border-radius:7px;font-size:13px;font-weight:600;color:var(--slate);transition:.16s}
.subtab.on{background:var(--red);color:#fff;box-shadow:0 6px 16px -6px var(--red)}

/* ── Fields ──────────────────────────────────────────────── */
.fieldgrid{display:grid;grid-template-columns:1fr 1fr;gap:14px;position:relative}
@media(max-width:560px){.fieldgrid{grid-template-columns:1fr}}
.field{position:relative}
.field label{display:block;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--slate-2);margin-bottom:7px}
.ctrl{display:flex;align-items:center;gap:9px;border:1px solid var(--line);border-radius:var(--r-sm);padding:0 12px;height:46px;background:#fff;transition:.18s}
.ctrl:focus-within{border-color:var(--red);box-shadow:0 0 0 3px var(--red-tint)}
.ctrl svg{color:var(--slate-2);flex:0 0 auto}
.ctrl input{border:none;outline:none;width:100%;font-size:14.5px;color:var(--ink);background:none}
.ctrl input::placeholder{color:var(--slate-2)}
.swap{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:3;width:34px;height:34px;border-radius:50%;background:#fff;border:1px solid var(--line);display:none;place-items:center;color:var(--red);box-shadow:var(--shadow)}
.swap:hover{background:var(--red);color:#fff;border-color:var(--red)}
.dt{display:grid;grid-template-columns:1.3fr 1fr;gap:10px}
.dtgroup{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:560px){.dtgroup{grid-template-columns:1fr}}

/* ── Autocomplete (custom fallback) ─────────────────────── */
.ac{position:absolute;z-index:30;top:74px;left:0;right:0;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);max-height:280px;overflow:auto;display:none}
.ac.open{display:block}
.ac .head{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--slate-2);font-weight:700;padding:11px 14px 6px;display:flex;align-items:center;justify-content:space-between}
.ac .opt{display:flex;align-items:center;gap:11px;padding:9px 14px;font-size:14px;color:var(--ink);cursor:pointer}
.ac .opt:hover{background:var(--mist)}
.ac .opt .pin{width:26px;height:26px;border-radius:7px;background:var(--mist);display:grid;place-items:center;color:var(--red);flex:0 0 auto}
.ac .opt .txt{overflow:hidden}
.ac .opt .txt b{font-weight:600}
.ac .opt small{display:block;color:var(--slate-2);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px}
.ac .opt .air{margin-left:auto;font-size:10px;font-weight:700;color:var(--gold);border:1px solid #EADfc4;background:#FBF6EA;border-radius:6px;padding:2px 6px;flex:0 0 auto}
.ac .note{padding:9px 14px;font-size:12.5px;color:var(--slate-2);display:flex;align-items:center;gap:8px}
.spin-sm{width:13px;height:13px;border:2px solid var(--line);border-top-color:var(--red);border-radius:50%;animation:sp .7s linear infinite}

/* ── Google Places pac-container override ───────────────── */
.pac-container{
  background:#fff !important;
  border:1px solid var(--line) !important;
  border-radius:12px !important;
  box-shadow:0 8px 30px -8px rgba(20,22,27,.22),0 2px 8px -2px rgba(20,22,27,.08) !important;
  margin-top:4px !important;
  font-family:var(--body) !important;
  z-index:99999 !important;
  pointer-events:auto !important;
  overflow:hidden !important;
}
.pac-container::after{display:none !important}
.pac-item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 14px !important;
  font-size:13.5px !important;
  color:var(--ink) !important;
  cursor:pointer !important;
  border-top:1px solid var(--line-2) !important;
  line-height:1.4 !important;
  pointer-events:auto !important;
}
.pac-item:first-child{border-top:none !important}
.pac-item:hover,.pac-item-selected{background:var(--mist) !important}
.pac-item-query{
  font-size:13.5px !important;
  color:var(--ink) !important;
  font-weight:600 !important;
  padding-right:4px !important;
}
.pac-matched{color:var(--red) !important;font-weight:700 !important}
.pac-icon,.pac-icon-marker{
  background-image:none !important;
  width:20px !important;
  height:20px !important;
  flex:0 0 auto;
  background:#F6F7F9 !important;
  border-radius:6px !important;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23E0301E' stroke-width='2.5'%3E%3Cpath d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E") !important;
  background-repeat:no-repeat !important;
  background-position:center !important;
  background-size:12px !important;
}

/* ── Map ─────────────────────────────────────────────────── */
.maprow{margin-top:18px;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
#map{height:240px;width:100%;background:#e8eaf0}
.maptag{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 14px;background:#fff;border-top:1px solid var(--line-2);font-size:12.5px;color:var(--slate)}
.maptag b{color:var(--ink)}
.gmapnote{font-size:11px;color:var(--slate-2);white-space:nowrap}
.eta{display:inline-flex;align-items:center;gap:5px;color:var(--slate)}
.grouplbl{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--slate-2);margin:18px 0 8px}

/* ── Cars ────────────────────────────────────────────────── */
.cars{display:grid;gap:12px}
.carcard{display:grid;grid-template-columns:64px 1fr auto;gap:14px;align-items:center;border:1.5px solid var(--line);border-radius:var(--r);padding:14px;transition:.18s;cursor:pointer;background:#fff}
.carcard:hover{border-color:var(--slate-2)}
.carcard.on{border-color:var(--red);box-shadow:0 0 0 3px var(--red-tint)}
.carcard .ill{width:64px;height:46px;display:grid;place-items:center;background:var(--mist);border-radius:10px;color:var(--ink)}
.carcard.on .ill{background:var(--red-tint);color:var(--red)}
.carcard .name{font-family:var(--disp);font-weight:700;font-size:16px;letter-spacing:-.01em}
.carcard .meta{font-size:12.5px;color:var(--slate);margin-top:2px}
.carcard .tags{display:flex;gap:6px;margin-top:7px;flex-wrap:wrap}
.tag{font-size:11px;font-weight:600;color:var(--slate);background:var(--mist);border-radius:6px;padding:2px 7px}
.carcard .price{text-align:right}
.carcard .price .amt{font-family:var(--disp);font-weight:800;font-size:19px}
.carcard .price .unit{font-size:11px;color:var(--slate-2);font-weight:600}
.lux .ill{background:#FBF6EA;color:var(--gold)}.lux.on .ill{background:#FBF6EA;color:var(--gold)}

/* ── Drive mode cards ────────────────────────────────────── */
.modecards{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:560px){.modecards{grid-template-columns:1fr}}
.modecard{position:relative;border:1.5px solid var(--line);border-radius:14px;padding:18px;cursor:pointer;transition:.18s;background:#fff}
.modecard:hover{border-color:var(--slate-2)}
.modecard.on{border-color:var(--red);box-shadow:0 0 0 3px var(--red-tint)}
.modecard.disabled{opacity:.45;cursor:not-allowed;pointer-events:none}
.modecard .mi{width:44px;height:44px;border-radius:12px;background:var(--mist);display:grid;place-items:center;color:var(--ink);margin-bottom:12px}
.modecard.on .mi{background:var(--red-tint);color:var(--red)}
.modecard h4{font-family:var(--disp);font-weight:700;font-size:17px;margin:0 0 4px}
.modecard p{font-size:12.5px;color:var(--slate);margin:0 0 10px;min-height:34px}
.modecard .ph{font-size:12.5px;font-weight:700;color:var(--ink)}
.modecard .ph small{font-weight:500;color:var(--slate-2)}
.modecard .chk{position:absolute;top:14px;right:14px;width:20px;height:20px;border-radius:50%;border:1.5px solid var(--line);display:grid;place-items:center;color:#fff}
.modecard.on .chk{background:var(--red);border-color:var(--red)}
.modecard.on .chk svg{display:block}.modecard .chk svg{display:none}
.modenote{margin-top:14px;font-size:12.5px;color:var(--slate);background:var(--mist);border-radius:10px;padding:11px 14px;display:none}
.modenote.show{display:flex;gap:8px;align-items:flex-start}
.modenote svg{color:var(--red);flex:0 0 auto;margin-top:1px}

/* ── Stack / form ────────────────────────────────────────── */
.stack{display:grid;gap:14px}
.ctrl.lg{height:48px}

/* ── Rail ────────────────────────────────────────────────── */
.rail{position:sticky;top:18px}
.rail .head{padding:18px 20px 12px;border-bottom:1px solid var(--line-2)}
.rail .head .k{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--slate-2)}
.meter{display:flex;align-items:baseline;gap:7px;margin-top:6px}
.meter .cur{font-family:var(--disp);font-weight:800;font-size:20px;color:var(--ink)}
.odo{display:flex;font-family:var(--mono);font-weight:700;font-size:34px;letter-spacing:.01em;color:var(--ink);line-height:1}
.odo .digit{position:relative;width:1ch;height:1em;overflow:hidden}
.odo .roll{position:absolute;left:0;top:0;display:flex;flex-direction:column;transition:transform .5s cubic-bezier(.2,.8,.2,1)}
.odo .roll span{height:1em;display:flex;align-items:center}
.odo .comma{width:.34ch}
.rail .sum{padding:14px 20px}
.line{display:flex;justify-content:space-between;font-size:13.5px;padding:7px 0;color:var(--slate)}
.line b{color:var(--ink);font-weight:600}
.line.muted{color:var(--slate-2)}
.rail hr{border:none;border-top:1px dashed var(--line);margin:8px 0}
.total{display:flex;justify-content:space-between;align-items:baseline;padding:12px 0 4px}
.total .t{font-weight:700;font-size:14px}
.total .v{font-family:var(--disp);font-weight:800;font-size:22px}
.railfoot{padding:0 20px 20px}
.pill{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;color:var(--ok);background:var(--ok-tint);border-radius:999px;padding:5px 11px;margin-top:4px}
.empty{color:var(--slate-2);font-size:13.5px;padding:14px;text-align:center;border:1px dashed var(--line);border-radius:12px}

/* ── Nav buttons ─────────────────────────────────────────── */
.navrow{display:flex;gap:10px;margin-top:22px}
.btn{height:48px;border-radius:11px;font-weight:700;font-size:14.5px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 20px;transition:.16s}
.btn-primary{background:var(--red);color:#fff;box-shadow:0 12px 24px -12px var(--red);flex:1}
.btn-primary:hover{background:var(--red-deep)}
.btn-primary:disabled{background:var(--line);color:var(--slate-2);box-shadow:none;cursor:not-allowed}
.btn-ghost{border:1px solid var(--line);color:var(--ink);background:#fff}
.btn-ghost:hover{background:var(--mist)}
.spin{width:18px;height:18px;border-radius:50%;border:2.5px solid rgba(255,255,255,.4);border-top-color:#fff;animation:sp .7s linear infinite;display:inline-block}
@keyframes sp{to{transform:rotate(360deg)}}
@keyframes pop{from{transform:scale(.3);opacity:0}to{transform:scale(1);opacity:1}}

/* ── API error ───────────────────────────────────────────── */
.api-error{background:var(--red-tint);border:1px solid var(--red);border-radius:10px;padding:12px 14px;font-size:13.5px;color:var(--red-deep);font-weight:500;margin-top:14px}

/* ── Done screen ─────────────────────────────────────────── */
.done{text-align:center;padding:40px 22px 30px;display:none;animation:rise .4s}
.done.on{display:block}
.tick2{width:74px;height:74px;border-radius:50%;background:var(--ok-tint);display:grid;place-items:center;margin:0 auto 16px;color:var(--ok)}
.tick2 svg{animation:pop .5s cubic-bezier(.2,1.4,.4,1)}
.done h2{font-family:var(--disp);font-weight:800;font-size:25px;margin:0 0 6px}
.done p{color:var(--slate);font-size:14px;margin:0 auto;max-width:380px}
.ticket{margin:22px auto 0;max-width:440px;text-align:left;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.ticket .th{background:var(--ink);color:#fff;padding:13px 18px;display:flex;justify-content:space-between;align-items:center;font-size:13px}
.ticket .th b{font-family:var(--mono);letter-spacing:.04em}
.ticket .tb{padding:6px 18px 14px}
.trow{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--line-2);font-size:13.5px}
.trow:last-child{border:none}
.trow .k{color:var(--slate)}.trow .v{font-weight:600;text-align:right}

/* ── Footer ──────────────────────────────────────────────── */
.footnote{text-align:center;color:var(--slate-2);font-size:12px;padding:0 0 40px}

/* ── Mobile (≤480px) ─────────────────────────────────────── */
@media(max-width:480px){
  /* Topbar */
  .topbar .wrap{height:56px;padding:0 14px}
  .logo img{height:36px}
  .contact-btn{padding:9px 12px;border-radius:10px;box-shadow:none}
  .contact-btn span{display:none}
  .contact-btn svg{width:16px;height:16px}

  /* Hero */
  .hero{padding:20px 0 0}
  .hero h1{font-size:clamp(24px,7vw,34px);margin-bottom:8px}
  .hero p{font-size:13.5px;line-height:1.55}
  .trustrow{gap:10px;margin-top:12px}
  .trust{font-size:12px;gap:6px}

  /* Layout */
  .wrap{padding:0 12px}
  .console{margin:14px 0 36px;gap:12px}

  /* Steps — tighter */
  .steps{padding:10px 12px;gap:2px}
  .step .dot{width:22px;height:22px;font-size:11px;flex-shrink:0}
  .step .bar{width:10px;flex-shrink:0}

  /* Pane */
  .pane{padding:16px 14px 18px}
  .pane h2{font-size:17px}
  .pane .sub{font-size:12.5px;margin-bottom:12px}

  /* Trip tabs — flex with equal widths, icon only */
  .triptabs{display:flex;padding:4px;gap:4px}
  .triptab{flex:1;min-width:0;padding:10px 4px;font-size:11px;gap:0;flex-direction:column}
  .triptab .t{display:none}
  .triptab svg{width:20px;height:20px}

  /* Sub-tabs */
  .subtabs{margin:-4px 0 12px}
  .subtab{padding:7px 14px;font-size:12.5px}

  /* Fields */
  .ctrl{height:44px;padding:0 10px}

  /* Date/time — keep 2-col at 480, inner side-by-side */
  .dt{grid-template-columns:1fr 1fr}
  .dtgroup{grid-template-columns:1fr}

  /* Map tag — stack on mobile */
  .maptag{flex-direction:column;align-items:flex-start;gap:2px;padding:8px 12px}
  .gmapnote{white-space:normal;font-size:10.5px}
  #map{height:200px}

  /* Car cards */
  .carcard{grid-template-columns:48px 1fr;grid-template-rows:auto auto;gap:8px;padding:12px}
  .carcard .ill{width:48px;height:38px;grid-row:1/3}
  .carcard .name{font-size:14px}
  .carcard .price{grid-column:2;text-align:left;display:flex;align-items:baseline;gap:6px}
  .carcard .price .amt{font-size:16px}
  .carcard .price .unit{font-size:10.5px}
  .carcard .tags{gap:4px;margin-top:5px}
  .tag{font-size:10.5px}

  /* Drive mode cards */
  .modecard{padding:14px}
  .modecard h4{font-size:15px}
  .modecard p{font-size:12px}

  /* Nav buttons */
  .navrow{flex-wrap:wrap;margin-top:16px;gap:8px}
  .navrow .btn-ghost{flex:1 0 100%;order:-1}
  .btn{height:46px;font-size:14px}

  /* Rail */
  .rail{position:static}
  .rail .head{padding:12px 14px 10px}
  .rail .sum{padding:8px 14px}
  .railfoot{padding:0 14px 14px}
  .odo{font-size:28px}
  .meter .cur{font-size:17px}

  /* Modals → bottom sheet */
  .modal-backdrop.open{align-items:flex-end}
  .modal-box{border-radius:20px 20px 0 0;max-height:90vh;overflow-y:auto}
}

/* ── Very small (≤360px) ─────────────────────────────────── */
@media(max-width:360px){
  .contact-btn{display:none}
  .hero h1{font-size:22px}
  .dt{grid-template-columns:1fr}
  .triptab svg{width:18px;height:18px}
  .triptab{padding:10px 4px}
  .step .dot{width:20px;height:20px;font-size:10px}
  .step .bar{width:6px}
}
