/* ============================================================
   MAGIC BOSSES — CSS COMMUN (toutes les pages)
   Couleurs : Noir #000 · Violet #7B2FBE · Orange #F5820A
   ============================================================ */

:root {
  --noir:       #000000;
  --violet:     #7B2FBE;
  --orange:     #F5820A;
  --blanc:      #FFFFFF;
  --gris:       rgba(255,255,255,0.80);
  --gris-dim:   rgba(255,255,255,0.55);
  --glass:      rgba(0,0,0,0.55);
  --glass-bord: rgba(255,255,255,0.08);
  --or:         #F5C518;
  --titre:      'Bebas Neue', sans-serif;
  --corps:      'Barlow', sans-serif;
  --ease:       cubic-bezier(0.22,1,0.36,1);
  --vite:       0.18s ease;
  --base:       0.32s var(--ease);
  --lent:       0.65s var(--ease);
}

/* ── RESET ─────────────────────────────────────────────── */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; overflow-x:hidden; }
body {
  background: var(--noir);
  color: var(--blanc);
  font-family: var(--corps);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
img { max-width:100%; height:auto; display:block; }
a   { text-decoration:none; color:inherit; }
button { font-family:var(--corps); cursor:pointer; border:none; }

/* ── FOND RAYONS ────────────────────────────────────────── */
#bgRays {
  position:fixed; inset:0;
  background: url('../bg-rays.png') center center / cover no-repeat;
  z-index:0; pointer-events:none;
  filter: brightness(1.5);
}
#orageCanvas { display:none; }
#eclairFlash  { display:none; }

/* ── SECTIONS ───────────────────────────────────────────── */
section,footer,.strip { position:relative; z-index:2; }
nav { position:fixed; z-index:200; }

/* ── SCROLLBAR ──────────────────────────────────────────── */
::-webkit-scrollbar              { width:6px; height:6px; }
::-webkit-scrollbar-track        { background:#000; }
::-webkit-scrollbar-thumb        { background:linear-gradient(180deg,var(--violet),var(--orange)); border-radius:3px; }
::-webkit-scrollbar-thumb:hover  { background:var(--orange); }
* { scrollbar-width:thin; scrollbar-color:var(--violet) #000; }

/* ── TOUCH TARGETS ─────────────────────────────────────── */
button,a[role="button"],.panneau,.contact-carte,
.btn-orange,.btn-contour,.btn-nav,.btn-hero-orange,.btn-hero-contour { min-height:44px; }

/* ── SCROLL REVEAL ─────────────────────────────────────── */
.rev   { opacity:0; transform:translateY(32px);  transition:opacity 0.7s var(--ease),transform 0.7s var(--ease); }
.rev-g { opacity:0; transform:translateX(-36px); transition:opacity 0.7s var(--ease),transform 0.7s var(--ease); }
.rev-d { opacity:0; transform:translateX(36px);  transition:opacity 0.7s var(--ease),transform 0.7s var(--ease); }
.rev.ok,.rev-g.ok,.rev-d.ok { opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce) {
  .rev,.rev-g,.rev-d { opacity:1; transform:none; transition:none; }
}

/* ── UTILITAIRES ────────────────────────────────────────── */
.label-section {
  display:block; font-family:var(--corps); font-size:11px; font-weight:600;
  letter-spacing:4px; text-transform:uppercase; color:var(--orange); margin-bottom:12px;
}
.titre-section {
  font-family:var(--titre); font-size:clamp(38px,5.5vw,60px);
  color:var(--blanc); letter-spacing:1.5px; line-height:1;
}
.titre-centre {
  font-family:var(--titre); font-size:clamp(36px,5vw,58px);
  color:var(--blanc); letter-spacing:2px; text-align:center; line-height:1;
}
.sous-titre { font-weight:400; font-size:16px; color:rgba(255,255,255,0.82); line-height:1.75; }
.separateur {
  width:56px; height:3px;
  background:linear-gradient(90deg,var(--violet),var(--orange));
  border-radius:2px; margin:14px auto 0;
  box-shadow:0 0 12px rgba(123,47,190,0.4);
}
.sep-gauche { margin-left:0; }
.en-tete    { text-align:center; margin-bottom:68px; }

/* ── BOUTONS ────────────────────────────────────────────── */
.btn-orange {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--orange); color:#000;
  padding:14px 36px; border-radius:6px;
  font-family:var(--titre); font-size:19px; letter-spacing:1px;
  transition:all var(--base);
  box-shadow:0 4px 24px rgba(245,130,10,0.4);
  position:relative; overflow:hidden;
}
.btn-orange::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.22),transparent);
  transform:translateX(-100%); transition:transform 0.5s ease;
}
.btn-orange:hover { transform:translateY(-2px); box-shadow:0 8px 32px rgba(245,130,10,0.55); }
.btn-orange:hover::after { transform:translateX(100%); }

.btn-contour {
  display:inline-flex; align-items:center; gap:8px;
  background:transparent; color:var(--blanc);
  padding:14px 36px; border-radius:6px;
  font-family:var(--titre); font-size:19px; letter-spacing:1px;
  border:1px solid rgba(255,255,255,0.22); transition:all var(--base);
}
.btn-contour:hover {
  background:rgba(255,255,255,0.06);
  border-color:rgba(255,255,255,0.5);
  transform:translateY(-2px);
}

/* ── NAVBAR ─────────────────────────────────────────────── */
#navbar {
  position:fixed; top:14px; left:14px; right:14px; z-index:200;
  background:rgba(0,0,0,0.50);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border:1px solid rgba(123,47,190,0.22);
  border-radius:14px; padding:0 24px;
  transition:all var(--base);
  box-shadow:0 4px 24px rgba(0,0,0,0.35);
}
#navbar.scrolle {
  background:rgba(0,0,0,0.90);
  border-color:rgba(123,47,190,0.40);
  box-shadow:0 8px 40px rgba(0,0,0,0.6);
}
.nav-cont {
  max-width:1280px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  height:62px; gap:20px;
}
.nav-logo img { width:145px; height:auto; }
.nav-logo-txt { font-family:var(--titre); font-size:24px; letter-spacing:2px; display:none; }
.nav-logo-txt span { color:var(--violet); }
.nav-liens { display:flex; list-style:none; gap:30px; align-items:center; }
.nav-liens a {
  color:rgba(255,255,255,0.60); font-size:12px; font-weight:600;
  letter-spacing:1.8px; text-transform:uppercase;
  transition:color var(--vite); position:relative;
}
.nav-liens a::after {
  content:''; position:absolute; bottom:-3px; left:0; right:0;
  height:1px; background:var(--orange);
  transform:scaleX(0); transform-origin:left; transition:transform var(--vite);
}
.nav-liens a:hover,.nav-liens a.actif { color:var(--blanc); }
.nav-liens a:hover::after,.nav-liens a.actif::after { transform:scaleX(1); }
.btn-nav {
  background:var(--orange); color:#000;
  padding:9px 22px; border-radius:7px;
  font-family:var(--titre); font-size:16px; letter-spacing:1px;
  transition:all var(--vite); box-shadow:0 2px 12px rgba(245,130,10,0.30);
  white-space:nowrap; border:none; cursor:pointer;
}
.btn-nav:hover { transform:translateY(-1px); box-shadow:0 5px 20px rgba(245,130,10,0.50); }
.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:4px; }
.hamburger span { display:block; width:24px; height:2px; background:rgba(255,255,255,0.75); border-radius:2px; transition:all 0.28s ease; }
.hamburger.ouvert span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.hamburger.ouvert span:nth-child(2) { opacity:0; }
.hamburger.ouvert span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }
@media (max-width:768px) {
  #navbar { top:10px; left:10px; right:10px; padding:0 16px; }
  .nav-liens {
    display:none; position:absolute; top:calc(100% + 10px); left:0; right:0;
    background:rgba(0,0,0,0.96); backdrop-filter:blur(24px);
    border:1px solid rgba(123,47,190,0.28); border-radius:12px;
    flex-direction:column; gap:0; padding:10px 0;
    box-shadow:0 12px 36px rgba(0,0,0,0.6);
  }
  .nav-liens.ouverte { display:flex; }
  .nav-liens li a { display:block; padding:13px 22px; border-bottom:1px solid rgba(255,255,255,0.04); font-size:13px; }
  .nav-liens li:last-child a { border-bottom:none; }
  .hamburger { display:flex; }
}

/* ── SÉPARATEUR RAYONS ─────────────────────────────────── */
.sep-rayons { position:relative; width:100%; height:220px; overflow:hidden; flex-shrink:0; }
.sep-rayons-img { position:absolute; inset:0; background:url('../bg-rays.png') center 40% / cover no-repeat; opacity:0.75; }
.sep-rayons::before,.sep-rayons::after {
  content:''; position:absolute; left:0; right:0; height:55%; z-index:1; pointer-events:none;
}
.sep-rayons::before { top:0; background:linear-gradient(to bottom,var(--noir),transparent); }
.sep-rayons::after  { bottom:0; background:linear-gradient(to top,var(--noir),transparent); }

/* ── STRIP RÉASSURANCE ─────────────────────────────────── */
.strip {
  background:rgba(123,47,190,0.06);
  border-top:1px solid rgba(123,47,190,0.15);
  border-bottom:1px solid rgba(245,130,10,0.10);
}
.strip-cont { max-width:1100px; margin:0 auto; display:flex; align-items:stretch; padding:0 32px; }
.strip-item { flex:1; display:flex; align-items:center; gap:18px; padding:42px 32px; transition:background var(--base); }
.strip-item:hover { background:rgba(245,130,10,0.03); }
.strip-item .strip-info { display:flex; flex-direction:column; gap:3px; }
.strip-item strong { font-size:14px; color:var(--blanc); font-weight:600; }
.strip-item span   { font-size:13px; color:rgba(255,255,255,0.74); }
.strip-icone {
  width:48px; height:48px;
  background:rgba(245,130,10,0.08); border:1px solid rgba(245,130,10,0.20);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  color:var(--orange); flex-shrink:0; transition:all var(--base);
}
.strip-item:hover .strip-icone { background:rgba(245,130,10,0.16); box-shadow:0 0 20px rgba(245,130,10,0.18); }
.strip-ligne { width:1px; background:rgba(255,255,255,0.05); margin:22px 0; }
@media (max-width:768px) {
  .strip-cont  { flex-direction:column; padding:0 20px; }
  .strip-ligne { width:100%; height:1px; margin:0; }
  .strip-item  { padding:26px 0; }
}

/* ── CTA FINAL ──────────────────────────────────────────── */
#cta-final { position:relative; overflow:hidden; padding:150px 24px; text-align:center; }
.logo-banniere { position:relative; width:100%; height:180px; overflow:hidden; display:flex; align-items:center; justify-content:center; }
.lb-img { position:absolute; inset:0; background:url('../logo-banner.png') center center / cover no-repeat; opacity:0.14; filter:blur(0.5px); }
.logo-banniere::before {
  content:''; position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(to right,  rgba(4,2,10,0.92) 0%,  transparent 30%),
    linear-gradient(to left,   rgba(4,2,10,0.92) 0%,  transparent 30%),
    linear-gradient(to bottom, rgba(4,2,10,0.80) 0%,  transparent 40%),
    linear-gradient(to top,    rgba(4,2,10,0.80) 0%,  transparent 40%);
}
.lb-texte { position:relative; z-index:2; text-align:center; display:flex; flex-direction:column; gap:6px; }
.lb-texte span  { font-size:11px; letter-spacing:4px; text-transform:uppercase; color:rgba(255,255,255,0.72); font-weight:600; }
.lb-texte strong { font-family:var(--titre); font-size:clamp(22px,3.5vw,38px); color:var(--blanc); letter-spacing:3px; }
.cta-lueur {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:120%; height:200%;
  background:
    radial-gradient(ellipse at 30% 50%,rgba(123,47,190,0.20),transparent 52%),
    radial-gradient(ellipse at 70% 50%,rgba(245,130,10,0.12),transparent 52%);
  pointer-events:none;
  animation:lueurBouge 12s ease-in-out infinite alternate;
}
@keyframes lueurBouge { 0% { opacity:1; transform:translate(-50%,-50%) scale(1); } 100% { opacity:0.75; transform:translate(-50%,-50%) scale(1.06) translateX(20px); } }
.cta-cont    { position:relative; z-index:2; max-width:660px; margin:0 auto; }
.cta-titre   { font-family:var(--titre); font-size:clamp(48px,8.5vw,92px); line-height:0.92; margin-bottom:22px; color:var(--blanc); }
.cta-accent  { background:linear-gradient(135deg,var(--violet) 0%,var(--orange) 100%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.cta-sous    { font-size:16px; color:rgba(255,255,255,0.78); line-height:1.80; margin-bottom:44px; max-width:460px; margin-left:auto; margin-right:auto; }
.cta-btn     { font-size:22px; padding:18px 52px; }
.cta-garanties { display:flex; justify-content:center; flex-wrap:wrap; gap:10px; margin-top:28px; }
.cta-garanties span { font-size:12px; color:rgba(255,255,255,0.74); background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.07); padding:5px 14px; border-radius:50px; }
@media (max-width:768px) { #cta-final { padding:90px 20px; } .cta-btn { width:100%; font-size:19px; padding:16px 24px; } }

/* ── CONTACT + FOOTER ───────────────────────────────────── */
#contact { background:transparent; }
.footer-trait { height:1px; background:linear-gradient(90deg,transparent,var(--violet) 30%,var(--orange) 70%,transparent); }
.contact-cont { max-width:600px; margin:0 auto; padding:95px 24px 75px; }
.contact-cartes { display:flex; flex-direction:column; gap:10px; margin-top:44px; }
.contact-carte {
  display:flex; align-items:center; gap:18px;
  background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.07);
  border-radius:18px; padding:22px 26px; color:var(--blanc); transition:all var(--base);
}
.contact-carte:hover { transform:translateY(-2px) scale(1.012); box-shadow:0 14px 40px rgba(0,0,0,0.5); }
.contact-wa { border-color:rgba(37,211,102,0.18); background:rgba(37,211,102,0.025); }
.contact-wa:hover { border-color:rgba(37,211,102,0.42); box-shadow:0 14px 40px rgba(37,211,102,0.06); }
.contact-wa .contact-icone { color:#25d366; background:rgba(37,211,102,0.08); border-color:rgba(37,211,102,0.20); }
.contact-icone {
  width:50px; height:50px; border-radius:13px;
  background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.09);
  display:flex; align-items:center; justify-content:center;
  color:var(--orange); flex-shrink:0; transition:all var(--base);
}
.contact-carte:not(.contact-wa):hover .contact-icone { background:rgba(245,130,10,0.10); border-color:rgba(245,130,10,0.32); }
.contact-info { display:flex; flex-direction:column; gap:2px; flex:1; }
.contact-label  { font-size:10px; text-transform:uppercase; letter-spacing:3px; color:rgba(255,255,255,0.62); }
.contact-valeur { font-family:var(--titre); font-size:21px; letter-spacing:0.5px; }
.contact-hint   { font-size:12px; color:rgba(255,255,255,0.66); }
.contact-wa .contact-hint { color:rgba(37,211,102,0.52); }
.contact-fleche { font-size:19px; color:rgba(255,255,255,0.12); transition:transform var(--vite),color var(--vite); }
.contact-carte:hover .contact-fleche { transform:translateX(6px); color:rgba(245,130,10,0.65); }
.pied-page { padding:44px 24px 36px; display:flex; flex-direction:column; align-items:center; gap:18px; border-top:1px solid rgba(255,255,255,0.04); }
.pied-logo { cursor:pointer; }
.pied-logo img { width:96px; }
.pied-social { display:flex; gap:11px; }
.pied-social a {
  width:42px; height:42px; border:1px solid rgba(255,255,255,0.07); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,0.72); background:rgba(255,255,255,0.025); transition:all var(--base);
}
.pied-social a:hover { border-color:rgba(245,130,10,0.48); color:var(--orange); background:rgba(245,130,10,0.07); box-shadow:0 4px 16px rgba(245,130,10,0.18); }
.pied-legal { font-size:11.5px; color:rgba(255,255,255,0.22); line-height:1.85; text-align:center; }
@media (max-width:768px) { .contact-cont { padding:68px 20px 56px; } .contact-carte { padding:17px 15px; gap:13px; } .contact-valeur { font-size:17px; } }

/* ── MASCOTTE ───────────────────────────────────────────── */
#mascotte {
  position:fixed; bottom:22px; right:22px; z-index:500;
  cursor:pointer; display:flex; flex-direction:column; align-items:flex-end;
}
#mascotte img { width:108px; filter:drop-shadow(0 8px 18px rgba(123,47,190,0.48)); transition:transform 0.2s; }
#mascotte:hover img { transform:scale(1.06); }
.mascotte-fallback {
  width:76px; height:92px;
  background:linear-gradient(135deg,#1a1a1a,#0d0d0d);
  border:2px solid var(--violet); border-radius:50% 50% 40% 40%;
  display:none; align-items:center; justify-content:center;
  font-family:var(--titre); font-size:13px; color:var(--orange);
}
#bulleFlottante {
  background:#fff; color:#000; padding:8px 14px;
  border-radius:11px 11px 4px 11px;
  font-size:13px; font-weight:600; white-space:nowrap;
  margin-bottom:7px; box-shadow:0 4px 14px rgba(0,0,0,0.38);
  animation:apparaitre 0.3s ease;
}
@keyframes apparaitre { from { opacity:0; transform:translateY(6px); } to { opacity:1; transform:none; } }
@keyframes clignote { 0%,100% { transform:scale(1); opacity:1; } 50% { transform:scale(1.4); opacity:0.6; } }

/* ── OVERLAY DEVIS ─────────────────────────────────────── */
#devisOverlay {
  position:fixed; inset:0;
  background:rgba(0,0,0,0.62); z-index:580;
  display:none; backdrop-filter:blur(4px);
}
#devisOverlay.ouvert { display:block; }

/* ── PANNEAU DEVIS ─────────────────────────────────────── */
#devisPanel {
  position:fixed; top:0; right:0; bottom:0;
  width:440px; max-width:100vw;
  background:rgba(4,2,14,0.97); backdrop-filter:blur(26px);
  border-left:1px solid rgba(123,47,190,0.18);
  z-index:600; transform:translateX(110%);
  transition:transform 0.38s var(--ease);
  overflow-y:auto; display:flex; flex-direction:column;
}
#devisPanel.ouvert { transform:translateX(0); }
.devis-entete {
  background:rgba(0,0,0,0.38); padding:17px 18px;
  border-bottom:1px solid rgba(123,47,190,0.14);
  display:flex; align-items:center; gap:11px;
  position:sticky; top:0; z-index:1; backdrop-filter:blur(12px);
}
.devis-entete img { width:52px; flex-shrink:0; }
.mascotte-sm {
  width:46px; height:54px; background:#111; border:1px solid var(--violet);
  border-radius:7px; display:none; align-items:center; justify-content:center;
  font-family:var(--titre); font-size:10px; color:var(--orange); flex-shrink:0;
}
#bullePanneau {
  flex:1; background:#fff; color:#000; padding:9px 12px;
  border-radius:11px 11px 11px 4px; font-size:13px; font-weight:600; line-height:1.4;
}
.devis-fermer { background:none; border:none; color:rgba(255,255,255,0.80); font-size:21px; cursor:pointer; flex-shrink:0; padding:4px 7px; }
.devis-fermer:hover { color:#fff; }
.devis-corps { padding:22px; flex:1; }
.devis-titre { font-family:var(--titre); font-size:25px; color:#fff; margin-bottom:20px; letter-spacing:1px; }
.form-ligne { display:grid; grid-template-columns:1fr 1fr; gap:11px; }
.form-champ { margin-bottom:13px; }
.form-champ label { display:block; font-size:11px; color:rgba(255,255,255,0.80); margin-bottom:5px; letter-spacing:1px; text-transform:uppercase; }
.form-champ input,.form-champ select,.form-champ textarea {
  width:100%; background:rgba(255,255,255,0.05);
  border:1px solid rgba(123,47,190,0.20); color:#fff;
  padding:10px 12px; border-radius:8px;
  font-family:var(--corps); font-size:14px; outline:none;
  transition:border-color 0.18s,box-shadow 0.18s;
}
.form-champ input:focus,.form-champ select:focus,.form-champ textarea:focus {
  border-color:var(--violet); box-shadow:0 0 0 3px rgba(123,47,190,0.11);
}
.form-champ select {
  cursor:pointer; appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237B2FBE' stroke-width='2' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 13px center;
}
.form-champ select option { background:#111; color:#fff; }
.form-champ textarea { resize:vertical; min-height:78px; }
.form-options { margin-bottom:13px; display:flex; flex-direction:column; gap:7px; }
.opt { display:flex; align-items:center; gap:9px; font-size:13px; color:rgba(255,255,255,0.60); cursor:pointer; }
.opt input[type="checkbox"] { width:15px; height:15px; accent-color:var(--violet); cursor:pointer; flex-shrink:0; }
.btn-photo {
  width:100%; background:rgba(245,130,10,0.05); border:1.5px dashed rgba(245,130,10,0.32);
  color:var(--orange); padding:13px; border-radius:8px;
  font-family:var(--titre); font-size:15px; letter-spacing:1px; cursor:pointer;
  transition:all 0.18s; display:flex; align-items:center; justify-content:center; gap:7px;
}
.btn-photo:hover { border-color:var(--orange); background:rgba(245,130,10,0.09); }
.dispo-label { font-size:11px; color:rgba(255,255,255,0.50); margin-bottom:7px; letter-spacing:1px; text-transform:uppercase; }
.dispo-grille { display:grid; grid-template-columns:repeat(3,1fr); gap:5px; }
.dispo-creneau {
  background:#111; border:1px solid rgba(255,255,255,0.07);
  color:rgba(255,255,255,0.66); padding:7px 4px; border-radius:6px;
  cursor:pointer; font-size:10px; font-family:var(--corps); font-weight:600;
  text-align:center; transition:all 0.14s; line-height:1.3;
}
.dispo-creneau:hover { border:1px solid rgba(245,130,10,0.38); color:rgba(245,130,10,0.68); }
.dispo-creneau.sel { background:rgba(245,130,10,0.11); border:1px solid var(--orange); color:var(--orange); }
.accept-bloc { background:rgba(123,47,190,0.05); border:1px solid rgba(123,47,190,0.20); border-radius:7px; padding:13px; margin-bottom:13px; }
.accept-label { display:flex; align-items:flex-start; gap:9px; cursor:pointer; font-size:12px; color:rgba(255,255,255,0.82); line-height:1.55; }
.accept-label input { width:15px; height:15px; accent-color:var(--violet); cursor:pointer; flex-shrink:0; margin-top:2px; }
.accept-label strong { color:rgba(255,255,255,0.80); }
.btn-envoyer {
  width:100%; background:var(--orange); color:#000; border:none;
  padding:14px; border-radius:8px; font-family:var(--titre);
  font-size:21px; letter-spacing:2px; cursor:pointer; transition:all 0.22s;
  box-shadow:0 4px 18px rgba(245,130,10,0.28); margin-top:2px;
}
.btn-envoyer:hover { transform:translateY(-1px); box-shadow:0 7px 26px rgba(245,130,10,0.42); }
.btn-envoyer:disabled { opacity:0.5; cursor:not-allowed; transform:none; }
.erreur-champ { color:var(--orange); font-size:0.75rem; display:block; margin-top:4px; }

/* ── ADMIN ──────────────────────────────────────────────── */
#adminPanel { position:fixed; inset:0; background:rgba(0,0,0,0.97); z-index:999; flex-direction:column; }
.admin-interieur { max-width:900px; margin:0 auto; padding:30px 22px; width:100%; height:100%; overflow-y:auto; display:flex; flex-direction:column; }
.admin-entete { display:flex; align-items:center; gap:14px; margin-bottom:24px; flex-wrap:wrap; }
.admin-entete h2 { font-family:var(--titre); font-size:26px; color:#fff; letter-spacing:2px; flex:1; }
.admin-btn { background:transparent; border:1px solid rgba(123,47,190,0.45); color:var(--violet); padding:7px 15px; border-radius:4px; font-size:13px; cursor:pointer; transition:all 0.18s; }
.admin-btn:hover { background:var(--violet); color:#fff; }
.admin-fermer { border-color:rgba(255,255,255,0.18); color:rgba(255,255,255,0.78); }
.admin-fermer:hover { background:rgba(255,255,255,0.09); color:#fff; }
.admin-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:13px; margin-bottom:20px; }
.admin-stat { background:#111; border:1px solid rgba(123,47,190,0.18); border-radius:7px; padding:13px; text-align:center; }
.admin-stat-val { font-family:var(--titre); font-size:30px; color:var(--orange); }
.admin-stat-lbl { font-size:10px; color:rgba(255,255,255,0.72); text-transform:uppercase; letter-spacing:1px; }
.admin-vide { text-align:center; padding:56px; color:rgba(255,255,255,0.64); font-style:italic; }
.devis-item { background:#0d0d0d; border:1px solid rgba(123,47,190,0.18); border-radius:8px; padding:17px; margin-bottom:13px; }
.devis-item-entete { display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-bottom:9px; }
.devis-item-id   { font-family:var(--titre); font-size:12px; color:rgba(255,255,255,0.66); letter-spacing:1px; }
.devis-item-nom  { font-weight:600; font-size:15px; color:#fff; flex:1; }
.devis-item-date { font-size:11px; color:rgba(255,255,255,0.66); }
.badge-statut { padding:3px 10px; border-radius:50px; font-size:11px; font-weight:700; letter-spacing:1px; }
.badge-attente  { background:rgba(245,130,10,0.18); color:var(--orange); border:1px solid var(--orange); }
.badge-planifie { background:rgba(123,47,190,0.18); color:var(--violet); border:1px solid var(--violet); }
.badge-termine  { background:rgba(74,222,128,0.18); color:#4ade80; border:1px solid #4ade80; }
.devis-item-corps { font-size:13px; color:rgba(255,255,255,0.80); line-height:1.75; }
.devis-item-actions { display:flex; gap:7px; margin-top:10px; flex-wrap:wrap; }
.action-btn { background:transparent; border:1px solid rgba(255,255,255,0.13); color:rgba(255,255,255,0.75); padding:4px 11px; border-radius:4px; font-size:11px; cursor:pointer; transition:all 0.15s; }
.action-btn:hover { border-color:var(--violet); color:var(--violet); }
@media (max-width:768px) { .admin-stats { grid-template-columns:1fr 1fr; } }

/* ── COOKIE BANNER ─────────────────────────────────────── */
#cookieBanner {
  position:fixed; bottom:0; left:0; right:0; z-index:999;
  background:#0c0c0c; border-top:1px solid rgba(123,47,190,0.30);
  padding:15px 22px; display:none; align-items:center;
  justify-content:space-between; gap:15px; flex-wrap:wrap;
}
#cookieBanner p { margin:0; font-size:13px; color:rgba(255,255,255,0.62); line-height:1.55; flex:1; min-width:240px; }
.cookie-btns { display:flex; gap:9px; flex-shrink:0; }
.cookie-btns button { background:transparent; border:1px solid rgba(255,255,255,0.22); color:rgba(255,255,255,0.58); padding:7px 15px; border-radius:5px; font-size:13px; cursor:pointer; }
.cookie-accepter { background:var(--orange) !important; border-color:var(--orange) !important; color:#000 !important; font-weight:600; }

/* ── CONFETTI ───────────────────────────────────────────── */
.confetti { position:fixed; width:9px; height:9px; top:-20px; z-index:999; border-radius:2px; pointer-events:none; animation:confettiFall linear forwards; }
@keyframes confettiFall { 0% { transform:translateY(-20px) rotate(0deg); opacity:1; } 100% { transform:translateY(100vh) rotate(720deg); opacity:0; } }

/* ── LIGHTBOX ───────────────────────────────────────────── */
#lightbox {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,0.92); backdrop-filter:blur(8px);
  z-index:900; align-items:center; justify-content:center;
}
#lightbox.ouvert { display:flex; }
#lbCont { max-width:90vw; max-height:90vh; position:relative; }
#lbImg img { max-width:90vw; max-height:85vh; border-radius:10px; display:block; }
.lb-fermer {
  position:absolute; top:-44px; right:0;
  background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.14);
  color:#fff; font-size:18px; cursor:pointer;
  width:34px; height:34px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; transition:background var(--vite);
}
.lb-fermer:hover { background:rgba(255,255,255,0.20); }
.lb-nav {
  position:absolute; top:50%; transform:translateY(-50%);
  background:rgba(123,47,190,0.45); backdrop-filter:blur(8px);
  border:1px solid rgba(123,47,190,0.38); color:#fff;
  font-size:24px; padding:10px 14px; cursor:pointer; border-radius:10px; transition:all var(--vite);
}
.lb-nav:hover { background:var(--violet); }
.lb-prec { left:-56px; }
.lb-suiv { right:-56px; }
@media (max-width:600px) { .lb-prec { left:4px; } .lb-suiv { right:4px; } }

/* ── BANNIÈRES LOGO ─────────────────────────────────────── */
.logo-banniere { position:relative; width:100%; height:180px; overflow:hidden; display:flex; align-items:center; justify-content:center; }
