/* ══════════════════════════════════════════
   PLANÈTE DRIVE — BOOKING WIDGET CSS
   ══════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;1,400&family=Outfit:wght@300;400;500&display=swap');

:root {
  --pd-gold:      #BFA46A;
  --pd-gold-b:    #D4B97E;
  --pd-gold-dim:  rgba(191,164,106,0.15);
  --pd-black:     #080808;
  --pd-surface:   #0F0F0F;
  --pd-surface2:  #161616;
  --pd-border:    rgba(191,164,106,0.18);
  --pd-text:      #EDE9DF;
  --pd-muted:     rgba(237,233,223,0.40);
  --pd-error:     #E07070;
  --pd-success:   #70C48A;
  --pd-info:      var(--pd-gold);
}

.pd-widget { max-width: 1020px; margin: 0 auto; font-family: 'Outfit', sans-serif; color: var(--pd-text); }

/* ── HERO ── */
.pd-hero { text-align: center; margin-bottom: 40px; animation: pd-reveal .8s ease both; }
.pd-tag  { font-size: 10px; font-weight: 500; letter-spacing: 5px; text-transform: uppercase; color: var(--pd-gold); display: flex; align-items: center; justify-content: center; gap: 10px; margin-bottom: 16px; }
.pd-tag::before, .pd-tag::after { content: ''; width: 32px; height: 1px; background: var(--pd-gold); opacity: .4; }
.pd-title { font-family: 'Playfair Display', serif; font-weight: 400; font-size: clamp(28px, 5vw, 52px); line-height: 1.12; margin: 0 0 14px; color: var(--pd-text); }
.pd-title em { font-style: italic; color: var(--pd-gold-b); }
.pd-subtitle { font-size: 14px; font-weight: 300; color: var(--pd-muted); margin: 0; }

/* ── TRUST BADGES ── */
.pd-trust { display: flex; justify-content: center; gap: 28px; margin-bottom: 36px; flex-wrap: wrap; }
.pd-badge { display: flex; align-items: center; gap: 7px; font-size: 11px; letter-spacing: 1.5px; color: var(--pd-muted); text-transform: uppercase; }
.pd-badge span:first-child { color: var(--pd-gold); }

/* ── CARD ── */
.pd-card { background: var(--pd-surface); border: 1px solid var(--pd-border); position: relative; }
.pd-card::before, .pd-card::after { content: ''; position: absolute; width: 46px; height: 46px; border-color: var(--pd-gold); border-style: solid; opacity: .25; pointer-events: none; z-index: 1; }
.pd-card::before { top: -6px; left: -6px; border-width: 1px 0 0 1px; }
.pd-card::after  { bottom: -6px; right: -6px; border-width: 0 1px 1px 0; }

/* ── PROGRESS ── */
.pd-progress-bar  { height: 2px; background: var(--pd-border); }
.pd-progress-fill { height: 100%; background: linear-gradient(90deg, var(--pd-gold), var(--pd-gold-b)); transition: width .6s cubic-bezier(.77,0,.18,1); }

/* ── STEPS ── */
.pd-steps { display: flex; border-bottom: 1px solid var(--pd-border); }
.pd-step  { flex: 1; padding: 17px 8px; background: none; border: none; cursor: default; font-family: 'Outfit', sans-serif; font-size: 10px; font-weight: 500; letter-spacing: 2.5px; text-transform: uppercase; color: var(--pd-muted); display: flex; align-items: center; justify-content: center; gap: 7px; position: relative; transition: color .3s; }
.pd-sn   { width: 21px; height: 21px; border: 1px solid currentColor; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 10px; flex-shrink: 0; }
.pd-step.active { color: var(--pd-text); }
.pd-step.active::after { content: ''; position: absolute; bottom: -1px; left: 0; right: 0; height: 1px; background: var(--pd-gold); }
.pd-step.done   { color: var(--pd-gold); }
.pd-step.done .pd-sn { border-color: var(--pd-gold); background: var(--pd-gold-dim); }

/* ── PANELS ── */
.pd-panel { display: none; padding: 40px 44px 36px; }
.pd-panel.active { display: block; }

/* ── FORM ELEMENTS ── */
.pd-row  { display: grid; gap: 18px; margin-bottom: 18px; }
.pd-c1   { grid-template-columns: 1fr; }
.pd-c2   { grid-template-columns: 1fr 1fr; }
.pd-c3   { grid-template-columns: 1fr 1fr 1fr; }
.pd-group { display: flex; flex-direction: column; gap: 6px; }
.pd-label { font-size: 9.5px; font-weight: 500; letter-spacing: 3px; text-transform: uppercase; color: var(--pd-gold); }
.pd-req   { color: var(--pd-error); margin-left: 2px; }
.pd-hint  { font-size: 11px; color: var(--pd-muted); font-weight: 300; }
.pd-input {
  background: rgba(255,255,255,0.025);
  border: 1px solid var(--pd-border);
  color: var(--pd-text);
  font-family: 'Outfit', sans-serif;
  font-size: 14px;
  font-weight: 300;
  padding: 13px 16px;
  outline: none;
  transition: border-color .25s, background .25s;
  width: 100%;
  -webkit-appearance: none;
  border-radius: 0;
}
.pd-input::placeholder { color: var(--pd-muted); }
.pd-input:focus { border-color: var(--pd-gold); background: rgba(191,164,106,0.04); }
.pd-input.pd-error { border-color: var(--pd-error); }
.pd-select {
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='7'%3E%3Cpath d='M0 0l5 6 5-6' fill='none' stroke='%23BFA46A' stroke-width='1.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  background-color: rgba(255,255,255,0.025);
  padding-right: 36px;
}
.pd-select option { background: #111; color: var(--pd-text); }
textarea.pd-input { resize: vertical; min-height: 80px; }

.pd-icon-wrap { position: relative; }
.pd-icon-wrap .pd-input { padding-left: 40px; }
.pd-ico { position: absolute; left: 13px; top: 50%; transform: translateY(-50%); pointer-events: none; font-size: 15px; }

/* ── SUGGESTIONS AUTOCOMPLETE ── */
.pd-suggestions { position: absolute; z-index: 9999; background: var(--pd-surface2); border: 1px solid var(--pd-border); width: 100%; display: none; }
.pd-suggestion-item { padding: 11px 14px; font-size: 13px; cursor: pointer; border-bottom: 1px solid var(--pd-border); transition: background .15s; }
.pd-suggestion-item:hover { background: var(--pd-gold-dim); color: var(--pd-gold); }
.pd-suggestion-item:last-child { border-bottom: none; }

/* ── GOOGLE MAP ── */
.pd-map-container { margin-bottom: 20px; border: 1px solid var(--pd-border); }
.pd-map { height: 260px; width: 100%; }
.pd-map-info { display: flex; gap: 24px; padding: 12px 16px; background: var(--pd-surface2); font-size: 13px; color: var(--pd-muted); border-top: 1px solid var(--pd-border); }
.pd-map-info span { color: var(--pd-text); }

/* ── DATE PICKER ── */
.pd-picker-wrap { position: relative; }
.pd-picker-display {
  background: rgba(255,255,255,0.025);
  border: 1px solid var(--pd-border);
  color: var(--pd-text);
  padding: 13px 16px 13px 40px;
  cursor: pointer;
  user-select: none;
  display: flex;
  align-items: center;
  transition: border-color .25s;
}
.pd-picker-display:hover, .pd-picker-display.pd-open { border-color: var(--pd-gold); background: rgba(191,164,106,0.04); }
.pd-ph  { color: var(--pd-muted); }
.pd-arr { margin-left: auto; font-size: 11px; color: var(--pd-muted); transition: transform .3s; }
.pd-picker-display.pd-open .pd-arr { transform: rotate(180deg); }

.pd-cal-popup {
  position: absolute; top: calc(100% + 5px); left: 0; z-index: 9999;
  background: var(--pd-surface2); border: 1px solid var(--pd-border);
  min-width: 290px; box-shadow: 0 20px 50px rgba(0,0,0,.8);
  display: none;
}
.pd-cal-popup.pd-open { display: block; animation: pd-pop .2s ease; }

.pd-cal-header { display: flex; align-items: center; justify-content: space-between; padding: 14px 16px 10px; border-bottom: 1px solid var(--pd-border); }
.pd-cal-header span { font-family: 'Playfair Display', serif; font-size: 15px; }
.pd-cal-nav { width: 28px; height: 28px; background: none; border: 1px solid var(--pd-border); color: var(--pd-gold); cursor: pointer; font-size: 15px; display: flex; align-items: center; justify-content: center; transition: background .2s; }
.pd-cal-nav:hover { background: var(--pd-gold-dim); }
.pd-cal-wdays { display: grid; grid-template-columns: repeat(7,1fr); padding: 8px 10px 2px; }
.pd-cal-wdays span { text-align: center; font-size: 9px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--pd-muted); }
.pd-cal-days { display: grid; grid-template-columns: repeat(7,1fr); padding: 0 10px 10px; gap: 2px; }
.pd-cal-day { aspect-ratio: 1; display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 300; cursor: pointer; border: 1px solid transparent; transition: all .15s; }
.pd-cal-day:not(.pd-cal-off):not(.pd-cal-empty):hover { border-color: var(--pd-gold); color: var(--pd-gold); }
.pd-cal-today  { color: var(--pd-gold-b); font-weight: 500; }
.pd-cal-picked { background: var(--pd-gold) !important; color: var(--pd-black) !important; font-weight: 500; border-color: var(--pd-gold) !important; }
.pd-cal-off    { color: rgba(237,233,223,.15); cursor: not-allowed; }
.pd-cal-empty  { cursor: default; }

/* ── TIME PICKER ── */
.pd-time-popup {
  position: absolute; top: calc(100% + 5px); left: 0; z-index: 9999;
  background: var(--pd-surface2); border: 1px solid var(--pd-border);
  width: 100%; box-shadow: 0 20px 50px rgba(0,0,0,.8);
  display: none;
}
.pd-time-popup.pd-open { display: block; animation: pd-pop .2s ease; }
.pd-time-head { padding: 12px 16px; border-bottom: 1px solid var(--pd-border); text-align: center; }
.pd-time-head small { font-size: 9px; letter-spacing: 3px; text-transform: uppercase; color: var(--pd-muted); display: block; margin-bottom: 3px; }
.pd-time-big  { font-family: 'Playfair Display', serif; font-size: 30px; color: var(--pd-gold-b); line-height: 1; }
.pd-time-slots { display: grid; grid-template-columns: repeat(4,1fr); gap: 3px; padding: 10px; max-height: 190px; overflow-y: auto; }
.pd-time-slots::-webkit-scrollbar { width: 3px; }
.pd-time-slots::-webkit-scrollbar-thumb { background: var(--pd-border); }
.pd-t-slot { padding: 8px 4px; text-align: center; font-size: 12px; font-weight: 300; cursor: pointer; border: 1px solid var(--pd-border); transition: all .15s; }
.pd-t-slot:hover { border-color: var(--pd-gold); color: var(--pd-gold); }
.pd-t-slot.pd-picked { background: var(--pd-gold); color: var(--pd-black); font-weight: 500; border-color: var(--pd-gold); }

/* ── SERVICE CARDS ── */
.pd-service-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; margin-bottom: 22px; }
.pd-svc { border: 1px solid var(--pd-border); padding: 22px 14px; text-align: center; cursor: pointer; transition: border-color .25s, background .25s, transform .2s; position: relative; }
.pd-svc:hover { border-color: rgba(191,164,106,.5); transform: translateY(-2px); }
.pd-svc.pd-selected { border-color: var(--pd-gold); background: var(--pd-gold-dim); }
.pd-svc.pd-selected::after { content: '✓'; position: absolute; top: 8px; right: 10px; font-size: 11px; color: var(--pd-gold); }
.pd-svc-icon { font-size: 28px; margin-bottom: 10px; display: block; }
.pd-svc-name { font-size: 11px; font-weight: 500; letter-spacing: 1.5px; text-transform: uppercase; margin-bottom: 5px; }
.pd-svc-desc { font-size: 11px; color: var(--pd-muted); line-height: 1.5; }

/* ── VEHICLE CARDS ── */
.pd-vehicle-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 12px; margin-bottom: 20px; }
.pd-v-card { border: 1px solid var(--pd-border); cursor: pointer; display: flex; overflow: hidden; transition: border-color .25s, transform .2s; position: relative; }
.pd-v-card:hover { border-color: rgba(191,164,106,.5); transform: translateY(-2px); }
.pd-v-card.pd-selected { border-color: var(--pd-gold); }
.pd-v-card.pd-selected::before { content: '✓'; position: absolute; top: 9px; right: 13px; font-size: 11px; color: var(--pd-gold); }
.pd-v-left  { padding: 18px 16px; flex: 1; }
.pd-v-icon  { font-size: 24px; margin-bottom: 8px; display: block; }
.pd-v-name  { font-size: 11px; font-weight: 500; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 3px; }
.pd-v-cap   { font-size: 11px; color: var(--pd-muted); }
.pd-v-right { background: var(--pd-surface2); border-left: 1px solid var(--pd-border); padding: 18px 14px; display: flex; flex-direction: column; align-items: center; justify-content: center; min-width: 90px; text-align: center; }
.pd-v-price { font-family: 'Playfair Display', serif; font-size: 24px; color: var(--pd-gold-b); line-height: 1; }
.pd-v-unite { font-size: 10px; color: var(--pd-muted); letter-spacing: 1.5px; text-transform: uppercase; margin-top: 4px; }

/* ── DISPO HOURS ── */
.pd-dispo-hours { background: var(--pd-surface2); border: 1px solid var(--pd-border); padding: 18px 22px; margin-bottom: 18px; }
.pd-dispo-title { font-size: 10px; letter-spacing: 3px; text-transform: uppercase; color: var(--pd-gold); margin-bottom: 12px; }
.pd-hours-grid { display: grid; grid-template-columns: repeat(6,1fr); gap: 7px; }
.pd-h-btn { padding: 10px 6px; text-align: center; font-size: 13px; font-weight: 300; cursor: pointer; border: 1px solid var(--pd-border); transition: all .15s; }
.pd-h-btn:hover { border-color: var(--pd-gold); color: var(--pd-gold); }
.pd-h-btn.pd-picked { background: var(--pd-gold); color: var(--pd-black); font-weight: 500; border-color: var(--pd-gold); }

/* ── TOTAL BANNER ── */
.pd-total-banner { background: var(--pd-surface2); border: 1px solid var(--pd-gold); padding: 16px 24px; display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; flex-wrap: wrap; gap: 10px; }
.pd-total-label  { font-size: 9px; letter-spacing: 3px; text-transform: uppercase; color: var(--pd-muted); margin-bottom: 3px; }
.pd-total-detail { font-size: 12px; color: var(--pd-muted); }
.pd-total-amount { font-family: 'Playfair Display', serif; font-size: 38px; color: var(--pd-gold-b); }

/* ── STEP SUBTITLE ── */
.pd-step-subtitle { font-size: 10px; letter-spacing: 3px; text-transform: uppercase; color: var(--pd-gold); margin-bottom: 18px; }

/* ── SUMMARY ── */
.pd-summary-box { background: var(--pd-surface2); border: 1px solid var(--pd-border); padding: 24px 28px; margin-bottom: 24px; }
.pd-summary-title { font-size: 9.5px; letter-spacing: 3.5px; text-transform: uppercase; color: var(--pd-gold); margin-bottom: 18px; padding-bottom: 12px; border-bottom: 1px solid var(--pd-border); }
.pd-summary-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 20px; }
.pd-s-item .pd-s-key { font-size: 9px; letter-spacing: 2px; text-transform: uppercase; color: var(--pd-muted); margin-bottom: 2px; }
.pd-s-item .pd-s-val { font-size: 14px; font-weight: 300; }
.pd-s-item.pd-hl .pd-s-val { color: var(--pd-gold-b); font-size: 20px; font-family: 'Playfair Display', serif; }
.pd-gold { color: var(--pd-gold); }

/* ── ALERTS ── */
.pd-alert { padding: 11px 16px; font-size: 12px; letter-spacing: 1px; margin-bottom: 16px; }
.pd-alert-error   { border: 1px solid var(--pd-error);   color: var(--pd-error);   background: rgba(224,112,112,.06); }
.pd-alert-success { border: 1px solid var(--pd-success); color: var(--pd-success); background: rgba(112,196,138,.06); }
.pd-alert-info    { border: 1px solid var(--pd-gold);    color: var(--pd-gold);    background: rgba(191,164,106,.06); }

/* ── NAV BUTTONS ── */
.pd-nav { display: flex; justify-content: space-between; align-items: center; margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--pd-border); }

.pd-btn-back { background: none; border: 1px solid var(--pd-border); color: var(--pd-muted); font-family: 'Outfit', sans-serif; font-size: 10px; letter-spacing: 3px; text-transform: uppercase; padding: 12px 24px; cursor: pointer; transition: all .25s; }
.pd-btn-back:hover { border-color: var(--pd-muted); color: var(--pd-text); }

.pd-btn-gold {
  background: transparent; border: 1px solid var(--pd-gold); color: var(--pd-gold);
  font-family: 'Outfit', sans-serif; font-size: 10px; font-weight: 500; letter-spacing: 4px;
  text-transform: uppercase; padding: 15px 38px; cursor: pointer;
  position: relative; overflow: hidden; transition: color .4s;
  display: inline-flex; align-items: center; gap: 8px;
}
.pd-btn-gold::before { content: ''; position: absolute; inset: 0; background: var(--pd-gold); transform: scaleX(0); transform-origin: left; transition: transform .4s cubic-bezier(.77,0,.18,1); }
.pd-btn-gold:hover::before { transform: scaleX(1); }
.pd-btn-gold:hover, .pd-btn-gold:hover span { color: var(--pd-black); }
.pd-btn-gold span { position: relative; z-index: 1; }
.pd-btn-gold:disabled { opacity: .5; cursor: not-allowed; }

.pd-btn-stripe {
  background: transparent; border: 1px solid #635BFF; color: #635BFF;
  font-family: 'Outfit', sans-serif; font-size: 11px; font-weight: 500; letter-spacing: 3px;
  text-transform: uppercase; padding: 17px 44px; cursor: pointer;
  position: relative; overflow: hidden; transition: color .4s;
  display: inline-flex; align-items: center; gap: 8px;
}
.pd-btn-stripe::before { content: ''; position: absolute; inset: 0; background: #635BFF; transform: scaleX(0); transform-origin: left; transition: transform .4s cubic-bezier(.77,0,.18,1); }
.pd-btn-stripe:hover::before { transform: scaleX(1); }
.pd-btn-stripe:hover, .pd-btn-stripe:hover strong { color: #fff; }
.pd-btn-stripe strong { position: relative; z-index: 1; }
.pd-btn-stripe:disabled { opacity: .5; cursor: not-allowed; }

/* ── PAYMENT STEP ── */
.pd-pay-text { font-size: 13px; color: var(--pd-muted); margin-bottom: 24px; line-height: 1.9; }
.pd-pay-note { font-size: 11px; color: var(--pd-muted); margin-top: 12px; letter-spacing: 1px; }

/* ── SUCCESS ── */
.pd-success { text-align: center; padding: 56px 28px; }
.pd-success-ring { width: 76px; height: 76px; border: 1px solid var(--pd-gold); border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 24px; font-size: 28px; color: var(--pd-gold); animation: pd-pop-in .5s cubic-bezier(.17,.67,.35,1.3) both; }
.pd-success h2 { font-family: 'Playfair Display', serif; font-weight: 400; font-size: 38px; margin-bottom: 12px; color: var(--pd-text); }
.pd-success p  { font-size: 14px; font-weight: 300; color: var(--pd-muted); line-height: 1.9; max-width: 440px; margin: 0 auto; }
.pd-ref { display: inline-block; margin-top: 22px; padding: 9px 22px; border: 1px solid var(--pd-border); font-size: 12px; letter-spacing: 3px; color: var(--pd-gold); }

/* ── ANIMATIONS ── */
@keyframes pd-reveal { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: translateY(0); } }
@keyframes pd-pop    { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: translateY(0); } }
@keyframes pd-pop-in { from { transform: scale(.5); opacity: 0; } to { transform: scale(1); opacity: 1; } }

/* ── RESPONSIVE ── */
@media (max-width: 720px) {
  .pd-panel { padding: 24px 18px; }
  .pd-c2, .pd-c3 { grid-template-columns: 1fr; }
  .pd-service-grid { grid-template-columns: 1fr; }
  .pd-vehicle-grid { grid-template-columns: 1fr; }
  .pd-summary-grid { grid-template-columns: 1fr; }
  .pd-hours-grid   { grid-template-columns: repeat(4,1fr); }
  .pd-step span:last-child { display: none; }
  .pd-trust { gap: 14px; }
}
@media (max-width: 480px) {
  .pd-btn-gold, .pd-btn-stripe { padding: 13px 22px; font-size: 9px; }
  .pd-total-amount { font-size: 28px; }
}
