:root{
  --navy:#0B1C3D;
  --green:#7ED321;
  --green2:#9BEF2F;
  --bg:#F7F9FB;
  --card:#FFFFFF;
  --stroke:#E5E7EB;
  --muted:#6B7280;
  --shadow:0 12px 32px rgba(11,28,61,.15);
  --radius:16px;
  --font: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--font);
  background:var(--bg);
  color:var(--navy);
}

a{color:inherit}
.container{max-width:1200px;margin:auto;padding:20px}
.small{font-size:12px;color:var(--muted)}
.muted{color:var(--muted)}
.badge{
  padding:6px 10px;border-radius:999px;border:1px solid var(--stroke);
  background:rgba(11,28,61,.03);font-size:12px;color:var(--navy)
}

/* HEADER / NAV */
header{
  background:#fff;
  border-bottom:1px solid var(--stroke);
  position:sticky; top:0; z-index:10;
}
.header-inner{
  max-width:1200px;
  margin:auto;
  padding:12px 20px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
  color:inherit;
  min-width:200px;
}
.logo{
  width:38px;height:38px;border-radius:12px;
  background:linear-gradient(135deg,var(--green),var(--green2));
  display:flex;align-items:center;justify-content:center;
  font-weight:900;
}
.brand span{font-weight:900; letter-spacing:.2px}
.nav{
  display:flex; gap:12px; flex-wrap:wrap; align-items:center; justify-content:flex-end;
}
.nav a{
  text-decoration:none;
  font-size:13px;
  padding:8px 10px;
  border-radius:12px;
  border:1px solid transparent;
}
.nav a:hover{border-color:var(--stroke); background:rgba(11,28,61,.02)}
.nav .cta{
  background:linear-gradient(135deg,var(--green),var(--green2));
  border-color:transparent;
  font-weight:900;
}

/* QUICK PICKUP / DROP-OFF (matches light theme) */
.quicktrip{
  background:#fff;
  border-bottom:1px solid var(--stroke);
}
.quicktrip-inner{
  max-width:1200px;
  margin:auto;
  padding:12px 20px;
  display:grid;
  grid-template-columns:1fr 1fr auto;
  gap:12px;
  align-items:end;
}
.quicktrip .qt-field label{
  display:block;
  font-size:12px;
  color:var(--muted);
  margin-bottom:6px;
}
.quicktrip .qt-field input{
  width:100%;
  padding:12px;
  border-radius:12px;
  border:1px solid var(--stroke);
  font-size:14px;
  background:#fff;
  color:var(--navy);
  outline:none;
}
.quicktrip .qt-actions{
  display:flex;
  gap:10px;
  align-items:stretch;
}
.quicktrip .qt-actions .btn,
.quicktrip .qt-actions a.btn{
  width:auto;
  margin-top:0;
  padding:12px 14px;
  border-radius:14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  white-space:nowrap;
}
.quicktrip-note{
  max-width:1200px;
  margin:auto;
  padding:0 20px 12px;
  font-size:12px;
  color:var(--muted);
}
@media(max-width:860px){
  .quicktrip-inner{grid-template-columns:1fr;}
  .quicktrip .qt-actions{width:100%;}
  .quicktrip .qt-actions .btn,
  .quicktrip .qt-actions a.btn{flex:1;}
}

/* HERO */
.hero{
  display:flex;
  gap:18px;
  align-items:flex-start;
  justify-content:space-between;
  margin-top:8px;
  flex-wrap:wrap;
}
.hero h1{margin:0 0 8px;font-size:28px}
.hero p{margin:0;color:var(--muted)}
.hero .hero-left{flex:1; min-width:280px}
.hero .hero-right{display:flex; gap:10px; flex-wrap:wrap; align-items:center}

/* LAYOUT */
.layout{
  display:grid;
  grid-template-columns:420px 1fr;
  gap:20px;
  margin-top:18px;
}
@media(max-width:900px){
  .layout{grid-template-columns:1fr}
  .brand{min-width:auto}
}

/* CARD */
.card{
  background:var(--card);
  border:1px solid var(--stroke);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:20px;
}
.card h2{margin:0 0 8px}
.sub{color:var(--muted); font-size:14px; margin:0 0 16px}

/* FORM */
.form-group{margin-bottom:14px}
label{
  font-size:12px;
  color:var(--muted);
  display:block;
  margin-bottom:6px;
}
input,select,textarea{
  width:100%;
  padding:12px;
  border-radius:12px;
  border:1px solid var(--stroke);
  font-size:14px;
  background:#fff;
  color:var(--navy);
}
textarea{min-height:110px; resize:vertical}
.row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
@media(max-width:900px){
  .row{grid-template-columns:1fr}
}

/* RIDE TYPES */
.rides{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
}
.ride{
  border:1px solid var(--stroke);
  border-radius:14px;
  padding:12px;
  cursor:pointer;
  user-select:none;
  background:#fff;
}
.ride.active{
  border-color:var(--green);
  background:rgba(126,211,33,.12);
}
.ride strong{display:block;font-size:13px}
.ride span{font-size:12px;color:var(--muted)}

/* ESTIMATE */
.estimate{
  margin-top:14px;
  padding:14px;
  border:1px solid var(--stroke);
  border-radius:14px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  background:#fff;
}
.estimate b{font-size:20px}

/* NOTICE */
.notice{
  margin-top:10px;
  padding:12px 14px;
  border:1px solid var(--stroke);
  border-radius:14px;
  background:#fff;
  color:var(--muted);
  font-size:13px;
}

/* BUTTONS */
.btn{
  width:100%;
  margin-top:16px;
  padding:14px;
  border:none;
  border-radius:14px;
  background:linear-gradient(135deg,var(--green),var(--green2));
  color:var(--navy);
  font-weight:900;
  font-size:15px;
  cursor:pointer;
}
.btn.secondary{
  background:#fff;
  border:1px solid var(--stroke);
  color:var(--navy);
}
.btn.inline{width:auto; margin-top:0}
.btn:active{transform:translateY(1px)}

/* MAP */
.map{
  background:#fff;
  border:1px solid var(--stroke);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  min-height:520px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  color:var(--muted);
  padding:20px;
  gap:10px;
}

/* FOOTER */
footer{
  margin-top:28px;
  padding:18px 0;
  border-top:1px solid var(--stroke);
  color:var(--muted);
  font-size:13px;
}
.footer-inner{
  max-width:1200px;
  margin:auto;
  padding:0 20px;
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap
}
