/* 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; }
}
/* ===========================
   ✅ MOBILE FIX (compact UI)
   Add at the VERY END of booking.css
=========================== */
@media (max-width: 768px){

  /* Page layout: reduce padding */
  .wrap, .grid{
    padding: 12px !important;
    gap: 14px !important;
  }

  /* If you have left banner + form in grid, stack clean */
  .grid{
    grid-template-columns: 1fr !important;
  }

  /* Titles: avoid huge text on mobile */
  h1{
    font-size: 34px !important;
    line-height: 1.1 !important;
    margin: 14px 0 12px !important;
  }
  h2{
    font-size: 22px !important;
    line-height: 1.2 !important;
    margin: 14px 0 10px !important;
  }

  /* Common “Step 1: Journey Details” style (covers many builders) */
  .step-title, .wizard-title, .form-title, .title, .heading{
    font-size: 34px !important;
    line-height: 1.1 !important;
    margin: 14px 0 12px !important;
  }

  /* Trip buttons (One Way / Round Trip): smaller + stack */
  .trip-type, .trip-options, .radio-group, .btn-group, .toggle-group{
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
  }

  /* Inputs/select: less “giant” */
  select, input, textarea{
    height: 48px !important;
    font-size: 16px !important;
    padding: 10px 12px !important;
    border-radius: 14px !important;
  }

  /* Buttons: smaller */
  button, .btn, .button{
    padding: 12px 14px !important;
    font-size: 16px !important;
    border-radius: 14px !important;
  }

  /* Reduce extra spacing between blocks */
  .section, .block, .field, .form-row, .row{
    margin-bottom: 12px !important;
  }
}

@media (max-width: 420px){
  h1, .step-title, .wizard-title, .form-title, .title, .heading{
    font-size: 30px !important;
  }
}
/* =========================================
   ✅ MOBILE: shrink/compact the whole form
   Paste at the VERY END of assets/css/booking.css
========================================= */
@media (max-width: 768px){

  /* 1) Reduce overall scale (best effect) */
  body{
    zoom: .92;                 /* Chrome/Android */
  }
  .wrap, .grid, .right, .form, form{
    transform: scale(.92);     /* iPhone/Safari */
    transform-origin: top center;
  }

  /* 2) Make big titles smaller */
  h1, .step-title, .wizard-title, .form-title, .title, .heading{
    font-size: 30px !important;
    line-height: 1.12 !important;
    margin: 12px 0 10px !important;
  }

  /* 3) Buttons One Way / Round Trip smaller */
  button, .btn, .button{
    font-size: 15px !important;
    padding: 10px 12px !important;
    border-radius: 12px !important;
  }

  /* 4) Inputs/select smaller */
  select, input, textarea{
    height: 44px !important;
    font-size: 15px !important;
    padding: 9px 12px !important;
    border-radius: 12px !important;
  }

  /* 5) Reduce spacing */
  .row, .form-row, .field, .section, .block{
    margin-bottom: 10px !important;
  }
}

@media (max-width: 420px){
  body{ zoom:.90; }
  .wrap, .grid, .right, .form, form{ transform: scale(.90); }

  h1, .step-title, .wizard-title, .form-title, .title, .heading{
    font-size: 28px !important;
  }
}


