/* assets/css/booking.css ✅ FINAL */
:root{
  --bg:#0f2320;
  --gold:#d4af37;
  --card:#ffffff;
  --muted:#6b7280;
  --text:#111827;
  --line:#e5e7eb;
  --err:#ef4444;
}

*{box-sizing:border-box}
body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial;
  background:#f6f7f8;
  color:var(--text);
}

.wrap{max-width:1100px;margin:auto;padding:18px}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:18px}
.left,.right{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px}

.hidden{display:none !important}

/* Tabs */
.tabs{display:flex;gap:8px;margin-bottom:14px}
.tab{
  flex:1;
  border:1px solid var(--line);
  background:#fff;
  padding:10px;
  border-radius:12px;
  font-weight:800;
  cursor:pointer;
}
.tab.active{
  border-color:var(--gold);
  box-shadow:0 0 0 2px rgba(212,175,55,.20) inset;
}

/* Steps */
.step{display:none}
.step.active{display:block}
.step h2{
  margin:0 0 14px;
  font-size:28px;
  font-weight:900;
  letter-spacing:-.3px;
}

/* Labels & Inputs */
label{display:block;font-weight:800;margin:10px 0 6px}

input,select,textarea{
  width:100%;
  padding:10px 12px;
  border:1px solid var(--line);
  border-radius:12px;
  outline:none;
  background:#fff;
}

input:focus,select:focus,textarea:focus{
  border-color:#cbd5e1;
  box-shadow:0 0 0 3px rgba(212,175,55,.14);
}

input.err,select.err,textarea.err{border-color:var(--err)}

.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-top:10px}

@media (max-width: 900px){
  .grid{grid-template-columns:1fr}
}

/* Price bar */
.pricebar{
  display:flex;
  flex-direction:column;
  gap:6px;
  margin-top:12px;
  padding:12px;
  border-radius:12px;
  background:#f9fafb;
  border:1px solid var(--line);
}
.smallHint{font-size:12px;color:#6b7280}

/* Buttons */
.actions{display:flex;gap:10px;margin-top:14px}
.btn{
  border:1px solid var(--line);
  background:#fff;
  padding:12px 14px;
  border-radius:12px;
  font-weight:900;
  cursor:pointer;
}
.btn.primary{
  background:var(--gold);
  border-color:var(--gold);
  color:#111;
}

/* Vehicles */
.vehicles{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.veh-card{
  position:relative;
  border:1px solid var(--line);
  border-radius:14px;
  padding:12px;
  background:#fff;
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:12px;
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.veh-card:hover{transform:translateY(-1px)}
.veh-card img{
  width:92px;
  height:56px;
  object-fit:contain;
  border-radius:10px;
  border:1px solid #eee;
  background:#fff;
}
.veh-title{font-weight:900;font-size:18px;line-height:1.1}
.veh-sub{font-size:12px;color:var(--muted);margin-top:4px;font-weight:700}
.veh-card.is-selected{
  border-color:var(--gold) !important;
  box-shadow:0 0 0 3px rgba(212,175,55,.20) !important;
}

/* Left Banner (image top, text bottom) */
.leftBanner{padding:0 !important; overflow:hidden}
.leftBannerImg{
  width:100%;
  height:260px;
  object-fit:cover;
  display:block;
}
.leftBannerText{padding:18px}
.leftBannerText h1{
  margin:0 0 10px 0;
  font-size:22px;
  font-weight:900;
  line-height:1.2;
}
.leftBannerText p{margin:0 0 10px 0;line-height:1.45;color:#111827}
.leftBannerContact{margin-top:12px;font-weight:900}
.leftBannerContact a{color:inherit;text-decoration:none}
.leftBannerContact a:hover{text-decoration:underline}

/* Trip pills (desktop + mobile) */
.tripRow{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin:6px 0 14px;
}
.tripPill{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 10px;
  border:1px solid #d1d5db;
  border-radius:14px;
  background:#fff;
  cursor:pointer;
  font-weight:900;
}
.tripPill input{
  width:auto;
  margin:0;
  transform:scale(1.15);
}
.tripPill span{
  display:block;
  line-height:1;
  white-space:nowrap;
}
.tripPill.is-selected{
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(212,175,55,.18) inset;
}

/* =========================
   MOBILE (clean like competitor)
========================= */
@media (max-width: 760px){

  body{background:#fff !important;}

  /* hide left */
  .left{display:none !important;}

  .wrap{padding:12px}
  .right{padding:0 !important;border:none !important;background:transparent !important}

  /* tabs off */
  .tabs{display:none !important}

  /* title center */
  .step h2{
    text-align:center;
    font-size:34px;
    margin:8px 0 18px;
  }

  /* layouts */
  .row2{grid-template-columns:1fr !important}
  .row3{grid-template-columns:1fr !important}

  label{font-size:18px;font-weight:900}

  select,
  input[type="text"], input[type="email"], input[type="tel"],
  input[type="date"], input[type="time"]{
    height:54px;
    border-radius:12px;
    border:1px solid #d1d5db;
    background:#eeeeee;
    padding:0 14px;
    font-size:18px;
  }

  /* vehicle squares */
  .vehicles{grid-template-columns:1fr 1fr !important; gap:14px !important}
  .veh-card{
    flex-direction:column !important;
    justify-content:center !important;
    text-align:center !important;
    gap:10px !important;
    min-height:170px !important;
    padding:14px !important;
    border-radius:16px !important;
    border:2px solid #d1d5db !important;
  }
  .veh-card img{
    width:120px !important;
    height:78px !important;
    border:none !important;
    background:transparent !important;
  }
  .veh-title{font-size:22px !important}
  .veh-sub{font-size:14px !important;color:#374151 !important;opacity:.9 !important}

  /* price box */
  .pricebar{
    background:#fff !important;
    border:1px solid #e5e7eb !important;
    border-radius:14px !important;
    padding:14px !important;
    font-size:18px !important;
    font-weight:900 !important;
  }

  /* buttons */
  .actions{gap:14px !important}
  .btn{
    border-radius:14px !important;
    padding:14px 18px !important;
    font-size:20px !important;
  }
  .btn.primary{
    border:none !important;
    padding:14px 22px !important;
    font-size:20px !important;
  }
}
/* 3 columns row (Luggages / Child / Booster) */
.row3{
  display:grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap:14px;
}

/* Notes textarea */
textarea{
  min-height:140px;
  resize:vertical;
  padding:14px;
  border-radius:14px;
}

/* Mobile: stack columns */
@media (max-width:760px){
  .row3{ grid-template-columns:1fr; }
}
