/* ═══════════════════════════════════════════
   SCORPX DESIGN — Marquage Flotte & Véhicule
   Thème : Corporate-Luxe B2B · Dark Gold · v1
   ═══════════════════════════════════════════ */

:root {
  --gold-hi:   #F5D78E;
  --gold:      #C9A84C;
  --gold-lo:   #9A6E2A;
  --gold-deep: #7A5118;
  --gold-glow: rgba(201,168,76,0.13);
  --gold-rim:  rgba(201,168,76,0.28);
  --gold-rim2: rgba(201,168,76,0.12);
  --gold-rim3: rgba(201,168,76,0.05);

  --bg:  #0C0A08;
  --bg2: #100E0A;
  --bg3: #141108;
  --bg4: #1A160F;

  --text:   #EDE8DF;
  --muted:  rgba(237,232,223,0.50);
  --dim:    rgba(237,232,223,0.22);
  --dimmer: rgba(237,232,223,0.10);
  --green:  #4CAF7A;
  --green-bg: rgba(76,175,122,0.12);

  --font-d: 'Cinzel', serif;
  --font-s: 'Cormorant Garamond', serif;
  --font-u: 'Raleway', sans-serif;
  --ease:   cubic-bezier(0.16,1,0.3,1);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { background: var(--bg); color: var(--text); font-family: var(--font-u); font-weight: 300; overflow-x: hidden; cursor: none; }

/* ── Grain ── */
.grain { position:fixed; inset:0; z-index:300; pointer-events:none; background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.88' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E"); background-size:180px 180px; opacity:0.45; }

/* ── Cursor ── */
#cur-dot, #cur-ring { position:fixed; border-radius:50%; pointer-events:none; z-index:9999; transform:translate(-50%,-50%); opacity:0; transition:opacity .3s; }
#cur-dot  { width:6px; height:6px; background:var(--gold); }
#cur-ring { width:32px; height:32px; border:1px solid rgba(201,168,76,.45); transition:width .25s, height .25s, opacity .3s, border-color .25s; }

/* ════════════════════════ HEADER ════════════════════════ */
.header { position:fixed; top:0; left:0; right:0; z-index:200; display:flex; align-items:center; justify-content:space-between; padding:22px 56px; background:linear-gradient(to bottom,rgba(12,10,8,.94),transparent); transition:background .4s, border-color .4s; }
.header.scrolled { background:rgba(12,10,8,.97); border-bottom:1px solid var(--gold-rim2); backdrop-filter:blur(14px); }
.logo-wrap { display:flex; align-items:center; gap:12px; text-decoration:none; }
.logo-hex  { width:40px; height:40px; flex-shrink:0; }
.logo-text { display:flex; flex-direction:column; gap:2px; }
.logo-name { font-family:var(--font-d); font-size:15px; font-weight:600; letter-spacing:.3em; background:linear-gradient(130deg,var(--gold-hi),var(--gold)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.logo-sub  { font-size:7px; font-weight:200; letter-spacing:.55em; color:var(--gold-lo); text-transform:uppercase; }
.nav { display:flex; align-items:center; gap:36px; }
.nav a { font-size:10px; font-weight:300; letter-spacing:.2em; text-transform:uppercase; text-decoration:none; color:var(--muted); transition:color .3s; position:relative; }
.nav a::after { content:''; position:absolute; bottom:-4px; left:0; right:0; height:1px; background:var(--gold); transform:scaleX(0); transform-origin:left; transition:transform .35s; }
.nav a:hover { color:var(--gold-hi); }
.nav a:hover::after { transform:scaleX(1); }
.nav-cta { color:var(--bg) !important; background:linear-gradient(130deg,var(--gold-hi),var(--gold)); padding:10px 24px; font-weight:400 !important; }
.nav-cta::after { display:none !important; }
.nav-cta:hover { transform:translateY(-2px); box-shadow:0 10px 28px rgba(201,168,76,.3); }
.burger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:none; padding:4px; }
.burger span { display:block; width:24px; height:1px; background:var(--gold); transition:.3s; }
.mobile-nav { display:none; position:fixed; top:70px; left:0; right:0; z-index:199; background:rgba(12,10,8,.97); border-bottom:1px solid var(--gold-rim2); padding:32px 40px; flex-direction:column; gap:24px; }
.mobile-nav a { font-size:13px; letter-spacing:.2em; text-transform:uppercase; text-decoration:none; color:var(--muted); }
.mobile-nav.open { display:flex; }

/* ════════════════════════ TYPO ════════════════════════ */
.section-tag { font-size:12px; font-weight:300; letter-spacing:.45em; text-transform:uppercase; color:var(--gold); margin-bottom:18px; }
.section-title { font-family:var(--font-d); font-size:clamp(26px,3.8vw,46px); font-weight:400; letter-spacing:.05em; line-height:1.18; color:var(--text); margin-bottom:18px; }
.section-title em { font-family:var(--font-s); font-style:italic; font-weight:300; background:linear-gradient(130deg,var(--gold-hi),var(--gold)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.section-sub { font-family:var(--font-s); font-size:18px; font-style:italic; color:var(--muted); line-height:1.7; margin-bottom:0; }

/* Boutons */
.btn-gold { display:inline-flex; align-items:center; gap:14px; font-size:10px; font-weight:400; letter-spacing:.22em; text-transform:uppercase; text-decoration:none; color:var(--bg); background:linear-gradient(130deg,var(--gold-hi),var(--gold)); padding:16px 38px; position:relative; overflow:hidden; transition:transform .3s, box-shadow .3s; }
.btn-gold::before { content:''; position:absolute; inset:0; background:linear-gradient(130deg,var(--gold),var(--gold-lo)); opacity:0; transition:opacity .35s; }
.btn-gold:hover { transform:translateY(-3px); box-shadow:0 18px 45px rgba(201,168,76,.35); }
.btn-gold:hover::before { opacity:1; }
.btn-gold span,.btn-gold svg { position:relative; z-index:1; }
.btn-gold svg { width:18px; transition:transform .3s; }
.btn-gold:hover svg { transform:translateX(5px); }
.btn-outline { display:inline-flex; align-items:center; font-size:10px; font-weight:300; letter-spacing:.22em; text-transform:uppercase; text-decoration:none; color:var(--gold); border:1px solid var(--gold-rim); padding:16px 38px; backdrop-filter:blur(8px); background:rgba(12,10,8,.25); transition:all .3s; }
.btn-outline:hover { color:var(--gold-hi); border-color:var(--gold); background:var(--gold-glow); transform:translateY(-3px); }

/* ════════════════════════ HERO ════════════════════════ */
.hero { position:relative; height:100vh; min-height:640px; overflow:hidden; }
.hero-video-wrap { position:absolute; inset:0; z-index:0; }
.hero-video { width:100%; height:100%; object-fit:cover; object-position:center; background:var(--bg3); }
.hero-vid-dark { position:absolute; inset:0; background:rgba(8,7,5,.6); }
.hero-vid-vignette { position:absolute; inset:0; background:radial-gradient(ellipse 80% 80% at 50% 50%, transparent 20%, rgba(4,3,2,.88) 100%); }
.hero-vid-scanlines { position:absolute; inset:0; pointer-events:none; background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,0,0,.05) 3px,rgba(0,0,0,.05) 4px); }

/* Bande verticale gauche — signature B2B */
.hero-stripe { position:absolute; left:0; top:0; bottom:0; z-index:15; width:56px; border-right:1px solid var(--gold-rim2); background:rgba(12,10,8,.45); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:20px; padding:20px 0; animation:stripeFade .8s var(--ease) both; }
.hs-num { font-family:var(--font-d); font-size:11px; letter-spacing:.25em; color:var(--gold-deep); writing-mode:vertical-rl; }
.hs-line { width:1px; height:60px; background:linear-gradient(to bottom,transparent,var(--gold-rim),transparent); }
.hs-text { font-size:7px; letter-spacing:.35em; text-transform:uppercase; color:var(--dim); writing-mode:vertical-rl; white-space:nowrap; }
@keyframes stripeFade { from{opacity:0;transform:translateX(-12px)} to{opacity:1;transform:translateX(0)} }

.hero-content { position:absolute; inset:0; z-index:20; display:flex; flex-direction:column; justify-content:center; padding:0 7% 0 calc(7% + 56px); pointer-events:none; }

.hero-badge { display:inline-flex; align-items:center; gap:10px; font-size:9px; font-weight:300; letter-spacing:.42em; text-transform:uppercase; color:var(--gold); border:1px solid var(--gold-rim); padding:8px 20px 8px 16px; background:rgba(12,10,8,.45); backdrop-filter:blur(8px); margin-bottom:32px; width:fit-content; animation:heroFade .8s .2s var(--ease) both; }
.badge-dot { width:5px; height:5px; border-radius:50%; background:var(--gold); animation:pulse 2s ease-in-out infinite; }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(.7)} }

.hero-title { font-family:var(--font-d); font-weight:900; line-height:1; margin-bottom:32px; animation:heroFade .8s .35s var(--ease) both; }
.hero-title .ht-main { display:block; font-size:clamp(46px,7.5vw,100px); color:var(--text); letter-spacing:-.01em; }
.hero-title em { display:block; font-family:var(--font-s); font-style:italic; font-weight:300; font-size:clamp(42px,7vw,92px); background:linear-gradient(160deg,var(--gold-hi) 0%,var(--gold) 55%,var(--gold-deep) 100%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.hero-title .ht-sub { display:block; font-family:var(--font-d); font-size:clamp(22px,3.5vw,48px); color:var(--muted); font-weight:400; letter-spacing:.06em; }

.hero-bottom { display:flex; align-items:flex-end; justify-content:space-between; flex-wrap:wrap; gap:28px; animation:heroFade .8s .5s var(--ease) both; }
.hero-tagline { font-family:var(--font-s); font-size:clamp(15px,1.8vw,20px); font-style:italic; color:var(--muted); line-height:1.75; }
.hero-actions { display:flex; gap:16px; flex-wrap:wrap; pointer-events:all; }
@keyframes heroFade { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:translateY(0)} }

.hc { position:absolute; z-index:15; width:44px; height:44px; pointer-events:none; }
.hc::before,.hc::after { content:''; position:absolute; background:var(--gold); opacity:.38; }
.hc::before { width:100%; height:1px; }
.hc::after  { width:1px; height:100%; }
.hc-tl{top:78px;left:calc(32px + 56px)}.hc-tl::before,.hc-tl::after{top:0;left:0}
.hc-tr{top:78px;right:32px;transform:rotate(90deg)}.hc-tr::before,.hc-tr::after{top:0;left:0}
.hc-bl{bottom:32px;left:calc(32px + 56px);transform:rotate(-90deg)}.hc-bl::before,.hc-bl::after{top:0;left:0}
.hc-br{bottom:32px;right:32px;transform:rotate(180deg)}.hc-br::before,.hc-br::after{top:0;left:0}

.hero-scroll { position:absolute; bottom:36px; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:10px; z-index:15; pointer-events:none; animation:fadeIn 1s 1.1s ease both; }
.scroll-track { width:1px; height:48px; background:linear-gradient(to bottom,var(--gold-rim),transparent); animation:scrollPulse 2s ease-in-out infinite; }
.scroll-txt { font-size:8px; letter-spacing:.4em; text-transform:uppercase; color:var(--dim); }
@keyframes scrollPulse { 0%,100%{transform:scaleY(1)} 50%{transform:scaleY(.55)} }
@keyframes fadeIn { from{opacity:0}to{opacity:1} }

/* ════════════════════════ IMPACT ════════════════════════ */
.impact-section { padding:80px 7%; border-top:1px solid var(--gold-rim2); background:var(--bg2); }
.impact-label { font-size:12px; letter-spacing:.4em; text-transform:uppercase; color:var(--dim); margin-bottom:48px; }
.impact-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--gold-rim2); border:1px solid var(--gold-rim2); }
.impact-card { background:var(--bg2); padding:40px 32px; display:flex; flex-direction:column; gap:12px; position:relative; overflow:hidden; transition:background .35s; }
.impact-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(to right,transparent,var(--gold),transparent); opacity:0; transition:opacity .4s; }
.impact-card:hover { background:var(--bg3); }
.impact-card:hover::before { opacity:1; }
.ic-val { display:flex; align-items:baseline; gap:4px; }
.ic-num { font-family:var(--font-d); font-size:clamp(42px,5vw,62px); font-weight:900; background:linear-gradient(130deg,var(--gold-hi),var(--gold)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; line-height:1; }
.ic-unit { font-family:var(--font-d); font-size:24px; font-weight:600; color:var(--gold); }
.ic-label { font-size:12px; line-height:1.65; color:var(--muted); }
.ic-bar { height:1px; background:var(--gold-rim2); margin-top:auto; }

/* ════════════════════════ AVANTAGES ════════════════════════ */
.avantages-section { padding:120px 7%; border-top:1px solid var(--gold-rim2); display:grid; grid-template-columns:360px 1fr; gap:100px; align-items:start; }
.av-left { position:sticky; top:100px; display:flex; flex-direction:column; gap:20px; }
.av-intro { font-size:14px; line-height:1.9; color:var(--muted); }
.av-cta { width:fit-content; margin-top:12px; }

.av-right { display:flex; flex-direction:column; gap:0; border:1px solid var(--gold-rim2); }
.av-item { display:flex; gap:28px; align-items:flex-start; padding:32px 36px; border-bottom:1px solid var(--gold-rim2); transition:background .3s; }
.av-item:last-child { border-bottom:none; }
.av-item:hover { background:var(--bg3); }
.av-num { font-family:var(--font-d); font-size:9px; letter-spacing:.3em; color:var(--gold-deep); flex-shrink:0; padding-top:4px; width:20px; }
.av-body h3 { font-family:var(--font-s); font-size:20px; font-weight:400; color:var(--text); margin-bottom:8px; }
.av-body p  { font-size:13px; line-height:1.8; color:var(--muted); }

/* ════════════════════════ VÉHICULES ════════════════════════ */
.vehicles-section { padding:120px 7%; background:var(--bg2); border-top:1px solid var(--gold-rim2); }
.veh-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; margin-top:56px; background:var(--gold-rim2); border:1px solid var(--gold-rim2); }

.veh-card { background:var(--bg2); display:flex; flex-direction:column; overflow:hidden; position:relative; transition:background .35s; }
.veh-card:hover { background:var(--bg4); }
.veh-featured { background:linear-gradient(160deg,#141008 0%,#0e0c08 100%); }
.veh-featured::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(to right,transparent,var(--gold),transparent); z-index:5; }

.veh-pill { position:absolute; top:14px; right:14px; z-index:6; font-size:8px; letter-spacing:.3em; text-transform:uppercase; color:var(--bg); background:linear-gradient(130deg,var(--gold-hi),var(--gold)); padding:4px 12px; }

.veh-img-wrap { position:relative; height:200px; overflow:hidden; flex-shrink:0; }
.veh-img { width:100%; height:100%; object-fit:cover; object-position:center; background:var(--bg3); transition:transform .6s var(--ease); }
.veh-card:hover .veh-img { transform:scale(1.05); }
.veh-img-overlay { position:absolute; inset:0; background:linear-gradient(to bottom,transparent 40%,var(--bg2) 100%); }
.veh-featured .veh-img-overlay { background:linear-gradient(to bottom,transparent 40%,#141008 100%); }

.veh-body { padding:22px 24px 28px; display:flex; flex-direction:column; gap:8px; }
.veh-type { font-size:9px; letter-spacing:.3em; text-transform:uppercase; color:var(--gold); }
.veh-body h3 { font-family:var(--font-s); font-size:20px; font-weight:400; color:var(--text); }
.veh-featured h3 { background:linear-gradient(130deg,var(--gold-hi),var(--gold)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.veh-body p  { font-size:12px; line-height:1.8; color:var(--muted); }
.veh-specs { display:flex; flex-direction:column; gap:4px; margin-top:6px; padding-top:14px; border-top:1px solid var(--gold-rim2); }
.veh-specs span { font-size:10px; letter-spacing:.1em; color:var(--dim); }

/* ════════════════════════ GALERIE ════════════════════════ */
.gallery-section { padding:120px 7%; border-top:1px solid var(--gold-rim2); }
.gallery-header { margin-bottom:56px; }

.gal-mosaic { display:grid; grid-template-columns:1fr 1fr; grid-template-rows:auto auto; gap:1px; background:var(--gold-rim2); border:1px solid var(--gold-rim2); }

/* Grande case gauche — 2 rangées */
.gal-tall { grid-row:span 2; }

/* Colonne droite */
.gal-col { display:flex; flex-direction:column; gap:1px; }
.gal-row { display:grid; grid-template-columns:1fr 1fr; gap:1px; }
.gal-wide { /* pleine largeur dans la col */ }

/* Bottom 2 cases */
.gal-mosaic > .gal-item:not(.gal-tall):not(.gal-col) { /* auto */ }

.gal-item { position:relative; overflow:hidden; background:var(--bg3); }
.gal-tall .gal-img { height:520px; }
.gal-row .gal-item .gal-img { height:200px; }
.gal-wide .gal-img { height:240px; }
.gal-mosaic > .gal-item:not(.gal-tall):not(.gal-col) .gal-img { height:260px; }

.gal-img { display:block; width:100%; object-fit:cover; object-position:center; background:var(--bg3); transition:transform .65s var(--ease), filter .4s; filter:brightness(.88) saturate(.8); }
.gal-item:hover .gal-img { transform:scale(1.04); filter:brightness(1.05) saturate(1.05); }

.gal-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(12,10,8,.9) 0%,transparent 55%); opacity:0; transition:opacity .4s; display:flex; flex-direction:column; justify-content:flex-end; padding:18px 20px; gap:4px; }
.gal-item:hover .gal-overlay { opacity:1; }
.gal-sector { font-size:9px; letter-spacing:.3em; text-transform:uppercase; color:var(--gold); }
.gal-detail { font-family:var(--font-s); font-size:16px; font-style:italic; color:var(--text); }

/* ════════════════════════ PROCESSUS ════════════════════════ */
.process-section { padding:120px 7%; background:var(--bg2); border-top:1px solid var(--gold-rim2); display:grid; grid-template-columns:320px 1fr; gap:100px; align-items:start; }
.proc-left { position:sticky; top:100px; display:flex; flex-direction:column; gap:16px; }
.proc-intro { font-size:14px; line-height:1.9; color:var(--muted); margin-bottom:12px; }
.proc-certif { display:flex; align-items:center; gap:12px; padding:12px 0; border-bottom:1px solid var(--gold-rim2); }
.proc-certif:last-child { border-bottom:none; }
.proc-certif svg { width:16px; height:16px; color:var(--green); flex-shrink:0; }
.proc-certif span { font-size:12px; color:var(--muted); letter-spacing:.04em; }

.proc-right { display:flex; flex-direction:column; }
.proc-step { display:flex; gap:0; position:relative; }
.proc-step:not(:last-child)::after { content:''; position:absolute; left:20px; top:44px; bottom:-1px; width:1px; background:linear-gradient(to bottom,var(--gold-rim),var(--gold-rim2)); }

.ps-head { display:flex; flex-direction:column; align-items:center; padding-right:28px; flex-shrink:0; padding-top:2px; }
.ps-num { font-family:var(--font-d); font-size:10px; letter-spacing:.25em; color:var(--gold); width:40px; height:40px; border:1px solid var(--gold-rim2); display:flex; align-items:center; justify-content:center; background:var(--bg2); transition:border-color .3s, background .3s; flex-shrink:0; }
.proc-step:hover .ps-num { border-color:var(--gold-rim); background:var(--bg3); }
.ps-line { display:none; }

.ps-body { padding:0 0 40px 0; flex:1; }
.ps-body h3 { font-family:var(--font-s); font-size:22px; font-weight:400; color:var(--text); margin-bottom:10px; padding-top:6px; }
.ps-body p  { font-size:13px; line-height:1.85; color:var(--muted); margin-bottom:10px; }
.ps-tag { font-size:9px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); }

/* ════════════════════════ ESTIMATEUR ════════════════════════ */
.estimator-section { padding:120px 7%; border-top:1px solid var(--gold-rim2); }
.estimator-section .section-sub { margin-bottom:60px; }

.estimator-layout { display:grid; grid-template-columns:1fr 380px; gap:60px; align-items:start; }

.est-form { display:flex; flex-direction:column; gap:40px; }
.est-group { display:flex; flex-direction:column; gap:14px; }
.est-label { font-size:9px; letter-spacing:.35em; text-transform:uppercase; color:var(--gold); }
.est-label strong { color:var(--gold-hi); font-weight:400; }

.est-btns { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--gold-rim2); border:1px solid var(--gold-rim2); }
.est-btns-3 { grid-template-columns:repeat(3,1fr); }
.est-btns-2 { grid-template-columns:repeat(2,1fr); }

.est-btn { background:var(--bg2); border:none; cursor:none; padding:18px 14px; display:flex; flex-direction:column; align-items:center; gap:6px; text-align:center; transition:background .3s; position:relative; }
.est-btn::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(to right,transparent,var(--gold),transparent); opacity:0; transition:opacity .3s; }
.est-btn:hover { background:var(--bg3); }
.est-btn.active { background:var(--bg4); }
.est-btn.active::before { opacity:1; }
.eb-icon { font-size:22px; line-height:1; }
.eb-name { font-size:11px; font-weight:400; letter-spacing:.06em; color:var(--text); line-height:1.2; }
.eb-hint { font-size:9px; color:var(--dim); letter-spacing:.04em; }

.est-slider-row { display:flex; align-items:center; gap:16px; }
.esr-min,.esr-max { font-size:10px; letter-spacing:.1em; color:var(--dim); flex-shrink:0; }
.est-slider { flex:1; -webkit-appearance:none; appearance:none; height:2px; background:var(--gold-rim2); outline:none; cursor:none; }
.est-slider::-webkit-slider-thumb { -webkit-appearance:none; width:16px; height:16px; background:var(--gold); border-radius:50%; border:2px solid var(--bg); box-shadow:0 0 0 1px var(--gold); cursor:none; transition:transform .2s; }
.est-slider::-webkit-slider-thumb:hover { transform:scale(1.3); }
.est-slider::-moz-range-thumb { width:16px; height:16px; background:var(--gold); border-radius:50%; border:2px solid var(--bg); cursor:none; }

.est-discount-note { font-size:11px; color:var(--green); letter-spacing:.05em; min-height:18px; transition:opacity .3s; }

/* Résultat */
.est-result { position:sticky; top:100px; border:1px solid var(--gold-rim); background:var(--bg2); padding:0; overflow:hidden; }
.er-header { padding:36px 32px; background:linear-gradient(160deg,#141008 0%,#0e0c08 100%); border-bottom:1px solid var(--gold-rim2); position:relative; }
.er-header::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(to right,transparent,var(--gold),transparent); }
.er-eyebrow { font-size:9px; letter-spacing:.4em; text-transform:uppercase; color:var(--gold-deep); display:block; margin-bottom:16px; }
.er-price-wrap { display:flex; align-items:baseline; gap:8px; margin-bottom:8px; flex-wrap:wrap; }
.er-from { font-size:11px; letter-spacing:.1em; color:var(--muted); }
.er-price { display:flex; align-items:baseline; gap:6px; }
#erTotal { font-family:var(--font-d); font-size:clamp(36px,5vw,52px); font-weight:900; background:linear-gradient(130deg,var(--gold-hi),var(--gold)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; line-height:1; transition:all .3s; }
.er-eur { font-family:var(--font-d); font-size:18px; color:var(--gold); }
.er-unit-price { font-size:12px; color:var(--muted); }
.er-unit-price span { color:var(--gold-hi); }

.er-lines { padding:24px 32px; display:flex; flex-direction:column; gap:0; border-bottom:1px solid var(--gold-rim2); }
.er-line { display:flex; justify-content:space-between; align-items:center; padding:12px 0; border-bottom:1px solid var(--gold-rim3); }
.er-line:last-child { border-bottom:none; }
.erl-label { font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--dim); }
.erl-val { font-size:12px; color:var(--muted); text-align:right; }
.er-discount { color:var(--green); }

.er-note { padding:16px 32px; font-size:10px; color:var(--dimmer); line-height:1.6; border-bottom:1px solid var(--gold-rim2); }

.er-cta { display:flex; align-items:center; justify-content:space-between; gap:14px; padding:20px 32px; background:none; color:var(--gold); text-decoration:none; font-size:10px; letter-spacing:.2em; text-transform:uppercase; font-weight:400; border:none; transition:background .3s, color .3s; }
.er-cta:hover { background:var(--gold-glow); color:var(--gold-hi); }
.er-cta svg { width:18px; flex-shrink:0; transition:transform .3s; }
.er-cta:hover svg { transform:translateX(5px); }

/* ════════════════════════ FAQ ════════════════════════ */
.faq-section { padding:120px 7%; background:var(--bg2); border-top:1px solid var(--gold-rim2); }
.faq-grid { display:grid; grid-template-columns:1fr 1fr; gap:0 1px; margin-top:60px; background:var(--gold-rim2); border:1px solid var(--gold-rim2); }
.faq-col { background:var(--bg2); display:flex; flex-direction:column; }
.faq-item { border-bottom:1px solid var(--gold-rim2); }
.faq-item:last-child { border-bottom:none; }
.faq-q { width:100%; display:flex; align-items:center; justify-content:space-between; gap:20px; padding:26px 32px; background:none; border:none; cursor:none; text-align:left; font-family:var(--font-s); font-size:18px; font-weight:400; color:var(--text); transition:color .3s, background .3s; }
.faq-q:hover,.faq-q[aria-expanded="true"] { color:var(--gold-hi); background:var(--bg3); }
.faq-arrow { width:16px; height:16px; flex-shrink:0; color:var(--gold); transition:transform .35s var(--ease); }
.faq-q[aria-expanded="true"] .faq-arrow { transform:rotate(180deg); }
.faq-a { max-height:0; overflow:hidden; transition:max-height .45s var(--ease); }
.faq-a.open { max-height:300px; }
.faq-a p { padding:0 32px 24px; font-size:13px; line-height:1.85; color:var(--muted); }
.faq-a p strong { color:var(--gold-hi); font-weight:400; }

/* ════════════════════════ CTA ════════════════════════ */
.cta-section { position:relative; padding:140px 7%; border-top:1px solid var(--gold-rim2); overflow:hidden; }
.cta-bg { position:absolute; inset:0; z-index:0; }
.cta-bg-img { width:100%; height:100%; object-fit:cover; object-position:center; background:var(--bg3); filter:brightness(.35) saturate(.65); }
.cta-bg-overlay { position:absolute; inset:0; background:linear-gradient(105deg,rgba(12,10,8,.94) 40%,rgba(12,10,8,.7) 100%); }
.cta-inner { position:relative; z-index:1; max-width:840px; margin:0 auto; text-align:center; }
.cta-decor { font-size:18px; color:var(--gold); letter-spacing:.5em; margin-bottom:28px; opacity:.6; }
.cta-title { font-family:var(--font-d); font-size:clamp(28px,4vw,46px); font-weight:400; letter-spacing:.06em; color:var(--text); margin-bottom:18px; line-height:1.2; }
.cta-title em { font-family:var(--font-s); font-style:italic; font-weight:300; background:linear-gradient(130deg,var(--gold-hi),var(--gold)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.cta-sub { font-family:var(--font-s); font-size:18px; font-style:italic; color:var(--muted); margin-bottom:56px; line-height:1.7; }
.cta-form { text-align:left; display:flex; flex-direction:column; gap:20px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.form-group { display:flex; flex-direction:column; gap:8px; }
.form-group.full { grid-column:span 2; }
.form-group label { font-size:9px; letter-spacing:.35em; text-transform:uppercase; color:var(--gold); }
.form-group input,.form-group select,.form-group textarea { background:rgba(12,10,8,.7); border:1px solid var(--gold-rim2); color:var(--text); font-family:var(--font-u); font-size:14px; font-weight:300; padding:14px 18px; outline:none; width:100%; backdrop-filter:blur(8px); -webkit-appearance:none; transition:border-color .3s, background .3s; }
.form-group input:focus,.form-group select:focus,.form-group textarea:focus { border-color:var(--gold); background:rgba(20,17,8,.8); }
.form-group input::placeholder,.form-group textarea::placeholder { color:var(--dimmer); }
.form-group select { cursor:none; }
.form-group select option { background:var(--bg3); }
.form-group textarea { resize:vertical; min-height:80px; }
.form-submit { display:inline-flex; align-items:center; justify-content:center; gap:14px; align-self:center; font-family:var(--font-u); font-size:10px; font-weight:400; letter-spacing:.22em; text-transform:uppercase; color:var(--bg); background:linear-gradient(130deg,var(--gold-hi),var(--gold)); padding:18px 60px; border:none; cursor:none; position:relative; overflow:hidden; transition:transform .3s, box-shadow .3s; }
.form-submit::before { content:''; position:absolute; inset:0; background:linear-gradient(130deg,var(--gold),var(--gold-lo)); opacity:0; transition:opacity .35s; }
.form-submit:hover { transform:translateY(-2px); box-shadow:0 16px 42px rgba(201,168,76,.38); }
.form-submit:hover::before { opacity:1; }
.form-submit span,.form-submit svg { position:relative; z-index:1; }
.form-submit svg { width:18px; transition:transform .3s; }
.form-submit:hover svg { transform:translateX(5px); }
.form-submit.sent { background:linear-gradient(130deg,#4CAF7A,#3a8a5e); }

/* ════════════════════════ FOOTER ════════════════════════ */
.footer { border-top:1px solid var(--gold-rim2); background:var(--bg2); }
.footer-top { display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:60px; padding:60px 7%; border-bottom:1px solid var(--gold-rim2); }
.footer-brand { display:flex; flex-direction:column; gap:8px; }
.footer-logo  { font-family:var(--font-d); font-size:14px; letter-spacing:.3em; background:linear-gradient(130deg,var(--gold-hi),var(--gold)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.footer-tagline { font-family:var(--font-s); font-size:14px; font-style:italic; color:var(--dim); }
.footer-links,.footer-contact { display:flex; flex-direction:column; gap:12px; }
.footer-links a,.footer-contact a,.footer-contact span { font-size:12px; letter-spacing:.06em; color:var(--muted); text-decoration:none; transition:color .3s; }
.footer-links a:hover,.footer-contact a:hover { color:var(--gold-hi); }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; padding:24px 7%; font-size:11px; color:var(--dim); letter-spacing:.05em; }

/* ════════════════════════ REVEAL ════════════════════════ */
.reveal { opacity:0; transform:translateY(32px); transition:opacity .8s var(--ease), transform .8s var(--ease); transition-delay:var(--delay,0s); }
.reveal.visible { opacity:1; transform:translateY(0); }

/* ════════════════════════ RESPONSIVE ════════════════════════ */
@media (max-width:1200px) {
  .avantages-section { grid-template-columns:1fr; gap:56px; }
  .av-left { position:static; }
  .process-section { grid-template-columns:1fr; gap:56px; }
  .proc-left { position:static; }
  .estimator-layout { grid-template-columns:1fr; }
  .est-result { position:static; }
  .veh-grid { grid-template-columns:1fr 1fr; }
  .impact-grid { grid-template-columns:1fr 1fr; }
}

@media (max-width:900px) {
  .gal-mosaic { grid-template-columns:1fr; }
  .gal-tall { grid-row:span 1; }
  .gal-col { gap:1px; }
  .gal-row { grid-template-columns:1fr 1fr; }
  .gal-tall .gal-img { height:300px; }
  .faq-grid { grid-template-columns:1fr; }
}

@media (max-width:768px) {
  .header { padding:18px 24px; }
  .nav { display:none; }
  .burger { display:flex; }
  .hero-stripe { display:none; }
  .hero-content { padding:0 24px; }
  .hero-bottom { flex-direction:column; align-items:flex-start; }
  .hc-tl { left:32px; }
  .hc-bl { left:32px; }
  .impact-section,.avantages-section,.vehicles-section,.gallery-section,.process-section,.estimator-section,.faq-section,.cta-section { padding:80px 24px; }
  .veh-grid { grid-template-columns:1fr; }
  .impact-grid { grid-template-columns:1fr 1fr; }
  .est-btns { grid-template-columns:1fr 1fr; }
  .form-row { grid-template-columns:1fr; }
  .form-group.full { grid-column:span 1; }
  .footer-top { grid-template-columns:1fr; gap:36px; padding:48px 24px; }
  .footer-bottom { flex-direction:column; gap:8px; text-align:center; padding:20px 24px; }
  .faq-q { padding:20px 24px; font-size:16px; }
  .faq-a p { padding:0 24px 20px; }
}
