:root{
  --bg:#070811; --bg2:#0b0e1c; --card:rgba(20,24,42,.55); --bd:rgba(255,255,255,.09);
  --ink:#eef1fb; --dim:#9aa3c4; --faint:#6b7396;
  --c1:#7c5cff; --c2:#a855f7; --c3:#22d3ee; --gold:#ffd479;
  --grad:linear-gradient(115deg,var(--c1),var(--c2) 45%,var(--c3));
  --radius:20px; --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  background:var(--bg); color:var(--ink); line-height:1.6; overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%}

/* ── Fonds animés ──────────────────────────────────────────── */
#fx{position:fixed;inset:0;z-index:-2;background:
  radial-gradient(1200px 600px at 80% -10%, rgba(124,92,255,.18), transparent 60%),
  radial-gradient(900px 500px at 0% 20%, rgba(34,211,238,.10), transparent 55%),
  var(--bg);}
#grid{position:fixed;inset:0;z-index:-2;opacity:.35;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:54px 54px;
  mask-image:radial-gradient(circle at 50% 0%,#000 0%,transparent 70%);
  -webkit-mask-image:radial-gradient(circle at 50% 0%,#000 0%,transparent 70%);}
#particles{position:fixed;inset:0;z-index:-1;pointer-events:none}
.blob{position:fixed;border-radius:50%;filter:blur(90px);opacity:.5;z-index:-2;animation:float 18s ease-in-out infinite}
.blob.a{width:480px;height:480px;background:radial-gradient(circle,rgba(124,92,255,.55),transparent 70%);top:-120px;left:-80px}
.blob.b{width:420px;height:420px;background:radial-gradient(circle,rgba(34,211,238,.4),transparent 70%);top:30%;right:-120px;animation-delay:-6s}
.blob.c{width:380px;height:380px;background:radial-gradient(circle,rgba(168,85,247,.4),transparent 70%);bottom:-100px;left:40%;animation-delay:-11s}
@keyframes float{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(40px,-30px) scale(1.08)}}

/* curseur glow */
#cursor{position:fixed;width:380px;height:380px;border-radius:50%;pointer-events:none;z-index:0;
  background:radial-gradient(circle,rgba(124,92,255,.13),transparent 65%);
  transform:translate(-50%,-50%);transition:opacity .3s;opacity:0;mix-blend-mode:screen}

/* ── Conteneur ─────────────────────────────────────────────── */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:22px;padding-right:22px;position:relative;z-index:1}
section{padding-top:112px;padding-bottom:112px;position:relative;z-index:1}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.78rem;font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;color:var(--c3);padding:7px 14px;border:1px solid var(--bd);border-radius:999px;
  background:rgba(255,255,255,.03);backdrop-filter:blur(8px)}
h1,h2,h3{line-height:1.12;letter-spacing:-.02em;font-weight:800}
.h-sec{font-size:clamp(1.9rem,4vw,2.9rem);text-align:center}
.sub-sec{text-align:center;color:var(--dim);max-width:640px;margin:16px auto 0;font-size:1.05rem}

/* ── Nav ───────────────────────────────────────────────────── */
nav{position:fixed;top:0;left:0;right:0;z-index:50;transition:.3s}
nav .bar{max-width:var(--maxw);margin:0 auto;padding:16px 22px;display:flex;align-items:center;gap:14px}
nav.scrolled{background:rgba(7,8,17,.72);backdrop-filter:blur(16px);border-bottom:1px solid var(--bd)}
.logo{font-weight:800;font-size:1.18rem;display:flex;align-items:center;gap:9px;letter-spacing:-.02em}
.logo .dot{width:11px;height:11px;border-radius:50%;background:var(--grad);box-shadow:0 0 16px var(--c1)}
.nav-links{margin-left:auto;display:flex;gap:28px;align-items:center}
.nav-links a{color:var(--dim);font-size:.93rem;font-weight:500;transition:.2s}
.nav-links a:hover{color:var(--ink)}
@media(max-width:760px){.nav-links a:not(.btn){display:none}}

/* ── Boutons ───────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;border:none;cursor:pointer;
  font-family:inherit;font-weight:600;font-size:.96rem;padding:13px 24px;border-radius:13px;transition:.25s;
  position:relative;white-space:nowrap}
.btn-primary{background:var(--grad);color:#fff;background-size:180% 180%;
  box-shadow:0 10px 30px -8px rgba(124,92,255,.6)}
.btn-primary:hover{background-position:100% 0;transform:translateY(-2px);box-shadow:0 16px 40px -8px rgba(124,92,255,.75)}
.btn-ghost{background:rgba(255,255,255,.04);color:var(--ink);border:1px solid var(--bd);backdrop-filter:blur(8px)}
.btn-ghost:hover{background:rgba(255,255,255,.09);transform:translateY(-2px)}
.btn-lg{padding:16px 32px;font-size:1.02rem;border-radius:15px}
.btn-block{width:100%}

/* ── Hero ──────────────────────────────────────────────────── */
.hero{padding-top:170px;padding-bottom:90px;text-align:center}
.hero h1{font-size:clamp(2.5rem,6.2vw,4.7rem);margin:26px 0 0}
.hero p.lead{color:var(--dim);font-size:clamp(1.05rem,2vw,1.32rem);max-width:680px;margin:22px auto 0}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:38px}
.hero-meta{margin-top:30px;display:flex;gap:24px;justify-content:center;flex-wrap:wrap;color:var(--faint);font-size:.86rem}
.hero-meta span{display:inline-flex;gap:7px;align-items:center}

/* mockup flottant sous le hero */
.showcase{margin:64px auto 0;max-width:1080px;display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.sc-card{background:var(--card);border:1px solid var(--bd);border-radius:var(--radius);padding:26px 22px;
  backdrop-filter:blur(14px);text-align:center;position:relative;overflow:hidden}
.sc-card .ic{font-size:1.9rem}
.sc-card h4{margin:14px 0 6px;font-size:1.08rem}
.sc-card p{color:var(--dim);font-size:.9rem;margin:0}
.sc-card::after{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad);opacity:.7}
@media(max-width:860px){.showcase{grid-template-columns:repeat(2,1fr)}}@media(max-width:500px){.showcase{grid-template-columns:1fr}}

/* ── Services détaillés ────────────────────────────────────── */
.features{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:54px}
.feat{background:var(--card);border:1px solid var(--bd);border-radius:var(--radius);padding:30px;backdrop-filter:blur(14px);transition:.3s}
.feat:hover{transform:translateY(-6px);border-color:rgba(124,92,255,.5)}
.feat .ring{width:54px;height:54px;border-radius:15px;display:grid;place-items:center;font-size:1.6rem;
  background:linear-gradient(145deg,rgba(124,92,255,.22),rgba(34,211,238,.14));border:1px solid var(--bd)}
.feat h3{font-size:1.22rem;margin:18px 0 8px}
.feat p{color:var(--dim);font-size:.95rem}
.feat ul{list-style:none;margin:16px 0 0}
.feat li{color:var(--dim);font-size:.9rem;padding:5px 0 5px 26px;position:relative}
.feat li::before{content:"✓";position:absolute;left:0;color:var(--c3);font-weight:700}
@media(max-width:980px){.features{grid-template-columns:repeat(2,1fr)}}@media(max-width:560px){.features{grid-template-columns:1fr}}

/* ── Tarifs ────────────────────────────────────────────────── */
.toggle{display:flex;justify-content:center;align-items:center;gap:14px;margin:34px 0 10px}
.toggle button{background:rgba(255,255,255,.05);border:1px solid var(--bd);color:var(--dim);
  padding:9px 20px;border-radius:999px;cursor:pointer;font-family:inherit;font-weight:600;font-size:.9rem;transition:.2s}
.toggle button.on{background:var(--grad);color:#fff;border-color:transparent}
.save-pill{font-size:.78rem;color:var(--gold);font-weight:600}
.pricing{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:34px;align-items:stretch}
@media(max-width:980px){.pricing{grid-template-columns:repeat(2,1fr)}}@media(max-width:560px){.pricing{grid-template-columns:1fr}}

.price-card{background:var(--card);border:1px solid var(--bd);border-radius:var(--radius);padding:30px 24px;
  backdrop-filter:blur(16px);display:flex;flex-direction:column;position:relative;transition:.3s;
  transform-style:preserve-3d;will-change:transform}
.price-card:hover{border-color:rgba(124,92,255,.45)}
.price-card .ic{font-size:1.7rem}
.price-card h3{font-size:1.16rem;margin:12px 0 4px}
.price-card .pc-tag{color:var(--faint);font-size:.85rem;min-height:38px}
.price-card .amt{margin:18px 0 4px;display:flex;align-items:baseline;gap:6px}
.price-card .amt .n{font-size:2.6rem;font-weight:800;letter-spacing:-.03em}
.price-card .amt .u{color:var(--dim);font-size:.92rem}
.price-card .ann{color:var(--gold);font-size:.8rem;min-height:18px}
.price-card ul{list-style:none;margin:20px 0 26px;flex:1}
.price-card li{font-size:.9rem;padding:7px 0 7px 26px;position:relative;color:var(--dim)}
.price-card li::before{content:"✓";position:absolute;left:0;color:var(--c2);font-weight:700}
/* pack en avant : bordure dégradée nette + lueur douce qui pulse autour */
.price-card.featured{border:1.5px solid transparent;
  background:linear-gradient(var(--bg2),var(--bg2)) padding-box,var(--grad) border-box;
  transform:scale(1.03)}
.price-card.featured::after{content:"";position:absolute;inset:-3px;border-radius:calc(var(--radius) + 3px);z-index:-1;
  background:var(--grad);filter:blur(22px);opacity:.4;animation:halo 4s ease-in-out infinite}
@keyframes halo{0%,100%{opacity:.32;filter:blur(20px)}50%{opacity:.6;filter:blur(30px)}}
@media(max-width:1080px){.price-card.featured{transform:scale(1)}}
.popular{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--grad);color:#fff;
  font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:6px 14px;border-radius:999px;
  white-space:nowrap;box-shadow:0 6px 20px -4px rgba(124,92,255,.7)}

/* ── Comparatif ────────────────────────────────────────────── */
.cmp{margin-top:54px;overflow:auto;border:1px solid var(--bd);border-radius:var(--radius);background:var(--card);backdrop-filter:blur(12px)}
.cmp-hint{display:none}
.lbl-mini{display:none}
table.cmp-t{width:100%;border-collapse:collapse;min-width:560px}
.cmp-t th,.cmp-t td{padding:15px 18px;text-align:center;border-bottom:1px solid var(--bd);font-size:.92rem}
.cmp-t th:first-child,.cmp-t td:first-child{text-align:left;color:var(--ink)}
.cmp-t thead th{color:var(--dim);font-weight:600;font-size:.85rem}
.cmp-t tbody td{color:var(--dim)}
.cmp-t .yes{color:var(--c3);font-weight:700}
.cmp-t .no{color:var(--faint)}
.cmp-t .pk{background:rgba(124,92,255,.08)}

/* ── Trust ─────────────────────────────────────────────────── */
.trust{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:48px}
.trust .t{background:var(--card);border:1px solid var(--bd);border-radius:16px;padding:24px;text-align:center;backdrop-filter:blur(12px)}
.trust .t .ic{font-size:1.7rem}
.trust .t h4{margin:10px 0 5px;font-size:1rem}
.trust .t p{color:var(--dim);font-size:.85rem}
@media(max-width:860px){.trust{grid-template-columns:repeat(2,1fr)}}

/* ── FAQ ───────────────────────────────────────────────────── */
.faq{max-width:760px;margin:48px auto 0}
.qa{border:1px solid var(--bd);border-radius:14px;background:var(--card);backdrop-filter:blur(10px);margin-bottom:12px;overflow:hidden}
.qa summary{padding:18px 22px;cursor:pointer;font-weight:600;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
.qa summary::-webkit-details-marker{display:none}
.qa summary::after{content:"+";color:var(--c3);font-size:1.4rem;transition:.2s}
.qa[open] summary::after{transform:rotate(45deg)}
.qa .a{padding:0 22px 20px;color:var(--dim);font-size:.94rem}

/* ── CTA final ─────────────────────────────────────────────── */
.cta-final{text-align:center;background:linear-gradient(145deg,rgba(124,92,255,.16),rgba(34,211,238,.08));
  border:1px solid var(--bd);border-radius:28px;padding:64px 28px;backdrop-filter:blur(14px);position:relative;overflow:hidden}
.cta-final h2{font-size:clamp(1.8rem,4vw,2.6rem)}
.cta-final p{color:var(--dim);max-width:520px;margin:14px auto 30px}

footer{padding:48px 0;border-top:1px solid var(--bd);color:var(--faint);font-size:.86rem;text-align:center}
footer .logo{justify-content:center;margin-bottom:12px;color:var(--ink)}

/* ── Modal ─────────────────────────────────────────────────── */
.modal-bg{position:fixed;inset:0;background:rgba(4,5,12,.7);backdrop-filter:blur(6px);z-index:100;
  display:none;align-items:center;justify-content:center;padding:20px}
.modal-bg.show{display:flex}
.modal{background:var(--bg2);border:1px solid var(--bd);border-radius:22px;max-width:440px;width:100%;padding:32px;
  position:relative;box-shadow:0 40px 90px -30px rgba(0,0,0,.8);animation:pop .3s ease}
@keyframes pop{from{transform:translateY(16px) scale(.97);opacity:0}to{transform:none;opacity:1}}
.modal h3{font-size:1.35rem}
.modal .mp{color:var(--dim);font-size:.92rem;margin:8px 0 20px}
.modal label{display:block;font-size:.82rem;color:var(--dim);margin:12px 0 5px}
.modal input,.modal textarea{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--bd);color:var(--ink);
  border-radius:11px;padding:12px 14px;font-family:inherit;font-size:.94rem}
.modal textarea{resize:vertical}
.modal .x{position:absolute;top:16px;right:18px;cursor:pointer;color:var(--dim);font-size:1.5rem;line-height:1;background:none;border:none}
.ok-msg{text-align:center;padding:20px 0}
.ok-msg .big{font-size:3rem}

/* ── Sections détaillées (split) ───────────────────────────── */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split>*{min-width:0}  /* empêche les items grid de déborder (carte fidélité) */
.split.reverse .split-text{order:2}
.split-text h2{font-size:clamp(1.6rem,3.2vw,2.4rem);margin:16px 0 0}
.split-text>p{color:var(--dim);margin-top:16px;font-size:1.03rem}
.split-list{list-style:none;margin-top:24px}
.split-list li{position:relative;padding:10px 0 10px 34px;font-size:.97rem}
.split-list li::before{content:"✓";position:absolute;left:0;top:9px;width:22px;height:22px;border-radius:7px;
  background:linear-gradient(145deg,var(--c1),var(--c3));color:#fff;font-size:.78rem;display:grid;place-items:center;font-weight:700}
.split-list li b{font-weight:600}
@media(max-width:900px){.split{grid-template-columns:1fr;gap:40px}.split.reverse .split-text{order:0}}

/* mockup générique (fenêtre) */
.mk{background:var(--card);border:1px solid var(--bd);border-radius:18px;backdrop-filter:blur(14px);overflow:hidden;
  box-shadow:0 36px 70px -34px rgba(0,0,0,.7)}
.mk-bar{display:flex;gap:7px;align-items:center;padding:14px 16px;border-bottom:1px solid var(--bd)}
.mk-bar i{width:11px;height:11px;border-radius:50%;background:#3a3f55}
.mk-bar i:nth-child(1){background:#ff5f57}.mk-bar i:nth-child(2){background:#febc2e}.mk-bar i:nth-child(3){background:#28c840}
.mk-bar .url{margin-left:10px;flex:1;font-size:.76rem;color:var(--faint);background:rgba(255,255,255,.04);padding:5px 12px;border-radius:7px}
.mk-body{padding:20px}
.mk-field{margin-bottom:14px}
.mk-field>span{display:block;font-size:.74rem;color:var(--faint);margin-bottom:6px}
.mk-input{background:rgba(255,255,255,.05);border:1px solid var(--bd);border-radius:9px;padding:10px 12px;font-size:.9rem}
.mk-input::after{content:"|";color:var(--c3);margin-left:2px;animation:blink 1.1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
.mk-photo{background:rgba(255,255,255,.03);border:1px dashed var(--bd);border-radius:9px;padding:18px;text-align:center;color:var(--faint);font-size:.85rem;margin-bottom:14px}
.mk-row{display:flex;justify-content:space-between;align-items:center;padding:11px 13px;background:rgba(255,255,255,.03);
  border:1px solid var(--bd);border-radius:10px;margin-bottom:10px;font-size:.86rem}
.mk-row .lbl{color:var(--dim)}
.sw{width:40px;height:23px;border-radius:999px;background:var(--grad);position:relative;flex:none}
.sw::after{content:"";position:absolute;top:3px;right:3px;width:17px;height:17px;border-radius:50%;background:#fff}
.sw.off{background:rgba(255,255,255,.13)}.sw.off::after{right:auto;left:3px}

/* carte de fidélité premium (réutilisée dans l'app Loyal) */
.loyalty{aspect-ratio:1.6/1;border-radius:22px;padding:26px;color:#fff;position:relative;overflow:hidden;
  background:radial-gradient(120% 140% at 0% 0%,#5b34d6,transparent 55%),linear-gradient(135deg,#1c1140,#3a1f7a 50%,#6d4bff);
  animation:lhalo 4.5s ease-in-out infinite}
@keyframes lhalo{
  0%,100%{box-shadow:0 40px 80px -30px rgba(124,92,255,.55),0 0 26px 0 rgba(124,92,255,.18),inset 0 1px 0 rgba(255,255,255,.18)}
  50%{box-shadow:0 44px 90px -28px rgba(124,92,255,.7),0 0 48px 9px rgba(124,92,255,.42),inset 0 1px 0 rgba(255,255,255,.2)}}
.loyalty.tilt{will-change:transform}
/* Sans souris (mobile) : balayage 3D auto, haut-gauche → haut-droite, en douceur */
@keyframes loyaltySweep{
  0%,100%{transform:perspective(900px) rotateX(5deg) rotateY(-8deg) translateY(-3px)}
  50%{transform:perspective(900px) rotateX(5deg) rotateY(8deg) translateY(-3px)}}
@media(hover:none){
  .loyalty.tilt{animation:lhalo 4.5s ease-in-out infinite, loyaltySweep 6.5s ease-in-out infinite}}
.loyalty-shine{position:absolute;top:-60%;left:-30%;width:70%;height:220%;transform:rotate(20deg);pointer-events:none;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);animation:shine 5.5s ease-in-out infinite}
@keyframes shine{0%,100%{transform:translateX(-60%) rotate(20deg)}50%{transform:translateX(320%) rotate(20deg)}}
.loyalty::after{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,.07) 1px,transparent 1px);background-size:18px 18px;opacity:.5}
.loyalty-top{display:flex;align-items:center;gap:14px;position:relative;z-index:1}
.loyalty-logo{width:52px;height:52px;border-radius:14px;background:rgba(255,255,255,.16);display:grid;place-items:center;
  font-size:1.6rem;border:1px solid rgba(255,255,255,.28)}
.loyalty-name{font-weight:800;font-size:1.18rem;letter-spacing:-.01em}
.loyalty-sub{font-size:.72rem;opacity:.82;text-transform:uppercase;letter-spacing:.16em}
.loyalty-stamps{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin:24px 0 18px;position:relative;z-index:1}
.loyalty .st{aspect-ratio:1;border-radius:50%;display:grid;place-items:center;font-size:.92rem;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.5)}
.loyalty .st.on{background:linear-gradient(145deg,#ffe08a,#ffb22e);border-color:transparent;color:#5a3a00;
  box-shadow:0 4px 12px -2px rgba(255,180,46,.55)}
.loyalty .st{overflow:visible}
.loyalty .st .cf{display:inline-block;border:2.5px double #c0392b;color:#b3261e;border-radius:5px;padding:3px 9px;
  transform:rotate(-13deg);font-size:.56rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;line-height:1.08;
  text-align:center;white-space:nowrap;position:relative;z-index:3}
.loyalty .st.gift{background:linear-gradient(145deg,#fff7d6,#f6cf57 45%,#d9a528);color:#5a3a00;font-size:.92rem;box-shadow:0 4px 14px -2px rgba(212,160,23,.6),inset 0 1px 0 rgba(255,255,255,.7)}
.loyalty-foot{display:flex;justify-content:space-between;font-size:.82rem;position:relative;z-index:1;opacity:.96}

/* assistant mockup */
.wave{display:flex;align-items:flex-end;gap:5px;height:56px;justify-content:center;margin-bottom:20px}
.wave span{width:5px;border-radius:3px;background:var(--grad);height:20%;animation:wv 1.1s ease-in-out infinite}
.wave span:nth-child(odd){animation-delay:.15s}.wave span:nth-child(3n){animation-delay:.32s}.wave span:nth-child(4n){animation-delay:.48s}
@keyframes wv{0%,100%{height:16%}50%{height:92%}}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.chip{font-size:.8rem;padding:7px 13px;border-radius:999px;border:1px solid var(--bd);color:var(--faint);background:rgba(255,255,255,.03)}
.chip.on{background:linear-gradient(145deg,rgba(124,92,255,.22),rgba(34,211,238,.14));border-color:rgba(124,92,255,.4);color:var(--ink)}

/* ── Reveal ────────────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}.blob,.price-card.featured::before{animation:none}}

/* ── Espace client / admin (portail connecté) ── */
body.espace-on .hero, body.espace-on > section, body.espace-on > footer{display:none!important}
.espace{position:relative;z-index:1;min-height:100vh;padding-top:88px}
.esp-wrap{max-width:1120px;margin:0 auto;padding:0 22px 80px}
.esp-head{padding:26px 0 8px}
.esp-head h1{font-size:1.9rem}
.esp-head .who{color:var(--dim);font-size:.95rem;margin-top:4px}
.esp-menu{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px}
.esp-h2{margin:34px 0 16px;font-size:1.3rem}
.esp-sites{display:flex;flex-direction:column;gap:24px}
.biz{background:var(--card);border:1px solid var(--bd);border-radius:18px;padding:22px;backdrop-filter:blur(12px)}
.biz h3{font-size:1.2rem}
.biz .sub{color:var(--faint);font-size:.85rem}
.variants{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px;margin-top:14px}
.variant{border:1px solid var(--bd);border-radius:14px;overflow:hidden;background:rgba(255,255,255,.02);transition:.2s}
.variant:hover{border-color:rgba(124,92,255,.5);transform:translateY(-3px)}
.variant.chosen{border-color:rgba(124,92,255,.5)}
.vprev{height:165px;overflow:hidden;position:relative;background:transparent;border-bottom:1px solid var(--bd)}
.vprev::after{content:"";position:absolute;bottom:0;left:0;right:0;height:40px;pointer-events:none;background:linear-gradient(to bottom,transparent,rgba(7,8,17,.92));z-index:2}
.vprev iframe{width:1280px;height:825px;border:0;transform:scale(.195);transform-origin:top left;pointer-events:none}
.vbadge{position:absolute;top:8px;left:8px;background:rgba(0,0,0,.55);color:#fff;font-size:.72rem;padding:3px 9px;border-radius:999px;backdrop-filter:blur(4px);z-index:3}
.vactions{display:flex;flex-direction:column;gap:7px;padding:12px}
.btn-sm{padding:8px 12px;font-size:.84rem;border-radius:9px;text-align:center}
.owner-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:12px;padding:12px 14px;background:rgba(124,92,255,.06);border:1px solid var(--bd);border-radius:11px}
.owner-row input{flex:1;min-width:200px;background:var(--bg2);border:1px solid var(--bd);color:var(--ink);border-radius:9px;padding:9px 12px;font-family:inherit;font-size:.9rem}
.owner-row label{color:var(--dim);font-size:.85rem}
.info-box{background:rgba(124,92,255,.08);border:1px solid var(--bd);border-radius:12px;padding:18px;color:var(--dim)}
.acct{display:inline-flex;gap:10px;align-items:center}

/* ── Modules "Prochainement" ── */
.soon-badge{background:linear-gradient(90deg,#7c5cff,#00c8f0)!important;color:#fff!important;border:none!important}
.price-card.soon{opacity:.92}
.price-card.soon .amt{opacity:.72}
.soon-tag{display:inline-block;font-size:.62rem;font-weight:700;vertical-align:middle;margin-left:8px;padding:3px 9px;border-radius:999px;background:linear-gradient(90deg,#7c5cff,#00c8f0);color:#fff;letter-spacing:.02em}

/* ── Espace commerçant unifié à onglets ── */
.esp-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;margin-bottom:22px}
.esp-actions{display:flex;gap:8px}
.esp-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:14px}
.esp-tab{display:inline-flex;align-items:center;gap:7px;font-family:inherit;font-size:.9rem;font-weight:600;color:#aab;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);border-radius:999px;padding:9px 16px;cursor:pointer;transition:all .2s}
.esp-tab:hover{color:#fff;border-color:rgba(124,92,255,.5)}
.esp-tab.on{color:#fff;background:linear-gradient(90deg,#7c5cff,#22d3ee);border-color:transparent}
.st-dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.st-on{background:#22c55e;box-shadow:0 0 8px #22c55e}
.st-soon{background:#f5b400;box-shadow:0 0 8px #f5b400}
.st-off{background:#6b7280}
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.svc-mini{display:flex;align-items:center;gap:14px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);border-radius:16px;padding:18px;cursor:pointer;transition:all .22s}
.svc-mini:hover{transform:translateY(-3px);border-color:rgba(124,92,255,.5)}
.svc-mini-ic{font-size:30px;flex:none}
.svc-mini-txt h4{font-family:'Sora',sans-serif;margin:0 0 4px;color:#fff;font-size:1rem}
.svc-mini-st{font-size:.82rem;color:#aab;display:flex;align-items:center;gap:6px}
.svc-mini.active{border-color:rgba(34,197,94,.4)}
.teaser{max-width:560px;margin:0 auto;text-align:center;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.1);border-radius:22px;padding:40px 32px}
.teaser-badge{display:inline-block;font-size:.78rem;font-weight:700;color:#fff;background:linear-gradient(90deg,#7c5cff,#22d3ee);padding:5px 14px;border-radius:999px;margin-bottom:18px}
.teaser-ic{font-size:54px;margin-bottom:10px}
.teaser-title{font-family:'Sora',sans-serif;color:#fff;font-size:1.6rem;margin-bottom:10px}
.teaser-desc{color:#bbc;font-size:1rem;margin-bottom:18px}
.teaser-feats{list-style:none;padding:0;margin:0 auto 22px;max-width:340px;text-align:left;display:flex;flex-direction:column;gap:9px}
.teaser-feats li{color:#ccd;font-size:.92rem;padding-left:26px;position:relative}
.teaser-feats li::before{content:"✓";position:absolute;left:0;color:#22d3ee;font-weight:800}
@media(max-width:760px){.svc-grid{grid-auto-flow:row;grid-template-columns:1fr}}

/* ── Bannière Pack pleine largeur (tout inclus) ── */
.pack-row{margin-top:18px}
.pack-banner{position:relative;display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;background:linear-gradient(120deg,rgba(124,92,255,.18),rgba(34,211,238,.10));border:1.5px solid rgba(124,92,255,.55);border-radius:22px;padding:30px 36px;overflow:hidden;box-shadow:0 22px 54px -26px rgba(124,92,255,.7)}
.pack-banner .pb-left{flex:1 1 340px;min-width:280px}
.pack-banner .pb-badge{display:inline-block;font-size:.72rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:#fff;background:linear-gradient(90deg,#7c5cff,#22d3ee);padding:5px 14px;border-radius:999px;margin-bottom:12px}
.pack-banner h3{font-family:'Sora',sans-serif;font-size:1.7rem;color:#fff;margin:0 0 6px}
.pack-banner .pb-feats{display:flex;flex-wrap:wrap;gap:8px 20px;margin:12px 0 0;list-style:none;padding:0}
.pack-banner .pb-feats li{color:#ccd;font-size:.9rem;display:flex;align-items:center;gap:7px}
.pack-banner .pb-feats li::before{content:"✓";color:#22d3ee;font-weight:800}
.pack-banner .pb-right{text-align:center;flex:none}
.pack-banner .pb-price{font-size:3rem;font-weight:800;color:#fff;line-height:1}
.pack-banner .pb-price small{font-size:1rem;color:#aab;font-weight:500}
@media(max-width:760px){.pack-banner{flex-direction:column;text-align:center;padding:26px 20px}.pack-banner .pb-feats{justify-content:center}}
/* ── Onglet Administrateur ── */
.esp-tab-admin{border-color:rgba(245,180,0,.45)}
.esp-tab-admin.on{background:linear-gradient(90deg,#f5b400,#ff7a18);border-color:transparent;color:#1a1206}
.adm-bar{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:14px}
.adm-search{width:100%;box-sizing:border-box;padding:12px 16px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);color:#fff;font-family:inherit;font-size:.95rem;margin-bottom:18px}
.adm-search::placeholder{color:#889}
.teaser .btn{margin-top:18px}
/* ── Accueil admin (2 cartes) + impersonation ── */
.adm-home{display:grid;grid-template-columns:1fr 1fr;gap:18px;max-width:760px;margin:10px auto 0}
@media(max-width:680px){.adm-home{grid-template-columns:1fr}}
.adm-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:32px 28px;cursor:pointer;transition:all .22s;text-align:center}
.adm-card:hover{transform:translateY(-4px);border-color:rgba(124,92,255,.55);box-shadow:0 18px 44px -22px rgba(124,92,255,.6)}
.adm-card-ic{font-size:46px;margin-bottom:12px}
.adm-card h3{font-family:'Sora',sans-serif;color:#fff;font-size:1.3rem;margin:0 0 8px}
.adm-card p{color:#bbc;font-size:.92rem;margin:0 0 14px;line-height:1.5}
.adm-card-cta{color:#22d3ee;font-weight:700;font-size:.92rem}
.imp-banner{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;background:rgba(245,180,0,.12);border:1px solid rgba(245,180,0,.4);border-radius:12px;padding:10px 16px;margin-bottom:18px;color:#f5d488;font-size:.9rem}
/* ── Toast ── */
.gt-toast{position:fixed;left:50%;bottom:26px;transform:translate(-50%,16px);z-index:9999;background:#161b22;color:#fff;border:1px solid rgba(124,92,255,.5);border-radius:12px;padding:13px 20px;font-size:.92rem;font-weight:600;box-shadow:0 16px 40px -12px rgba(0,0,0,.6);opacity:0;transition:opacity .25s,transform .25s;max-width:90vw}
.gt-toast.show{opacity:1;transform:translate(-50%,0)}
.gt-toast.err{border-color:#f85149;color:#ffb3ad}
.adm-del{color:#ff9b94 !important;border-color:rgba(248,81,73,.4) !important}
.adm-del:hover{border-color:#f85149 !important}
.prospect-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;border:1px solid rgba(255,255,255,.08);border-radius:10px;margin-bottom:8px;background:rgba(255,255,255,.03)}
.prospect-row .sub{font-size:.78rem}
.prospect-row.is-client{border-color:rgba(34,197,94,.4);background:rgba(34,197,94,.06)}
/* ── Aide "?" + ligne domaine ── */
.help{display:inline-flex;align-items:center;justify-content:center;width:17px;height:17px;border-radius:50%;background:rgba(255,255,255,.12);color:#cdd;font-size:11px;font-weight:700;cursor:help;margin:0 6px 0 4px;vertical-align:middle;border:1px solid rgba(255,255,255,.2)}
.help:hover{background:#7c5cff;color:#fff;border-color:transparent}
.domain-line{margin-top:14px;padding-top:12px;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:.9rem;color:#ccd}
/* ── Cartes "autres services" (accueil commerçant) ── */
.svc-box{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);border-radius:16px;padding:22px;text-align:center;display:flex;flex-direction:column;align-items:center}
.svc-box.active{border-color:rgba(34,197,94,.4)}
.svc-box-ic{font-size:34px;margin-bottom:8px}
.svc-box h4{font-family:'Sora',sans-serif;color:#fff;margin:0 0 4px;font-size:1.05rem}
.svc-box-st{font-size:.82rem;color:#aab;display:flex;align-items:center;gap:6px;justify-content:center}
.svc-box .btn{margin-top:auto}
.esp-h2{font-family:'Sora',sans-serif;color:#fff;font-size:1.15rem;margin:0 0 14px}
/* ── Infobulle "?" (au survol) ── */
.help{position:relative}
.help:hover::after{content:attr(data-tip);position:absolute;left:50%;bottom:155%;transform:translateX(-50%);background:#161b22;color:#e8eaf0;border:1px solid rgba(124,92,255,.55);border-radius:8px;padding:8px 11px;font-size:.76rem;font-weight:400;line-height:1.45;width:220px;max-width:62vw;white-space:normal;text-align:left;z-index:60;box-shadow:0 10px 26px rgba(0,0,0,.55);pointer-events:none}
/* ── Card "Votre entreprise" à colonnes ── */
.ent-card{padding:24px}
.ent-name{font-family:'Sora',sans-serif;color:#fff;font-size:1.35rem;margin:0 0 16px}
.ent-row{display:flex;gap:14px;align-items:stretch;flex-wrap:wrap}
.ent-col{flex:1 1 165px;min-width:150px;display:flex;flex-direction:column}
.ent-col-site{flex:1 1 165px;min-width:150px}
.ent-label{font-size:.74rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#8b92a5;margin-bottom:10px;text-align:center;min-height:2.4em;display:flex;align-items:center;justify-content:center}
.ent-col-site .ent-label{justify-content:center}
.ent-svc{flex:1;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);border-radius:14px;padding:16px 12px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px}
.ent-svc.active{border-color:rgba(34,197,94,.35)}
.ent-svc-ic{font-size:30px}
.ent-svc-btn{margin-top:auto;width:100%;padding-top:10px}
.ent-svc-btn .btn{width:100%;box-sizing:border-box}
.ent-variants{display:grid;gap:12px}
@media(max-width:780px){.ent-col,.ent-col-site{flex:1 1 100%}}
/* ── Mini-aperçu carte de fidélité (réplique de la vraie carte) ── */
.mc-card{width:100%;color:#fff;border-radius:16px;padding:14px;position:relative;overflow:hidden;margin-bottom:10px;animation:mchalo 4.5s ease-in-out infinite}
@keyframes mchalo{0%,100%{box-shadow:0 14px 30px -14px rgba(20,20,60,.5),0 0 16px 0 color-mix(in srgb,var(--mc,#6C5CE7) 40%,transparent),inset 0 1px 0 rgba(255,255,255,.28)}50%{box-shadow:0 18px 38px -12px rgba(20,20,60,.55),0 0 32px 6px color-mix(in srgb,var(--mc,#6C5CE7) 55%,transparent),inset 0 1px 0 rgba(255,255,255,.3)}}
.mc-card::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;background-image:radial-gradient(rgba(255,255,255,.09) 1px,transparent 1px);background-size:12px 12px}
.mc-shine{position:absolute;top:-60%;left:-40%;width:48%;height:220%;transform:rotate(20deg);pointer-events:none;z-index:1;background:linear-gradient(90deg,transparent,rgba(255,255,255,.22),transparent);animation:mcsh 6s ease-in-out infinite}
@keyframes mcsh{0%,100%{transform:translateX(-60%) rotate(20deg)}55%{transform:translateX(440%) rotate(20deg)}}
.mc-top{display:flex;align-items:center;gap:8px;position:relative;z-index:2}
.mc-logo{width:30px;height:30px;border-radius:9px;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;overflow:hidden}
.mc-logo img{width:100%;height:100%;object-fit:cover}
.mc-txt{min-width:0;text-align:left}
.mc-name{font-weight:800;font-size:.82rem;line-height:1.1;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mc-sub{font-size:.54rem;opacity:.85;text-transform:uppercase;letter-spacing:.12em;margin-top:2px}
.mc-stamps{display:grid;grid-template-columns:repeat(5,1fr);gap:5px;margin-top:11px;position:relative;z-index:2}
.mc-stamp{aspect-ratio:1;border-radius:50%;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.28);display:flex;align-items:center;justify-content:center;overflow:visible}
.mc-stamp.on{background:linear-gradient(145deg,#ffe08a,#ffb22e);border-color:transparent;box-shadow:0 2px 6px -1px rgba(255,170,30,.55),inset 0 1px 0 rgba(255,255,255,.6)}
.mc-cf{display:inline-block;border:1.5px double #c0392b;color:#b3261e;border-radius:3px;padding:1px 2px;transform:rotate(-13deg);font-size:.26rem;font-weight:800;text-transform:uppercase;letter-spacing:.02em;line-height:1.05;text-align:center;white-space:nowrap}
.mc-stamp.gift{background:linear-gradient(145deg,#fff7d6,#f6cf57 45%,#d9a528);border-color:transparent;overflow:hidden;padding:2px;box-shadow:0 2px 9px -1px rgba(212,160,23,.6),inset 0 1px 0 rgba(255,255,255,.7)}
.mc-stamp.gift img{width:100%;height:100%;object-fit:contain;display:block}
/* ── Popup « Gérer vos avis » ── */
.avis-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;background:rgba(8,10,20,.55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);opacity:0;transition:opacity .3s ease}
.avis-modal.show{opacity:1}
.avis-box{width:min(960px,96vw);height:min(86vh,860px);background:#0e1118;border:1px solid rgba(124,92,255,.4);border-radius:18px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 30px 80px -20px rgba(0,0,0,.7),0 0 50px -10px rgba(124,92,255,.45);transform:translateY(34px) scale(.93);opacity:0;transition:transform .36s cubic-bezier(.2,.85,.25,1),opacity .36s ease}
.avis-modal.show .avis-box{transform:translateY(0) scale(1);opacity:1}
.avis-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;font-family:'Sora',sans-serif;font-weight:700;color:#fff;background:linear-gradient(90deg,rgba(124,92,255,.28),transparent);border-bottom:1px solid rgba(255,255,255,.08)}
.avis-x{width:32px;height:32px;border-radius:50%;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.06);color:#fff;font-size:15px;cursor:pointer;transition:.18s;line-height:1}
.avis-x:hover{background:#e5484d;border-color:transparent;transform:rotate(90deg)}
.avis-box iframe{flex:1;width:100%;border:0;background:#0b0d13}
/* ── Images des cases service (avis IA / standard IA) ── */
.ent-svc-img{position:relative;width:100%;border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.12);box-shadow:0 12px 30px -14px rgba(0,0,0,.65)}
.ent-svc-img img{display:block;width:100%;aspect-ratio:3/2;object-fit:cover;transition:transform .5s ease}
.ent-svc:hover .ent-svc-img img{transform:scale(1.05)}
.ent-svc-glow{position:absolute;inset:0;pointer-events:none;background:radial-gradient(120% 80% at 50% -12%,rgba(255,255,255,.18),transparent 55%),linear-gradient(180deg,transparent 58%,rgba(8,10,20,.5))}
.avis-scan{position:absolute;left:50%;transform:translateX(-50%);font-size:.85rem;padding:7px 14px;background:linear-gradient(115deg,var(--c1,#7c5cff),var(--c2,#a855f7))}
.avis-bar{position:relative}
.svc-scan-btn{width:100%;box-sizing:border-box;margin-bottom:6px;text-align:center;justify-content:center}
.vsite-status{display:flex;align-items:center;justify-content:center;gap:6px;padding:7px 0 0;font-size:.82rem;color:#9aa3c4}
.review-count{font-size:.78rem;text-align:center;padding:5px 8px;border-radius:8px;margin-top:4px}
.review-count.ok{color:#4ade80;background:rgba(34,197,94,.1)}
.review-count.warn{color:#fbbf24;background:rgba(251,191,36,.1)}
.vsite-online{text-align:center;padding:8px;font-size:.85rem;font-weight:700;color:#4ade80;background:rgba(34,197,94,.12);border-radius:9px;border:1px solid rgba(34,197,94,.25)}
.vsite-copy{width:100%;box-sizing:border-box;border-color:rgba(34,197,94,.4);color:#4ade80}
.vsite-copy:hover{background:rgba(34,197,94,.1);border-color:rgba(34,197,94,.6)}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE MOBILE — golemtech.ovh/offre-pme/
   ══════════════════════════════════════════════════════════ */
@media(max-width:640px){

  /* ── Nav ── */
  nav .bar{padding:11px 12px;gap:7px}
  .logo{font-size:.95rem;gap:6px}
  .logo .dot{width:9px;height:9px}
  .nav-links{gap:7px}
  .nav-links a:not(.btn){display:none}
  /* boutons compacts pour que "Se connecter" + "Voir les offres" tiennent */
  .acct{display:flex;gap:7px}
  .acct .btn,.nav-links .btn{padding:8px 11px;font-size:.77rem;border-radius:10px;box-shadow:none}
  .acct .btn:hover,.nav-links .btn:hover{transform:none}

  /* ── Hero ── */
  .hero{padding-top:110px;padding-bottom:60px}
  .hero h1{font-size:clamp(2rem,9vw,3rem)}
  .hero-cta{flex-direction:column;align-items:stretch;gap:10px}
  .hero-cta .btn{width:100%;justify-content:center}
  .hero-meta{gap:12px;font-size:.78rem}

  /* ── Sections ── */
  section{padding-top:64px;padding-bottom:64px}
  .wrap{padding-left:14px;padding-right:14px}

  /* ── Tarifs ── */
  .pricing{grid-template-columns:1fr}
  .pack-banner{flex-direction:column;gap:18px}
  .pb-right{text-align:center}

  /* ── Carte de fidélité démo : ne déborde plus ── */
  .loyalty{padding:18px}
  .loyalty-stamps{gap:7px}
  .loyalty .st{min-width:0}
  .loyalty .st .cf{padding:2px 5px;font-size:.46rem}
  .loyalty-foot{font-size:.74rem;gap:6px}

  /* ── Cartes confiance : compactes ── */
  .trust{gap:9px;margin-top:32px}
  .trust .t{padding:13px 9px;border-radius:12px}
  .trust .t .ic{font-size:1.25rem}
  .trust .ic .flag-fr{width:1.25rem}
  .trust .t h4{font-size:.8rem;margin:6px 0 3px}
  .trust .t p{font-size:.71rem;line-height:1.35}

  /* ── Tableau comparatif : tient SANS scroll, en-têtes en icônes ── */
  .cmp{overflow:hidden}
  table.cmp-t{min-width:0;width:100%;table-layout:fixed}
  .cmp-t th,.cmp-t td{padding:8px 2px;font-size:.62rem;text-align:center;line-height:1.3;word-break:break-word}
  .cmp-t th:first-child,.cmp-t td:first-child{width:29%;padding-left:7px;font-size:.68rem;line-height:1.25;text-align:left}
  .lbl-full{display:none}
  .lbl-mini{display:inline-block;font-size:.6rem;line-height:1.35;font-weight:600}
  .cmp-hint{display:none}

  /* ── Features ── */
  .features{grid-template-columns:1fr}

  /* ── Espace : en-tête ── */
  .esp-head{flex-direction:column;align-items:flex-start;gap:8px}
  .esp-head .esp-actions{display:flex;flex-wrap:wrap;gap:6px;width:100%}
  .esp-head .esp-actions .btn{flex:1 1 auto;min-width:0;font-size:.8rem;padding:8px 10px;text-align:center}

  /* ── Espace : card entreprise ── */
  .ent-card{padding:16px 12px}
  .ent-name{font-size:1.1rem}
  .ent-row{flex-direction:column;gap:12px}
  .ent-col,.ent-col-site{flex:1 1 100%;min-width:0}
  .ent-label{min-height:unset;margin-bottom:6px;justify-content:flex-start}

  /* ── Variant card (aperçu site) ── */
  .vprev{height:140px}
  .vactions{gap:6px;padding:10px}
  .vactions .btn{font-size:.82rem;padding:8px 10px}
  .vsite-status{padding:5px 0}

  /* ── Case service (carte/avis/standard) ── */
  .ent-svc{padding:14px 10px}
  .ent-svc-btn .btn,.svc-scan-btn{font-size:.82rem;padding:8px 10px}
  .mc-card{border-radius:14px;padding:12px}
  .mc-name{font-size:.76rem}
  .mc-stamps{gap:4px;margin-top:9px}

  /* ── Domaine / import line ── */
  .domain-line{flex-wrap:wrap;font-size:.82rem}
  .domain-line .btn{font-size:.78rem;padding:6px 10px}
  .help{display:none} /* trop petit sur mobile */

  /* ── Popup (avis/carte/standard) ── */
  .avis-modal{padding:8px}
  .avis-box{width:100%;height:94vh;border-radius:14px}
  .avis-bar{padding:10px 12px;font-size:.88rem}
  .avis-x{width:28px;height:28px;font-size:13px}
  .avis-scan{font-size:.78rem;padding:6px 10px}

  /* ── Modal générique (notif / domain / create site) ── */
  #modal-body{padding:18px 14px}
  #modal-body h3{font-size:1.05rem}
  .adm-search{font-size:.9rem;padding:10px 12px}
  .prospect-row{flex-wrap:wrap;gap:6px}

  /* ── Admin back-office ── */
  .adm-search-bar{flex-direction:column;gap:8px}
  .esp-actions{flex-wrap:wrap;gap:6px}

  /* ── Boutons généraux ── */
  .btn-sm{padding:7px 10px;font-size:.81rem}
  .btn-lg{padding:13px 20px;font-size:.95rem}
}

@media(max-width:400px){
  .ent-svc-btn .btn,.svc-scan-btn{padding:7px 8px;font-size:.78rem}
  .vactions .btn{font-size:.78rem}
}
/* Drapeau France SVG (remplace l'emoji 🇫🇷 non rendu sur Windows) */
.flag-fr{display:inline-block;border-radius:3px;box-shadow:0 1px 3px rgba(0,0,0,.4);vertical-align:middle}
.trust .ic .flag-fr{width:1.7rem;height:auto}
.hero-meta .flag-fr{width:1.15em;height:auto;margin-right:1px}
/* ── Photo IA incrustée dans le mockup Assistant téléphonique ── */
.assistant-photo{position:relative;border-radius:13px;overflow:hidden;margin-bottom:18px;aspect-ratio:16/8;box-shadow:0 14px 32px -16px rgba(0,0,0,.65);border:1px solid rgba(255,255,255,.08)}
.assistant-photo img{width:100%;height:100%;object-fit:cover;object-position:center 30%;display:block}
.assistant-photo::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,transparent 32%,rgba(11,14,28,.92)),radial-gradient(120% 80% at 100% 0%,rgba(124,92,255,.22),transparent 55%)}
.assistant-badge{position:absolute;left:12px;bottom:11px;z-index:2;display:inline-flex;align-items:center;gap:7px;font-size:.74rem;font-weight:600;color:#fff;background:rgba(8,10,20,.5);backdrop-filter:blur(8px);padding:6px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.16)}
.assistant-badge i{width:7px;height:7px;border-radius:50%;background:#28c840;box-shadow:0 0 9px #28c840;animation:liveBlink 1.6s ease-in-out infinite}
@keyframes liveBlink{0%,100%{opacity:1}50%{opacity:.35}}

/* ── Vitrine métiers interactive (section « Site web ») ─────────────────── */
.catprev{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);gap:18px;align-items:start}
.catprev-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.cp-item{display:flex;align-items:center;gap:12px;padding:11px 13px;border:1px solid var(--bd);border-radius:14px;background:var(--card);cursor:pointer;transition:transform .25s,border-color .25s,background .25s,box-shadow .25s;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.cp-item:hover{border-color:rgba(124,92,255,.5)}
.cp-emo{font-size:20px;line-height:1;flex:none;filter:grayscale(.25);transition:filter .25s}
.cp-txt{display:flex;flex-direction:column;min-width:0}
.cp-txt b{font-size:14px;color:var(--ink);font-weight:600;line-height:1.2}
.cp-txt i{font-style:normal;font-size:12px;color:var(--dim);max-height:0;opacity:0;overflow:hidden;transition:max-height .3s ease,opacity .3s ease,margin .3s ease}
.cp-item.is-active{border-color:transparent;background:linear-gradient(115deg,rgba(124,92,255,.18),rgba(34,211,238,.12));box-shadow:0 0 0 1px rgba(124,92,255,.4),0 12px 32px -14px rgba(124,92,255,.55);transform:translateX(5px)}
.cp-item.is-active .cp-emo{filter:none}
.cp-item.is-active .cp-txt i{max-height:20px;opacity:1;margin-top:2px}
.catprev-screen{position:sticky;top:90px}
.catprev-link{display:block;text-decoration:none;color:inherit}
.catprev-frame{border:1px solid var(--bd);border-radius:16px;overflow:hidden;background:#0d1117;box-shadow:0 30px 60px -25px rgba(0,0,0,.7);cursor:pointer;transition:border-color .25s,box-shadow .25s}
.catprev-link:hover .catprev-frame{border-color:rgba(124,92,255,.6);box-shadow:0 30px 60px -22px rgba(124,92,255,.4)}
.catprev-open{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) translateY(8px);background:rgba(8,10,20,.8);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.22);color:#fff;font-size:13px;font-weight:600;padding:9px 16px;border-radius:999px;opacity:0;transition:opacity .25s,transform .25s;pointer-events:none;z-index:3;white-space:nowrap}
.catprev-link:hover .catprev-open{opacity:1;transform:translate(-50%,-50%)}
.catprev-bar{display:flex;align-items:center;gap:6px;padding:9px 12px;background:rgba(255,255,255,.04);border-bottom:1px solid var(--bd)}
.catprev-bar i{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.18);flex:none}
.catprev-url{margin-left:8px;font-size:11px;color:var(--dim);font-family:ui-monospace,Menlo,Consolas,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.catprev-view{height:340px;overflow:hidden;position:relative;background:#0d1117}
.catprev-img{width:100%;display:block;will-change:transform}
.catprev-iframe{border:0;display:block;background:#fbf6ea;pointer-events:none;transform-origin:top left}
@keyframes cp-scroll{from{transform:translateY(0)}to{transform:translateY(var(--cp-end,0))}}
.catprev-cap{text-align:center;font-size:12px;color:var(--faint);margin:10px 0 0}
.catprev-cap b{color:var(--dim);font-weight:600}
@media (max-width:760px){.catprev{grid-template-columns:1fr}.catprev-screen{position:static}.catprev-view{height:300px}}
@media (prefers-reduced-motion:reduce){.catprev-img{animation:none!important}}
