/* VTCGo — Formulaire de réservation */
/* Palette : dark #0d0d0d, gold #c9a84c, bg #f8f8f6 */

.vtcgo-wrap { --vtc-accent: #1a1a2e; --vtc-gold: #c9a84c; --vtc-dark: #0d0d0d; --vtc-bg: #f8f8f6; --vtc-text: #1a1a1a; }

.vtcgo-wrap { max-width: 640px; margin: 0 auto; font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; color: var(--vtc-text); }

/* ── Steps bar ─────────────────────────────────────────────────────────────── */
.vtc-steps-bar { display:flex; align-items:center; margin-bottom:28px; }
.vtc-step-dot { display:flex; flex-direction:column; align-items:center; gap:4px; }
.vtc-step-dot span { width:32px; height:32px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.85rem; font-weight:700; background:#e5e7eb; color:#9ca3af; }
.vtc-step-dot em { font-size:.68rem; font-style:normal; color:#9ca3af; white-space:nowrap; }
.vtc-step-dot.active span { background:var(--vtc-dark); color:var(--vtc-gold); }
.vtc-step-dot.active em { color:var(--vtc-dark); font-weight:600; }
.vtc-step-dot.done span { background:var(--vtc-gold); color:var(--vtc-dark); }
.vtc-step-line { flex:1; height:2px; background:#e5e7eb; margin:0 6px; margin-bottom:18px; }
.vtc-step-line.done { background:var(--vtc-gold); }

/* ── Titre étape ───────────────────────────────────────────────────────────── */
.vtc-step-title { font-size:1.2rem; font-weight:700; margin:0 0 20px; color:var(--vtc-dark); }

/* ── Tabs de mode ──────────────────────────────────────────────────────────── */
.vtc-mode-tabs { display:grid; grid-template-columns:repeat(auto-fit, minmax(140px,1fr)); gap:10px; margin-bottom:24px; }
.vtc-mode-tab { display:flex; flex-direction:column; align-items:center; gap:4px; padding:14px 10px; border:2px solid #e5e7eb; border-radius:12px; background:#fff; cursor:pointer; transition:all .2s; text-align:center; }
.vtc-mode-tab:hover { border-color:var(--vtc-gold); }
.vtc-mode-tab.active { border-color:var(--vtc-dark); background:var(--vtc-dark); }
.vtc-tab-ico { font-size:1.5rem; }
.vtc-tab-label { font-size:.9rem; font-weight:700; color:#374151; }
.vtc-mode-tab.active .vtc-tab-label { color:var(--vtc-gold); }
.vtc-tab-sub { font-size:.72rem; color:#9ca3af; }
.vtc-mode-tab.active .vtc-tab-sub { color:#888; }

/* ── Champs ────────────────────────────────────────────────────────────────── */
.vtc-field { margin-bottom:16px; }
.vtc-field label { display:block; font-size:.83rem; font-weight:600; color:#374151; margin-bottom:6px; }
.vtc-field-hint { font-size:.75rem; color:#9ca3af; margin:4px 0 0; }
.vtc-req { color:#ef4444; }
.vtc-input-wrap { position:relative; display:flex; align-items:center; border:1.5px solid #e5e7eb; border-radius:10px; background:#fff; overflow:hidden; transition:border-color .2s; }
.vtc-input-wrap:focus-within { border-color:var(--vtc-gold); }
.vtc-ico { padding:0 10px 0 12px; font-size:1rem; flex-shrink:0; }
.vtc-input-wrap input, .vtc-input-wrap select, .vtc-input-wrap textarea { flex:1; border:none; outline:none; padding:11px 12px 11px 0; font-size:.92rem; background:transparent; color:var(--vtc-text); font-family:inherit; }
.vtc-input-wrap textarea { padding:10px 12px 10px 0; resize:vertical; min-height:64px; }
.vtc-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media (max-width:520px) { .vtc-row { grid-template-columns:1fr; } }

/* ── Forfaits ──────────────────────────────────────────────────────────────── */
.vtc-forfaits { display:flex; flex-direction:column; gap:10px; }
.vtc-forfait-card { border:2px solid #e5e7eb; border-radius:12px; padding:14px 16px; cursor:pointer; background:#fff; transition:all .2s; }
.vtc-forfait-card:hover { border-color:var(--vtc-gold); }
.vtc-forfait-card.active { border-color:var(--vtc-dark); background:var(--vtc-dark); }
.vtc-forfait-route { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-bottom:4px; }
.vtc-forfait-from, .vtc-forfait-to { font-weight:600; font-size:.9rem; color:#374151; }
.vtc-forfait-card.active .vtc-forfait-from,
.vtc-forfait-card.active .vtc-forfait-to { color:#fff; }
.vtc-forfait-arrow { color:#9ca3af; }
.vtc-forfait-label { font-size:.78rem; color:#9ca3af; margin-bottom:4px; }
.vtc-forfait-duration { font-size:.78rem; color:#9ca3af; }
.vtc-forfait-price { font-size:1.3rem; font-weight:800; color:var(--vtc-gold); margin-top:8px; }
.vtc-forfait-card.active .vtc-forfait-price { color:var(--vtc-gold); }

/* ── Info MAD ──────────────────────────────────────────────────────────────── */
.vtc-mad-info { display:flex; gap:10px; background:#f0f9ff; border:1px solid #bae6fd; border-radius:10px; padding:12px 14px; margin-top:8px; }
.vtc-mad-info span { font-size:1.2rem; flex-shrink:0; }
.vtc-mad-info p { margin:0; font-size:.82rem; color:#0369a1; line-height:1.5; }

/* ── Durée display ─────────────────────────────────────────────────────────── */
#vtc-duration-display { padding:8px 14px; background:#f0fdf4; border:1px solid #bbf7d0; border-radius:8px; font-size:.82rem; color:#166534; text-align:center; margin-bottom:10px; }

/* ── Véhicules ─────────────────────────────────────────────────────────────── */
.vtc-vehicles { display:grid; grid-template-columns:repeat(auto-fit, minmax(150px,1fr)); gap:10px; margin-bottom:16px; }
.vtc-vehicle { border:2px solid #e5e7eb; border-radius:12px; padding:14px; cursor:pointer; transition:all .2s; background:#fff; }
.vtc-vehicle:hover { border-color:var(--vtc-gold); }
.vtc-vehicle.active { border-color:var(--vtc-dark); box-shadow:0 0 0 3px rgba(201,168,76,.2); }
.vtcv-top { display:flex; align-items:center; gap:10px; margin-bottom:8px; }
.vtcv-emoji { font-size:1.6rem; }
.vtcv-name { font-weight:700; font-size:.9rem; color:var(--vtc-dark); }
.vtcv-pass { font-size:.75rem; color:#9ca3af; }
.vtcv-price { font-weight:800; font-size:1.05rem; color:var(--vtc-gold); }

/* ── Slot badge ────────────────────────────────────────────────────────────── */
#vtc-slot-badge { display:inline-block; background:#fef9c3; color:#854d0e; border:1px solid #fde68a; border-radius:20px; font-size:.72rem; font-weight:600; padding:2px 10px; margin-top:4px; }

/* ── Options ───────────────────────────────────────────────────────────────── */
.vtc-opts { display:flex; flex-direction:column; gap:8px; }
.vtc-opt-item { display:flex; align-items:center; gap:10px; padding:8px 12px; border:1.5px solid #e5e7eb; border-radius:8px; cursor:pointer; font-size:.85rem; transition:border-color .2s; }
.vtc-opt-item:hover { border-color:var(--vtc-gold); }
.vtc-opt-item input { width:16px; height:16px; flex-shrink:0; }

/* ── Price box ─────────────────────────────────────────────────────────────── */
.vtc-price-box { display:flex; align-items:center; justify-content:space-between; background:var(--vtc-dark); color:#fff; border-radius:12px; padding:16px 20px; margin-bottom:16px; }
.vtc-price-box span { font-size:.85rem; color:#aaa; }
.vtc-price-box small { font-size:.75rem; color:#666; }
.vtc-price-box strong { font-size:1.5rem; font-weight:800; color:var(--vtc-gold); }

/* ── Summary ───────────────────────────────────────────────────────────────── */
.vtc-summary { display:flex; align-items:center; justify-content:space-between; background:#f9fafb; border:1px solid #e5e7eb; border-radius:10px; padding:10px 14px; margin-bottom:18px; font-size:.83rem; color:#374151; gap:10px; }
.vtc-edit-link { background:none; border:none; color:#9ca3af; font-size:.8rem; cursor:pointer; white-space:nowrap; padding:0; }
.vtc-edit-link:hover { color:var(--vtc-dark); }

/* ── Recap ─────────────────────────────────────────────────────────────────── */
.vtc-recap { background:#f9fafb; border:1px solid #e5e7eb; border-radius:12px; overflow:hidden; margin-bottom:18px; }
.vtc-recap-table { width:100%; border-collapse:collapse; }
.vtc-recap-label { padding:8px 14px; color:#6b7280; font-size:.82rem; border-bottom:1px solid #f0f0f0; width:40%; }
.vtc-recap-val { padding:8px 14px; color:var(--vtc-text); font-size:.85rem; border-bottom:1px solid #f0f0f0; font-weight:500; }
.vtc-recap-total { display:flex; justify-content:space-between; align-items:center; padding:14px 16px; background:var(--vtc-dark); color:#fff; }
.vtc-recap-total span { font-size:.9rem; color:#aaa; }
.vtc-recap-total strong { font-size:1.3rem; font-weight:800; color:var(--vtc-gold); }

/* ── Payment info ──────────────────────────────────────────────────────────── */
.vtc-payment-info { display:flex; gap:14px; align-items:flex-start; background:#f8fafc; border:1px solid #e2e8f0; border-radius:10px; padding:14px; margin-bottom:16px; }
.vtc-pay-icon { font-size:1.5rem; }
.vtc-payment-info strong { font-size:.9rem; }
.vtc-payment-info small { font-size:.78rem; color:#64748b; }

/* ── CGV ───────────────────────────────────────────────────────────────────── */
.vtc-cgv-label { display:flex; align-items:center; gap:8px; font-size:.83rem; color:#374151; cursor:pointer; margin-bottom:16px; }
.vtc-cgv-label input { width:16px; height:16px; }
.vtc-cgv-label a { color:var(--vtc-dark); }

/* ── Boutons ───────────────────────────────────────────────────────────────── */
.vtc-btn-main { width:100%; padding:14px; background:var(--vtc-dark); color:var(--vtc-gold); border:none; border-radius:12px; font-size:1rem; font-weight:700; cursor:pointer; transition:background .2s, transform .15s; }
.vtc-btn-main:hover { background:#1a1a2e; transform:translateY(-1px); }
.vtc-btn-sec { padding:12px 20px; background:#fff; color:var(--vtc-dark); border:1.5px solid #e5e7eb; border-radius:12px; font-size:.9rem; font-weight:600; cursor:pointer; transition:all .2s; }
.vtc-btn-sec:hover { border-color:var(--vtc-dark); }
.vtc-btn-pay { flex:1; padding:14px; background:var(--vtc-gold); color:var(--vtc-dark); border:none; border-radius:12px; font-size:1rem; font-weight:800; cursor:pointer; transition:all .2s; }
.vtc-btn-pay:hover { background:#b8952e; transform:translateY(-1px); }
.vtc-btn-row { display:grid; grid-template-columns:auto 1fr; gap:12px; }
.vtc-error { background:#fef2f2; border:1px solid #fecaca; color:#dc2626; padding:10px 14px; border-radius:8px; font-size:.85rem; margin-bottom:12px; }
.vtc-notice { color:#9ca3af; font-size:.85rem; padding:20px; text-align:center; }
