/* Limo Booking Plugin - Frontend Styles */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600&family=Jost:wght@300;400;500&display=swap');

:root {
  --limo-primary: #1a1a2e;
  --limo-accent:  #c9a84c;
  --limo-bg:      #f8f6f1;
  --limo-white:   #ffffff;
  --limo-text:    #1a1a2e;
  --limo-muted:   #7a7a7a;
  --limo-border:  #e0dbd0;
  --limo-error:   #c0392b;
  --limo-success: #27ae60;
  --limo-radius:  6px;
  --limo-shadow:  0 4px 24px rgba(26,26,46,0.10);
}

/* Inject JS colors */
.limo-booking-wrap { --limo-primary: var(--limo-primary-js, #1a1a2e); --limo-accent: var(--limo-accent-js, #c9a84c); }

.limo-booking-wrap {
  font-family: 'Jost', sans-serif;
  max-width: 780px;
  margin: 0 auto;
  background: var(--limo-white);
  border-radius: 12px;
  box-shadow: var(--limo-shadow);
  overflow: hidden;
  color: var(--limo-text);
}

/* ── Steps ──────────────────────────────── */
.limo-steps {
  display: flex;
  align-items: center;
  background: var(--limo-primary);
  padding: 20px 32px;
  gap: 0;
}
.limo-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  flex: none;
}
.step-num {
  width: 32px; height: 32px;
  border-radius: 50%;
  border: 2px solid rgba(201,168,76,0.4);
  display: flex; align-items: center; justify-content: center;
  font-size: 13px;
  color: rgba(255,255,255,0.4);
  font-weight: 500;
  transition: all 0.3s;
}
.step-label {
  font-size: 11px;
  color: rgba(255,255,255,0.3);
  letter-spacing: 0.5px;
  white-space: nowrap;
  transition: color 0.3s;
}
.limo-step.active .step-num  { background: var(--limo-accent); border-color: var(--limo-accent); color: var(--limo-primary); }
.limo-step.active .step-label{ color: var(--limo-accent); }
.limo-step.done   .step-num  { background: rgba(201,168,76,0.2); border-color: var(--limo-accent); color: var(--limo-accent); }
.limo-step.done   .step-label{ color: rgba(255,255,255,0.6); }
.limo-step-divider { flex: 1; height: 1px; background: rgba(201,168,76,0.2); margin: 0 8px; margin-bottom: 20px; }

/* ── Form area ──────────────────────────── */
.limo-form-step { display: none; padding: 36px 40px; }
.limo-form-step.active { display: block; }

.limo-step-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 26px;
  font-weight: 500;
  color: var(--limo-primary);
  margin: 0 0 28px;
  letter-spacing: 0.5px;
}

/* ── Service Cards ──────────────────────── */
.limo-service-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap: 10px;
  margin-bottom: 4px;
}
.limo-service-card {
  border: 1.5px solid var(--limo-border);
  border-radius: var(--limo-radius);
  padding: 16px 8px;
  text-align: center;
  cursor: pointer;
  transition: all 0.2s;
  background: var(--limo-bg);
}
.limo-service-card:hover { border-color: var(--limo-accent); background: #fffef8; }
.limo-service-card.selected { border-color: var(--limo-accent); background: var(--limo-primary); }
.limo-service-card.selected .service-icon { filter: none; }
.limo-service-card.selected .service-label { color: var(--limo-accent); }
.service-icon { font-size: 24px; margin-bottom: 6px; }
.service-label { font-size: 11px; font-weight: 500; letter-spacing: 0.5px; color: var(--limo-muted); text-transform: uppercase; }

/* ── Form fields ────────────────────────── */
.limo-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.limo-field, .limo-col { margin-bottom: 16px; }
.limo-col { margin-bottom: 0; }
.limo-field-group { margin-bottom: 20px; }

.limo-label {
  display: block;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  color: var(--limo-muted);
  margin-bottom: 7px;
}
.limo-label .required { color: var(--limo-accent); }
.limo-label small { text-transform: none; font-weight: 400; letter-spacing: 0; font-size: 11px; }

.limo-input, .limo-textarea, .limo-select {
  width: 100%;
  padding: 11px 14px;
  border: 1.5px solid var(--limo-border);
  border-radius: var(--limo-radius);
  font-family: 'Jost', sans-serif;
  font-size: 14px;
  color: var(--limo-text);
  background: var(--limo-white);
  transition: border-color 0.2s;
  box-sizing: border-box;
}
.limo-input:focus, .limo-textarea:focus { outline: none; border-color: var(--limo-accent); }
.limo-input.error { border-color: var(--limo-error); }
.limo-textarea { resize: vertical; }

/* ── Passenger counter ──────────────────── */
.limo-passenger-counter {
  display: flex; align-items: center; gap: 16px;
}
.counter-btn {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1.5px solid var(--limo-border);
  background: var(--limo-bg);
  font-size: 18px;
  cursor: pointer;
  color: var(--limo-primary);
  display: flex; align-items: center; justify-content: center;
  transition: all 0.2s;
  line-height: 1;
}
.counter-btn:hover { border-color: var(--limo-accent); color: var(--limo-accent); }
#pax-count { font-size: 20px; font-weight: 500; min-width: 24px; text-align: center; }

/* ── Vehicles ───────────────────────────── */
.limo-vehicles-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 14px;
  margin-bottom: 24px;
}
.limo-vehicle-card {
  border: 1.5px solid var(--limo-border);
  border-radius: 8px;
  padding: 20px 16px;
  cursor: pointer;
  transition: all 0.2s;
  background: var(--limo-bg);
}
.limo-vehicle-card:hover { border-color: var(--limo-accent); transform: translateY(-2px); box-shadow: 0 6px 20px rgba(26,26,46,0.08); }
.limo-vehicle-card.selected { border-color: var(--limo-accent); background: var(--limo-primary); }
.limo-vehicle-card.selected .vehicle-name { color: var(--limo-accent); }
.limo-vehicle-card.selected .vehicle-price { color: var(--limo-accent); }
.limo-vehicle-card.selected .vehicle-cap { color: rgba(255,255,255,0.5); }
.limo-vehicle-card.disabled { opacity: 0.4; cursor: not-allowed; }
.vehicle-icon { font-size: 32px; margin-bottom: 10px; }
.vehicle-name { font-size: 15px; font-weight: 500; color: var(--limo-text); margin-bottom: 4px; }
.vehicle-cap  { font-size: 12px; color: var(--limo-muted); margin-bottom: 10px; }
.vehicle-price { font-size: 20px; font-weight: 600; color: var(--limo-primary); font-family: 'Cormorant Garamond', serif; }
.vehicle-price small { font-size: 12px; font-weight: 400; font-family: 'Jost', sans-serif; color: var(--limo-muted); }

/* ── Promo ──────────────────────────────── */
.limo-promo-row { display: flex; gap: 10px; }
.limo-promo-row .limo-input { flex: 1; }
.limo-promo-result { margin-top: 6px; font-size: 13px; }
.limo-promo-result.success { color: var(--limo-success); }
.limo-promo-result.error   { color: var(--limo-error); }

/* ── Summary / Confirm ──────────────────── */
.limo-summary {
  background: var(--limo-bg);
  border-radius: 8px;
  padding: 20px 24px;
  margin-bottom: 16px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px 24px;
}
.summary-item { }
.summary-key { font-size: 11px; letter-spacing: 0.8px; text-transform: uppercase; color: var(--limo-muted); margin-bottom: 3px; }
.summary-val { font-size: 14px; color: var(--limo-text); font-weight: 500; }

.limo-price-box {
  border: 1.5px solid var(--limo-border);
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: 20px;
}
.price-row { display: flex; justify-content: space-between; padding: 12px 20px; font-size: 14px; border-bottom: 1px solid var(--limo-border); }
.price-row:last-child { border-bottom: none; }
.total-row { background: var(--limo-primary); color: var(--limo-accent); font-size: 18px; font-weight: 600; font-family: 'Cormorant Garamond', serif; }

.limo-terms { margin-bottom: 20px; font-size: 13px; }
.limo-terms input { margin-right: 8px; accent-color: var(--limo-accent); }
.limo-terms a { color: var(--limo-accent); }

.limo-error {
  background: #fdf0ed;
  border: 1px solid #f5c6bc;
  border-radius: var(--limo-radius);
  padding: 12px 16px;
  font-size: 13px;
  color: var(--limo-error);
  margin-bottom: 16px;
}

/* ── Navigation buttons ─────────────────── */
.limo-step-nav { display: flex; justify-content: space-between; align-items: center; margin-top: 8px; }
.limo-btn {
  padding: 12px 28px;
  border-radius: var(--limo-radius);
  font-family: 'Jost', sans-serif;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 1px;
  text-transform: uppercase;
  cursor: pointer;
  border: none;
  transition: all 0.2s;
}
.limo-btn-next, .limo-btn-submit {
  background: var(--limo-primary);
  color: var(--limo-accent);
  border: 1.5px solid var(--limo-primary);
}
.limo-btn-next:hover, .limo-btn-submit:hover { background: var(--limo-accent); color: var(--limo-primary); border-color: var(--limo-accent); }
.limo-btn-back { background: transparent; color: var(--limo-muted); border: 1.5px solid var(--limo-border); }
.limo-btn-back:hover { border-color: var(--limo-muted); color: var(--limo-text); }
.limo-btn-outline { background: transparent; color: var(--limo-primary); border: 1.5px solid var(--limo-border); white-space: nowrap; }
.limo-btn-outline:hover { border-color: var(--limo-accent); color: var(--limo-accent); }
.limo-btn-submit:disabled { opacity: 0.6; cursor: not-allowed; }

/* ── Success ────────────────────────────── */
.limo-success {
  padding: 60px 40px;
  text-align: center;
}
.success-icon {
  width: 64px; height: 64px;
  background: var(--limo-success);
  color: white;
  border-radius: 50%;
  font-size: 28px;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 20px;
}
.limo-success h2 { font-family: 'Cormorant Garamond', serif; font-size: 30px; font-weight: 500; margin: 0 0 12px; color: var(--limo-primary); }
.limo-success p { color: var(--limo-muted); font-size: 15px; margin: 0 0 24px; }
.success-ref-box { background: var(--limo-primary); border-radius: 8px; padding: 20px 32px; display: inline-block; margin-bottom: 20px; }
.ref-label { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,0.5); margin-bottom: 8px; }
.ref-number { font-size: 24px; font-weight: 700; letter-spacing: 4px; color: var(--limo-accent); }
.success-note { font-size: 13px !important; color: #aaa !important; }

/* ── Responsive ─────────────────────────── */
@media (max-width: 600px) {
  .limo-form-step { padding: 24px 20px; }
  .limo-row { grid-template-columns: 1fr; }
  .limo-steps { padding: 16px 20px; }
  .step-label { display: none; }
  .limo-summary { grid-template-columns: 1fr; }
  .limo-vehicles-grid { grid-template-columns: 1fr 1fr; }
}
