cat > /home/ec2-user/limo_app_folder/static/css/style.css <<'CSS'
/* RESET */

*, *::before, *::after {
  box-sizing: border-box;
}
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

/* BODY – Best Buy style */
body {
  font-family: Arial, Helvetica, sans-serif;
  background-color: #F0F2F5; /* light gray */
  color: #000000;
}

/* NAVBAR */
.navbar {
  background-color: #FFFFFF;
  border-bottom: 1px solid #DADDE1;
  padding: 16px 0;
}

.nav-container {
  width: 90%;
  max-width: 1400px;
  margin: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* LOGO */
.logo {
  font-size: 22px;
  font-weight: bold;
  color: #0046BE; /* Best Buy blue */
}

/* NAV LINKS */
.nav-links a {
  margin: 0 12px;
  text-decoration: none;
  color: #000000;
  font-size: 14px;
}

.nav-links a:hover {
  text-decoration: underline;
}

/* PHONE BUTTON */
.phone-btn {
  background-color: #0046BE;
  color: #FFFFFF;
  padding: 10px 18px;
  border-radius: 4px;
  text-decoration: none;
  font-weight: bold;
  font-size: 14px;
}

.phone-btn:hover {
  background-color: #00339A;
}

/* HERO */
.hero {
  background: #FFFFFF;
  padding: 30px 0;
}

.hero-container {
  width: 90%;
  max-width: 1400px;
  margin: auto;
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 24px;
  align-items: start;
}

.hero-image-placeholder {
  height: 420px;
  border: 1px solid #DADDE1;
  border-radius: 8px;
  background: #F0F2F5;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #6B7280;
  font-weight: bold;
}

.hero-box {
  background: #FFFFFF;
  border: 1px solid #DADDE1;
  border-radius: 8px;
  padding: 18px;
}

.hero-box h1 {
  font-size: 22px;
  margin-bottom: 6px;
}

.hero-box p {
  font-size: 14px;
  color: #444;
  margin-bottom: 14px;
}

.booking-form label {
  display: block;
  font-size: 12px;
  font-weight: bold;
  margin: 10px 0 6px;
}

.booking-form input {
  width: 100%;
  padding: 10px;
  border: 1px solid #DADDE1;
  border-radius: 6px;
  background: #FFFFFF;
  font-size: 14px;
}

.two-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.primary-btn {
  margin-top: 14px;
  width: 100%;
  background: #0046BE;
  color: #FFFFFF;
  border: none;
  border-radius: 6px;
  padding: 12px;
  font-weight: bold;
  cursor: pointer;
}

.primary-btn:hover {
  background: #00339A;
}
CSS






/* SERVICES SECTION (Best Buy style) */
.services {
  background: #F0F2F5;
  padding: 40px 0;
}

.services-container {
  width: 90%;
  max-width: 1400px;
  margin: auto;
}

.section-title {
  font-size: 22px;
  margin-bottom: 20px;
}

.services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.service-card {
  background: #FFFFFF;
  border: 1px solid #DADDE1;
  border-radius: 8px;
  padding: 16px;
}

.service-image {
  height: 160px;
  background: #F0F2F5;
  border: 1px solid #DADDE1;
  border-radius: 6px;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #6B7280;
  font-weight: bold;
}

.service-card h3 {
  font-size: 16px;
  margin-bottom: 6px;
}

.service-card p {
  font-size: 14px;
  color: #444;
}

/* FLEET SECTION (Best Buy style) */
.fleet {
  background: #FFFFFF;
  padding: 40px 0;
}

.fleet-container {
  width: 90%;
  max-width: 1400px;
  margin: auto;
}

.fleet-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

.fleet-card {
  background: #FFFFFF;
  border: 1px solid #DADDE1;
  border-radius: 8px;
  padding: 16px;
}

.fleet-image {
  height: 160px;
  background: #F0F2F5;
  border: 1px solid #DADDE1;
  border-radius: 6px;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #6B7280;
  font-weight: bold;
}

.secondary-btn {
  margin-top: 12px;
  width: 100%;
  background: #FFFFFF;
  color: #0046BE;
  border: 1px solid #0046BE;
  border-radius: 6px;
  padding: 10px;
  font-weight: bold;
  cursor: pointer;
}

.secondary-btn:hover {
  background: #EAF1FF;
}



/* TESTIMONIALS */
.testimonials {
  background: #F0F2F5;
  padding: 40px 0;
}

.testimonials-container {
  width: 90%;
  max-width: 1400px;
  margin: auto;
}

.testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.testimonial-card {
  background: #FFFFFF;
  border: 1px solid #DADDE1;
  border-radius: 8px;
  padding: 16px;
  font-size: 14px;
}



/* FOOTER (Best Buy style) */
.site-footer {
  background: #FFFFFF;
  border-top: 1px solid #DADDE1;
  margin-top: 30px;
}

.footer-container {
  width: 90%;
  max-width: 1400px;
  margin: auto;
  padding: 30px 0;
  display: grid;
  grid-template-columns: 1.2fr 0.6fr 0.8fr 1fr;
  gap: 20px;
}

.footer-logo {
  font-size: 22px;
  font-weight: bold;
  color: #0046BE;
  margin-bottom: 8px;
}

.site-footer h4 {
  font-size: 14px;
  margin-bottom: 10px;
}

.site-footer a {
  display: block;
  color: #000000;
  text-decoration: none;
  font-size: 14px;
  margin: 6px 0;
}

.site-footer a:hover {
  text-decoration: underline;
}

.footer-text {
  font-size: 14px;
  color: #444;
  margin: 6px 0;
}

.footer-map {
  height: 140px;
  background: #F0F2F5;
  border: 1px solid #DADDE1;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #6B7280;
  font-weight: bold;
}

.footer-bottom {
  text-align: center;
  padding: 14px 0;
  border-top: 1px solid #DADDE1;
  font-size: 13px;
  color: #444;
}


/* QUOTE CONFIRMATION PAGE */
.quote-page {
  background: #F0F2F5;
  padding: 40px 0;
}

.quote-container {
  width: 90%;
  max-width: 800px;
  margin: auto;
}

.quote-card {
  background: #FFFFFF;
  border: 1px solid #DADDE1;
  border-radius: 8px;
  padding: 22px;
}

.quote-card h1 {
  font-size: 22px;
  margin-bottom: 8px;
}

.quote-sub {
  color: #444;
  font-size: 14px;
  margin-bottom: 16px;
}

.quote-details {
  border-top: 1px solid #DADDE1;
  padding-top: 14px;
}

.quote-row {
  display: flex;
  justify-content: space-between;
  padding: 10px 0;
  border-bottom: 1px solid #F0F2F5;
  font-size: 14px;
}

.quote-btn {
  display: inline-block;
  margin-top: 16px;
  text-align: center;
  text-decoration: none;
}


/* QUOTE PAGE (Best Buy style) */
.quote-page {
  background: #F0F2F5;
  padding: 40px 0;
}

.quote-container {
  width: 90%;
  max-width: 800px;
  margin: auto;
}

.quote-card {
  background: #FFFFFF;
  border: 1px solid #DADDE1;
  border-radius: 8px;
  padding: 22px;
}

.quote-card h1 {
  font-size: 22px;
  margin-bottom: 8px;
}

.quote-sub {
  font-size: 14px;
  color: #444;
  margin-bottom: 16px;
}

.quote-details {
  border-top: 1px solid #DADDE1;
  padding-top: 12px;
}

.quote-row {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 10px 0;
  border-bottom: 1px solid #F0F2F5;
  font-size: 14px;
}

.quote-row span {
  color: #444;
}

.quote-actions {
  margin-top: 16px;
}

.quote-btn {
  display: inline-block;
  text-decoration: none;
  text-align: center;
}


/* ==============================
   BOOKING FORM GRID (Screenshot Layout)
   ============================== */

.booking-form .form-row {
  display: grid;
  gap: 12px;
  margin-top: 12px;
}

.booking-form .form-row.three-cols {
  grid-template-columns: repeat(3, 1fr);
}

.booking-form .form-row.two-cols {
  grid-template-columns: repeat(2, 1fr);
}

.booking-form .form-group label {
  display: block;
  font-size: 12px;
  font-weight: bold;
  margin: 0 0 6px;
}

.booking-form .form-group input,
.booking-form .form-group select {
  width: 100%;
  padding: 10px;
  border: 1px solid #DADDE1;
  border-radius: 6px;
  background: #FFFFFF;
  font-size: 14px;
}

/* Make the form match screenshot on mobile (stack) */
@media (max-width: 900px) {
  .booking-form .form-row.three-cols,
  .booking-form .form-row.two-cols {
    grid-template-columns: 1fr;
  }
}


.booking-form input,
.booking-form select {
  width: 100%;
  height: 44px;
}



/* =========================
   ADMIN (Quotes Dashboard)
   ========================= */
.admin-page {
  padding: 30px 0;
}

.admin-container {
  width: 90%;
  max-width: 1400px;
  margin: auto;
}

.admin-header {
  background: #ffffff;
  border: 1px solid #DADDE1;
  border-radius: 10px;
  padding: 16px 18px;
  margin-bottom: 14px;
}

.admin-header h1 {
  font-size: 22px;
  margin-bottom: 4px;
}

.admin-sub {
  font-size: 13px;
  color: #555;
}

.admin-table-wrap {
  background: #ffffff;
  border: 1px solid #DADDE1;
  border-radius: 10px;
  overflow: auto;
}

.admin-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 1100px;
}

.admin-table th,
.admin-table td {
  border-bottom: 1px solid #EEF0F2;
  padding: 12px 10px;
  font-size: 13px;
  vertical-align: top;
}

.admin-table th {
  background: #F7F8FA;
  font-weight: bold;
  text-align: left;
  position: sticky;
  top: 0;
}

.admin-table .mono {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

.admin-table .center {
  text-align: center;
}

.admin-table .muted {
  color: #666;
  font-size: 12px;
}

.admin-route-line {
  margin-bottom: 4px;
}

.admin-actions {
  display: flex;
  gap: 8px;
  align-items: center;
}

.admin-actions form {
  margin: 0;
}

.admin-btn {
  display: inline-block;
  padding: 8px 10px;
  border-radius: 6px;
  border: 1px solid #DADDE1;
  background: #FFFFFF;
  text-decoration: none;
  color: #111;
  font-size: 13px;
  cursor: pointer;
}

.admin-btn:hover {
  background: #F7F8FA;
}

.admin-btn.danger {
  border-color: #F1B4B4;
  background: #FFF5F5;
}

.admin-btn.danger:hover {
  background: #FFECEC;
}

.empty {
  text-align: center;
  padding: 18px;
  color: #666;
}

/* Detail card */
.admin-card {
  background: #ffffff;
  border: 1px solid #DADDE1;
  border-radius: 10px;
  padding: 18px;
}

.admin-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}

.admin-field span {
  display: block;
  font-size: 12px;
  color: #666;
  margin-bottom: 6px;
}

.admin-field strong {
  display: block;
  font-size: 14px;
  color: #111;
}

.admin-detail-actions {
  display: flex;
  gap: 10px;
  margin-top: 16px;
}



/* =========================
   ADMIN LOGIN PAGE
========================= */

.admin-login-page {
  padding: 40px 16px;
}

.admin-login-wrap {
  max-width: 520px;
  margin: 0 auto;
}

.admin-login-card {
  background: #ffffff;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 16px;
  padding: 24px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.08);
}

.admin-login-title {
  margin: 0 0 6px;
  font-size: 28px;
}

.admin-login-subtitle {
  margin-bottom: 18px;
  opacity: 0.7;
}

.admin-login-alert {
  background: rgba(220,53,69,0.08);
  border: 1px solid rgba(220,53,69,0.25);
  color: #b02a37;
  padding: 12px 14px;
  border-radius: 12px;
  margin-bottom: 14px;
  font-weight: 600;
}

.admin-login-form {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.admin-field label {
  display: block;
  margin-bottom: 6px;
  font-weight: 700;
}

.admin-field input {
  width: 100%;
  padding: 12px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,0.2);
  font-size: 16px;
}

.admin-field input:focus {
  border-color: #0d6efd;
  box-shadow: 0 0 0 4px rgba(13,110,253,0.12);
  outline: none;
}

.admin-login-btn {
  width: 100%;
  padding: 12px;
  border-radius: 12px;
  font-size: 16px;
  font-weight: 800;
  cursor: pointer;
}

.admin-login-help {
  text-align: center;
  margin-top: 6px;
}

.admin-login-help a {
  text-decoration: none;
  font-weight: 700;
}



/* Admin Topbar */
.admin-topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin: 20px 0;
}

.admin-title{
  margin:0;
  font-size: 24px;
}

.admin-logout-btn{
  display:inline-block;
  padding:10px 14px;
  border-radius:10px;
  text-decoration:none;
  border:1px solid #ddd;
  font-weight:600;
}

.admin-logout-btn:hover{
  opacity:0.9;
}

/* ===== Reserve (Centered card layout) ===== */
.reserve-page{
  background:#f4f6f8;
  padding:40px 0 60px;
}

.reserve-shell{
  width:min(1100px, 92%);
  margin:0 auto;
}

.reserve-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-bottom:18px;
}

.reserve-link{
  color:#1b5cff;
  font-weight:600;
  text-decoration:none;
}

.reserve-banner{
  flex:1;
  display:flex;
  justify-content:center;
}
.reserve-banner img{
  max-width:420px;
  width:100%;
  border-radius:10px;
  border:1px solid #e6e8eb;
}

.reserve-card{
  background:#fff;
  border:1px solid #e6e8eb;
  border-radius:16px;
  padding:22px;
  box-shadow:0 12px 28px rgba(0,0,0,0.07);
}

.reserve-title{ margin:0; font-size:40px; color:#111; }
.reserve-subtitle{ margin:6px 0 18px; color:#555; }

.reserve-step{
  border:1px solid #eef0f2;
  border-radius:14px;
  padding:16px;
  margin-bottom:12px;
  background:#fff;
}
.reserve-step h2{ margin:0 0 14px; font-size:20px; }

.reserve-step.muted{ opacity:.65; }

.reserve-grid{
  display:grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap:16px;
  align-items:start;
}

.reserve-form{ display:flex; flex-direction:column; gap:12px; }

.form-row label{ display:block; font-size:14px; font-weight:600; margin-bottom:6px; color:#333; }

.reserve-form input,
.reserve-form select{
  width:100%;
  padding:12px;
  border:1px solid #d8dde3;
  border-radius:10px;
  font-size:15px;
}

.form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}

.reserve-map{
  border:1px solid #e6e8eb;
  border-radius:14px;
  overflow:hidden;
  height:340px;
}
.reserve-map iframe{
  width:100%;
  height:100%;
  border:0;
}

.btn-primary{
  margin-top:6px;
  width:fit-content;
  padding:12px 18px;
  border-radius:12px;
  border:none;
  background:#1b5cff;
  color:#fff;
  font-weight:700;
  cursor:pointer;
}

@media (max-width: 800px){
  .reserve-grid{ grid-template-columns:1fr; }
  .reserve-map{ height:260px; }
  .reserve-title{ font-size:32px; }
}


/* Fix form touching map */
.reserve-form {
  padding-right: 12px;
}

/* Extra safety on mobile */
@media (max-width: 800px) {
  .reserve-form {
    padding-right: 0;
    margin-bottom: 16px;
  }
}


/* Reserve Page */
.reserve-page { background:#f5f6f8; padding: 28px 0 40px; }
.reserve-wrap { max-width: 1100px; margin: 0 auto; padding: 0 16px; }

.reserve-title { margin: 0; font-size: 34px; }
.reserve-subtitle { margin: 6px 0 18px; color: #555; }

.reserve-steps { display:flex; gap:10px; margin: 16px 0 18px; }
.reserve-steps .step {
  flex:1; padding: 12px 12px; border-radius: 10px;
  background:#fff; border:1px solid #e6e6e6; font-weight:600; color:#777;
}
.reserve-steps .step.active { border-color:#1f6feb; color:#1f6feb; }

.reserve-grid {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 16px;
  align-items: start;
}

.reserve-card, .summary-card {
  background:#fff; border:1px solid #e6e6e6; border-radius: 12px;
  padding: 16px;
}

.card-title { margin: 0 0 8px; font-size: 20px; }
.card-subtitle { margin: 0 0 14px; color:#666; }

.reserve-map iframe { border-radius: 12px; }

.reserve-error {
  background:#fff3f3; border:1px solid #ffd0d0; color:#a10000;
  padding: 10px 12px; border-radius: 10px; margin: 10px 0 14px;
}

/* Buttons */
.btn-primary {
  background:#1f6feb; color:#fff; border:none; cursor:pointer;
  border-radius: 8px; padding: 12px 14px; font-weight: 700;
}
.btn-primary:hover { opacity: .95; }

.btn-outline {
  width: 100%;
  background:#fff; border:1px solid #1f6feb; color:#1f6feb;
  border-radius: 8px; padding: 10px 12px; font-weight: 700; cursor:pointer;
}
.btn-outline:hover { background:#f3f8ff; }

.link-back { color:#1f6feb; text-decoration:none; font-weight:600; }
.reserve-actions { margin-top: 12px; }

/* Step 2 Vehicles */
.vehicle-grid { display:grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }

.vehicle-card {
  border:1px solid #e6e6e6; border-radius: 12px; padding: 14px;
  background:#fff;
}
.vehicle-head { display:flex; justify-content:space-between; gap: 10px; margin-bottom: 8px; }
.vehicle-name { font-weight: 800; }
.vehicle-price { font-weight: 800; color:#1f6feb; }
.vehicle-meta { display:flex; gap: 12px; color:#666; font-size: 14px; margin: 10px 0 12px; }

/* Summary */
.summary-title { margin: 0 0 10px; font-size: 18px; }
.summary-row { display:flex; justify-content:space-between; gap:10px; padding: 8px 0; border-bottom: 1px solid #f0f0f0; }
.summary-row:last-child { border-bottom:none; }

/* Mobile */
@media (max-width: 900px) {
  .reserve-grid { grid-template-columns: 1fr; }
  .vehicle-grid { grid-template-columns: 1fr; }
}


/* ===== Reserve Success Page ===== */
.page-wrap {
  padding: 60px 16px;
  background: #f5f7fb;
}

.page-wrap .container {
  max-width: 900px;
  margin: 0 auto;
}

.page-wrap .card {
  background: #ffffff;
  border-radius: 14px;
  padding: 28px 32px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.08);
}

.page-wrap h1 {
  font-size: 26px;
  margin-bottom: 12px;
}

.page-wrap h3 {
  margin-bottom: 12px;
}

.page-wrap p {
  font-size: 15px;
  color: #444;
}

.page-wrap .btn {
  display: inline-block;
  padding: 10px 18px;
  border-radius: 8px;
  background: #111;
  color: #fff;
  text-decoration: none;
  margin-right: 10px;
}

.page-wrap .btn-outline {
  background: transparent;
  border: 1px solid #111;
  color: #111;
}


.form-row.two-cols {
  display: flex;
  gap: 16px;
}

.form-row.two-cols .form-group {
  flex: 1;
}


/* Remove browser number spinners */
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

input[type=number] {
  -moz-appearance: textfield;
}



.counter input[type="number"] {
  width: 60px;
  height: 48px;
  border: none;
  text-align: center;
  font-size: 18px;
  background: #fff;
  outline: none;
}


.btn-counter {
  width: 48px;
  height: 48px;
  border: none;
  background: #fff;
  font-size: 22px;
  cursor: pointer;
}

.btn-counter:hover {
  background: #f0f0f0;
}




/* Passengers/Luggage counter */
.counter{
  display:flex;
  align-items:stretch;
  gap:0;
  border:1px solid #d6dbe5;
  border-radius:8px;
  overflow:hidden;
  background:#fff;
  height:54px;
}

.counter-icon{
  width:54px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-right:1px solid #d6dbe5;
  font-size:18px;
}

.btn-counter{
  width:54px;
  border:0;
  background:#fff;
  cursor:pointer;
  font-size:22px;
  border-right:1px solid #d6dbe5;
}

.counter input{
  flex:1;              /* <-- THIS is the key */
  min-width:0;         /* prevents collapse */
  border:0;
  outline:none;
  text-align:center;
  font-size:18px;
  background:#fff;
}

.counter .btn-counter:last-child{
  border-right:0;
}

/* optional: hide number spinners */
.counter input::-webkit-outer-spin-button,
.counter input::-webkit-inner-spin-button{ -webkit-appearance:none; margin:0; }
.counter input[type=number]{ -moz-appearance:textfield; }




/* ===== Reserve page professional layout ===== */

.reserve-layout{
  display:grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap:24px;
  align-items:stretch;
}

.reserve-card{
  background:#fff;
  border:1px solid #e6eaf2;
  border-radius:14px;
  box-shadow:0 10px 30px rgba(0,0,0,.06);
  padding:22px;
}

.form-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:16px;
}

.form-grid .full{
  grid-column:1 / -1;
}

.field-label{
  display:block;
  font-weight:600;
  margin:0 0 8px;
}

.input,
select,
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="date"],
input[type="time"],
input[type="number"]{
  width:100%;
  height:44px;
  padding:10px 12px;
  border:1px solid #d8deea;
  border-radius:10px;
  outline:none;
  background:#fff;
}

/* Date + Time same row */
.dt-row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
}

/* Pickup + Dropoff same row */
.loc-row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
}

/* Counters row */
.counter-row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
  align-items:end;
}

/* Counter control (keeps inputs visible and centered) */
.counter{
  display:flex;
  align-items:stretch;
  border:1px solid #d8deea;
  border-radius:10px;
  overflow:hidden;
  height:44px;
  background:#fff;
}
.counter-icon{
  width:44px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-right:1px solid #d8deea;
}
.btn-counter{
  width:44px;
  border:0;
  background:#fff;
  cursor:pointer;
  font-size:18px;
  border-right:1px solid #d8deea;
}
.counter input{
  flex:1;
  min-width:0;
  border:0;
  text-align:center;
  font-size:16px;
  background:#fff;
}
.counter .btn-counter:last-child{ border-right:0; }

/* Button */
.reserve-btn{
  width:100%;
  height:48px;
  border-radius:12px;
  border:0;
  font-weight:700;
}

/* Map card */
.map-card{
  height:100%;
  min-height:360px;
  overflow:hidden;
}
.map-card iframe{
  width:100%;
  height:100%;
  border:0;
  border-radius:12px;
}

/* Responsive */
@media (max-width: 900px){
  .reserve-layout{ grid-template-columns: 1fr; }
}


.ride-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 16px;
}

.ride-grid .full {
  grid-column: 1 / -1;
}

.ride-grid .half {
  grid-column: span 1;
}

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


.reserve-grid{
  align-items: stretch;   /* make both columns same height */
}

.reserve-map{
  height: auto;
  overflow: hidden;
  border-radius: 14px;
}

.reserve-map iframe{
  display: block;
  width: 100%;
  height: 100%;           /* match the left card height */
  min-height: 0;          /* important */
  border: 0;
}


/* ===== Admin Reservations (NEW) ===== */
.admin-card{background:#fff;border:1px solid #e9eef5;border-radius:14px;padding:14px;box-shadow:0 10px 30px rgba(16,24,40,.06)}
.admin-table-wrap{overflow:auto;border-radius:12px}
.admin-table{width:100%;border-collapse:separate;border-spacing:0;min-width:980px}
.admin-table thead th{position:sticky;top:0;background:#f8fafc;color:#0f172a;font-weight:700;font-size:13px;padding:12px 12px;border-bottom:1px solid #e9eef5;white-space:nowrap}
.admin-table tbody td{padding:12px;border-bottom:1px solid #eef2f7;color:#111827;font-size:14px;vertical-align:middle}
.admin-table tbody tr:hover{background:#fbfdff}
.mono{font-variant-numeric:tabular-nums;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:13px}
.strong{font-weight:700}
.truncate{max-width:180px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;border:1px solid #dbe7ff;background:#eff6ff;color:#1d4ed8;font-weight:700;font-size:12px}
.status-select{height:38px;border-radius:10px;border:1px solid #dbe2ea;background:#fff;padding:0 10px;font-weight:700;color:#0f172a}
.btn-danger-sm{height:38px;padding:0 12px;border-radius:10px;border:0;background:#ef4444;color:#fff;font-weight:800;cursor:pointer}
.btn-danger-sm:hover{filter:brightness(.95)}
.admin-search{display:flex;gap:10px;align-items:center;margin:14px 0}
.admin-search-input{flex:1;height:44px;border-radius:12px;border:1px solid #dbe2ea;padding:0 14px}



.admin-search .btn-primary{height:44px}
.admin-search .btn-outline{height:44px;display:inline-flex;align-items:center}



.status-select {
  height: 40px;
  min-width: 140px;        /* NEW — forces enough width */
  padding: 0 14px;         /* NEW — space for text */
  border-radius: 10px;
  border: 1px solid #dbe2ea;
  background: #fff;
  font-weight: 700;
  color: #0f172a;
  appearance: auto;        /* NEW — keeps native arrow */
}


.status-select {
  height: 42px;            /* NEW */
  min-width: 160px;        /* NEW */
  font-size: 14px;         /* NEW */
}


.status-select { /* NEW */
  min-width: 140px; /* NEW */
  padding: 8px 10px; /* NEW */
  border-radius: 10px; /* NEW */
  border: 1px solid #d0d0d0; /* NEW */
  font-weight: 700; /* NEW */
  cursor: pointer; /* NEW */
}

/* NEW */
.status-confirmed { background: #e8fff0; border-color: #25a55b; color: #137a3c; }

/* NEW */
.status-pending   { background: #fff7e6; border-color: #f0a500; color: #8a5a00; }

/* NEW */
.status-cancelled { background: #ffecec; border-color: #e24545; color: #a01717; }

/* NEW */
.status-completed { background: #eaf2ff; border-color: #3a6ff0; color: #1f4bb8; }

.btn-outline { margin-right: 8px; } /* NEW */


.btn-danger {
  margin-top: 15px; /* NEW */
}


.admin-detail-actions { /* NEW */
  margin-top: 20px;     /* NEW */
  display: flex;        /* NEW */
  gap: 12px;            /* NEW */
  align-items: center;  /* NEW */
}

.admin-detail-actions .btn-outline { /* NEW */
  padding: 8px 14px;    /* NEW */
  border-radius: 6px;   /* NEW */
  text-decoration: none;/* NEW */
}

.admin-detail-actions .btn-danger { /* NEW */
  padding: 8px 14px;    /* NEW */
  border-radius: 6px;   /* NEW */
}


.admin-detail-actions { /* NEW */
  margin-top: 20px; /* NEW */
  display: flex; /* NEW */
  align-items: center; /* NEW */
  justify-content: space-between; /* NEW */
  gap: 12px; /* NEW */
} /* NEW */



.flash { /* NEW */
  margin: 12px 0; /* NEW */
  padding: 12px 16px; /* NEW */
  border-radius: 10px; /* NEW */
  font-weight: 500; /* NEW */
} /* NEW */

.flash-success { /* NEW */
  background: #e8f7ee; /* NEW */
  color: #0f5132; /* NEW */
  border: 1px solid #b6e2c6; /* NEW */
} /* NEW */


.flash-message {
  padding: 10px 14px;
  border-radius: 10px;
  margin: 12px 0;
  font-weight: 600;
}

/* RED info message */
.flash-info {
  background-color: #ffe8e8;
  color: #b00020;
  border: 1px solid #ffb3b3;
}

/* Optional */
.flash-success {
  background-color: #e8fff0;
  color: #0b6b2a;
  border: 1px solid #9be7b2;
}


.hero-image {
    width: 100%;
    height: auto;
    max-height: 600px;
    object-fit: cover;
    display: block;
}



.service-image {
    width: 100%;
    height: 220px;        /* controls the card image height */
    object-fit: cover;   /* fills the box */
    display: block;
    border-radius: 12px;
}


.fleet-image {
    width: 100%;
    height: 220px;
    object-fit: cover;
    display: block;
    border-radius: 12px;
}


.hero-wrapper {
  position: relative;
}

.hero-img {
  width: 100%;
  height: auto;
  display: block;
}

.hero-text {
  position: absolute;
  bottom: 20px;
  left: 20px;
}

.hero-text h1 {
  margin: 0 0 10px 0;
}

.hero-buttons a {
  margin-right: 10px;
  text-decoration: none;
}





/* HERO IMAGE WRAPPER */
.hero-image {
  position: relative;
}

/* TEXT + BUTTONS OVER IMAGE */
.hero-content {
  position: absolute;
  top: 30px;              /* move down/up if needed */
  left: 30px;             /* move left/right if needed */
  z-index: 2;
}

/* TITLE */
.hero-content h1 {
  color: #ffffff;
  font-size: 34px;
  font-weight: 700;
  margin-bottom: 15px;
  max-width: 600px;
}

/* BUTTON WRAPPER */
.hero-buttons {
  display: flex;
  gap: 15px;
}

/* CALL NOW BUTTON */
.btn-call {
  background-color: #d4af37; /* gold */
  color: #000;
  padding: 12px 22px;
  border-radius: 6px;
  text-decoration: none;
  font-weight: 600;
}

/* GET A QUOTE BUTTON */

.btn-quote {
  background-color: #0d4fdc;   /* ← ADD # */
  color: #ffffff;
  padding: 12px 22px;
  border-radius: 6px;
  text-decoration: none;
  font-weight: 600;
}

.btn-quote:hover {
  background-color: #0b3fb3;
}

/* BUTTON HOVER */
.btn-call:hover,
.btn-quote:hover {
  opacity: 0.9;
}



.hero-image {
  position: relative;
}

.hero-text {
  position: absolute;
  top: 20px;
  left: 30px;
  z-index: 10;
}

.hero-text h1 {
  color:   #d4af37;
  font-size: 34px;
  font-weight: 700;
  margin: 0;
}


.hero-buttons {
  position: absolute;
  bottom: 10px;       /* 👈 THIS puts buttons at bottom */
  left: 130px;
  transform: translateY(50%);
  display: flex;
  gap: 15px;
}



.hero-subtitle {
  color:  #ffffff;
  font-size: 18px;
  margin: 10px 0 20px;
  font-weight: 500;
  text-align: center;
  font-weight: 400;
}



/* =========================
   CONTACT PAGE
========================= */

.contact-section{
  padding: 60px 20px;
  background: #f5f6f8;
}

.contact-container{
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 40px;
  align-items: start;
}

/* Left side */
.contact-left{
  background: #111827;           /* dark like your theme */
  color: #ffffff;
  border-radius: 14px;
  padding: 40px;
  min-height: 520px;
  position: relative;
}

.contact-title{
  font-size: 42px;
  line-height: 1.1;
  margin: 0 0 16px 0;
  color: #d4af37;                /* gold accent */
  font-weight: 800;
}

.contact-desc{
  margin: 0 0 26px 0;
  color: rgba(255,255,255,0.85);
  font-size: 16px;
  line-height: 1.6;
  max-width: 520px;
}

.contact-info p{
  margin: 12px 0;
  font-size: 16px;
}

.contact-info a{
  color: #ffffff;
  text-decoration: underline;
}

/* Right side card */
.contact-card{
  background: #ffffff;
  border-radius: 16px;
  padding: 28px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.10);
}

.contact-row{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.contact-field{
  margin-bottom: 14px;
}

.contact-field label{
  display: block;
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 8px;
  color: #111827;
}

.contact-field input,
.contact-field textarea{
  width: 100%;
  padding: 12px 12px;
  border: 1px solid #d1d5db;
  border-radius: 10px;
  font-size: 15px;
  outline: none;
  background: #ffffff;
}

.contact-field input:focus,
.contact-field textarea:focus{
  border-color: #0d4fdc; /* your blue */
  box-shadow: 0 0 0 3px rgba(13,79,220,0.18);
}

.contact-submit{
  width: 100%;
  margin-top: 10px;
  padding: 14px 18px;
  border: none;
  border-radius: 999px;
  background: #d4af37;  /* gold like your Call Now */
  color: #111827;
  font-weight: 800;
  font-size: 16px;
  cursor: pointer;
}

.contact-submit:hover{
  filter: brightness(0.95);
}

/* Mobile */
@media (max-width: 980px){
  .contact-container{
    grid-template-columns: 1fr;
  }
  .contact-left{
    min-height: auto;
  }
  .contact-title{
    font-size: 34px;
  }
}

@media (max-width: 560px){
  .contact-row{
    grid-template-columns: 1fr;
  }
}
