/* =========================================
   CLÉS CAROUGE v2 — Mobile-first Wizard
   ========================================= */

:root {
  --navy:      #0D1B2A;
  --navy2:     #1a2d45;
  --gold:      #C9A84C;
  --gold-l:    #e8c96a;
  --white:     #FFFFFF;
  --g100:      #f5f6f8;
  --g200:      #e8e9ed;
  --g400:      #b0b3be;
  --g600:      #6b6f7e;
  --g800:      #2a2d3a;
  --green:     #22c55e;
  --red:       #ef4444;
  --font:      'Inter', system-ui, sans-serif;
  --r:         14px;
  --r-lg:      20px;
  --sh:        0 4px 24px rgba(13,27,42,.10);
  --sh-lg:     0 12px 48px rgba(13,27,42,.18);
  --ease:      cubic-bezier(.4,0,.2,1);
  --t:         .25s var(--ease);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0 }
html  { scroll-behavior:smooth; font-size:16px; -webkit-text-size-adjust:100% }
body  { font-family:var(--font); color:var(--navy); background:var(--white); -webkit-font-smoothing:antialiased }
img   { max-width:100%; height:auto; display:block }
a     { text-decoration:none; color:inherit }
ul    { list-style:none }
button { font-family:var(--font); cursor:pointer }

/* ── Layout ── */
.container { max-width:1100px; margin:0 auto; padding:0 20px }
.section   { padding:80px 0 }
.section-sm{ padding:48px 0 }
.tc        { text-align:center }

/* ── Typography ── */
h1 { font-size:clamp(2rem,5vw,3.4rem); font-weight:800; line-height:1.12 }
h2 { font-size:clamp(1.6rem,3vw,2.4rem); font-weight:700; line-height:1.2 }
h3 { font-size:1.2rem; font-weight:700 }
.badge {
  display:inline-block;
  background:rgba(201,168,76,.12);
  color:var(--gold);
  border:1px solid rgba(201,168,76,.3);
  border-radius:50px;
  padding:5px 16px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  margin-bottom:16px
}
.section-sub { font-size:1.05rem; color:var(--g600); max-width:560px; margin:0 auto 48px; line-height:1.7 }

/* ── Buttons ── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:14px 28px; border-radius:50px;
  font-size:.95rem; font-weight:600; border:none;
  transition:transform var(--t), box-shadow var(--t), background var(--t);
  white-space:nowrap; -webkit-tap-highlight-color:transparent
}
.btn-primary {
  background:linear-gradient(135deg, var(--gold), var(--gold-l));
  color:var(--navy);
  box-shadow:0 4px 20px rgba(201,168,76,.38)
}
.btn-primary:hover  { transform:translateY(-2px); box-shadow:0 8px 32px rgba(201,168,76,.5) }
.btn-primary:active { transform:translateY(0) }
.btn-outline {
  background:transparent; color:var(--white);
  border:2px solid rgba(255,255,255,.35)
}
.btn-outline:hover { background:rgba(255,255,255,.08); border-color:var(--white) }
.btn-ghost {
  background:transparent; color:var(--navy);
  border:2px solid var(--g200)
}
.btn-ghost:hover { background:var(--g100); border-color:var(--g400) }
.btn-lg   { padding:18px 40px; font-size:1.05rem }
.btn-full { width:100%; padding:18px }
.btn-loading { pointer-events:none; opacity:.75 }
.btn-loading::after {
  content:'';
  display:inline-block; width:16px; height:16px;
  border:2px solid rgba(13,27,42,.25); border-top-color:var(--navy);
  border-radius:50%; animation:spin .7s linear infinite; margin-left:8px
}
@keyframes spin { to { transform:rotate(360deg) } }

/* ── Topbar ── */
.topbar { background:var(--navy); color:rgba(255,255,255,.7); font-size:13px; padding:9px 0 }
.topbar .container { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px }
.topbar-group { display:flex; gap:20px; align-items:center; flex-wrap:wrap }
.topbar-item  { display:flex; align-items:center; gap:6px }
.topbar-item a { color:var(--gold) }

/* ── Header ── */
.site-header {
  position:sticky; top:0; z-index:900;
  background:rgba(13,27,42,.97);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(201,168,76,.15);
  padding:14px 0; transition:box-shadow var(--t)
}
.header-inner { display:flex; align-items:center; justify-content:space-between; gap:20px }
.site-logo    { display:flex; align-items:center; gap:10px; color:var(--white); font-size:1.25rem; font-weight:800 }
.logo-icon    { width:38px; height:38px; background:linear-gradient(135deg,var(--gold),var(--gold-l)); border-radius:9px; display:flex; align-items:center; justify-content:center; font-size:20px }
.logo-text span { color:var(--gold) }
.site-nav     { display:flex; align-items:center; gap:28px }
.site-nav a   { color:rgba(255,255,255,.75); font-size:14px; font-weight:500; transition:color var(--t) }
.site-nav a:hover { color:var(--gold) }
.hamburger    { display:none; background:none; border:none; flex-direction:column; gap:5px; padding:4px }
.hamburger span { display:block; width:24px; height:2px; background:var(--white); border-radius:2px; transition:var(--t) }
.mobile-nav {
  display:none; position:fixed; inset:0; background:var(--navy);
  z-index:9999; flex-direction:column; align-items:center; justify-content:center; gap:28px
}
.mobile-nav.open   { display:flex }
.mobile-nav a      { color:var(--white); font-size:1.4rem; font-weight:700 }
.mobile-nav a:hover{ color:var(--gold) }
.mobile-nav-close  { position:absolute; top:20px; right:20px; background:none; border:none; color:var(--white); font-size:28px; cursor:pointer }

/* ── Hero ── */
.hero {
  background:linear-gradient(135deg, var(--navy) 0%, var(--navy2) 60%, #0a1520 100%);
  color:var(--white); padding:80px 0 70px; position:relative; overflow:hidden
}
.hero::before {
  content:''; position:absolute; top:-30%; right:-15%;
  width:600px; height:600px;
  background:radial-gradient(circle, rgba(201,168,76,.07) 0%, transparent 70%);
  pointer-events:none
}
.hero::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent)
}
.hero-inner { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center }
.hero-label {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(201,168,76,.1); border:1px solid rgba(201,168,76,.25);
  border-radius:50px; padding:7px 16px; font-size:12px; font-weight:700;
  color:var(--gold-l); letter-spacing:.06em; text-transform:uppercase; margin-bottom:20px
}
.hero-label::before { content:'●'; font-size:7px; color:var(--gold) }
.hero h1    { color:var(--white); margin-bottom:20px }
.hero h1 em { font-style:normal; background:linear-gradient(135deg,var(--gold),var(--gold-l)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text }
.hero-desc  { font-size:1.05rem; color:rgba(255,255,255,.68); line-height:1.75; margin-bottom:36px; max-width:460px }
.hero-btns  { display:flex; gap:14px; flex-wrap:wrap; align-items:center }
.hero-trust { display:flex; gap:24px; margin-top:40px; flex-wrap:wrap }
.trust-item { display:flex; align-items:center; gap:8px; font-size:13px; color:rgba(255,255,255,.55) }
.trust-item svg { color:var(--gold); flex-shrink:0 }

/* Hero card */
.hero-card {
  background:rgba(255,255,255,.05); backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.1); border-radius:20px; padding:36px;
  animation:float 5s ease-in-out infinite
}
@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }
.hero-card-badge {
  background:linear-gradient(135deg,var(--gold),var(--gold-l)); color:var(--navy);
  font-weight:700; font-size:12px; padding:7px 20px; border-radius:50px;
  display:inline-block; margin-bottom:24px
}
.hero-steps   { display:flex; flex-direction:column; gap:18px }
.hero-step    { display:flex; align-items:flex-start; gap:14px }
.step-num     { width:34px; height:34px; min-width:34px; background:rgba(201,168,76,.15); border:1px solid rgba(201,168,76,.3); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:13px; font-weight:800; color:var(--gold) }
.step-content h4 { color:var(--white); font-size:14px; margin-bottom:3px }
.step-content p  { color:rgba(255,255,255,.5); font-size:13px; line-height:1.5 }

.hero-stat-row { display:flex; gap:12px; margin-top:20px }
.hero-stat-chip {
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.1);
  border-radius:12px; padding:12px 16px; display:flex; align-items:center; gap:10px; flex:1
}
.chip-icon { font-size:20px }
.chip-val  { font-size:15px; font-weight:800; color:var(--white); display:block; line-height:1 }
.chip-lbl  { font-size:11px; color:rgba(255,255,255,.5); display:block; margin-top:2px }

/* ── Counters ── */
.counters { background:var(--navy); padding:56px 0 }
.counters-grid { display:grid; grid-template-columns:repeat(4,1fr) }
.counter-item  { text-align:center; padding:32px 16px; border-right:1px solid rgba(255,255,255,.06) }
.counter-item:last-child { border-right:none }
.counter-num   { font-size:clamp(2rem,3.5vw,3rem); font-weight:800; color:var(--white); display:block; line-height:1; margin-bottom:8px }
.counter-num-gold { color:var(--gold) }
.counter-label { font-size:14px; color:rgba(255,255,255,.5); line-height:1.4 }

/* ── How it works ── */
.how-it-works { background:var(--g100) }
.steps-grid   { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; position:relative }
.steps-grid::before {
  content:''; position:absolute; top:52px; left:22%; right:22%; height:2px;
  background:linear-gradient(90deg,var(--gold),var(--gold-l),var(--gold)); z-index:0
}
.step-card {
  background:var(--white); border-radius:var(--r-lg); padding:36px 28px;
  text-align:center; box-shadow:var(--sh); position:relative; z-index:1;
  transition:transform var(--t), box-shadow var(--t)
}
.step-card:hover { transform:translateY(-5px); box-shadow:var(--sh-lg) }
.step-icon-wrap  {
  width:72px; height:72px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  margin:0 auto 20px; font-size:30px; background:linear-gradient(135deg,var(--navy),var(--navy2));
  box-shadow:0 6px 20px rgba(13,27,42,.2); position:relative
}
.step-num-badge {
  position:absolute; top:-6px; right:-6px; width:22px; height:22px;
  background:var(--gold); border-radius:50%; display:flex; align-items:center;
  justify-content:center; font-size:11px; font-weight:800; color:var(--navy)
}
.step-card h3 { margin-bottom:10px }
.step-card p  { color:var(--g600); font-size:14px; line-height:1.7 }

/* ══════════════════════════════════════════
   WIZARD
══════════════════════════════════════════ */
.wizard-section { background:var(--white) }

/* Progress bar */
.wizard-progress {
  display:flex; align-items:center; justify-content:center;
  gap:0; margin-bottom:52px; position:relative
}
.wp-step {
  display:flex; flex-direction:column; align-items:center; gap:8px;
  position:relative; z-index:1
}
.wp-bubble {
  width:44px; height:44px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:16px; font-weight:800; border:2px solid var(--g200);
  background:var(--white); color:var(--g400);
  transition:all var(--t)
}
.wp-step.active .wp-bubble  { background:var(--navy); border-color:var(--navy); color:var(--white) }
.wp-step.done   .wp-bubble  { background:var(--gold); border-color:var(--gold); color:var(--navy) }
.wp-label { font-size:12px; font-weight:600; color:var(--g400); white-space:nowrap; transition:color var(--t) }
.wp-step.active .wp-label { color:var(--navy) }
.wp-step.done   .wp-label { color:var(--gold) }
.wp-line { flex:1; height:2px; background:var(--g200); max-width:80px; margin-bottom:22px; transition:background var(--t) }
.wp-line.done { background:var(--gold) }

/* Step panels */
.wizard-panel    { display:none }
.wizard-panel.active { display:block; animation:fadeSlide .35s var(--ease) both }
@keyframes fadeSlide { from{opacity:0;transform:translateY(16px)} to{opacity:1;transform:translateY(0)} }

/* ── Step 1: Brand grid ── */
.wizard-header { text-align:center; margin-bottom:36px }
.wizard-header h2 { margin-bottom:8px }
.wizard-header p  { color:var(--g600); font-size:1rem }

.search-box {
  display:flex; align-items:center; gap:12px;
  background:var(--g100); border:1.5px solid var(--g200); border-radius:50px;
  padding:10px 20px; max-width:420px; margin:0 auto 36px;
  transition:border-color var(--t)
}
.search-box:focus-within { border-color:var(--gold); background:var(--white) }
.search-box input { border:none; background:transparent; font-size:15px; flex:1; outline:none; font-family:var(--font); color:var(--navy) }
.search-box input::placeholder { color:var(--g400) }

.brands-grid {
  display:grid; grid-template-columns:repeat(auto-fill, minmax(160px,1fr)); gap:16px
}
.brand-card {
  background:var(--g100); border:2px solid var(--g200); border-radius:var(--r-lg);
  padding:24px 16px; text-align:center; cursor:pointer;
  transition:all var(--t); -webkit-tap-highlight-color:transparent;
  display:flex; flex-direction:column; align-items:center; gap:10px
}
.brand-card:hover  { border-color:var(--gold); background:var(--white); transform:translateY(-3px); box-shadow:var(--sh) }
.brand-card:active { transform:translateY(0) }
.brand-card.selected { border-color:var(--gold); background:rgba(201,168,76,.06); box-shadow:0 0 0 3px rgba(201,168,76,.2) }
.brand-logo {
  width:64px; height:44px; object-fit:contain;
  filter:grayscale(1); transition:filter var(--t)
}
.brand-card:hover .brand-logo,
.brand-card.selected .brand-logo { filter:none }
.brand-logo-placeholder {
  width:64px; height:44px; display:flex; align-items:center; justify-content:center;
  font-size:28px
}
.brand-name { font-size:14px; font-weight:700; color:var(--navy) }
.brand-count { font-size:12px; color:var(--g400) }
.brand-card.hidden { display:none }

/* ── Step 2: Model grid ── */
.back-btn {
  display:inline-flex; align-items:center; gap:6px;
  color:var(--g600); font-size:14px; font-weight:500; margin-bottom:24px;
  background:none; border:none; transition:color var(--t); padding:0
}
.back-btn:hover { color:var(--navy) }

.models-grid {
  display:grid; grid-template-columns:repeat(auto-fill, minmax(200px,1fr)); gap:20px
}
.model-card {
  background:var(--white); border:2px solid var(--g200); border-radius:var(--r-lg);
  overflow:hidden; cursor:pointer; transition:all var(--t);
  -webkit-tap-highlight-color:transparent
}
.model-card:hover  { border-color:var(--gold); transform:translateY(-3px); box-shadow:var(--sh-lg) }
.model-card:active { transform:translateY(0) }
.model-card.selected { border-color:var(--gold); box-shadow:0 0 0 3px rgba(201,168,76,.2) }
.model-img-wrap { position:relative; aspect-ratio:4/3; background:var(--g100); overflow:hidden }
.model-img-wrap img { width:100%; height:100%; object-fit:cover; transition:transform .4s var(--ease) }
.model-card:hover .model-img-wrap img { transform:scale(1.05) }
/* ── Model badges (flux-based) ── */
.model-badge {
  position:absolute; top:10px; right:10px;
  background:rgba(13,27,42,.88); color:var(--gold); font-size:10px; font-weight:700;
  padding:4px 10px; border-radius:50px; backdrop-filter:blur(4px); white-space:nowrap
}
.model-badge--carte       { background:rgba(13,27,42,.88); color:var(--gold) }
.model-badge--cle_modele  { background:rgba(13,27,42,.88); color:#7dd3fc }
.model-badge--photo_libre { background:rgba(13,27,42,.88); color:#86efac }
.model-badge--contact     { background:rgba(13,27,42,.88); color:#fda4af }
.model-badge--a_venir     { background:rgba(201,168,76,.18); color:var(--gold); border:1px solid rgba(201,168,76,.3) }

/* ── Disabled / coming-soon model cards ── */
.model-card--disabled { opacity:.55; cursor:not-allowed }
.model-card--disabled:hover { transform:none; border-color:var(--g200); box-shadow:none }
.model-card--soon { opacity:.48; cursor:default; filter:grayscale(.4) }
.model-card--soon:hover { transform:none; border-color:var(--g200); box-shadow:none }

/* ── Contact button inside model card ── */
.model-contact-btn {
  display:inline-flex; align-items:center; gap:6px;
  margin-top:10px; padding:8px 14px; border-radius:8px;
  background:var(--navy); color:var(--white); font-size:13px; font-weight:600;
  text-decoration:none; transition:background var(--t)
}
.model-contact-btn:hover { background:var(--gold); color:var(--navy) }
.model-contact-btn--info { background:var(--g200); color:var(--g600); cursor:default }

/* ── Price states ── */
.model-price--na { font-size:14px; color:var(--g400) }

.model-info    { padding:16px }
.model-name    { font-size:15px; font-weight:700; color:var(--navy); margin-bottom:4px }
.model-ref     { font-size:12px; color:var(--g400); margin-bottom:8px }
.model-desc    { font-size:13px; color:var(--g600); line-height:1.5; margin-bottom:10px }
.model-price   { font-size:16px; font-weight:800; color:var(--gold) }
.model-price span { font-size:12px; font-weight:500; color:var(--g400) }

.model-img-placeholder {
  width:100%; height:100%; display:flex; align-items:center; justify-content:center;
  color:var(--g300)
}

/* ════════════════════════════════════════
   FLUX-ADAPTIVE FORM ELEMENTS
════════════════════════════════════════ */

/* ── Carte choice bar ── */
.carte-choice-bar {
  background:var(--g50); border:1px solid var(--g200); border-radius:var(--r-lg);
  padding:20px; margin-bottom:24px
}
.choice-label { font-size:14px; font-weight:700; color:var(--navy); margin-bottom:12px }
.choice-btns  { display:grid; grid-template-columns:1fr 1fr; gap:10px }
.choice-btn {
  display:flex; flex-direction:column; align-items:center; gap:6px;
  padding:14px 12px; border-radius:12px; border:2px solid var(--g200);
  background:var(--white); cursor:pointer; font-size:13px; font-weight:600;
  color:var(--navy); transition:all var(--t); line-height:1.3; text-align:center
}
.choice-btn:hover { border-color:var(--gold) }
.choice-btn.active {
  border-color:var(--gold); background:rgba(201,168,76,.07);
  box-shadow:0 0 0 3px rgba(201,168,76,.15)
}
.choice-price {
  font-size:15px; font-weight:800; color:var(--gold);
  background:rgba(201,168,76,.1); padding:3px 10px; border-radius:20px
}
@media (max-width:400px) { .choice-btns { grid-template-columns:1fr } }

/* ── No-carte info block ── */
.no-carte-info { margin-bottom:24px }
.no-carte-alert {
  background:#fff8e1; border-left:4px solid var(--gold); border-radius:0 12px 12px 0;
  padding:16px 20px; margin-bottom:16px
}
.no-carte-alert strong { display:block; margin-bottom:6px; color:var(--navy) }
.no-carte-alert p { font-size:13px; color:var(--g600); line-height:1.6; margin:0 }
.dup-form-links { }
.dup-btns { display:flex; flex-wrap:wrap; gap:10px }
.dup-btn {
  display:inline-flex; align-items:center; gap:6px;
  padding:10px 18px; border-radius:10px; border:2px solid var(--gold);
  color:var(--gold); font-size:13px; font-weight:700; text-decoration:none;
  background:rgba(201,168,76,.06); transition:all var(--t)
}
.dup-btn:hover { background:var(--gold); color:var(--navy) }
.dup-btn--na   { opacity:.5; cursor:default; border-style:dashed }
.dup-btn--na:hover { background:transparent; color:var(--gold) }

/* ── Cle-modele instructions ── */
.cle-modele-instructions { margin-bottom:24px }
.info-box {
  background:linear-gradient(135deg,var(--navy),var(--navy2));
  border-radius:var(--r-lg); padding:24px 28px; color:var(--white)
}
.info-box h4 { font-size:16px; margin-bottom:14px; color:var(--gold) }
.info-box ol  { padding-left:20px; margin:0 0 14px }
.info-box ol li { font-size:14px; line-height:1.7; color:rgba(255,255,255,.85) }
.info-box ol li strong { color:var(--white) }
.info-note { font-size:13px; color:rgba(255,255,255,.6); margin:0 }

/* ── Demandeur (type selector) ── */
.demandeur-group { margin-bottom:24px }
.radio-group { display:flex; flex-wrap:wrap; gap:10px }
.radio-opt {
  display:flex; align-items:center; gap:8px;
  padding:10px 16px; border-radius:10px; border:2px solid var(--g200);
  cursor:pointer; font-size:14px; font-weight:600; color:var(--navy);
  transition:all var(--t); background:var(--white)
}
.radio-opt:has(input:checked) { border-color:var(--gold); background:rgba(201,168,76,.07) }
.radio-opt input { accent-color:var(--gold) }
@media (max-width:480px) { .radio-group { flex-direction:column } }

/* Selected model summary */
.model-selected-summary {
  display:none; background:linear-gradient(135deg,var(--navy),var(--navy2));
  border-radius:var(--r-lg); padding:20px 24px; color:var(--white);
  align-items:center; gap:16px; margin-bottom:28px
}
.model-selected-summary.visible { display:flex }
.mss-img { width:72px; height:54px; object-fit:cover; border-radius:8px; flex-shrink:0 }
.mss-info h4 { font-size:15px; margin-bottom:2px }
.mss-info p  { font-size:13px; color:rgba(255,255,255,.6) }
.mss-change  { margin-left:auto; color:var(--gold); font-size:13px; font-weight:600; background:none; border:none; cursor:pointer; flex-shrink:0 }

/* Loading state */
.models-loading {
  text-align:center; padding:48px; display:none; flex-direction:column; align-items:center; gap:16px
}
.models-loading.visible { display:flex }
.spinner {
  width:36px; height:36px; border:3px solid var(--g200);
  border-top-color:var(--gold); border-radius:50%; animation:spin .8s linear infinite
}

.models-empty {
  text-align:center; padding:48px; display:none; flex-direction:column; align-items:center; gap:12px; color:var(--g600)
}
.models-empty.visible { display:flex }

/* ── Step 3: Form ── */
.form-layout { display:grid; grid-template-columns:1fr 360px; gap:36px; align-items:start }

.form-card  { background:var(--white); border:1px solid var(--g200); border-radius:20px; overflow:hidden; box-shadow:var(--sh) }
.fcard-head { background:linear-gradient(135deg,var(--navy),var(--navy2)); padding:28px 32px; color:var(--white) }
.fcard-head h3 { font-size:1.2rem; margin-bottom:6px }
.fcard-head p  { font-size:14px; color:rgba(255,255,255,.6) }
.fcard-body { padding:28px 32px }

.form-section-title {
  font-size:11px; text-transform:uppercase; letter-spacing:.1em;
  color:var(--g400); font-weight:700; margin-bottom:20px
}
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px }
.form-group { margin-bottom:20px }
.form-group label { display:block; font-size:13px; font-weight:600; color:var(--navy); margin-bottom:7px }
.form-group label .req { color:var(--gold) }
.form-group input,
.form-group select,
.form-group textarea {
  width:100%; padding:13px 16px; border:1.5px solid var(--g200); border-radius:10px;
  font-size:15px; font-family:var(--font); color:var(--navy); background:var(--g100);
  transition:all var(--t); -webkit-appearance:none; appearance:none
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  outline:none; border-color:var(--gold); background:var(--white);
  box-shadow:0 0 0 3px rgba(201,168,76,.12)
}
.form-group select {
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%230D1B2A' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 14px center; padding-right:40px; cursor:pointer
}
.form-group textarea { resize:vertical; min-height:80px }
.form-divider { height:1px; background:var(--g200); margin:24px 0 }
.input-error { border-color:var(--red) !important; box-shadow:0 0 0 3px rgba(239,68,68,.12) !important }
.field-error { font-size:12px; color:var(--red); margin-top:5px }

/* Upload / Camera zone */
.upload-zone {
  border:2px dashed var(--g200); border-radius:14px; padding:28px 20px;
  text-align:center; cursor:pointer; transition:all var(--t);
  background:var(--g100); position:relative; overflow:hidden
}
.upload-zone:hover, .upload-zone.drag-over { border-color:var(--gold); background:rgba(201,168,76,.03) }
.upload-zone input { position:absolute; inset:0; opacity:0; cursor:pointer; width:100%; height:100% }
.upload-icon  { font-size:36px; display:block; margin-bottom:10px }
.upload-main  { font-weight:700; font-size:15px; color:var(--navy); display:block; margin-bottom:4px }
.upload-sub   { font-size:13px; color:var(--g600) }

/* Camera buttons on mobile */
.upload-actions { display:flex; gap:10px; margin-top:14px; justify-content:center; flex-wrap:wrap }
.upload-btn {
  display:inline-flex; align-items:center; gap:6px;
  padding:9px 18px; border-radius:50px; font-size:13px; font-weight:600;
  border:1.5px solid var(--g200); background:var(--white); color:var(--navy);
  cursor:pointer; transition:all var(--t)
}
.upload-btn:hover { border-color:var(--gold); color:var(--gold) }
.upload-btn-camera { border-color:var(--gold); background:rgba(201,168,76,.08); color:var(--navy) }

.upload-preview { display:none; margin-top:16px; position:relative; border-radius:10px; overflow:hidden }
.upload-preview img { width:100%; max-height:200px; object-fit:cover }
.upload-preview-pdf { display:flex; align-items:center; gap:10px; background:var(--g100); padding:12px 16px; border-radius:10px; font-size:13px }
.upload-remove {
  position:absolute; top:8px; right:8px;
  background:rgba(13,27,42,.8); color:var(--white); border:none;
  width:28px; height:28px; border-radius:50%; cursor:pointer; font-size:13px;
  display:flex; align-items:center; justify-content:center
}

/* Form alerts */
.alert {
  padding:14px 18px; border-radius:10px; font-size:14px;
  margin-bottom:18px; display:flex; align-items:center; gap:10px
}
.alert-success { background:rgba(34,197,94,.1); color:#166534; border:1px solid rgba(34,197,94,.25) }
.alert-error   { background:rgba(239,68,68,.1);  color:#991b1b; border:1px solid rgba(239,68,68,.25) }

/* Sidebar */
.order-sidebar { position:sticky; top:100px }
.sidebar-card  { background:var(--g100); border:1px solid var(--g200); border-radius:var(--r-lg); padding:24px; margin-bottom:16px }
.sidebar-card.dark { background:linear-gradient(135deg,var(--navy),var(--navy2)); border-color:transparent; color:var(--white) }
.sidebar-card h4 { font-size:15px; margin-bottom:14px; display:flex; align-items:center; gap:8px }
.sidebar-card.dark h4 { color:var(--white) }
.sidebar-list li { display:flex; align-items:flex-start; gap:9px; font-size:14px; color:var(--g800); line-height:1.5; padding:5px 0 }
.sidebar-card.dark .sidebar-list li { color:rgba(255,255,255,.75) }
.price-box     { border:2px solid var(--gold); border-radius:var(--r-lg); padding:20px 24px; text-align:center; margin-bottom:16px }
.price-label   { font-size:12px; color:var(--g600); margin-bottom:6px }
.price-value   { font-size:2rem; font-weight:800; color:var(--navy); line-height:1 }
.price-value span { font-size:.9rem; font-weight:500; color:var(--g600) }
.price-note    { font-size:12px; color:var(--g600); margin-top:6px }

/* ── Testimonials ── */
.testimonials { background:var(--g100) }
.rating-wrap  { display:flex; justify-content:center; margin-bottom:44px }
.rating-badge { background:var(--white); border-radius:var(--r-lg); padding:18px 28px; display:inline-flex; align-items:center; gap:20px; box-shadow:var(--sh) }
.rating-big   { font-size:3rem; font-weight:800; color:var(--navy); line-height:1 }
.rating-stars { color:#f59e0b; font-size:20px; letter-spacing:2px }
.rating-sub   { font-size:14px; color:var(--g600) }
.google-g     { font-size:13px; font-weight:800; margin-top:4px }
.g-blue{color:#4285F4}.g-red{color:#EA4335}.g-yellow{color:#FBBC05}.g-green{color:#34A853}

.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px }
.tcard {
  background:var(--white); border-radius:var(--r-lg); padding:28px; box-shadow:var(--sh);
  transition:transform var(--t), box-shadow var(--t); position:relative
}
.tcard:hover { transform:translateY(-4px); box-shadow:var(--sh-lg) }
.tcard::before { content:'"'; position:absolute; top:12px; right:20px; font-size:64px; color:rgba(201,168,76,.1); font-family:Georgia,serif; line-height:1 }
.tcard-stars { color:#f59e0b; font-size:16px; letter-spacing:2px; margin-bottom:14px }
.tcard-text  { font-size:14px; line-height:1.75; color:var(--g800); margin-bottom:20px }
.tcard-author { display:flex; align-items:center; gap:12px }
.tcard-avatar { width:44px; height:44px; border-radius:50%; background:linear-gradient(135deg,var(--navy),var(--gold)); display:flex; align-items:center; justify-content:center; font-weight:800; color:var(--white); font-size:16px; flex-shrink:0 }
.tcard-name   { font-weight:700; font-size:14px }
.tcard-city   { font-size:12px; color:var(--g400) }

/* ── FAQ ── */
.faq-section { background:var(--white) }
.faq-list    { max-width:720px; margin:0 auto }
.faq-item    { background:var(--g100); border:1px solid var(--g200); border-radius:var(--r); margin-bottom:10px; overflow:hidden }
.faq-q       { width:100%; background:none; border:none; padding:18px 22px; text-align:left; font-size:15px; font-weight:600; color:var(--navy); cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:14px; font-family:var(--font) }
.faq-q:hover { color:var(--gold) }
.faq-arrow   { width:26px; height:26px; min-width:26px; border-radius:50%; background:var(--white); display:flex; align-items:center; justify-content:center; color:var(--gold); transition:transform var(--t); font-size:14px }
.faq-item.open .faq-arrow { transform:rotate(180deg) }
.faq-ans     { max-height:0; overflow:hidden; transition:max-height .4s var(--ease) }
.faq-ans p   { padding:0 22px 18px; font-size:14px; color:var(--g600); line-height:1.75 }
.faq-item.open .faq-ans { max-height:280px }

/* ── Trust ── */
.trust-section { background:var(--navy); padding:44px 0 }
.trust-grid    { display:flex; align-items:center; justify-content:center; gap:44px; flex-wrap:wrap }
.trust-logo    { display:flex; flex-direction:column; align-items:center; gap:7px; color:rgba(255,255,255,.45); transition:color var(--t) }
.trust-logo:hover { color:var(--gold) }
.trust-logo-icon { font-size:32px }
.trust-logo-text { font-size:11px; font-weight:700; letter-spacing:.08em; text-transform:uppercase }

/* ── CTA Section ── */
.cta-section { background:linear-gradient(135deg,var(--navy),var(--navy2)); color:var(--white); text-align:center }
.cta-section h2 { color:var(--white); margin-bottom:14px }

/* ── Footer ── */
.site-footer   { background:#060d14; color:rgba(255,255,255,.6); padding:60px 0 0 }
.footer-grid   { display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:40px; padding-bottom:50px; border-bottom:1px solid rgba(255,255,255,.07) }
.footer-brand p { font-size:14px; line-height:1.7; margin-bottom:20px; max-width:280px }
.footer-title  { color:var(--white); font-size:14px; font-weight:700; margin-bottom:16px }
.footer-links  { display:flex; flex-direction:column; gap:9px }
.footer-links a { font-size:13px; transition:color var(--t) }
.footer-links a:hover { color:var(--gold) }
.footer-contact { display:flex; flex-direction:column; gap:12px }
.fci { display:flex; align-items:flex-start; gap:10px; font-size:13px; line-height:1.5 }
.fci-icon { color:var(--gold); font-size:16px; flex-shrink:0; margin-top:1px }
.footer-bottom { padding:20px 0; display:flex; align-items:center; justify-content:space-between; font-size:12px; flex-wrap:wrap; gap:10px }
.footer-bottom a { color:var(--gold) }

/* ── Success Page ── */
.success-page { min-height:65vh; display:flex; align-items:center; justify-content:center }
.success-card { background:var(--white); border-radius:20px; padding:52px 44px; text-align:center; max-width:520px; box-shadow:var(--sh-lg); border:1px solid var(--g200) }
.success-icon { width:72px; height:72px; background:linear-gradient(135deg,var(--green),#16a34a); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:32px; margin:0 auto 24px }
.success-card h2 { margin-bottom:14px }
.success-card p  { color:var(--g600); font-size:15px; line-height:1.7; margin-bottom:28px }

/* ── Scroll reveal ── */
.reveal { opacity:0; transform:translateY(24px); transition:opacity .6s var(--ease), transform .6s var(--ease) }
.reveal.visible { opacity:1; transform:translateY(0) }

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media (max-width:1024px) {
  .hero-inner  { grid-template-columns:1fr }
  .hero-visual { display:none }
  .form-layout { grid-template-columns:1fr }
  .order-sidebar { position:static }
  .footer-grid { grid-template-columns:1fr 1fr }
}
@media (max-width:768px) {
  .section { padding:56px 0 }
  .hero { padding:56px 0 48px }
  .counters-grid { grid-template-columns:repeat(2,1fr) }
  .counter-item  { border-right:none; border-bottom:1px solid rgba(255,255,255,.06) }
  .counter-item:nth-child(2n) { border-bottom:none }
  .steps-grid    { grid-template-columns:1fr }
  .steps-grid::before { display:none }
  .testimonials-grid { grid-template-columns:1fr }
  .brands-grid   { grid-template-columns:repeat(2,1fr) }
  .models-grid   { grid-template-columns:repeat(2,1fr) }
  .form-row      { grid-template-columns:1fr }
  .site-nav      { display:none }
  .hamburger     { display:flex }
  .footer-grid   { grid-template-columns:1fr; gap:28px }
  .hero-btns     { flex-direction:column; align-items:flex-start }
  .wp-label      { display:none }
  .fcard-body    { padding:20px }
  .fcard-head    { padding:20px 24px }
  .wizard-progress { gap:0 }
  .wp-line       { max-width:48px }
}
@media (max-width:480px) {
  .brands-grid  { grid-template-columns:repeat(2,1fr) }
  .models-grid  { grid-template-columns:1fr }
  .rating-badge { flex-direction:column; text-align:center }
  h1 { font-size:1.85rem }
}
