/* ═══════════════════════════════════════════════════════════
   EvenGaming Configurateur — Front CSS V2
   Palette: --evg-accent (#ff8c00 orange) + --evg-accent2 (#2f86ff bleu)
   Injected dynamically via wp_add_inline_style
   ═══════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&display=swap');

:root {
  /* Brand colors injected dynamically — defaults here */
  --evg-accent:  #ff8c00;
  --evg-accent2: #2f86ff;

  /* Derived */
  --evg-accent-glow:  rgba(255,140,0,.18);
  --evg-accent2-glow: rgba(47,134,255,.18);

  /* UI */
  --evg-bg:       #f5f6fa;
  --evg-surface:  #ffffff;
  --evg-surface2: #f8f9fc;
  --evg-border:   #e4e8f0;
  --evg-text:     #0f1724;
  --evg-text2:    #5a6a85;
  --evg-text3:    #9aaabb;
  --evg-green:    #16a34a;
  --evg-red:      #dc2626;
  --evg-radius:   16px;
  --evg-shadow:   0 4px 24px rgba(0,0,0,.07);
  --evg-font:     'Outfit', -apple-system, sans-serif;
}

/* ─── Reset scoped ─────────────────────────────────── */
.evg-page *, .evg-form-box * {
  box-sizing: border-box;
}
.evg-page {
  font-family: var(--evg-font);
  color: var(--evg-text);
  line-height: 1.5;

  /* ── Breakout du layout WordPress ── */
  display: block !important;
  float: none !important;
  clear: both !important;
  position: relative !important;
  z-index: 1;

  /* Escape the theme content column with full-viewport width */
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: calc(-50vw + 50%) !important;
  margin-right: calc(-50vw + 50%) !important;
  left: 0 !important;
  right: 0 !important;
  box-sizing: border-box !important;
}
.evg-form-box {
  font-family: var(--evg-font);
  color: var(--evg-text);
  line-height: 1.5;
  display: block !important;
}
.sr-only { position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0,0,0,0); }
.evg-page fieldset { border:0; padding:0; margin:0; min-width:0; }

/* ════════════════════════════════════════════════════
   HERO
════════════════════════════════════════════════════ */
.evg-hero {
  position: relative;
  display: block !important;
  width: 100% !important;
  margin-top: 38px !important;
  padding: clamp(56px,7vw,88px) 0;
  overflow: hidden;
  background: linear-gradient(150deg, #0f1724 0%, #1a2540 60%, #0d1b38 100%);
  clear: both;
  box-sizing: border-box !important;
}
.evg-hero-bg {
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 700px 400px at 5% 0%,  rgba(255,140,0,.12),  transparent 60%),
    radial-gradient(ellipse 600px 350px at 90% 10%, rgba(47,134,255,.12), transparent 60%),
    radial-gradient(ellipse 400px 300px at 50% 100%,rgba(47,134,255,.06), transparent 70%);
}
.evg-hero-inner {
  position: relative; z-index: 1;
  max-width: 1200px; margin: 0 auto; padding: 0 40px;
  display: flex !important;
  flex-direction: row !important;
  align-items: center;
  justify-content: space-between;
  gap: 48px;
}
.evg-hero-content { max-width: 560px; }

.evg-kicker {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 7px 16px;
  background: rgba(255,140,0,.12);
  border: 1px solid rgba(255,140,0,.3);
  color: var(--evg-accent);
  font-size: 11px; font-weight: 800; letter-spacing: 2.5px; text-transform: uppercase;
  margin-bottom: 18px;
}
.evg-kicker-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--evg-accent);
  box-shadow: 0 0 8px var(--evg-accent);
  animation: evgBlink 1.8s ease-in-out infinite;
}
@keyframes evgBlink { 0%,100%{opacity:1} 50%{opacity:.25} }

.evg-hero-title {
  font-size: clamp(28px,3.8vw,52px);
  font-weight: 900;
  line-height: 1.0;
  letter-spacing: -.02em;
  color: #fff;
  margin: 0 0 18px;
  white-space: normal;
  word-break: normal;
}

.evg-hero-sub {
  font-size: 16px; font-weight: 300; color: rgba(255,255,255,.7);
  line-height: 1.7; margin: 0 0 28px; max-width: 460px;
}

.evg-trust {
  display: flex; flex-wrap: wrap; gap: 10px;
}
.evg-trust-item {
  display: flex; align-items: center; gap: 7px;
  padding: 7px 13px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.8);
  font-size: 12px; font-weight: 600;
  border-radius: 6px;
}

/* ── HERO VISUAL — SVG isometric PC tower ───────────── */
.evg-hero-pc {
  position: relative;
  width: 230px;
  height: 330px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.evg-hero-pc-inner {
  position: relative;
  animation: evgHeroFloat 5s ease-in-out infinite;
  filter: drop-shadow(0 32px 48px rgba(0,0,0,.55));
}
@keyframes evgHeroFloat {
  0%,100% { transform: translateY(0px) rotate(-1deg); }
  50%     { transform: translateY(-12px) rotate(-1deg); }
}
.evg-hero-pc-glow {
  position: absolute;
  bottom: -20px; left: 50%; transform: translateX(-50%);
  width: 120px; height: 20px;
  background: radial-gradient(ellipse, rgba(255,140,0,.4), transparent 70%);
  filter: blur(10px);
  animation: evgGlowPulse 5s ease-in-out infinite;
}
@keyframes evgGlowPulse {
  0%,100% { opacity:.7; transform: translateX(-50%) scaleX(1); }
  50%     { opacity:1;  transform: translateX(-50%) scaleX(1.15); }
}
.evg-hero-pc-label {
  position: absolute; bottom: -42px; left: 0; right: 0;
  text-align: center; font-size: 10px; color: rgba(255,255,255,.25);
  font-weight: 700; letter-spacing: 3px; text-transform: uppercase;
}
/* RGB strip animation on SVG */
.evg-iso-rgb { animation: evgRGBhero 3.5s ease-in-out infinite; }
.evg-iso-fan1 { animation: evgSpin 2s linear infinite; transform-origin: 50% 50%; }
.evg-iso-fan2 { animation: evgSpin 1.6s linear infinite reverse; transform-origin: 50% 50%; }
@keyframes evgRGBhero {
  0%,100% { filter: hue-rotate(0deg) brightness(1); }
  33%     { filter: hue-rotate(60deg) brightness(1.4); }
  66%     { filter: hue-rotate(200deg) brightness(1.2); }
}
@keyframes evgSpin { to { transform: rotate(360deg); } }

/* ════════════════════════════════════════════════════
   MAIN LAYOUT
════════════════════════════════════════════════════ */
.evg-main { background: var(--evg-bg); padding: 32px 0 72px; display: block !important; width: 100% !important; clear: both !important; box-sizing: border-box !important; }
.evg-main-inner {
  max-width: 1200px; margin: 0 auto; padding: 0 24px;
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 24px;
  align-items: start;
}

/* ─── SIDEBAR ─── */
.evg-sidebar { display:flex; flex-direction:column; gap:16px; position:sticky; top:20px; }
.evg-side-card {
  background: var(--evg-surface);
  border: 1px solid var(--evg-border);
  border-radius: var(--evg-radius);
  padding: 20px;
  box-shadow: var(--evg-shadow);
}
.evg-side-title {
  font-size: 14px; font-weight: 800; text-transform: uppercase;
  letter-spacing: 1px; color: var(--evg-text); margin: 0 0 14px;
  padding-bottom: 10px; border-bottom: 2px solid var(--evg-accent);
  display: inline-block;
}
.evg-how-list {
  padding-left: 20px; margin: 0;
  display:flex; flex-direction:column; gap:10px;
}
.evg-how-list li { font-size:13px; color:var(--evg-text2); line-height:1.5; }
.evg-how-list li strong { color:var(--evg-text); }

/* FAQ sidebar */
.evg-faq { display:flex; flex-direction:column; gap:6px; }
.evg-faq-q {
  width:100%; text-align:left; padding:10px 14px;
  background:var(--evg-surface2); border:1px solid var(--evg-border);
  border-radius:10px; color:var(--evg-text); font-family:var(--evg-font);
  font-size:13px; font-weight:600; cursor:pointer;
  transition: border-color .15s, background .15s;
}
.evg-faq-q:hover { border-color:var(--evg-accent); background:#fff8f0; }
.evg-faq-a {
  display:none; padding:10px 14px; font-size:13px; color:var(--evg-text2);
  background:#fff8f0; border:1px solid rgba(255,140,0,.2);
  border-radius:10px; line-height:1.6;
}

/* ════════════════════════════════════════════════════
   FORM BOX
════════════════════════════════════════════════════ */
.evg-form-box {
  background: var(--evg-surface);
  border: 1px solid var(--evg-border);
  border-radius: var(--evg-radius);
  padding: 28px;
  box-shadow: var(--evg-shadow);
}

/* Notices */
.evg-notice {
  display:flex; align-items:flex-start; gap:12px;
  padding:14px 18px; border-radius:12px;
  margin-bottom:20px; font-size:14px; font-weight:500;
}
.evg-notice-icon { font-size:20px; flex-shrink:0; margin-top:1px; }
.evg-notice--ok  { background:#f0fdf4; border:1px solid #86efac; color:#15803d; }
.evg-notice--err { background:#fef2f2; border:1px solid #fca5a5; color:#dc2626; }

/* HP anti-spam */
.evg-hp { position:absolute; left:-9999px; opacity:0; pointer-events:none; height:0; }

/* ─── PROGRESS HEADER ─── */
.evg-prog-header {
  display:flex; align-items:center; gap:16px;
  margin-bottom:24px; padding-bottom:20px;
  border-bottom: 1px solid var(--evg-border);
}
.evg-prog-track { flex:1; }
.evg-prog-bar {
  height:6px; background:var(--evg-border);
  border-radius:999px; overflow:hidden; margin-bottom:10px;
}
.evg-prog-bar span {
  display:block; height:100%;
  background: linear-gradient(90deg, var(--evg-accent), var(--evg-accent2));
  border-radius:999px; transition: width .35s ease;
}
.evg-prog-steps { display:flex; gap:7px; align-items:center; }
.evg-prog-dot {
  /* Force circle — override all theme/Elementor button styles */
  width:32px !important; height:32px !important;
  min-width:32px !important; min-height:32px !important;
  max-width:32px !important; max-height:32px !important;
  border-radius:50% !important;
  border:2px solid var(--evg-border) !important;
  background:var(--evg-surface2) !important;
  font-size:12px !important; font-weight:800 !important; color:var(--evg-text3) !important;
  cursor:pointer; transition:all .15s;
  display:flex !important; align-items:center !important; justify-content:center !important;
  font-family:var(--evg-font) !important;
  padding:0 !important; margin:0 !important;
  line-height:1 !important; text-align:center !important;
  box-sizing:border-box !important; flex-shrink:0 !important;
  outline:none !important;
}
.evg-prog-dot.is-active { background:var(--evg-accent) !important; border-color:var(--evg-accent) !important; color:#fff !important; box-shadow:0 0 14px var(--evg-accent-glow) !important; }
.evg-prog-dot.is-done   { background:var(--evg-green) !important; border-color:var(--evg-green) !important; color:#fff !important; }

.evg-prog-info { text-align:right; flex-shrink:0; }
.evg-prog-title { display:block; font-size:16px; font-weight:800; color:var(--evg-text); }
.evg-prog-sub   { font-size:11px; color:var(--evg-text3); margin-top:2px; display:block; }

.evg-form-error {
  background:#fef2f2; border:1px solid #fca5a5; color:#dc2626;
  padding:10px 14px; border-radius:10px; font-size:13px; font-weight:600;
  margin-bottom:14px; display:none;
}
.evg-form-error:not(:empty) { display:block; }

/* ─── STEPS ─── */
.evg-step { display:none; }
.evg-step.is-active { display:block; animation:evgFadeUp .3s ease; }
@keyframes evgFadeUp { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:translateY(0)} }
.evg-step-intro { font-size:14px; color:var(--evg-text2); margin:0 0 16px; }

/* ─── FIELDS ─── */
.evg-row-2 { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:14px; }
.evg-field { display:flex; flex-direction:column; gap:6px; margin-bottom:14px; }
.evg-field label { font-size:13px; font-weight:700; color:var(--evg-text); }
.evg-field label small { font-weight:400; color:var(--evg-text3); }
.evg-req { color:var(--evg-accent); }

.evg-field input[type=text],
.evg-field input[type=email],
.evg-field input[type=tel],
.evg-field input[type=date],
.evg-field select,
.evg-field textarea {
  padding:11px 14px;
  background:var(--evg-surface2);
  border:1.5px solid var(--evg-border);
  border-radius:10px;
  font-family:var(--evg-font);
  font-size:14px; color:var(--evg-text);
  transition: border-color .15s, box-shadow .15s;
  width:100%;
}
.evg-field input:focus,
.evg-field select:focus,
.evg-field textarea:focus {
  outline:none;
  border-color:var(--evg-accent);
  box-shadow:0 0 0 4px rgba(255,140,0,.1);
}
.evg-field input::placeholder,
.evg-field textarea::placeholder { color:var(--evg-text3); }

/* ─── PREFERENCE PICKS ─── */
.evg-picks {
  display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-bottom:16px;
}
.evg-pick {
  display:flex; flex-direction:column; align-items:center; gap:6px;
  padding:14px 8px;
  background:var(--evg-surface2); border:1.5px solid var(--evg-border);
  border-radius:12px; cursor:pointer; text-align:center;
  font-size:12px; font-weight:600; color:var(--evg-text2);
  transition:all .15s;
}
.evg-pick:hover { border-color:var(--evg-accent); color:var(--evg-text); background:#fff8f0; }
.evg-pick input { display:none; }
.evg-pick:has(input:checked) {
  border-color:var(--evg-accent); background:rgba(255,140,0,.08);
  color:var(--evg-accent); box-shadow:0 0 0 1px var(--evg-accent);
}
.evg-pick-icon { font-size:24px; line-height:1; }

/* Expert panel */
.evg-expert-panel {
  border:1px dashed var(--evg-border); border-radius:12px;
  margin-bottom:14px; overflow:hidden;
}
.evg-expert-panel > summary {
  padding:12px 16px; cursor:pointer;
  font-size:13px; font-weight:600; color:var(--evg-text2);
  background:var(--evg-surface2); list-style:none;
}
.evg-expert-panel > summary::-webkit-details-marker { display:none; }
.evg-expert-body { padding:14px 16px; }

/* Consent */
.evg-consent {
  display:flex; align-items:flex-start; gap:10px;
  font-size:13px; color:var(--evg-text2); font-weight:500;
  cursor:pointer; margin:8px 0 14px;
}
.evg-consent input { margin-top:3px; accent-color:var(--evg-accent); }

/* ─── ESTIMATION LIVE ─── */
.evg-estimate {
  background: linear-gradient(135deg, #fff8f0, #f0f7ff);
  border: 1.5px solid rgba(255,140,0,.25);
  border-radius: 14px;
  padding: 18px;
  margin: 0 0 16px;
}
.evg-estimate-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; gap:10px; flex-wrap:wrap; }
.evg-estimate-badge {
  display:inline-flex; align-items:center; gap:6px;
  background: linear-gradient(90deg, var(--evg-accent), var(--evg-accent2));
  color:#fff; padding:5px 12px; border-radius:999px;
  font-size:11px; font-weight:800; letter-spacing:.5px;
}
.evg-estimate-tier {
  font-size:12px; font-weight:700; color:var(--evg-accent);
  background:rgba(255,140,0,.1); padding:4px 10px; border-radius:999px;
  border:1px solid rgba(255,140,0,.2);
}

.evg-estimate-specs {
  display:grid; grid-template-columns:repeat(4,1fr); gap:8px; margin-bottom:14px;
}
.evg-spec-card {
  display:flex; flex-direction:column; align-items:center; gap:4px;
  padding:10px 6px;
  background:#fff; border:1px solid var(--evg-border); border-radius:10px;
  text-align:center; transition:all .2s;
}
.evg-spec-card.is-highlight { border-color:var(--evg-accent); background:#fff8f0; }
.evg-spec-icon { font-size:20px; line-height:1; }
.evg-spec-label { font-size:9px; color:var(--evg-text3); text-transform:uppercase; letter-spacing:1px; font-weight:700; }
.evg-spec-val { font-size:11px; font-weight:800; color:var(--evg-text); line-height:1.3; }
.evg-spec-price { font-size:10px; font-weight:700; color:var(--evg-accent); background:rgba(255,140,0,.1); padding:1px 6px; border-radius:999px; margin-top:1px; min-height:15px; }

/* Extra rows (alim/boitier) */
.evg-estimate-extra {
  display:flex; gap:8px; margin-bottom:12px;
}
.evg-extra-row {
  flex:1; display:flex; align-items:center; gap:6px;
  padding:7px 10px;
  background:#fff; border:1px solid var(--evg-border); border-radius:10px;
  font-size:11px;
}
.evg-extra-lbl { color:var(--evg-text3); font-weight:600; white-space:nowrap; }
.evg-extra-val { flex:1; font-weight:800; color:var(--evg-text); font-size:11px; }

.evg-budget-warn {
  background:#fff8f0; border:1px solid rgba(255,140,0,.35);
  color:#e65100; border-radius:8px; padding:8px 12px;
  font-size:12px; font-weight:600; margin:6px 0;
}

.evg-estimate-perf { display:flex; flex-direction:column; gap:8px; margin-bottom:10px; }
.evg-perf-row { display:grid; grid-template-columns:70px 1fr 36px; gap:10px; align-items:center; }
.evg-perf-row > span:first-child { font-size:12px; color:var(--evg-text2); font-weight:600; }
.evg-perf-track {
  height:8px; background:rgba(0,0,0,.07); border-radius:999px; overflow:hidden;
}
.evg-perf-fill {
  height:100%; width:0%; border-radius:999px;
  background: linear-gradient(90deg, var(--evg-accent), var(--evg-accent2));
  transition: width .5s cubic-bezier(.34,1.56,.64,1);
}
.evg-perf-pct { font-size:11px; font-weight:800; color:var(--evg-text2); text-align:right; }

.evg-estimate-price {
  text-align:center; font-size:13px; font-weight:800;
  color:var(--evg-accent); margin-top:4px;
  padding:6px; background:rgba(255,140,0,.08);
  border-radius:8px;
}
.evg-estimate-note { font-size:11px; color:var(--evg-text3); margin:8px 0 0; font-style:italic; text-align:center; }

/* ─── RECAP (étape 4) ─── */
.evg-recap {
  background:var(--evg-surface2); border:1.5px solid var(--evg-border);
  border-radius:12px; padding:16px; margin-bottom:16px;
}
.evg-recap-row { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-bottom:14px; }
.evg-recap-cell { display:flex; flex-direction:column; gap:3px; }
.evg-recap-lbl { font-size:9px; text-transform:uppercase; letter-spacing:1px; color:var(--evg-text3); font-weight:700; display:block; }
.evg-recap-val { font-size:13px; font-weight:700; color:var(--evg-text); }
.evg-recap-config { border-top:1px solid var(--evg-border); padding-top:12px; }
.evg-recap-specs { display:flex; flex-wrap:wrap; gap:8px; margin-top:8px; }
.evg-rs {
  display:flex; align-items:center; gap:5px;
  padding:5px 10px; background:#fff; border:1px solid var(--evg-border); border-radius:8px; font-size:12px;
}
.evg-rs em { font-style:normal; color:var(--evg-accent); font-weight:700; font-size:10px; letter-spacing:.5px; text-transform:uppercase; }
.evg-rs strong { color:var(--evg-text); font-weight:700; }

/* ────────────────────────────────────────────────────
   3D VIEWER (étape 4) — CSS 3D advanced
──────────────────────────────────────────────────── */

.evg-stage3d {
  position:relative; height:320px;
  border-radius:10px; overflow:hidden;
  background: radial-gradient(ellipse 80% 60% at 50% 30%, rgba(47,134,255,.08), transparent),
              radial-gradient(ellipse 60% 40% at 20% 70%, rgba(255,140,0,.06), transparent),
              #060b18;
  touch-action:none; cursor:grab;
}
.evg-stage3d.is-dragging { cursor:grabbing; }
.evg-stage-grid {
  position:absolute; inset:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.02) 1px, transparent 1px);
  background-size:40px 40px;
}
.evg-scene {
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  perspective:900px;
}

/* ── PC Wrap (rotatable) ── */
.evg-pc-wrap {
  transform-style: preserve-3d;
  transition: none;
}

/* ── Box faces ── */
.evg-pc-box {
  width: 160px; height: 290px;
  transform-style: preserve-3d;
  position: relative;
}
.evg-pc-face {
  position: absolute;
  backface-visibility: hidden;
  border: 1px solid rgba(255,255,255,.06);
}
.evg-pc-front {
  width:160px; height:290px;
  transform:translateZ(40px);
  background: linear-gradient(180deg, #141c2e, #0d1525);
  border-radius:10px 10px 6px 6px;
  overflow:hidden;
}
.evg-pc-back {
  width:160px; height:290px;
  transform:rotateY(180deg) translateZ(40px);
  background:#0a1020;
}
.evg-pc-left {
  width:80px; height:290px;
  left:-40px; top:0;
  transform:rotateY(-90deg) translateZ(0px);
  transform-origin:right center;
  background: linear-gradient(90deg, #0a1020, #111828);
}
.evg-pc-right {
  width:80px; height:290px;
  right:-40px; top:0;
  transform:rotateY(90deg) translateZ(0px);
  transform-origin:left center;
  background: linear-gradient(90deg, #111828, #0a1020);
}
.evg-pc-top {
  width:160px; height:80px;
  top:-40px; left:0;
  transform:rotateX(90deg) translateZ(250px);
  transform-origin:bottom center;
  background:#0f1628;
  display:flex; align-items:center; justify-content:center;
}
.evg-pc-bottom {
  width:160px; height:80px;
  bottom:-40px; left:0;
  transform:rotateX(-90deg) translateZ(250px);
  transform-origin:top center;
  background:#080e1a;
}

/* Tempered glass panel */
.evg-pc-glass-panel {
  position:absolute; left:10px; right:10px; top:12px; bottom:36px;
  background: linear-gradient(180deg, rgba(160,200,255,.1), rgba(120,170,255,.04));
  border:1px solid rgba(255,255,255,.12);
  border-radius:8px;
  overflow:hidden;
}
.evg-pc-glass-panel.is-white {
  background: linear-gradient(180deg, rgba(255,255,255,.7), rgba(240,245,255,.5));
  border-color:rgba(0,0,0,.08);
}
.evg-pc-inside { position:relative; width:100%; height:100%; }

/* GPU block */
.evg-pc-gpu {
  position:absolute; left:8px; right:8px; top:55%; height:52px;
  background: linear-gradient(135deg, #1a2540, #243060);
  border:1px solid rgba(47,134,255,.3);
  border-radius:8px;
  display:flex; align-items:center; gap:5px; padding:0 8px;
}
.evg-pc-gpu-fan {
  width:30px; height:30px; border-radius:50%;
  border:2px solid rgba(47,134,255,.4);
  position:relative; flex-shrink:0;
}
.evg-pc-gpu-fan .evg-fan-blade {
  position:absolute; inset:4px; border-radius:50%;
  background:conic-gradient(from 0deg, transparent 0deg 60deg, rgba(47,134,255,.3) 60deg 120deg, transparent 120deg 180deg, rgba(47,134,255,.3) 180deg 240deg, transparent 240deg 300deg, rgba(47,134,255,.3) 300deg 360deg);
  animation:evgSpin 1.6s linear infinite;
}
.evg-pc-gpu-body {
  flex:1; height:12px; border-radius:4px;
  background:linear-gradient(90deg, rgba(255,255,255,.2), rgba(255,255,255,.05));
}

/* Motherboard */
.evg-pc-mobo {
  position:absolute; right:8px; top:8px; width:38px; bottom:58px;
  background:#1a2a1a; border:1px solid rgba(100,200,100,.12); border-radius:4px;
  display:flex; flex-direction:column; gap:4px; padding:4px;
}
.evg-pc-mobo-slots {
  height:6px; border-radius:2px;
  background:linear-gradient(90deg, rgba(100,200,100,.2), rgba(100,200,100,.06));
}

/* RGB strips */
.evg-pc-rgb-strip {
  position:absolute; width:6px; border-radius:999px;
  background: linear-gradient(180deg, var(--evg-accent), var(--evg-accent2), #b44bff);
  opacity:0;
  box-shadow:0 0 14px var(--evg-accent);
  pointer-events:none;
  transition:opacity .4s;
}
.evg-pc-rgb-strip.evg-rgb-top { left:4px; top:8px; height:40%; }
.evg-pc-rgb-strip.evg-rgb-bottom { left:4px; top:52%; height:40%; }
.evg-pc-rgb-strip.is-on {
  opacity:1;
  animation:evgRGBpulse 2.5s ease-in-out infinite;
}
@keyframes evgRGBpulse {
  0%,100%{ filter:hue-rotate(0deg); box-shadow:0 0 12px var(--evg-accent); }
  50%{ filter:hue-rotate(50deg); box-shadow:0 0 22px var(--evg-accent2); }
}

/* PSU */
.evg-pc-psu {
  position:absolute; left:8px; right:8px; bottom:6px; height:18px;
  background:#111828; border:1px solid rgba(255,255,255,.07); border-radius:4px;
}

/* Bloom / ambient light */
.evg-pc-bloom {
  position:absolute; inset:-10px;
  border-radius:50%;
  background:radial-gradient(circle, transparent 40%, transparent);
  pointer-events:none; transition:all .4s;
}
.evg-pc-bloom.is-on {
  background: radial-gradient(circle, rgba(255,140,0,.05) 0%, transparent 70%);
}

/* Power button */
.evg-pc-panel-btn {
  position:absolute; right:12px; top:12px;
  width:10px; height:10px; border-radius:50%;
  background:#2a3a50; border:1px solid rgba(255,255,255,.15);
}
.evg-pwr.is-on { background:var(--evg-accent); box-shadow:0 0 8px var(--evg-accent); }

/* USB ports */
.evg-pc-usb-row {
  position:absolute; right:10px; bottom:10px;
  display:flex; gap:3px;
}
.evg-pc-usb-row span {
  width:8px; height:5px; background:rgba(255,255,255,.12); border-radius:1px;
}

/* Top fan */
.evg-pc-top-fan {
  width:50px; height:50px; border-radius:50%;
  border:2px solid rgba(47,134,255,.3);
  display:flex; align-items:center; justify-content:center;
}
.evg-pc-top-fan .evg-fan-blade {
  width:32px; height:32px;
  background:conic-gradient(from 0deg, transparent 0deg 60deg, rgba(47,134,255,.25) 60deg 120deg, transparent 120deg 180deg, rgba(47,134,255,.25) 180deg 240deg, transparent 240deg 300deg, rgba(47,134,255,.25) 300deg 360deg);
  border-radius:50%;
  animation:evgSpin 2s linear infinite;
}

/* White theme */
.evg-pc-box.is-white .evg-pc-face { background: linear-gradient(180deg, #e8edf5, #d4dae8) !important; }
.evg-pc-box.is-white .evg-pc-front { background: linear-gradient(180deg, #d8e0f0, #c8d4e8) !important; }

/* Ground shadow under PC */
.evg-scene::after {
  content:''; position:absolute; bottom:8%; left:50%;
  transform:translateX(-50%);
  width:200px; height:30px;
  background:radial-gradient(ellipse, rgba(0,0,0,.4), transparent 70%);
  filter:blur(8px); pointer-events:none;
}

}

/* ═══════════════════════════════════════════════════════════
   BOUTONS & ACTIONS NAVIGATION
═══════════════════════════════════════════════════════════ */
.evg-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 28px;
  padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,.06);
}

.evg-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  padding: 13px 28px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 700;
  font-family: inherit;
  cursor: pointer;
  border: none;
  transition: transform .15s, box-shadow .15s, background .15s, opacity .15s;
  white-space: nowrap;
  text-decoration: none;
  line-height: 1;
}
.evg-btn:disabled { opacity: .45; cursor: not-allowed; }
.evg-btn:active   { transform: scale(.97); }

/* Bouton Suivant */
.evg-btn-next {
  background: linear-gradient(135deg, var(--evg-accent, #ff8c00), var(--evg-accent2, #2f86ff));
  color: #fff;
  box-shadow: 0 4px 18px rgba(255,140,0,.25);
  min-width: 160px;
}
.evg-btn-next:hover {
  box-shadow: 0 6px 28px rgba(255,140,0,.40);
  transform: translateY(-1px);
}

/* Bouton Retour */
.evg-btn-prev {
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.6);
  border: 1px solid rgba(255,255,255,.1);
  padding: 12px 22px;
  font-size: 13px;
}
.evg-btn-prev:hover {
  background: rgba(255,255,255,.1);
  color: rgba(255,255,255,.9);
  border-color: rgba(255,255,255,.2);
}

/* Bouton Submit final */
.evg-btn-submit {
  background: linear-gradient(135deg, var(--evg-accent, #ff8c00), #e65c00);
  color: #fff;
  box-shadow: 0 4px 20px rgba(255,140,0,.35);
  font-size: 15px;
  padding: 15px 36px;
  min-width: 200px;
}
.evg-btn-submit:hover {
  box-shadow: 0 8px 32px rgba(255,140,0,.5);
  transform: translateY(-2px);
}
.evg-btn-submit span { pointer-events: none; }


/* ═══════════════════════════════════════════════════════════
   V8 ADDITIONS — Auto-save · Validation · Témoignages · Share
═══════════════════════════════════════════════════════════ */

/* Restore banner */
.evg-restore-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff8e6;border:1px solid #f59e0b;border-radius:8px;padding:10px 16px;margin-bottom:14px;font-size:13px;color:#92400e;}
.evg-restore-discard{background:none;border:1px solid #d97706;color:#d97706;padding:4px 10px;border-radius:5px;cursor:pointer;font-size:12px;}
.evg-restore-discard:hover{background:#d97706;color:#fff;}

/* Social proof */
.evg-social-proof{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--evg-text2,#5a6a85);margin-bottom:16px;}
.evg-sp-dot{width:8px;height:8px;border-radius:50%;background:#16a34a;box-shadow:0 0 8px rgba(22,163,74,.6);flex-shrink:0;animation:sp-pulse 2s ease-in-out infinite;border:1px solid rgba(22,163,74,.3);}
@keyframes sp-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.85)}}

/* Price badge in estimate */
.evg-price-badge{display:inline-flex;align-items:center;padding:3px 10px;background:rgba(255,140,0,.15);border:1px solid rgba(255,140,0,.35);border-radius:20px;font-size:12px;font-weight:700;color:var(--evg-accent,#ff8c00);margin-left:auto;}

/* Down-tier comparison */
.evg-down-tier{background:rgba(47,134,255,.07);border:1px solid rgba(47,134,255,.2);border-radius:8px;padding:10px 14px;font-size:12px;color:rgba(255,255,255,.62);margin-top:10px;line-height:1.6;}
.evg-down-label{font-weight:700;color:var(--evg-accent2,#2f86ff);}
.evg-down-diff{color:rgba(34,197,94,.75);}

/* Testimonials */
.evg-testimonials{margin:20px 0 0;padding-top:18px;border-top:1px solid rgba(255,255,255,.06);}
.evg-testi-title{font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:12px;}
.evg-testi-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
@media(max-width:560px){.evg-testi-grid{grid-template-columns:1fr;}}
.evg-testi{background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.06);border-radius:9px;padding:13px 15px;}
.evg-testi-stars{color:#f59e0b;font-size:12px;margin-bottom:6px;letter-spacing:1px;}
.evg-testi p{font-size:12px;color:rgba(255,255,255,.58);margin:0 0 8px;line-height:1.55;font-style:italic;}
.evg-testi-author{font-size:11px;color:rgba(255,255,255,.32);}

/* Validation states */
.evg-field input.evg-field-ok,
.evg-field select.evg-field-ok{border-color:rgba(34,197,94,.55)!important;}
.evg-field input.evg-field-err,
.evg-field select.evg-field-err{border-color:rgba(239,68,68,.65)!important;box-shadow:0 0 0 2px rgba(239,68,68,.1);}
.evg-field-hint{font-size:11px;color:#ef4444;margin-top:4px;display:none;}

/* Estimate header with price */
.evg-estimate-header{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:14px;}

/* Recap config header */
.evg-recap-config-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:6px;margin-bottom:10px;}
.evg-recap-price{font-size:12px;color:rgba(255,255,255,.45);}
.evg-recap-price strong{color:var(--evg-accent,#ff8c00);font-weight:700;}

/* Recap perf bars */
.evg-recap-perf{margin-top:14px;padding-top:14px;border-top:1px solid rgba(255,255,255,.06);}

/* Share row */
.evg-share-row{display:flex;justify-content:flex-end;margin:10px 0 -4px;}
.evg-btn-ghost{background:transparent;border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.5);padding:7px 14px;border-radius:7px;font-size:12px;cursor:pointer;font-family:inherit;transition:all .18s;}
.evg-btn-ghost:hover{border-color:var(--evg-accent,#ff8c00);color:var(--evg-accent,#ff8c00);}

/* Step transition base */
.evg-step{transition:none;}

/* SVG icons in spec cards */
.evg-spec-icon svg{display:block;opacity:.7;}

/* Extra row SVG */
.evg-extra-lbl{display:flex;align-items:center;gap:5px;}

.evg-estimate-action{margin-top:18px;padding-top:16px;border-top:1px solid rgba(255,255,255,.06);display:flex;justify-content:flex-end;}

/* Prevent tier label vertical overflow */
.evg-tier-badge, [class*="evg-tier-"] {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  max-width: 100%;
}

/* ═══════════════════════════════════════════════════════════
   Responsive fixes (mobile / tablet)
   ═══════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
  .evg-page {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    overflow-x: hidden;
  }

  .evg-hero-inner {
    padding: 0 24px;
    gap: 28px;
  }

  .evg-main-inner {
    grid-template-columns: 1fr;
  }

  .evg-sidebar {
    position: static;
    order: 2;
  }

  .evg-form-box {
    order: 1;
  }

  .evg-picks {
    grid-template-columns: repeat(2, 1fr);
  }

  .evg-estimate-specs,
  .evg-recap-row {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .evg-hero {
    padding: 44px 0;
  }

  .evg-hero-inner {
    flex-direction: column !important;
    align-items: flex-start;
    padding: 0 18px;
    gap: 24px;
  }

  .evg-hero-content,
  .evg-hero-sub {
    max-width: 100%;
  }

  .evg-hero-pc {
    width: min(100%, 230px);
    height: auto;
    margin: 0 auto;
  }

  .evg-hero-pc svg {
    width: 100%;
    height: auto;
    display: block;
  }

  .evg-main {
    padding: 24px 0 48px;
  }

  .evg-main-inner {
    padding: 0 14px;
    gap: 16px;
  }

  .evg-form-box,
  .evg-side-card {
    padding: 18px;
    border-radius: 14px;
  }

  .evg-prog-header {
    flex-wrap: wrap;
    gap: 12px;
  }

  .evg-prog-track,
  .evg-prog-info {
    width: 100%;
  }

  .evg-prog-info {
    text-align: left;
  }

  .evg-prog-steps {
    justify-content: space-between;
    width: 100%;
    gap: 6px;
  }

  .evg-row-2,
  .evg-estimate-specs,
  .evg-recap-row,
  .evg-testi-grid {
    grid-template-columns: 1fr;
  }

  .evg-picks {
    grid-template-columns: 1fr 1fr;
  }

  .evg-estimate-extra,
  .evg-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .evg-share-row,
  .evg-estimate-action {
    justify-content: stretch;
  }

  .evg-btn,
  .evg-btn-next,
  .evg-btn-prev,
  .evg-btn-submit,
  .evg-btn-ghost {
    width: 100%;
    min-width: 0;
  }

  .evg-perf-row {
    grid-template-columns: 64px 1fr 40px;
    gap: 8px;
  }

  .evg-stage3d {
    height: 260px;
  }
}

@media (max-width: 560px) {
  .evg-hero-title {
    font-size: clamp(26px, 9vw, 34px);
    line-height: 1.08;
  }

  .evg-kicker {
    letter-spacing: 1.6px;
    padding: 7px 12px;
  }

  .evg-trust {
    flex-direction: column;
    align-items: stretch;
  }

  .evg-trust-item {
    width: 100%;
  }

  .evg-main-inner {
    padding: 0 10px;
  }

  .evg-form-box,
  .evg-side-card {
    padding: 14px;
  }

  .evg-prog-dot {
    width: 28px !important;
    height: 28px !important;
    min-width: 28px !important;
    min-height: 28px !important;
    max-width: 28px !important;
    max-height: 28px !important;
    font-size: 11px !important;
  }

  .evg-picks {
    grid-template-columns: 1fr;
  }

  .evg-extra-row {
    flex-wrap: wrap;
  }

  .evg-recap-specs {
    flex-direction: column;
  }

  .evg-rs {
    width: 100%;
    justify-content: space-between;
  }

  .evg-stage3d {
    height: 220px;
  }
}
