/* =====================================================================
   WEBNOVA — base + hero shader (porté en vanilla)
   Objectif : spectaculaire ET accessible / responsive / sans lag.
   ===================================================================== */
@import url('https://api.fontshare.com/v2/css?f[]=clash-display@400,500,600,700&f[]=general-sans@400,500,600&display=swap');

:root{
  --bg:#05060A;
  --ink:#F4F1EA;
  --amber:#FFB347;
  --orange:#FF7A2F;
  --gold:#FFD27A;
  --muted:rgba(244,241,234,.72);
  --display:'Clash Display', system-ui, sans-serif;
  --sans:'General Sans', system-ui, sans-serif;
  --ease:cubic-bezier(0.22,1,0.36,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;scroll-behavior:smooth;scroll-padding-top:6rem}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);overflow-x:hidden}
a{text-decoration:none;color:inherit}
::selection{background:var(--orange);color:#0a0a0a}

/* ---------------- HERO ---------------- */
.hero{position:relative;width:100%;min-height:100dvh;overflow:hidden;background:#000;
  display:flex;align-items:center;justify-content:center}

/* Fond de secours (dégradé nébuleuse) — toujours dessous le canvas */
.hero__fallback{position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(60% 50% at 30% 35%, rgba(255,122,47,.35), transparent 60%),
    radial-gradient(55% 60% at 75% 65%, rgba(255,180,71,.28), transparent 60%),
    radial-gradient(80% 80% at 50% 50%, rgba(40,18,8,.9), #000 75%);
}
.hero__canvas{position:absolute;inset:0;z-index:1;width:100%;height:100%;display:block;touch-action:none}
/* si WebGL indisponible, on masque le canvas et on garde le fallback */
body.no-webgl .hero__canvas{display:none}

.hero__overlay{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;
  justify-content:center;text-align:center;padding:6rem 1.25rem;max-width:62rem;margin:0 auto}

/* Badge */
.badge{display:inline-flex;align-items:center;gap:.6rem;margin-bottom:2rem;
  padding:.7rem 1.2rem;border-radius:999px;font-size:.82rem;letter-spacing:.01em;
  color:var(--gold);background:rgba(255,122,47,.10);
  border:1px solid rgba(255,180,71,.28);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.badge__icon{color:var(--amber)}

/* Titre + dégradés animés */
.title{font-family:var(--display);font-weight:600;line-height:.98;letter-spacing:-.02em;
  font-size:clamp(2.6rem,9vw,7rem);display:flex;flex-direction:column;gap:.1em}
.grad{background-clip:text;-webkit-background-clip:text;color:transparent;
  background-size:200% 200%;animation:gradShift 6s ease infinite}
.grad--1{background-image:linear-gradient(90deg,var(--gold),var(--amber),var(--gold))}
.grad--2{background-image:linear-gradient(90deg,var(--amber),var(--orange),#ff4d4d,var(--amber))}

/* Sous-titre */
.subtitle{margin:1.8rem auto 0;max-width:44rem;color:var(--muted);font-weight:400;
  font-size:clamp(1rem,2.4vw,1.3rem);line-height:1.6}

/* Boutons */
.cta{display:flex;gap:1rem;margin-top:2.6rem;flex-wrap:wrap;justify-content:center}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;
  padding:.95rem 1.8rem;border-radius:999px;font-family:var(--sans);font-weight:600;font-size:1rem;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .35s var(--ease)}
.btn--primary{color:#0a0a0a;background:linear-gradient(90deg,var(--orange),var(--amber))}
.btn--primary:hover{transform:translateY(-2px) scale(1.03);box-shadow:0 18px 40px -14px rgba(255,122,47,.55)}
.btn--ghost{color:var(--gold);background:rgba(255,122,47,.08);border:1px solid rgba(255,180,71,.3);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.btn--ghost:hover{transform:translateY(-2px) scale(1.03);background:rgba(255,122,47,.16)}
.btn:active{transform:scale(.98)}

/* Indicateur de scroll */
.hero__scroll{position:absolute;z-index:2;bottom:1.6rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.7rem;
  font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted)}
.hero__scroll-line{width:1px;height:42px;background:linear-gradient(var(--amber),transparent);
  animation:scrollLine 2s var(--ease) infinite}

/* ---- Animations d'entrée ---- */
.reveal{opacity:0;transform:translateY(26px);animation:fadeUp .9s var(--ease) forwards}
.reveal[data-d="0"]{animation-delay:.05s}
.reveal[data-d="1"]{animation-delay:.18s}
.reveal[data-d="2"]{animation-delay:.32s}
.reveal[data-d="3"]{animation-delay:.5s}
.reveal[data-d="4"]{animation-delay:.66s}
@keyframes fadeUp{to{opacity:1;transform:none}}
@keyframes gradShift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes scrollLine{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* =====================================================================
   TIMELINE ORBITALE
   ===================================================================== */
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-size:.68rem;letter-spacing:.28em;
  text-transform:uppercase;color:var(--gold);border:1px solid rgba(255,180,71,.3);border-radius:999px;padding:.45rem .9rem}
.eyebrow::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--orange)}

.orbital{position:relative;background:#000;overflow:hidden;padding:5rem 1.25rem 3rem;
  display:flex;flex-direction:column;align-items:center}
.orbital__head{text-align:center;max-width:46rem;margin:0 auto 1.5rem}
.orbital__head h2{font-family:var(--display);font-weight:600;line-height:1;margin:1rem 0 .8rem;
  font-size:clamp(2rem,6vw,3.6rem);background:linear-gradient(90deg,var(--gold),var(--amber),var(--orange));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.orbital__head p{color:var(--muted);font-size:clamp(.95rem,2.2vw,1.15rem);line-height:1.5}

.orbital__stage{position:relative;width:100%;max-width:64rem;height:clamp(460px,80vh,760px);margin-inline:auto}
.orbital__nodes{position:absolute;inset:0;z-index:6;pointer-events:none}

/* encadrés d'arrière-plan (mêmes étapes + même icône que les planètes) */
.orbital__frames{position:absolute;inset:0;z-index:3;pointer-events:none}
.oframe{position:absolute;pointer-events:auto;display:flex;flex-direction:column;gap:.5rem;
  width:clamp(165px,21vw,290px);padding:1.15rem 1.25rem;cursor:pointer;text-align:left;
  background:rgba(255,180,71,.045);border:1px solid rgba(255,180,71,.16);border-radius:.9rem;
  -webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);opacity:.5;
  transition:opacity .4s var(--ease),transform .4s var(--ease),border-color .4s,background .4s}
.oframe:hover{opacity:.96;border-color:rgba(255,180,71,.45);background:rgba(255,180,71,.09);transform:scale(1.03)}
.oframe.is-related{opacity:.8;border-color:rgba(255,180,71,.32)}
.oframe.is-active{opacity:1;border-color:var(--amber);background:rgba(255,180,71,.13);box-shadow:0 0 40px -10px rgba(255,180,71,.5)}
.oframe__head{display:flex;align-items:center;gap:.7rem}
.oframe__ico{flex:none;width:2.4rem;height:2.4rem;border-radius:50%;display:grid;place-items:center;
  border:2px solid rgba(255,180,71,.4);background:#000;color:var(--amber);transition:background .3s,color .3s,border-color .3s}
.oframe__ico .osvg{width:17px;height:17px}
.oframe.is-active .oframe__ico{background:var(--amber);color:#0a0a0a;border-color:var(--gold)}
.oframe.is-related .oframe__ico{background:rgba(255,180,71,.5);color:#0a0a0a}
.oframe__no{font-family:var(--display);font-weight:600;font-size:1.8rem;line-height:1;color:var(--amber)}
.oframe__title{font-family:var(--display);font-weight:500;font-size:1.1rem;color:#fff}
.oframe__txt{font-size:.78rem;line-height:1.45;color:rgba(244,241,234,.72)}
.oframe--tl{top:1rem;left:1rem}
.oframe--bl{bottom:20%;left:.5rem;width:clamp(158px,19vw,256px)}
.oframe--tr{top:1rem;right:1rem;text-align:right;align-items:flex-end}
.oframe--br{bottom:20%;right:.5rem;width:clamp(158px,19vw,256px);text-align:right;align-items:flex-end}
.oframe--tr .oframe__head,.oframe--br .oframe__head{flex-direction:row-reverse}
/* 05 : sous l'animation, centré, hors de l'orbite */
.oframe--below{position:static;margin:1.6rem auto 0;text-align:center;align-items:center}
.oframe--below:hover{transform:scale(1.03)}

/* noyau central */
.orbital__center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:4rem;height:4rem;border-radius:50%;display:grid;place-items:center;z-index:10;pointer-events:none;
  background:linear-gradient(135deg,var(--orange),var(--amber),var(--gold));animation:corePulse 3s ease-in-out infinite}
.orbital__center .core-dot{width:2rem;height:2rem;border-radius:50%;background:rgba(255,255,255,.85);backdrop-filter:blur(6px)}
.orbital__center .ring1,.orbital__center .ring2{position:absolute;top:50%;left:50%;border-radius:50%;
  border:1px solid rgba(255,210,122,.45);transform:translate(-50%,-50%)}
.orbital__center .ring1{width:5rem;height:5rem;opacity:.7;animation:ping 2.6s cubic-bezier(0,0,.2,1) infinite}
.orbital__center .ring2{width:6rem;height:6rem;opacity:.5;animation:ping 2.6s cubic-bezier(0,0,.2,1) infinite;animation-delay:.7s}
.orbital__orbit{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;
  border:1px solid rgba(255,180,71,.14);pointer-events:none}

/* nœuds */
.onode{position:absolute;top:50%;left:50%;cursor:pointer;will-change:transform;pointer-events:auto}
.onode__hit{position:relative;display:grid;place-items:center}
.onode__dot{width:2.6rem;height:2.6rem;border-radius:50%;display:grid;place-items:center;
  border:2px solid rgba(255,180,71,.4);background:#000;color:var(--amber);
  transition:transform .3s var(--ease),background .3s,color .3s,border-color .3s,box-shadow .3s}
.onode.is-related .onode__dot{background:rgba(255,180,71,.5);color:#0a0a0a;border-color:var(--amber)}
.onode.is-active .onode__dot{background:var(--amber);color:#0a0a0a;border-color:var(--gold);
  transform:scale(1.5);box-shadow:0 0 26px rgba(255,180,71,.55)}
.onode__label{position:absolute;top:3rem;left:50%;transform:translateX(-50%);white-space:nowrap;
  font-size:.7rem;font-weight:600;letter-spacing:.1em;color:rgba(244,241,234,.7);transition:color .3s,transform .3s}
.onode.is-active .onode__label{color:#fff;transform:translateX(-50%) scale(1.2)}

/* carte détaillée */
.ocard{position:absolute;top:4.6rem;left:50%;transform:translateX(-50%);width:min(17rem,80vw);
  background:rgba(0,0,0,.9);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(255,180,71,.3);border-radius:.9rem;box-shadow:0 24px 60px -22px rgba(255,122,47,.35);
  padding:1rem;z-index:200;text-align:left;animation:fadeUp .4s var(--ease)}
.ocard::before{content:'';position:absolute;top:-12px;left:50%;width:1px;height:12px;background:rgba(255,180,71,.5)}
.ocard__top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}
.ocard__badge{font-size:.58rem;letter-spacing:.08em;padding:.22rem .55rem;border-radius:999px;border:1px solid}
.badge--completed{color:#0a0a0a;background:var(--amber);border-color:var(--gold)}
.badge--in-progress{color:var(--amber);background:rgba(255,180,71,.12);border-color:rgba(255,180,71,.5)}
.badge--pending{color:rgba(244,241,234,.7);background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.2)}
.ocard__date{font-size:.6rem;font-family:ui-monospace,monospace;color:rgba(244,241,234,.5)}
.ocard h3{font-size:.98rem;margin-bottom:.4rem;color:#fff;font-family:var(--display);font-weight:600}
.ocard p{font-size:.78rem;color:rgba(244,241,234,.8);line-height:1.5}
.ocard__energy{margin-top:.8rem;padding-top:.7rem;border-top:1px solid rgba(255,255,255,.1)}
.ocard__energy .row{display:flex;justify-content:space-between;align-items:center;font-size:.64rem;color:rgba(244,241,234,.7);margin-bottom:.35rem}
.ocard__energy .row span{display:inline-flex;align-items:center;gap:.3rem}
.ocard__bar{height:4px;border-radius:999px;background:rgba(255,255,255,.1);overflow:hidden}
.ocard__bar span{display:block;height:100%;background:linear-gradient(90deg,var(--orange),var(--gold))}
.ocard__links{margin-top:.8rem;padding-top:.7rem;border-top:1px solid rgba(255,255,255,.1)}
.ocard__links h4{font-size:.58rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(244,241,234,.7);
  margin-bottom:.45rem;display:flex;align-items:center;gap:.3rem}
.ocard__links .chips{display:flex;flex-wrap:wrap;gap:.35rem}
.ochip{display:inline-flex;align-items:center;gap:.25rem;font-size:.62rem;padding:.28rem .55rem;
  border:1px solid rgba(255,180,71,.25);background:transparent;color:rgba(244,241,234,.85);
  cursor:pointer;border-radius:.35rem;transition:background .3s}
.ochip:hover{background:rgba(255,180,71,.14)}
.osvg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.onode__dot .osvg{width:18px;height:18px}

@keyframes corePulse{0%,100%{opacity:1}50%{opacity:.55}}
@keyframes ping{75%,100%{transform:translate(-50%,-50%) scale(2.1);opacity:0}}

@media (max-width:760px){
  .oframe{width:clamp(104px,30vw,164px);padding:.7rem .8rem;opacity:.4;gap:.35rem}
  .oframe__txt{display:none}
  .oframe__head{gap:.45rem}
  .oframe__ico{width:1.8rem;height:1.8rem}
  .oframe__ico .osvg{width:13px;height:13px}
  .oframe__title{font-size:.84rem}
  .oframe__no{font-size:1.25rem}
}
@media (max-width:640px){
  .orbital{padding:3.5rem 1rem 2.5rem}
  .onode__dot{width:2.3rem;height:2.3rem}
  .ocard{width:min(15rem,82vw)}
}
@media (prefers-reduced-motion:reduce){
  .orbital__center,.orbital__center .ring1,.orbital__center .ring2{animation:none}
  .onode__dot,.onode__label,.ocard,.oframe{transition:none;animation:none}
}

/* =====================================================================
   LISTE DE CATÉGORIES (survol 100% CSS)
   ===================================================================== */
.cats{background:#000;padding:clamp(4rem,9vw,6.5rem) 1.25rem}
.cats__wrap{max-width:56rem;margin:0 auto}
.cats__head{text-align:center;margin-bottom:clamp(2.5rem,6vw,4rem)}
.cats__hicon{width:4rem;height:4rem;border-radius:50%;display:grid;place-items:center;margin:0 auto 1.5rem;
  background:linear-gradient(135deg,var(--orange),var(--amber));color:#0a0a0a}
.cats__hicon .osvg{width:26px;height:26px;stroke-width:2}
.cats__title{font-family:var(--display);font-weight:600;line-height:1.04;font-size:clamp(2rem,6vw,3.3rem);letter-spacing:-.01em}
.cats__title--muted{color:rgba(244,241,234,.38)}

.cats__list{display:flex;flex-direction:column;gap:.85rem}
.cat{position:relative;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  height:6rem;padding:0 clamp(1.2rem,3vw,2rem);text-decoration:none;cursor:pointer;overflow:hidden;
  border:1px solid rgba(255,180,71,.18);background:rgba(255,255,255,.02);border-radius:.5rem;
  transition:height .35s var(--ease),border-color .35s var(--ease),background .35s var(--ease),box-shadow .35s var(--ease)}
.cat:hover,.cat:focus-visible,.cat:active{height:8rem;border-color:var(--amber);background:rgba(255,180,71,.06);
  box-shadow:0 18px 44px -22px rgba(255,122,47,.45);outline:none}
.cat__txt{flex:1;min-width:0}
.cat__txt h3{font-family:var(--display);font-weight:600;font-size:1.35rem;color:#fff;transition:color .3s}
.cat--featured .cat__txt h3{font-size:clamp(1.55rem,4vw,1.9rem)}
.cat:hover .cat__txt h3,.cat:focus-visible .cat__txt h3,.cat:active .cat__txt h3{color:var(--amber)}
.cat__txt p{margin-top:.25rem;font-size:.92rem;color:rgba(244,241,234,.6);transition:color .3s}
.cat:hover .cat__txt p,.cat:focus-visible .cat__txt p,.cat:active .cat__txt p{color:rgba(244,241,234,.92)}
.cat__icon{flex:none;color:var(--amber);opacity:0;transform:translateX(-10px);transition:opacity .3s var(--ease),transform .3s var(--ease)}
.cat__icon .osvg{width:30px;height:30px}
.cat:hover .cat__icon,.cat:focus-visible .cat__icon,.cat:active .cat__icon{opacity:1;transform:none}
/* coins en équerre qui apparaissent au survol */
.cat__br{position:absolute;width:1.1rem;height:1.1rem;opacity:0;transition:opacity .3s}
.cat:hover .cat__br,.cat:focus-visible .cat__br,.cat:active .cat__br{opacity:1}
.cat__br--tl{top:.7rem;left:.7rem;border-top:2px solid var(--amber);border-left:2px solid var(--amber)}
.cat__br--br{bottom:.7rem;right:.7rem;border-bottom:2px solid var(--amber);border-right:2px solid var(--amber)}

@media (max-width:640px){
  .cat{height:5.4rem}
  .cat:hover,.cat:focus-visible,.cat:active{height:6.8rem}
  .cat__txt h3{font-size:1.15rem}
  .cat__txt p{font-size:.82rem}
  .cat__icon .osvg{width:24px;height:24px}
}
@media (prefers-reduced-motion:reduce){
  .cat,.cat__txt h3,.cat__txt p,.cat__icon,.cat__br{transition:none}
}

/* Panneau "Nos engagements" — révélé au clic via :target (sans JS) */
.engage{max-height:0;opacity:0;overflow:hidden;transition:max-height .6s var(--ease),opacity .5s var(--ease)}
.engage:target{max-height:1800px;opacity:1}
.engage__inner{padding:1.4rem .15rem .3rem}
.engage__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.engage__card{background:rgba(255,180,71,.05);border:1px solid rgba(255,180,71,.16);border-radius:.85rem;padding:1.3rem;
  transition:border-color .3s,background .3s}
.engage__card:hover{border-color:rgba(255,180,71,.4);background:rgba(255,180,71,.09)}
.engage__ic{width:2.4rem;height:2.4rem;border-radius:.6rem;display:grid;place-items:center;margin-bottom:.85rem;
  background:linear-gradient(135deg,var(--orange),var(--amber));color:#0a0a0a}
.engage__ic .osvg{width:18px;height:18px}
.engage__card h4{font-family:var(--display);font-weight:600;font-size:1.05rem;color:#fff;margin-bottom:.35rem}
.engage__card p{font-size:.86rem;line-height:1.5;color:rgba(244,241,234,.7)}
.engage__close{display:inline-block;margin-top:1.3rem;font-size:.8rem;color:var(--muted);text-decoration:none;
  border:1px solid rgba(255,180,71,.25);border-radius:999px;padding:.5rem 1.1rem;transition:color .3s,background .3s}
.engage__close:hover{color:#fff;background:rgba(255,180,71,.12)}
@media(max-width:760px){.engage__grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.engage__grid{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){.engage{transition:none}}

/* =====================================================================
   EXTRAS — nav flottante · marquee · chiffres · footer · reveal
   ===================================================================== */

/* Nav flottante en verre */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:center;padding:1.1rem 1.25rem;pointer-events:none}
.nav__inner{pointer-events:auto;display:flex;align-items:center;gap:1.5rem;width:min(100%,56rem);
  padding:.55rem .6rem .55rem 1.3rem;border-radius:999px;background:rgba(8,7,5,.55);
  border:1px solid rgba(255,180,71,.18);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  box-shadow:0 16px 40px -24px rgba(0,0,0,.85)}
.nav__brand{font-family:var(--display);font-weight:600;font-size:1.18rem;color:#fff;letter-spacing:-.01em}
.nav__brand span{color:var(--amber)}
.nav__links{display:flex;gap:1.4rem;margin-left:auto}
.nav__links a{font-size:.9rem;color:var(--muted);transition:color .3s}
.nav__links a:hover{color:#fff}
.nav__cta{display:inline-flex;align-items:center;gap:.45rem;padding:.55rem 1.1rem;border-radius:999px;
  font-size:.88rem;font-weight:600;color:#0a0a0a;background:linear-gradient(90deg,var(--orange),var(--amber));
  transition:transform .3s var(--ease)}
.nav__cta:hover{transform:scale(1.04)}
@media(max-width:600px){.nav__links{display:none}.nav__inner{gap:1rem}}

/* Barre de navigation (texte, large, surbrillance au survol) */
.dock{position:fixed;top:.9rem;left:50%;transform:translateX(-50%);z-index:120;
  display:flex;align-items:center;gap:clamp(.2rem,1.2vw,.7rem);
  max-width:calc(100vw - 1.2rem);overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;
  padding:.5rem .7rem;border-radius:999px;background:rgba(20,16,12,.6);
  border:1px solid rgba(255,180,71,.18);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);
  box-shadow:0 16px 44px -22px rgba(0,0,0,.85),inset 0 1px 0 rgba(255,255,255,.08)}
.dock::-webkit-scrollbar{display:none}
.dock__link{position:relative;white-space:nowrap;text-decoration:none;
  padding:.7rem clamp(1rem,2.4vw,1.7rem);border-radius:999px;
  font-family:var(--sans);font-weight:500;font-size:clamp(.9rem,1.5vw,1.05rem);color:var(--muted);
  transition:color .3s var(--ease),background .3s var(--ease),box-shadow .3s var(--ease),text-shadow .3s var(--ease)}
.dock__link:hover,.dock__link:focus-visible{color:#fff;background:rgba(255,180,71,.14);outline:none;
  box-shadow:inset 0 0 0 1px rgba(255,180,71,.35),0 10px 26px -12px rgba(255,122,47,.55);
  text-shadow:0 0 18px rgba(255,180,71,.55)}
.dock__link--cta{color:#0a0a0a;font-weight:600;background:linear-gradient(90deg,var(--orange),var(--amber))}
.dock__link--cta:hover,.dock__link--cta:focus-visible{color:#0a0a0a;filter:brightness(1.08);text-shadow:none;
  box-shadow:0 10px 26px -10px rgba(255,122,47,.65)}
@media (max-width:600px){.dock__link{padding:.6rem .9rem;font-size:.85rem}}
@media (prefers-reduced-motion:reduce){.dock__link{transition:none}}

/* Bandeau de mots-clés défilant */
.kw-marquee{background:#000;border-block:1px solid rgba(255,180,71,.14);overflow:hidden;white-space:nowrap;padding:1.1rem 0}
.kw-track{display:inline-flex;gap:2.4rem;align-items:center;animation:kwScroll 30s linear infinite;will-change:transform}
.kw-marquee:hover .kw-track{animation-play-state:paused}
.kw-track span{font-family:var(--display);font-size:clamp(1.05rem,2.6vw,1.6rem);font-weight:500;color:rgba(244,241,234,.5)}
.kw-track .dot{color:var(--amber)}
@keyframes kwScroll{to{transform:translateX(-50%)}}

/* Chiffres */
.stats{background:#000;border-top:1px solid rgba(255,180,71,.1);padding:clamp(3rem,7vw,5rem) 1.25rem}
.stats__wrap{max-width:60rem;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
.stat{text-align:center}
.stat__n{font-family:var(--display);font-weight:600;font-size:clamp(2.4rem,6vw,3.6rem);line-height:1;
  background:linear-gradient(90deg,var(--gold),var(--amber),var(--orange));-webkit-background-clip:text;background-clip:text;color:transparent}
.stat__l{margin-top:.6rem;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
@media(max-width:640px){.stats__wrap{grid-template-columns:1fr 1fr;gap:2.4rem 1.5rem}}
.stats__wrap--3{grid-template-columns:repeat(3,1fr)}
@media(max-width:640px){.stats__wrap--3{grid-template-columns:1fr}}

/* Footer */
.foot{background:#000;border-top:1px solid rgba(255,180,71,.14);padding:clamp(3rem,7vw,5rem) 1.25rem 2rem;overflow:hidden}
.foot__big{font-family:var(--display);font-weight:700;text-align:center;line-height:.85;letter-spacing:.02em;
  font-size:clamp(3.5rem,18vw,11rem);color:transparent;-webkit-text-stroke:1px rgba(255,180,71,.22);margin-bottom:2.5rem}
.foot__grid{max-width:56rem;margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:2rem;
  border-top:1px solid rgba(255,255,255,.08);padding-top:2.5rem}
.foot__brand{font-family:var(--display);font-weight:600;font-size:1.4rem;color:#fff;margin-bottom:.6rem}
.foot__brand span{color:var(--amber)}
.foot p,.foot a{color:var(--muted);font-size:.92rem;display:block;padding:.2rem 0;transition:color .3s}
.foot a:hover{color:var(--amber)}
.foot h4{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:.9rem}
.foot__bottom{max-width:56rem;margin:2.5rem auto 0;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.08);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;font-size:.8rem;color:rgba(244,241,234,.45)}
@media(max-width:640px){.foot__grid{grid-template-columns:1fr;gap:1.6rem}}

/* Apparition au scroll */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1;transform:none;transition:none}
  .kw-track{animation:none}
  .nav__cta{transition:none}
}

/* =====================================================================
   PAGE CONNEXION (auth) — esprit Webnova, textes en surbrillance
   ===================================================================== */
.auth-body{min-height:100vh;background:#000}
.auth-back{position:fixed;top:1.2rem;left:1.3rem;z-index:10;font-size:.85rem;color:var(--muted);text-decoration:none;
  display:inline-flex;align-items:center;gap:.35rem;transition:color .3s var(--ease),text-shadow .3s var(--ease)}
.auth-back:hover{color:#fff;text-shadow:0 0 16px rgba(255,180,71,.55)}

.auth{min-height:100vh;display:grid;grid-template-columns:1fr}
@media(min-width:860px){.auth{grid-template-columns:clamp(360px,38%,460px) 1fr}}
.auth__form-side{display:flex;align-items:center;justify-content:center;padding:4.5rem 1.5rem 3rem}
.auth__box{width:min(360px,100%);display:flex;flex-direction:column;gap:1.1rem;animation:authUp .8s var(--ease)}
.auth__brand{font-family:var(--display);font-weight:600;font-size:1.45rem;color:#fff;text-decoration:none;text-align:center;margin-bottom:.3rem;transition:text-shadow .3s}
.auth__brand:hover{text-shadow:0 0 18px rgba(255,180,71,.5)}
.auth__brand span{color:var(--amber)}

.auth__form{display:none;flex-direction:column;gap:1.1rem}
.auth__head{text-align:center;margin-bottom:.2rem}
.auth__head h1{font-family:var(--display);font-weight:600;font-size:1.7rem;color:#fff;letter-spacing:-.01em}
.auth__head p{font-size:.88rem;color:var(--muted);margin-top:.4rem}

.field{display:flex;flex-direction:column;gap:.45rem}
.field label{font-size:.78rem;letter-spacing:.03em;color:var(--muted);font-weight:500}
.field input{height:2.9rem;border-radius:.7rem;border:1px solid rgba(255,180,71,.18);background:rgba(255,255,255,.03);
  padding:0 .9rem;color:#fff;font-family:var(--sans);font-size:.95rem;transition:border-color .3s,box-shadow .3s,background .3s}
.field input::placeholder{color:rgba(244,241,234,.32)}
.field input:focus{outline:none;border-color:var(--amber);background:rgba(255,180,71,.06);box-shadow:0 0 0 3px rgba(255,180,71,.16)}
.pw{position:relative}
.pw input{width:100%;padding-right:2.9rem}
.pw-toggle{position:absolute;top:0;right:0;height:100%;width:2.9rem;display:grid;place-items:center;background:none;border:0;color:var(--muted);cursor:pointer;transition:color .3s}
.pw-toggle:hover{color:var(--amber)}
.pw-toggle .osvg{width:18px;height:18px}
.pw-toggle .eye-off{display:none}
.pw-toggle[data-show="1"] .eye-on{display:none}
.pw-toggle[data-show="1"] .eye-off{display:inline-flex}

.auth__submit{margin-top:.3rem;height:2.9rem;border:0;border-radius:.7rem;cursor:pointer;font-family:var(--sans);font-weight:600;font-size:.95rem;
  color:#0a0a0a;background:linear-gradient(90deg,var(--orange),var(--amber),var(--orange));background-size:200% 100%;animation:authBtn 5s linear infinite;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),filter .3s var(--ease)}
.auth__submit:hover{transform:translateY(-1px);filter:brightness(1.07);box-shadow:0 14px 34px -14px rgba(255,122,47,.6)}
.auth__submit:active{transform:scale(.99)}

.auth__toggle{text-align:center;font-size:.86rem;color:var(--muted)}
.auth__switch{background:none;border:0;cursor:pointer;color:var(--amber);font:inherit;font-weight:600;padding:0 .15rem;transition:color .3s,text-shadow .3s}
.auth__switch:hover{color:#fff;text-shadow:0 0 16px rgba(255,180,71,.65)}

.auth__divider{position:relative;text-align:center;margin:.2rem 0}
.auth__divider::before{content:'';position:absolute;top:50%;left:0;right:0;height:1px;background:rgba(255,255,255,.1)}
.auth__divider span{position:relative;background:#000;padding:0 .8rem;font-size:.78rem;color:var(--muted)}

.auth__google{display:flex;align-items:center;justify-content:center;gap:.6rem;height:2.9rem;border-radius:.7rem;cursor:pointer;
  border:1px solid rgba(255,180,71,.2);background:rgba(255,255,255,.02);color:#fff;font-family:var(--sans);font-weight:500;font-size:.92rem;
  transition:background .3s,border-color .3s,text-shadow .3s}
.auth__google:hover{background:rgba(255,180,71,.08);border-color:rgba(255,180,71,.4);text-shadow:0 0 14px rgba(255,180,71,.45)}
.auth__google img{width:18px;height:18px}
.auth__note{text-align:center;font-size:.74rem;color:rgba(244,241,234,.4);margin-top:.1rem;transition:color .3s}
.auth__note.show{color:var(--amber)}
.auth__note.is-err{color:#ff9a8a}
.field label .opt{opacity:.55;font-weight:400;text-transform:none;letter-spacing:0}
.auth__nocode{background:none;border:0;cursor:pointer;color:var(--muted);font:inherit;font-size:.82rem;
  text-decoration:underline;text-underline-offset:3px;padding:.3rem;transition:color .3s,text-shadow .3s}
.auth__nocode:hover{color:#fff;text-shadow:0 0 14px rgba(255,180,71,.5)}

/* Colonne visuelle */
.auth__media{position:relative;display:none;overflow:hidden}
@media(min-width:860px){.auth__media{display:block}}
.auth__media-img{position:absolute;inset:-6%;background-size:cover;background-position:center;filter:brightness(.68) saturate(1.08);
  animation:kenburns 22s var(--ease) infinite alternate;will-change:transform}
.auth__aurora{position:absolute;inset:0;z-index:1;mix-blend-mode:overlay;opacity:.55;
  background:linear-gradient(120deg,rgba(255,122,47,.5),rgba(255,180,71,.2),rgba(255,90,30,.45),rgba(255,170,60,.25));
  background-size:240% 240%;animation:authAurora 14s ease infinite}
.auth__orb{position:absolute;z-index:1;border-radius:50%;filter:blur(55px);opacity:.5;pointer-events:none}
.auth__orb--1{width:42%;aspect-ratio:1;left:-8%;top:6%;background:radial-gradient(circle,rgba(255,122,47,.85),transparent 70%);animation:authFloat1 16s ease-in-out infinite}
.auth__orb--2{width:38%;aspect-ratio:1;right:-7%;bottom:4%;background:radial-gradient(circle,rgba(255,180,71,.75),transparent 70%);animation:authFloat2 19s ease-in-out infinite}
.auth__media::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,.2),rgba(0,0,0,.25) 45%,rgba(0,0,0,.9))}
.auth__media-top{position:absolute;inset:0 0 auto 0;z-index:2;padding:clamp(2rem,5vh,3.5rem) 2.5rem 0;text-align:center;animation:authUp 1s var(--ease)}
.auth__media-brand{font-family:var(--display);font-weight:600;font-size:1.6rem;color:#fff;text-decoration:none;transition:text-shadow .3s}
.auth__media-brand:hover{text-shadow:0 0 22px rgba(255,180,71,.6)}
.auth__media-brand span{color:var(--amber)}
.auth__media-tag{margin:.7rem auto 0;font-size:1rem;color:rgba(244,241,234,.88);max-width:26ch;line-height:1.4}
.auth__quote{position:absolute;inset:auto 0 0 0;z-index:2;padding:0 2.5rem 3.2rem;text-align:center}
.auth__quote p{font-family:var(--display);font-size:clamp(1.2rem,2vw,1.5rem);font-weight:500;color:#fff;line-height:1.3;min-height:2.6em}
.auth__quote cite{display:block;margin-top:.8rem;font-style:normal;font-size:.85rem;color:var(--amber)}
.tw-cursor{color:var(--amber);animation:twBlink 1s step-end infinite}
@keyframes twBlink{50%{opacity:0}}
@keyframes kenburns{0%{transform:scale(1.04) translate(0,0)}100%{transform:scale(1.2) translate(-2.5%,-2%)}}
@keyframes authAurora{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes authFloat1{0%,100%{transform:translate(0,0)}50%{transform:translate(8%,6%)}}
@keyframes authFloat2{0%,100%{transform:translate(0,0)}50%{transform:translate(-7%,-5%)}}
@keyframes authUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
@keyframes authBtn{to{background-position:200% 0}}

/* Affichage selon le mode */
body[data-mode="signin"] .auth__form[data-form="signin"]{display:flex}
body[data-mode="signup"] .auth__form[data-form="signup"]{display:flex}
[data-when]{display:none}
body[data-mode="signin"] [data-when="signin"]{display:inline}
body[data-mode="signup"] [data-when="signup"]{display:inline}

@media(prefers-reduced-motion:reduce){
  .tw-cursor,.auth__media-img,.auth__aurora,.auth__orb,.auth__submit,.auth__box,.auth__media-top{animation:none}
  .auth__submit,.auth__switch,.auth-back,.field input{transition:none}
}

/* =====================================================================
   PAGE CONTACT
   ===================================================================== */
.contact-body{min-height:100vh;background:#000;position:relative;overflow-x:hidden}
.contact__bg{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.55;
  background:radial-gradient(45% 40% at 18% 18%,rgba(255,122,47,.28),transparent 60%),
             radial-gradient(42% 42% at 86% 82%,rgba(255,180,71,.22),transparent 60%)}
.contact{position:relative;z-index:1;max-width:64rem;margin:0 auto;min-height:100vh;
  display:grid;grid-template-columns:1fr;gap:2.5rem;align-items:center;padding:6rem 1.5rem 4rem}
@media(min-width:900px){.contact{grid-template-columns:1fr 1.1fr;gap:4rem}}
.contact__intro .auth__brand{display:inline-block;text-align:left;margin-bottom:1.4rem}
.contact__title{font-family:var(--display);font-weight:600;line-height:1;letter-spacing:-.02em;
  font-size:clamp(2.4rem,6vw,4rem);color:#fff}
.contact__title span{color:var(--amber)}
.contact__lead{margin-top:1.3rem;color:var(--muted);font-size:1.05rem;line-height:1.6;max-width:38ch}
.contact__perks{list-style:none;margin-top:1.8rem;display:flex;flex-direction:column;gap:.55rem}
.contact__perks li{color:rgba(244,241,234,.85);font-size:.95rem}
.contact__panel{background:rgba(255,255,255,.03);border:1px solid rgba(255,180,71,.18);border-radius:1.2rem;
  padding:clamp(1.5rem,3vw,2.2rem);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  box-shadow:0 30px 70px -40px rgba(0,0,0,.9);animation:authUp .8s var(--ease)}
.contact__form{display:flex;flex-direction:column;gap:1.05rem}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:480px){.grid2{grid-template-columns:1fr}}
.field textarea{border-radius:.7rem;border:1px solid rgba(255,180,71,.18);background:rgba(255,255,255,.03);
  padding:.7rem .9rem;color:#fff;font-family:var(--sans);font-size:.95rem;resize:vertical;min-height:120px;
  transition:border-color .3s,box-shadow .3s,background .3s}
.field textarea::placeholder{color:rgba(244,241,234,.32)}
.field textarea:focus{outline:none;border-color:var(--amber);background:rgba(255,180,71,.06);box-shadow:0 0 0 3px rgba(255,180,71,.16)}
.su-avatar{display:flex;align-items:center;gap:.8rem}
.su-avatar__preview{flex:none;width:3rem;height:3rem;border-radius:50%;display:grid;place-items:center;
  background:rgba(255,180,71,.1);border:1px solid rgba(255,180,71,.25);font-size:1.1rem;background-size:cover;background-position:center}
.su-avatar input[type=file]{flex:1;font-size:.82rem;color:var(--muted)}
.su-avatar input[type=file]::file-selector-button{margin-right:.7rem;padding:.5rem .9rem;border-radius:.6rem;
  border:1px solid rgba(255,180,71,.3);background:rgba(255,180,71,.08);color:var(--amber);font:inherit;font-size:.82rem;cursor:pointer}
.contact__req{font-size:.76rem;color:rgba(244,241,234,.45)}
.contact__ok{display:none;margin-top:.2rem;background:rgba(255,180,71,.12);border:1px solid rgba(255,180,71,.4);
  border-radius:.7rem;padding:1rem 1.1rem;color:var(--gold);font-size:.9rem;line-height:1.5}
.contact__ok.show{display:block;animation:authUp .5s var(--ease)}

/* =====================================================================
   PAGE NOTRE HISTOIRE
   ===================================================================== */
.story-body{min-height:100vh;background:#000;position:relative;overflow-x:hidden}
/* Fond animé "Starship" (WebGL2) — derrière tout le contenu */
.story__canvas{position:fixed;inset:0;z-index:0;width:100%;height:100%;display:block;
  pointer-events:none;opacity:.8}
body.no-webgl .story__canvas{display:none}
/* Voile sombre : garde le fond visible mais rend le texte lisible.
   Plus dense au centre (colonne de lecture) que sur les bords. */
.story__scrim{position:fixed;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(120% 80% at 50% 40%,rgba(0,0,0,.78),rgba(0,0,0,.5) 55%,rgba(0,0,0,.35))}
.story{position:relative;z-index:2;text-shadow:0 1px 16px rgba(0,0,0,.55);max-width:60rem;margin:0 auto;
  padding:7rem 1.5rem 5rem;display:flex;flex-direction:column;gap:clamp(3rem,7vw,5.5rem)}
.story__hero{text-align:center}
.story__hero h1{font-family:var(--display);font-weight:600;line-height:1;letter-spacing:-.02em;
  font-size:clamp(2.6rem,7vw,5rem);color:#fff;margin-top:1rem}
.story__hero h1 span{color:var(--amber)}
.story__lead{margin:1.5rem auto 0;max-width:48ch;color:var(--muted);font-size:1.1rem;line-height:1.6}
.story__block{max-width:44rem;margin:0 auto;text-align:center}
.story__h2,.story__block h2{font-family:var(--display);font-weight:600;color:#fff;
  font-size:clamp(1.8rem,4vw,2.6rem);margin-bottom:1rem}
.story__block p{color:var(--muted);font-size:1.05rem;line-height:1.7}
.story__plus{font-family:var(--display);font-size:clamp(1.4rem,3vw,2rem);color:var(--muted);line-height:1.4}
.story__plus strong{color:var(--amber);font-weight:600}
.story__center{text-align:center}

/* Fondateurs */
.story__founders{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
@media(max-width:760px){.story__founders{grid-template-columns:1fr}}
.founder{background:rgba(255,255,255,.03);border:1px solid rgba(255,180,71,.18);border-radius:1.2rem;padding:2rem;
  transition:transform .5s var(--ease),border-color .5s var(--ease),box-shadow .5s var(--ease)}
.founder:hover{transform:translateY(-5px);border-color:rgba(255,180,71,.42);box-shadow:0 30px 60px -40px rgba(255,122,47,.5)}
.founder__avatar{width:3.4rem;height:3.4rem;border-radius:50%;display:grid;place-items:center;margin-bottom:1.2rem;
  color:#0a0a0a;background:linear-gradient(135deg,var(--orange),var(--amber))}
.founder__avatar .osvg{width:20px;height:20px;stroke-width:2}
.founder__role{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--amber)}
.founder h3{font-family:var(--display);font-weight:600;font-size:1.5rem;color:#fff;margin:.25rem 0 .8rem}
.founder p{color:var(--muted);line-height:1.6;font-size:.96rem}

/* Frise */
.story__tl{position:relative;border-left:1px solid rgba(255,180,71,.25);margin-left:.5rem;max-width:46rem}
.tl{position:relative;padding:0 0 2.5rem 2rem}
.tl:last-child{padding-bottom:0}
.tl::before{content:'';position:absolute;left:-5px;top:.35rem;width:9px;height:9px;border-radius:50%;
  background:var(--amber);box-shadow:0 0 12px rgba(255,180,71,.65)}
.tl__year{font-family:var(--display);font-weight:600;color:var(--amber);font-size:.95rem}
.tl h3{font-family:var(--display);font-weight:600;color:#fff;font-size:1.3rem;margin:.2rem 0 .4rem}
.tl p{color:var(--muted);font-size:.95rem;line-height:1.55;max-width:50ch}

/* =====================================================================
   PAGE RÉALISATIONS — projets + témoignages audio/vidéo
   ===================================================================== */
/* Cartes projets (mockup navigateur) */
.proj-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
@media(max-width:760px){.proj-grid{grid-template-columns:1fr}}
.proj{display:block;text-decoration:none;border-radius:1rem;overflow:hidden;border:1px solid rgba(255,180,71,.16);
  background:rgba(255,255,255,.02);transition:transform .5s var(--ease),border-color .5s var(--ease),box-shadow .5s var(--ease)}
.proj:hover{transform:translateY(-6px);border-color:rgba(255,180,71,.42);box-shadow:0 30px 60px -40px rgba(255,122,47,.5)}
.proj__frame{padding:.6rem .6rem 0}
.proj__bar{display:flex;align-items:center;gap:.4rem;padding:.5rem .7rem;background:rgba(0,0,0,.45);
  border:1px solid rgba(255,255,255,.07);border-bottom:0;border-radius:.6rem .6rem 0 0}
.proj__bar span{width:.55rem;height:.55rem;border-radius:50%;background:rgba(255,255,255,.25)}
.proj__bar em{margin-left:.6rem;font-style:normal;font-size:.7rem;color:rgba(244,241,234,.5);
  background:rgba(255,255,255,.06);padding:.15rem .65rem;border-radius:999px}
.proj__shot{aspect-ratio:16/10;display:grid;place-items:center;border:1px solid rgba(255,255,255,.07);border-top:0}
.proj__shot span{font-family:var(--display);font-weight:600;font-size:clamp(1.4rem,3vw,2rem);color:#fff;text-shadow:0 4px 22px rgba(0,0,0,.5)}
.proj__shot--5{background:linear-gradient(135deg,#0a0a0b,#171614,#c9a24a)}
.proj__shot--6{background:linear-gradient(135deg,#060608,#0c1a22,#00e5ff)}

/* FAQ (accordéon CSS-only via <details>) */
.faq{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:.85rem}
.faq__item{border:1px solid rgba(255,255,255,.1);border-radius:.85rem;background:rgba(255,255,255,.03);
  overflow:hidden;transition:border-color .25s,background .25s}
.faq__item[open]{border-color:rgba(255,180,71,.4);background:rgba(255,180,71,.05)}
.faq__item summary{list-style:none;cursor:pointer;padding:1.1rem 1.3rem;display:flex;align-items:center;justify-content:space-between;
  gap:1rem;font-family:var(--display);font-weight:600;font-size:1.06rem;color:#fff}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:'+';flex:none;width:1.6rem;height:1.6rem;border-radius:50%;display:grid;place-items:center;
  color:var(--amber);background:rgba(255,180,71,.12);font-size:1.2rem;line-height:1;transition:transform .25s}
.faq__item[open] summary::after{content:'−';transform:rotate(180deg)}
.faq__item summary:hover{color:var(--amber)}
.faq__a{padding:0 1.3rem 1.2rem;color:var(--muted);font-size:.95rem;line-height:1.65}
.faq__a p{margin:0}
.faq__inlink{color:var(--amber);font-weight:600}
.faq__inlink:hover{text-shadow:0 0 12px rgba(255,180,71,.6)}
@media (prefers-reduced-motion:reduce){.faq__item,.faq__item summary::after{transition:none}}

/* Teaser Scraping Premium (verrouillé jusqu'au palier d'abonnés) */
.scrape-premium{position:relative;margin-bottom:1.2rem;padding:1.3rem 1.4rem;border-radius:.9rem;overflow:hidden;
  border:1px solid rgba(255,180,71,.35);background:linear-gradient(135deg,rgba(255,150,40,.12),rgba(255,180,71,.04))}
.scrape-premium.is-unlocked{border-color:rgba(90,209,122,.5);background:linear-gradient(135deg,rgba(90,209,122,.14),rgba(90,209,122,.04))}
.scrape-premium__top{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.6rem}
.scrape-premium__badge{font-family:var(--display);font-weight:700;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;
  color:#0a0a0a;background:linear-gradient(135deg,var(--orange),var(--amber));padding:.28rem .7rem;border-radius:999px}
.scrape-premium__lock{font-size:.82rem;color:var(--amber);font-weight:600}
.scrape-premium__title{font-family:var(--display);font-weight:600;font-size:1.2rem;color:#fff;margin:0 0 .35rem}
.scrape-premium__desc{color:rgba(244,241,234,.78);font-size:.9rem;line-height:1.55;margin:0 0 .9rem}
.scrape-premium__barwrap{height:8px;border-radius:999px;background:rgba(255,255,255,.1);overflow:hidden;margin-bottom:.5rem}
.scrape-premium__bar{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--orange),var(--amber));
  width:0;transition:width .6s ease}
.scrape-premium.is-unlocked .scrape-premium__bar{background:linear-gradient(90deg,#3fae62,#5ad17a)}
.scrape-premium__meta{font-size:.85rem;color:rgba(244,241,234,.8)}
.scrape-premium__meta strong{color:var(--amber)}
.scrape-premium__cta{display:inline-flex;align-items:center;gap:.4rem;margin-top:1rem;padding:.6rem 1.1rem;border-radius:.6rem;
  text-decoration:none;font-family:var(--display);font-weight:600;font-size:.9rem;color:#0a0a0a;
  background:linear-gradient(135deg,var(--orange),var(--amber));transition:transform .15s,box-shadow .2s}
.scrape-premium__cta:hover{transform:translateY(-1px);box-shadow:0 8px 22px rgba(255,150,40,.32)}

/* Carte « Mon abonnement » (Paramètres) */
.sub-status{margin-bottom:1rem}
.sub-badge{display:inline-block;font-size:.78rem;font-weight:600;padding:.25rem .65rem;border-radius:999px;
  border:1px solid rgba(255,255,255,.18);color:var(--muted);margin-bottom:.5rem}
.sub-badge--on{color:#0a0a0a;border-color:transparent;background:linear-gradient(135deg,var(--orange),var(--amber))}
.sub-line{color:rgba(244,241,234,.82);font-size:.9rem;margin-top:.2rem}
.sub-line strong{color:#fff}
.sub-actions{display:flex;gap:.6rem;flex-wrap:wrap}
.cl-btn--danger{border-color:rgba(255,90,90,.45);color:#ff9a8a}
.cl-btn--danger:hover{background:rgba(255,90,90,.12)}
.scrape__free{font-family:var(--body,inherit);font-weight:500;font-size:.8rem;color:var(--muted)}
@media(prefers-reduced-motion:reduce){.scrape-premium__bar{transition:none}}

/* Scraping de leads (cold caller) */
.scrape__form{display:flex;flex-direction:column;gap:1.1rem;margin:.8rem 0 1.2rem}
.scrape__fields{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
@media(max-width:560px){.scrape__fields{grid-template-columns:1fr}}
.scrape__form .set-field{margin:0}
.scrape__chips{display:flex;flex-wrap:wrap;gap:.45rem;margin:-.2rem 0 .1rem}
.scrape__chips button{border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.04);color:rgba(244,241,234,.82);
  font:500 .82rem/1 inherit;padding:.42rem .7rem;border-radius:999px;cursor:pointer;transition:all .18s}
.scrape__chips button:hover{border-color:rgba(255,180,71,.5);color:#fff;background:rgba(255,180,71,.08)}
.scrape__chips button.is-active{border-color:transparent;color:#0a0a0a;background:linear-gradient(135deg,var(--orange),var(--amber))}
.scrape__actions{display:flex;gap:.5rem;flex-wrap:wrap}
.cl-btn--accent{border-color:transparent;color:#0a0a0a;background:linear-gradient(135deg,var(--orange),var(--amber))}
.cl-btn--accent:hover{box-shadow:0 6px 18px rgba(255,150,40,.3)}
.scrape__seen{display:inline-block;margin-left:.4rem;font-size:.66rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;
  color:#ffcaa0;background:rgba(255,150,40,.14);border:1px solid rgba(255,150,40,.35);padding:.08rem .4rem;border-radius:999px}
.scrape__table tr.is-seen{opacity:.5}
.scrape__gmap{color:var(--muted)}
.scrape__radius>span{display:flex;justify-content:space-between;align-items:baseline}
.scrape__radius strong{color:var(--amber);font-size:1rem}
.scrape__range{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:999px;margin:.5rem 0 .1rem;
  background:rgba(255,255,255,.14);outline:none;cursor:pointer}
.scrape__range::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:#fff;
  border:3px solid var(--amber);cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.45),0 0 0 6px rgba(255,180,71,.12)}
.scrape__range::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#fff;border:3px solid var(--amber);cursor:pointer}
.scrape__range-scale{display:flex;justify-content:space-between;color:var(--muted);font-size:.72rem}
.scrape__range-scale i{font-style:normal}
.scrape__opt{display:inline-flex;align-items:center;gap:.5rem;color:rgba(244,241,234,.82);font-size:.85rem;cursor:pointer}
.scrape__opt input{width:1.05rem;height:1.05rem;accent-color:var(--amber);cursor:pointer}
.scrape__go{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;width:100%;padding:.95rem 1rem;border:0;
  border-radius:.7rem;cursor:pointer;font-family:var(--display);font-weight:600;font-size:1rem;color:#0a0a0a;
  background:linear-gradient(135deg,var(--orange),var(--amber));transition:transform .15s,box-shadow .2s}
.scrape__go:hover{transform:translateY(-1px);box-shadow:0 10px 26px rgba(255,150,40,.32)}
.scrape__go:disabled{opacity:.6;cursor:wait;transform:none;box-shadow:none}
.scrape__go .osvg{width:18px;height:18px;stroke-width:2.4}

/* Scanner radar (pendant la recherche) */
.scanner{display:flex;align-items:center;gap:1.3rem;padding:1.2rem 1.3rem;margin-bottom:1.1rem;border-radius:.9rem;
  border:1px solid rgba(255,180,71,.28);background:rgba(255,180,71,.05)}
.scanner__radar{position:relative;flex:none;width:84px;height:84px;border-radius:50%;overflow:hidden;
  background:radial-gradient(circle,rgba(255,180,71,.1),transparent 72%);border:1px solid rgba(255,180,71,.3)}
.scanner__ring{position:absolute;inset:16px;border:1px solid rgba(255,180,71,.22);border-radius:50%}
.scanner__ring--2{inset:32px}
.scanner__sweep{position:absolute;inset:0;border-radius:50%;
  background:conic-gradient(from 0deg,rgba(255,180,71,.6),rgba(255,180,71,0) 70deg,transparent 360deg);
  animation:radarSweep 1.4s linear infinite}
.scanner__dot{position:absolute;top:50%;left:50%;width:6px;height:6px;margin:-3px;border-radius:50%;
  background:var(--amber);box-shadow:0 0 10px 2px var(--amber)}
@keyframes radarSweep{to{transform:rotate(360deg)}}
.scanner__meta{flex:1;min-width:0}
.scanner__msg{color:#fff;font-weight:600;margin-bottom:.45rem}
.scanner__nums{display:flex;gap:1.4rem;color:var(--muted);font-size:.9rem;flex-wrap:wrap}
.scanner__count strong{color:var(--amber);font-size:1.15rem;font-variant-numeric:tabular-nums}
.scanner__timer{font-variant-numeric:tabular-nums}
@media(prefers-reduced-motion:reduce){.scanner__sweep{animation:none}}

.scrape__status{padding:.6rem .85rem;border-radius:.55rem;font-size:.88rem;margin-bottom:1rem;
  border:1px solid rgba(255,255,255,.1);color:var(--muted)}
.scrape__status--ok{color:#9be7b4;border-color:rgba(90,209,122,.35);background:rgba(90,209,122,.08)}
.scrape__status--err{color:#ff9a8a;border-color:rgba(255,120,90,.35);background:rgba(255,120,90,.08)}
.scrape__bar{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:.7rem}
.scrape__all{display:inline-flex;align-items:center;gap:.5rem;color:rgba(244,241,234,.85);font-size:.85rem;cursor:pointer}
.scrape__all input{width:1.05rem;height:1.05rem;accent-color:var(--amber);cursor:pointer}
.scrape__chk{width:2.6rem;text-align:center}
.scrape__table input[type="checkbox"]{width:1.05rem;height:1.05rem;accent-color:var(--amber);cursor:pointer}
.scrape__table tbody tr{animation:scrapeRow .32s ease both}
@keyframes scrapeRow{from{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:none}}
.scrape__no{color:var(--muted)}
.scrape__legal{margin-top:1rem;font-size:.78rem;opacity:.7}
@media(prefers-reduced-motion:reduce){.scrape__go,.scrape__table tbody tr{animation:none;transition:none}}
.proj__body{padding:1.1rem 1.25rem 1.3rem}
.proj__body h3{font-family:var(--display);font-weight:600;font-size:1.25rem;color:#fff;margin-bottom:.3rem}
.proj__body p{color:var(--muted);font-size:.9rem;margin-bottom:.7rem}
.proj__link{color:var(--amber);font-size:.85rem;font-weight:600;transition:text-shadow .3s}
.proj:hover .proj__link{text-shadow:0 0 14px rgba(255,180,71,.55)}

/* Grille de témoignages */
.testi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
@media(max-width:760px){.testi-grid{grid-template-columns:1fr}}
.testi{display:flex;flex-direction:column;background:rgba(255,255,255,.03);border:1px solid rgba(255,180,71,.16);border-radius:1rem;padding:1.5rem}
.testi--wide{grid-column:span 2}
@media(max-width:760px){.testi--wide{grid-column:span 1}}
.testi__head{display:flex;align-items:center;gap:.8rem}
.testi__avatar{flex:none;width:2.6rem;height:2.6rem;border-radius:50%;display:grid;place-items:center;
  font-family:var(--display);font-weight:700;font-size:.92rem;color:#0a0a0a;background:linear-gradient(135deg,var(--orange),var(--amber))}
.testi__id{flex:1;min-width:0}
.testi__name{font-weight:600;color:#fff;font-size:.95rem}
.testi__co{font-size:.8rem;color:var(--muted)}
.testi__type{flex:none;font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;padding:.25rem .55rem;
  border-radius:999px;border:1px solid rgba(255,180,71,.3);color:var(--amber)}
.testi__type--video{color:#ff9a5a;border-color:rgba(255,154,90,.4)}
.testi__quote{margin-top:1rem;color:rgba(244,241,234,.85);font-style:italic;line-height:1.5}
.testi__hint,.video__hint{display:none;margin-top:.6rem;font-size:.72rem;color:rgba(255,180,71,.75)}
.testi__hint code,.video__hint code{font-family:ui-monospace,monospace}
.testi--text{justify-content:space-between}
.testi__quotemark{font-family:var(--display);font-size:3rem;line-height:0;color:var(--amber);height:1.4rem}
.testi__bigquote{font-family:var(--display);font-weight:500;font-size:clamp(1.1rem,2vw,1.4rem);color:#fff;line-height:1.4;margin:1rem 0 1.5rem}

/* Lecteur audio */
.audio{display:flex;align-items:center;gap:.8rem;margin-top:1.1rem;background:rgba(0,0,0,.32);
  border:1px solid rgba(255,180,71,.16);border-radius:.7rem;padding:.55rem .7rem}
.audio__play{flex:none;width:2.6rem;height:2.6rem;border-radius:50%;border:0;cursor:pointer;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--orange),var(--amber));transition:transform .2s var(--ease)}
.audio__play:hover{transform:scale(1.07)}
.audio__play .osvg{width:15px;height:15px}
.audio__play .ic-play{fill:#0a0a0a;stroke:none;margin-left:2px}
.audio__play .ic-pause{stroke:#0a0a0a;fill:none;stroke-width:2.6}
.audio .ic-pause{display:none}
.audio.is-playing .ic-play{display:none}
.audio.is-playing .ic-pause{display:block}
.audio__wave{flex:1;height:6px;border-radius:999px;background:rgba(255,255,255,.12);overflow:hidden}
.audio__prog{height:100%;width:0;background:linear-gradient(90deg,var(--orange),var(--amber))}
.audio__time{flex:none;font-size:.72rem;color:var(--muted);min-width:3.4rem;text-align:right;font-variant-numeric:tabular-nums}
.audio.is-missing{opacity:.7}
.audio.is-missing .audio__play{filter:grayscale(1);cursor:not-allowed}
.audio.is-missing ~ .testi__hint{display:block}

/* Lecteur vidéo */
.video{position:relative;margin-top:1.1rem;border-radius:.8rem;overflow:hidden;background:#0a0a0a;aspect-ratio:16/9}
.video video{width:100%;height:100%;object-fit:cover;display:block}
.video__play{position:absolute;inset:0;margin:auto;width:4rem;height:4rem;border-radius:50%;border:0;cursor:pointer;
  display:grid;place-items:center;background:linear-gradient(135deg,var(--orange),var(--amber));
  box-shadow:0 10px 30px -8px rgba(0,0,0,.65);transition:transform .25s var(--ease)}
.video__play .osvg{width:24px;height:24px;fill:#0a0a0a;stroke:none;margin-left:3px}
.video__play:hover{transform:scale(1.08)}
.video.is-playing .video__play{display:none}
.video.is-missing .video__play{filter:grayscale(1)}
.video.is-missing .video__hint{display:block}

@media(prefers-reduced-motion:reduce){
  .proj,.audio__play,.video__play,.proj__link{transition:none}
}

/* =====================================================================
   ESPACE CLIENT (dashboard)
   ===================================================================== */
.dash-body{min-height:100vh;background:#070707;color:var(--ink)}
.dash{min-height:100vh;display:grid;grid-template-columns:255px 1fr}
@media(max-width:820px){.dash{grid-template-columns:1fr}}
.dash__side{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:1.4rem;padding:1.6rem 1.2rem;
  background:#0c0a08;border-right:1px solid rgba(255,180,71,.12)}
@media(max-width:820px){.dash__side{position:static;height:auto;border-right:0;border-bottom:1px solid rgba(255,180,71,.12)}}
.dash__brand{font-family:var(--display);font-weight:600;font-size:1.4rem;color:#fff;text-decoration:none;padding:.3rem .4rem}
.dash__brand span{color:var(--amber)}
.dash__nav{display:flex;flex-direction:column;gap:.3rem;flex:1}
@media(max-width:820px){.dash__nav{flex-direction:row;overflow-x:auto;flex:none;scrollbar-width:none}.dash__nav::-webkit-scrollbar{display:none}}
.dash__navlink{display:flex;align-items:center;gap:.7rem;padding:.7rem .8rem;border-radius:.6rem;color:var(--muted);
  text-decoration:none;font-size:.92rem;white-space:nowrap;transition:background .25s,color .25s}
.dash__navlink .osvg{width:18px;height:18px}
.dash__navlink:hover{color:#fff;background:rgba(255,180,71,.07)}
.dash__navlink.is-active{color:#0a0a0a;background:linear-gradient(135deg,var(--orange),var(--amber));font-weight:600}
.dash__logout{display:flex;align-items:center;gap:.7rem;padding:.7rem .8rem;border-radius:.6rem;color:var(--muted);
  text-decoration:none;font-size:.9rem;transition:color .25s,background .25s}
.dash__logout .osvg{width:18px;height:18px}
.dash__logout:hover{color:#ff8a5a;background:rgba(255,90,40,.08)}
@media(max-width:820px){.dash__logout{display:none}}

.dash__main{padding:clamp(1.4rem,3vw,2.4rem);min-width:0}
.dash__top{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap;margin-bottom:2rem}
.dash__hello{font-family:var(--display);font-weight:600;font-size:1.7rem;color:#fff}
.dash__sub{color:var(--muted);margin-top:.3rem;font-size:.92rem}
.dash__sub strong{color:var(--amber)}
.dash__period{display:inline-flex;gap:.2rem;background:rgba(255,255,255,.04);border:1px solid rgba(255,180,71,.14);border-radius:999px;padding:.25rem}
.dash__period button{border:0;background:none;cursor:pointer;color:var(--muted);font:inherit;font-size:.82rem;padding:.4rem .9rem;border-radius:999px;transition:background .25s,color .25s}
.dash__period button.is-active{background:rgba(255,180,71,.16);color:#fff}

.dash__cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.2rem}
@media(max-width:900px){.dash__cards{grid-template-columns:1fr 1fr}}
.dcard{background:rgba(255,255,255,.03);border:1px solid rgba(255,180,71,.14);border-radius:1rem;padding:1.3rem}
.dcard--accent{background:linear-gradient(160deg,rgba(255,122,47,.14),rgba(255,180,71,.05));border-color:rgba(255,180,71,.3)}
.dcard__top{display:flex;justify-content:space-between;align-items:center;gap:.5rem}
.dcard__lbl{font-size:.8rem;color:var(--muted)}
.dcard__trend{font-size:.72rem;color:#7bdca0;font-weight:600;white-space:nowrap}
.dcard__trend.is-down{color:#e88}
.dcard__num{font-family:var(--display);font-weight:600;font-size:clamp(1.8rem,3.5vw,2.4rem);color:#fff;margin-top:.6rem;font-variant-numeric:tabular-nums}

.dash__grid{display:grid;grid-template-columns:1.5fr 1fr;gap:1.2rem}
@media(max-width:900px){.dash__grid{grid-template-columns:1fr}}
.dpanel{background:rgba(255,255,255,.03);border:1px solid rgba(255,180,71,.14);border-radius:1rem;padding:1.4rem}
.dpanel__head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1.2rem}
.dpanel__head h2{font-family:var(--display);font-weight:600;font-size:1.1rem;color:#fff}
.dpanel__hint{font-size:.75rem;color:var(--muted)}
.chart{display:flex;align-items:flex-end;gap:3px;height:180px}
.chart__bar{flex:1;min-width:0;height:0;border-radius:4px 4px 0 0;
  background:linear-gradient(180deg,var(--amber),rgba(255,122,47,.5));transition:height .6s var(--ease);transition-delay:var(--d,0s)}
.chart.in .chart__bar{height:var(--h)}
.chart__bar:hover{background:linear-gradient(180deg,#fff,var(--amber))}
.dlist{list-style:none;display:flex;flex-direction:column;gap:.1rem}
.dlist li{display:flex;align-items:center;gap:.8rem;padding:.7rem .2rem;border-bottom:1px solid rgba(255,255,255,.06)}
.dlist li:last-child{border-bottom:0}
.dlist__av{flex:none;width:2.1rem;height:2.1rem;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:.8rem;color:#0a0a0a;background:linear-gradient(135deg,var(--orange),var(--amber))}
.dlist li>div{flex:1;min-width:0}
.dlist__name{color:#fff;font-size:.88rem}
.dlist__meta{color:var(--muted);font-size:.74rem}
.dlist__tag{flex:none;font-size:.66rem;padding:.2rem .5rem;border-radius:999px;border:1px solid}
.dlist__empty{color:var(--muted);font-size:.82rem;line-height:1.5;padding:.4rem .2rem;list-style:none}
.tag--msg{color:var(--amber);border-color:rgba(255,180,71,.4)}
.tag--call{color:#ff9a5a;border-color:rgba(255,154,90,.4)}
.dash__demo{margin-top:1.5rem;font-size:.76rem;color:rgba(255,180,71,.6);text-align:center}
@media(prefers-reduced-motion:reduce){.chart__bar,.dash__period button,.dash__navlink{transition:none}}

/* =====================================================================
   CENTRE DE PILOTAGE (admin) — boot "Jarvis" + HUD
   ===================================================================== */
.pilot-body{min-height:100vh;background:#040506;color:var(--ink);position:relative;overflow-x:hidden}

/* --- Boot / réticule --- */
.boot{position:fixed;inset:0;z-index:1000;background:#040506;display:grid;place-items:center;
  transition:opacity .8s var(--ease),transform .8s var(--ease)}
.boot.done{opacity:0;transform:scale(1.06);pointer-events:none}
.boot__inner{display:flex;flex-direction:column;align-items:center;gap:1rem;width:min(92vw,520px);text-align:center}
.boot__brand{font-family:var(--display);font-weight:600;font-size:1.6rem;letter-spacing:.15em;color:#fff;margin-top:.5rem;
  opacity:0;animation:rfade .6s ease 1.1s forwards}
.boot__brand span{color:var(--amber)}
.boot__log{font-family:ui-monospace,monospace;font-size:.78rem;line-height:1.7;color:rgba(255,180,71,.85);
  min-height:9.5em;width:100%;max-width:30rem;text-align:left}
.bln{opacity:0;animation:rfade .25s ease forwards}
.boot__bar{width:min(80vw,18rem);height:3px;border-radius:999px;background:rgba(255,180,71,.15);overflow:hidden;
  opacity:0;animation:rfade .5s ease 1.2s forwards}
.boot__bar span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--orange),var(--amber));transition:width .4s var(--ease)}

.reticle{width:min(420px,72vw);height:auto;color:var(--amber);filter:drop-shadow(0 0 7px rgba(255,180,71,.55))}
.reticle line,.reticle .rin,.reticle .rcenter path{stroke:currentColor;stroke-width:.6;fill:none}
.reticle .rdots circle{fill:currentColor}
.reticle .router{fill:currentColor;opacity:.45;stroke:none;transform-box:fill-box;transform-origin:center;animation:routerIn 1s var(--ease) forwards}
.rline{stroke-dasharray:170;stroke-dashoffset:170;animation:rdraw .85s var(--ease) .3s forwards}
.rin{stroke-dasharray:540;stroke-dashoffset:540;transform-box:fill-box;transform-origin:center}
.rin1{animation:rdraw 1.2s var(--ease) .3s forwards, rspin 22s linear 1.6s infinite}
.rin2{animation:rdraw 1.2s var(--ease) .35s forwards, rspinR 18s linear 1.6s infinite}
.rcenter path{stroke-dasharray:130;stroke-dashoffset:130;animation:rdraw .7s var(--ease) 1.15s forwards}
.rdots{opacity:0;animation:rfade .6s ease 1.2s forwards}
@keyframes rdraw{to{stroke-dashoffset:0}}
@keyframes rfade{to{opacity:1}}
@keyframes routerIn{from{opacity:0;transform:rotate(90deg)}to{opacity:.45;transform:rotate(0)}}
@keyframes rspin{to{transform:rotate(360deg)}}
@keyframes rspinR{to{transform:rotate(-360deg)}}

/* --- Cadre HUD --- */
.hud{position:fixed;inset:12px;z-index:60;pointer-events:none;border:1px solid rgba(255,180,71,.14);border-radius:14px;
  box-shadow:inset 0 0 60px -20px rgba(255,122,47,.25)}
.hud__c{position:absolute;width:26px;height:26px}
.hud__c--tl{top:-1px;left:-1px;border-top:2px solid var(--amber);border-left:2px solid var(--amber);border-top-left-radius:14px}
.hud__c--tr{top:-1px;right:-1px;border-top:2px solid var(--amber);border-right:2px solid var(--amber);border-top-right-radius:14px}
.hud__c--bl{bottom:-1px;left:-1px;border-bottom:2px solid var(--amber);border-left:2px solid var(--amber);border-bottom-left-radius:14px}
.hud__c--br{bottom:-1px;right:-1px;border-bottom:2px solid var(--amber);border-right:2px solid var(--amber);border-bottom-right-radius:14px}
.hud__notch{position:absolute;top:-1px;left:50%;transform:translateX(-50%);background:#040506;
  border:1px solid rgba(255,180,71,.2);border-top:0;border-radius:0 0 10px 10px;padding:.35rem 1.4rem;
  font-family:ui-monospace,monospace;font-size:.62rem;letter-spacing:.25em;color:var(--amber)}

/* --- Coquille dashboard --- */
.pilot{position:relative;z-index:1;max-width:72rem;margin:0 auto;padding:clamp(2.5rem,6vw,4rem) clamp(1.4rem,4vw,3rem)}
.pilot__top{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap;margin-bottom:2.5rem}
.pilot__title{font-family:var(--display);font-weight:600;font-size:clamp(2rem,5vw,3rem);color:#fff;letter-spacing:-.01em}
.pilot__sub{color:var(--muted);margin-top:.4rem;font-family:ui-monospace,monospace;font-size:.8rem;letter-spacing:.05em}
.pilot__status{display:inline-flex;align-items:center;gap:.5rem;font-size:.78rem;color:var(--amber);
  border:1px solid rgba(255,180,71,.25);border-radius:999px;padding:.45rem .9rem}
.pilot__status .dot{width:7px;height:7px;border-radius:50%;background:#5ad17a;box-shadow:0 0 8px #5ad17a;animation:pulseDot 1.8s ease-in-out infinite}
@keyframes pulseDot{50%{opacity:.4}}
.pilot__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
@media(max-width:820px){.pilot__grid{grid-template-columns:1fr}}
.pmod{position:relative;background:rgba(255,255,255,.03);border:1px solid rgba(255,180,71,.16);border-radius:1rem;
  padding:1.6rem;min-height:11rem;transition:border-color .4s,transform .4s var(--ease),box-shadow .4s}
.pmod:hover{border-color:rgba(255,180,71,.4);transform:translateY(-4px);box-shadow:0 24px 50px -34px rgba(255,122,47,.5)}
.pmod__k{font-family:ui-monospace,monospace;font-size:.7rem;color:var(--amber);opacity:.6}
.pmod h2{font-family:var(--display);font-weight:600;font-size:1.25rem;color:#fff;margin:.3rem 0 .5rem}
.pmod p{color:var(--muted);font-size:.9rem;line-height:1.5}
.pmod__soon{position:absolute;top:1.2rem;right:1.2rem;font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--amber);border:1px dashed rgba(255,180,71,.4);border-radius:999px;padding:.2rem .55rem}
.pilot__note{margin-top:2rem;text-align:center;font-size:.78rem;color:rgba(255,180,71,.6)}

@media(prefers-reduced-motion:reduce){
  .reticle *{animation:none!important}
  .reticle .rline,.reticle .rin,.reticle .rcenter path{stroke-dashoffset:0}
  .reticle .router{opacity:.45;transform:none}
  .reticle .rdots,.boot__brand,.boot__bar{opacity:1;animation:none}
  .boot{transition:none}
  .pilot__status .dot{animation:none}
}

/* =====================================================================
   DASHBOARD COLD CALLER
   ===================================================================== */
.pmod--live{display:block;text-decoration:none;cursor:pointer}
.pmod__open{position:absolute;top:1.2rem;right:1.2rem;font-size:.66rem;letter-spacing:.06em;text-transform:uppercase;
  color:#0a0a0a;background:linear-gradient(135deg,var(--orange),var(--amber));border-radius:999px;padding:.25rem .7rem;font-weight:600}

.cc-streak{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--amber);
  border:1px solid rgba(255,180,71,.25);border-radius:999px;padding:.45rem .9rem}
.cc-streak strong{color:#fff}

[data-stat].pulse{animation:ccpulse .5s var(--ease)}
@keyframes ccpulse{0%{transform:scale(1)}40%{transform:scale(1.14);color:var(--amber)}100%{transform:scale(1)}}

.cc-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:1.2rem;align-items:start}
@media(max-width:980px){.cc-grid{grid-template-columns:1fr}}
.cc-side{display:flex;flex-direction:column;gap:1.2rem}

/* File d'appels */
.ccqueue{list-style:none;display:flex;flex-direction:column}
.ccrow{display:flex;align-items:center;gap:.85rem;padding:.8rem .2rem;border-bottom:1px solid rgba(255,255,255,.06);
  transition:opacity .3s,transform .3s var(--ease)}
.ccrow.done{opacity:0;transform:translateX(20px)}
.ccrow__av{flex:none;width:2.3rem;height:2.3rem;border-radius:.6rem;display:grid;place-items:center;font-weight:700;font-size:.9rem;
  color:#0a0a0a;background:linear-gradient(135deg,var(--orange),var(--amber))}
.ccrow__id{flex:1;min-width:0}
.ccrow__name{color:#fff;font-size:.92rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ccrow__meta{color:var(--muted);font-size:.76rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ccrow__call{flex:none;width:2.2rem;height:2.2rem;border-radius:50%;display:grid;place-items:center;color:#5ad17a;
  border:1px solid rgba(90,209,122,.35);transition:background .25s,transform .25s}
.ccrow__call .osvg{width:15px;height:15px}
.ccrow__call:hover{background:rgba(90,209,122,.14);transform:scale(1.06)}
.ccrow__act{flex:none;display:flex;gap:.3rem}
.ccrow__act button{width:2rem;height:2rem;border-radius:.5rem;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.03);
  color:var(--muted);cursor:pointer;font-size:.9rem;line-height:1;transition:all .2s}
.ccrow__act button:hover{transform:translateY(-1px)}
.out--rdv:hover{background:rgba(90,209,122,.18);border-color:#5ad17a;color:#5ad17a}
.out--rappel:hover{background:rgba(255,180,71,.18);border-color:var(--amber);color:var(--amber)}
.out--refus:hover{background:rgba(232,120,120,.18);border-color:#e88;color:#e88}
.out--absent:hover{background:rgba(255,255,255,.08);border-color:#aaa;color:#ddd}
.ccqueue__empty{padding:2.5rem 1rem;text-align:center;color:var(--amber);font-family:var(--display);font-size:1.1rem}

/* Anneau objectif */
.cc-obj{text-align:center}
.cc-ring{position:relative;width:160px;height:160px;margin:.5rem auto .2rem;border-radius:50%;
  background:conic-gradient(var(--amber) calc(var(--p,0)*1%), rgba(255,255,255,.08) 0);transition:background .6s var(--ease)}
.cc-ring__hole{position:absolute;inset:13px;border-radius:50%;background:#0b0a08;display:grid;place-items:center}
.cc-ring__num{font-family:var(--display);font-weight:600;color:#fff;font-size:2rem;line-height:1}
.cc-ring__num small{display:block;font-size:.62rem;color:var(--muted);font-weight:400;letter-spacing:.05em;margin-top:.2rem}
.cc-obj__txt{color:var(--muted);font-size:.85rem;margin-top:.6rem}

/* Mini semaine */
.chart__bar.is-today{background:linear-gradient(180deg,#fff,var(--amber))}
.cc-week{display:flex;gap:3px;margin-top:.5rem}
.cc-week span{flex:1;text-align:center;font-size:.66rem;color:var(--muted)}

/* Toast */
.cc-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);z-index:80;
  background:rgba(20,16,12,.95);border:1px solid rgba(255,180,71,.3);border-radius:.7rem;padding:.7rem 1.1rem;
  color:#fff;font-size:.86rem;opacity:0;pointer-events:none;transition:opacity .3s,transform .3s var(--ease);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}
.cc-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.cc-toast.is-gold{border-color:var(--amber);box-shadow:0 0 30px -8px rgba(255,180,71,.6)}

@media(prefers-reduced-motion:reduce){.ccrow,.cc-ring,.cc-toast,.ccrow__call,.ccrow__act button{transition:none}}

/* ---- Placeholder section ---- */
.placeholder{min-height:40vh;display:grid;place-items:center;background:#05060A;color:var(--muted);
  font-family:var(--display);font-size:clamp(1rem,3vw,1.6rem);text-align:center;padding:3rem 1.25rem}

/* ---- Responsive ---- */
@media (max-width:640px){
  .hero__overlay{padding:5rem 1.1rem}
  .cta{flex-direction:column;width:100%;max-width:340px}
  .btn{width:100%}
  .badge{font-size:.74rem}
}

/* ---- Accessibilité : pas d'animation si l'utilisateur le demande ---- */
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;animation:none}
  .grad{animation:none}
  .hero__scroll-line{animation:none}
}

/* =====================================================================
   VUES (onglets) + IMPORT CSV + TABLES LEADS / RDV
   ===================================================================== */
.dview{display:none;animation:dviewIn .35s var(--ease)}
.dview.is-active{display:block}
@keyframes dviewIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* Zone d'import CSV */
.lead-import{border:1.5px dashed rgba(255,180,71,.35);border-radius:1rem;padding:2.2rem 1.4rem;text-align:center;
  background:rgba(255,180,71,.03);transition:border-color .25s,background .25s,transform .25s var(--ease);cursor:pointer}
.lead-import:hover{border-color:rgba(255,180,71,.6);background:rgba(255,180,71,.06)}
.lead-import.is-drag{border-color:var(--amber);background:rgba(255,180,71,.1);transform:scale(1.01)}
.lead-import__ic{width:34px;height:34px;color:var(--amber);margin-bottom:.6rem}
.lead-import p{color:#fff;font-size:.95rem}
.lead-import small{display:block;margin-top:.5rem;color:var(--muted);font-size:.78rem}
.lead-import small b{color:rgba(255,180,71,.85);font-weight:500}
.lead-import a{color:var(--amber);text-decoration:underline;text-underline-offset:2px}
.lead-browse{background:none;border:0;color:var(--amber);font:inherit;cursor:pointer;text-decoration:underline;text-underline-offset:2px;padding:0}

/* Barre d'outils leads */
.lead-bar{display:flex;justify-content:space-between;align-items:center;margin:1.3rem 0 .6rem}
.lead-count{font-size:.85rem;color:var(--muted)}
.lead-clear{background:none;border:1px solid rgba(255,90,90,.3);color:#ff7a7a;border-radius:.5rem;
  padding:.4rem .8rem;font:inherit;font-size:.8rem;cursor:pointer;transition:background .25s}
.lead-clear:hover{background:rgba(255,90,90,.1)}

/* Tables leads / RDV */
.ltable-wrap{position:relative;border:1px solid rgba(255,255,255,.07);border-radius:1rem;overflow-x:auto;overflow-y:hidden}
.ltable{width:100%;border-collapse:collapse;font-size:.88rem}
.ltable th{text-align:left;padding:.85rem 1rem;color:var(--muted);font-weight:500;font-size:.74rem;white-space:nowrap;
  text-transform:uppercase;letter-spacing:.05em;background:rgba(255,255,255,.02);border-bottom:1px solid rgba(255,255,255,.07)}
.ltable td{padding:.8rem 1rem;color:#e7e7ea;border-bottom:1px solid rgba(255,255,255,.05);vertical-align:middle;
  max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ltable tbody tr:last-child td{border-bottom:0}
.ltable tbody tr:hover{background:rgba(255,255,255,.02)}
.ltable td a{color:#9fe3b0;text-decoration:none}
.ltable td a:hover{text-decoration:underline}
.lead-empty{padding:2.5rem 1rem;text-align:center;color:var(--muted);font-size:.9rem}

/* Badges statut */
.st{display:inline-block;font-size:.72rem;padding:.25rem .6rem;border-radius:999px;border:1px solid transparent;white-space:nowrap}
.st--todo{color:var(--muted);border-color:rgba(255,255,255,.15)}
.st--rdv{color:#5ad17a;border-color:rgba(90,209,122,.4);background:rgba(90,209,122,.1)}
.st--rappel{color:var(--amber);border-color:rgba(255,180,71,.4);background:rgba(255,180,71,.08)}
.st--refus{color:#ff7a7a;border-color:rgba(255,90,90,.35);background:rgba(255,90,90,.08)}
.st--absent{color:var(--muted);border-color:rgba(255,255,255,.12);background:rgba(255,255,255,.03)}

/* Bouton appeler désactivé (lead sans numéro) */
.ccrow__call.is-off{color:var(--muted);border-color:rgba(255,255,255,.12);cursor:not-allowed;opacity:.5}
/* Bouton email (lead sans téléphone mais avec email) */
.ccrow__call--mail{color:var(--amber);border-color:rgba(255,180,71,.4)}
.ccrow__call--mail:hover{background:rgba(255,180,71,.14)}

/* Placeholder "À venir" */
.dsoon{border:1px solid rgba(255,180,71,.16);border-radius:1rem;background:rgba(255,255,255,.02);
  padding:clamp(2rem,5vw,3.5rem);text-align:center;max-width:34rem;margin:1rem auto}
.dsoon__badge{display:inline-block;font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--amber);
  border:1px dashed rgba(255,180,71,.4);border-radius:999px;padding:.25rem .7rem;margin-bottom:1rem}
.dsoon h2{font-family:var(--display);font-weight:600;font-size:1.5rem;color:#fff;margin-bottom:.6rem}
.dsoon p{color:var(--muted);line-height:1.6;font-size:.92rem}

@media(prefers-reduced-motion:reduce){.dview{animation:none}}

/* =====================================================================
   MOBILE : dock actif · timeline orbitale · dashboard cold caller
   ===================================================================== */

/* Dock : lien actif "encadré" en orange (le CTA Contact garde son fond plein) */
.dock__link.is-active:not(.dock__link--cta){color:var(--amber);background:rgba(255,180,71,.1);
  box-shadow:inset 0 0 0 1px var(--amber),0 0 18px -7px rgba(255,180,71,.65)}

/* Timeline orbitale : scroll plus propre sur mobile */
@media (max-width:760px){
  .orbital__stage{height:clamp(360px,60vh,520px)}
  .orbital__frames{display:none}        /* encadrés d'angle masqués (ils se chevauchaient) */
  .oframe--below{margin-top:1rem}
}

/* Dashboard cold caller : lisible et utilisable sur téléphone */
@media (max-width:560px){
  .dash__main{padding:1rem}
  .dash__top{margin-bottom:1.1rem;gap:.6rem}
  .dash__hello{font-size:1.3rem}
  .dash__cards{gap:.6rem}
  .dcard{padding:.9rem}
  .dcard__num{font-size:1.45rem}
  .cc-streak{font-size:.74rem;padding:.35rem .65rem}
  /* barre d'onglets : chips compactes icône au-dessus du label */
  .dash__side{padding:.7rem .5rem;gap:.6rem}
  .dash__nav{gap:.4rem;padding-bottom:.35rem}
  .dash__navlink{flex-direction:column;align-items:center;gap:.25rem;text-align:center;
    font-size:.6rem;line-height:1.1;padding:.45rem .5rem;min-width:62px}
  .dash__navlink .osvg{width:20px;height:20px}
  .dpanel{padding:1rem}
  .lead-import{padding:1.4rem 1rem}
  .lead-import p{font-size:.88rem}
}

/* =====================================================================
   CARTE D'APPEL compacte + note (mobile-first) — remplace l'ancien .ccrow
   ===================================================================== */
.ccqueue{gap:.7rem}
.ccrow{display:flex;flex-direction:column;gap:.55rem;align-items:stretch;padding:.8rem;
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:.8rem}
.ccrow__main{display:flex;align-items:center;justify-content:space-between;gap:.7rem}
.ccrow__id{min-width:0;flex:1}
.ccrow__name{color:#fff;font-weight:600;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ccrow__phone{display:inline-block;margin-top:.1rem;color:var(--amber);font-size:.85rem;text-decoration:none}
.ccrow__phone:hover{text-decoration:underline}
.ccrow__phone--none{color:var(--muted)}
.ccrow__call{flex:none;display:inline-flex;align-items:center;gap:.4rem;width:auto;height:auto;border-radius:.6rem;
  padding:.5rem .85rem;font-size:.82rem;font-weight:600;color:#0a0a0a;border:0;text-decoration:none;white-space:nowrap;
  background:linear-gradient(135deg,var(--orange),var(--amber))}
.ccrow__call .osvg{width:15px;height:15px}
.ccrow__call.is-off{background:rgba(255,255,255,.06);color:var(--muted);pointer-events:none}
.ccrow__call--mail{background:linear-gradient(135deg,var(--amber),var(--gold))}
.ccrow__note{width:100%;height:2.3rem;border-radius:.55rem;border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.03);color:#fff;font:inherit;font-size:.85rem;padding:0 .7rem}
.ccrow__note::placeholder{color:rgba(255,255,255,.35)}
.ccrow__note:focus{outline:none;border-color:var(--amber);background:rgba(255,180,71,.06)}
.ccrow__act{display:grid;grid-template-columns:1fr 1fr;gap:.45rem}
.ccrow__act button{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;width:auto;min-width:0;height:2.5rem;padding:0 .5rem;
  border-radius:.6rem;border:1px solid;background:transparent;font:inherit;font-size:.78rem;font-weight:600;
  cursor:pointer;white-space:nowrap;transition:transform .15s var(--ease),background .2s,border-color .2s,color .2s}
.ccrow__act button .osvg{width:15px;height:15px;flex:none}
.ccrow__act button:hover{transform:translateY(-1px)}
.ccrow__act button:active{transform:translateY(0)}
/* Couleurs par défaut (toujours visibles, lisibles, distinctes) */
.ccrow__act .out--rdv{color:#6ee08c;border-color:rgba(90,209,122,.4);background:rgba(90,209,122,.1)}
.ccrow__act .out--rdv:hover,.ccrow__act .out--rdv:active{background:rgba(90,209,122,.22);border-color:#5ad17a;color:#8af0a3}
.ccrow__act .out--rappel{color:var(--amber);border-color:rgba(255,180,71,.38);background:rgba(255,180,71,.09)}
.ccrow__act .out--rappel:hover,.ccrow__act .out--rappel:active{background:rgba(255,180,71,.22);border-color:var(--amber);color:var(--gold)}
.ccrow__act .out--refus{color:#ff9090;border-color:rgba(255,120,120,.34);background:rgba(255,90,90,.08)}
.ccrow__act .out--refus:hover,.ccrow__act .out--refus:active{background:rgba(255,90,90,.2);border-color:#ff8a8a;color:#ffa6a6}
.ccrow__act .out--absent{color:#b9b9c2;border-color:rgba(255,255,255,.15);background:rgba(255,255,255,.04)}
.ccrow__act .out--absent:hover,.ccrow__act .out--absent:active{background:rgba(255,255,255,.1);border-color:#aaa;color:#e6e6ea}
@media(min-width:620px){.ccrow__act{grid-template-columns:repeat(4,1fr)}.ccrow__act button{font-size:.76rem}}
@media(max-width:380px){.ccrow__act button span{font-size:.72rem}}

/* Statut éditable (menu déroulant) dans « Mes leads » */
.st-edit{font:inherit;font-size:.74rem;font-weight:500;padding:.3rem 1.7rem .3rem .65rem;border-radius:999px;
  border:1px solid rgba(255,255,255,.15);background-color:rgba(255,255,255,.03);color:var(--muted);cursor:pointer;
  -webkit-appearance:none;-moz-appearance:none;appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23ffb447' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat:no-repeat;background-position:right .55rem center;transition:border-color .2s,color .2s,background-color .2s}
.st-edit:hover{border-color:var(--amber)}
.st-edit:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 3px rgba(255,180,71,.15)}
.st-edit option{background:#15110c;color:#fff}
.st-edit--rdv{color:#6ee08c;border-color:rgba(90,209,122,.45);background-color:rgba(90,209,122,.12)}
.st-edit--rappel{color:var(--amber);border-color:rgba(255,180,71,.45);background-color:rgba(255,180,71,.1)}
.st-edit--refus{color:#ff8a8a;border-color:rgba(255,90,90,.4);background-color:rgba(255,90,90,.1)}
.st-edit--absent{color:var(--muted);border-color:rgba(255,255,255,.14);background-color:rgba(255,255,255,.04)}
.st-edit--a_appeler{color:var(--muted);border-color:rgba(255,255,255,.15)}

/* =====================================================================
   MES CLOSERS — agenda partagé verrouillé + RDV
   ===================================================================== */
.cl-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem .9rem;border-radius:.6rem;cursor:pointer;
  border:1px solid rgba(255,180,71,.4);background:rgba(255,180,71,.1);color:var(--amber);font:inherit;font-size:.82rem;
  font-weight:600;transition:background .2s,border-color .2s,transform .15s}
.cl-btn:hover{background:rgba(255,180,71,.2);border-color:var(--amber);transform:translateY(-1px)}
.cl-add{margin:.4rem 0 1rem;padding:1rem;border:1px solid rgba(255,180,71,.18);border-radius:.8rem;background:rgba(255,255,255,.02)}
.cl-add__act{display:flex;gap:.6rem;align-items:center;margin-top:.9rem}
.cl-cancel{background:none;border:0;color:var(--muted);cursor:pointer;font:inherit;font-size:.85rem;text-decoration:underline}
.cl-cancel:hover{color:#fff}

.cl-grid{list-style:none;display:flex;flex-direction:column;gap:.6rem;margin-top:.4rem}
.cl-card{display:flex;align-items:center;gap:.85rem;padding:.8rem;border-radius:.8rem;
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08)}
.cl-card__av{flex:none;width:2.4rem;height:2.4rem;border-radius:.6rem;display:grid;place-items:center;font-weight:700;
  color:#0a0a0a;background:linear-gradient(135deg,var(--orange),var(--amber))}
.cl-card__id{flex:1;min-width:0}
.cl-card__name{color:#fff;font-weight:600;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cl-card__meta{color:var(--muted);font-size:.78rem;margin-top:.1rem}
.cl-card__open{flex:none;padding:.5rem .85rem;border-radius:.6rem;cursor:pointer;font:inherit;font-size:.82rem;font-weight:600;
  color:#0a0a0a;border:0;background:linear-gradient(135deg,var(--orange),var(--amber));transition:transform .15s,filter .2s}
.cl-card__open:hover{transform:translateY(-1px);filter:brightness(1.08)}
.cl-card__del{flex:none;width:1.9rem;height:1.9rem;border-radius:.5rem;cursor:pointer;font-size:.85rem;
  border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.03);color:var(--muted);transition:all .2s}
.cl-card__del:hover{border-color:#ff7a7a;color:#ff7a7a;background:rgba(255,90,90,.1)}

.cl-back{background:none;border:0;color:var(--amber);cursor:pointer;font:inherit;font-size:.9rem;font-weight:600;
  padding:.2rem 0 1rem;display:inline-block}
.cl-back:hover{text-decoration:underline}

/* Écran de déverrouillage */
.cl-lock{text-align:center;max-width:30rem;margin:0 auto}
.cl-lock__ic{font-size:2.4rem;margin-bottom:.3rem}
.cl-lock h2{margin-bottom:.3rem}
.cl-lock h2 span{color:var(--amber)}
.cl-lock p{color:var(--muted);font-size:.9rem;margin-bottom:1.1rem}
.cl-lock__form{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:center}
.cl-lock__form input{flex:1;min-width:12rem;height:2.7rem;border-radius:.6rem;border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.03);color:#fff;font:inherit;padding:0 .9rem}
.cl-lock__form input:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 3px rgba(255,180,71,.15)}
.cl-lock__err{color:#ff7a7a;font-size:.85rem;margin-top:.8rem}

/* Bannière notifications */
.cl-notice{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  padding:.8rem 1rem;border-radius:.7rem;margin-bottom:1.2rem;font-size:.86rem;line-height:1.5;
  border:1px solid rgba(255,180,71,.25);background:rgba(255,180,71,.07);color:rgba(244,241,234,.9)}
.cl-notice strong{color:var(--amber)}
.cl-notice--ok{border-color:rgba(90,209,122,.3);background:rgba(90,209,122,.08)}
.cl-notice--ok strong{color:#6ee08c}
.cl-notice--gcal{border-color:rgba(120,170,255,.3);background:rgba(120,170,255,.08)}
.cl-notice--gcal strong{color:#9cc0ff}

/* Colonne formulaire RDV */
.cl-side{display:flex;flex-direction:column;gap:1.2rem}
.cl-form .set-field{margin-bottom:.8rem}
.cl-form textarea{border-radius:.6rem;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.03);
  color:#fff;font:inherit;font-size:.9rem;padding:.6rem .8rem;resize:vertical;min-height:74px}
.cl-form textarea:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 3px rgba(255,180,71,.12)}
.cl-form input[type=time]{color-scheme:dark;max-width:9rem}

/* Liste des RDV */
.cl-rdvs{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.cl-rdv{padding:.8rem;border-radius:.7rem;border:1px solid rgba(255,255,255,.09);background:rgba(255,255,255,.03)}
.cl-rdv.is-past{opacity:.5}
.cl-rdv__top{display:flex;align-items:baseline;justify-content:space-between;gap:.6rem;flex-wrap:wrap}
.cl-rdv__co{color:#fff;font-weight:600;font-size:.95rem}
.cl-rdv__when{color:var(--amber);font-size:.82rem;font-weight:500;white-space:nowrap}
.cl-rdv__tel{display:inline-block;margin-top:.35rem;color:rgba(244,241,234,.85);font-size:.85rem;text-decoration:none}
.cl-rdv__tel:hover{color:var(--amber)}
.cl-rdv__note{margin-top:.4rem;color:var(--muted);font-size:.85rem;line-height:1.45;white-space:pre-wrap}
.cl-rdv__act{display:flex;align-items:center;gap:.6rem;margin-top:.7rem;flex-wrap:wrap}
.cl-gcal{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .75rem;border-radius:.5rem;font-size:.8rem;
  font-weight:600;text-decoration:none;color:#9cc0ff;border:1px solid rgba(120,170,255,.35);background:rgba(120,170,255,.08);
  transition:background .2s,border-color .2s}
.cl-gcal:hover{background:rgba(120,170,255,.18);border-color:#9cc0ff}
.cl-rdv__edit{background:none;border:0;color:var(--amber);cursor:pointer;font:inherit;font-size:.8rem;text-decoration:underline}
.cl-rdv__edit:hover{color:var(--gold)}
.cl-rdv__del{background:none;border:0;color:var(--muted);cursor:pointer;font:inherit;font-size:.8rem;text-decoration:underline}
.cl-rdv__del:hover{color:#ff7a7a}
.cl-rdv.is-editing{border-color:var(--amber);box-shadow:0 0 0 1px rgba(255,180,71,.3) inset}

/* Accès Google Agenda (identifiants + agenda intégré) */
.cl-btn--sm{padding:.32rem .65rem;font-size:.76rem}
.gcal-panel{margin-bottom:1.2rem}
.gcred{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.06)}
.gcred__lbl{flex:none;width:5.5rem;color:var(--muted);font-size:.8rem}
.gcred__val{flex:1;min-width:8rem;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:.9rem;color:#fff;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:.45rem;padding:.35rem .6rem;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gcal-actions{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.9rem}
/* Demandes d'accès Google (cold caller ↔ closer) */
.ga-actions{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.9rem;align-items:center}
.cl-btn--wa{display:inline-flex;align-items:center;gap:.35rem;text-decoration:none;
  border-color:rgba(37,211,102,.5);color:#bff5d2}
.cl-btn--wa:hover{background:rgba(37,211,102,.14)}
.ga-ok{color:#9be7b4}
.ga-pending{color:var(--amber)}
.ga-denied{color:#ff9a8a}
/* Liste des demandes d'accès (côté closer) */
.acc-reqs{list-style:none;display:flex;flex-direction:column;gap:.6rem;margin:.4rem 0 0}
.acc-req{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap;padding:.7rem .85rem;border-radius:.65rem;
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08)}
.acc-req__id{display:flex;align-items:center;gap:.6rem;flex:1;min-width:11rem}
.acc-req__av{flex:none;width:2.1rem;height:2.1rem;border-radius:50%;display:grid;place-items:center;font-weight:700;
  color:#0a0a0a;background:linear-gradient(135deg,var(--orange),var(--amber))}
.acc-req__name{color:#fff;font-weight:600;font-size:.92rem}
.acc-req__meta{color:var(--muted);font-size:.78rem}
.acc-req__act{display:flex;gap:.45rem;flex-wrap:wrap}
.gcal-embed{margin-top:1rem;border-radius:.7rem;overflow:hidden;border:1px solid rgba(255,255,255,.1);background:#fff}
.gcal-embed iframe{display:block;width:100%}
.gcal-embed .cl-hint{padding:.6rem .8rem;margin:0;background:rgba(20,16,12,.6)}
.gconn{display:flex;align-items:center;justify-content:space-between;gap:.8rem;flex-wrap:wrap;
  padding:.6rem .8rem;border-radius:.6rem;background:rgba(90,209,122,.08);border:1px solid rgba(90,209,122,.3)}
.gconn__ok{font-size:.9rem;color:rgba(244,241,234,.9)}
.gconn__ok strong{color:#6ee08c}
.gevents{margin-top:.7rem;display:flex;flex-direction:column;gap:.4rem}
.gevent{display:flex;gap:.7rem;align-items:baseline;padding:.45rem .6rem;border-radius:.5rem;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07)}
.gevent__t{flex:none;font-size:.78rem;color:var(--amber);white-space:nowrap}
.gevent__s{flex:1;font-size:.88rem;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gcred-edit{margin-top:1rem;padding-top:.8rem;border-top:1px solid rgba(255,255,255,.08)}
.gtuto{margin-top:1rem;border-top:1px solid rgba(255,255,255,.08);padding-top:.6rem}
.gtuto summary{cursor:pointer;color:var(--amber);font-size:.88rem;font-weight:600}
.gtuto__list{margin:.8rem 0 0;padding-left:1.3rem;display:flex;flex-direction:column;gap:.55rem;color:rgba(244,241,234,.85);font-size:.86rem;line-height:1.5}
.gtuto__list code{background:rgba(255,255,255,.08);border-radius:.3rem;padding:.05rem .35rem;font-size:.82rem}

/* Indice + favoris + 1ʳᵉ connexion */
.cl-hint{color:var(--muted);font-size:.82rem;margin:.2rem 0 .9rem;line-height:1.5}
.cl-card{position:relative}
.cl-card.is-fav{border-color:rgba(255,180,71,.35);background:rgba(255,180,71,.05)}
.cl-card__star{flex:none;width:1.9rem;height:1.9rem;border:0;background:none;cursor:pointer;font-size:1.1rem;line-height:1;
  color:rgba(255,255,255,.35);transition:color .2s,transform .15s}
.cl-card__star:hover{transform:scale(1.15);color:var(--amber)}
.cl-card.is-fav .cl-card__star{color:var(--amber)}
.cl-lock__form--col{flex-direction:column;align-items:stretch;max-width:18rem;margin:0 auto}

/* Bouton d'annulation de modif (sous le formulaire RDV) */
.cl-form__act{display:flex;align-items:center;gap:.9rem;flex-wrap:wrap;margin-top:.3rem}

/* Calendrier vanilla (porté de React Aria) */
.cl-cal{border:1px solid rgba(255,255,255,.1);border-radius:.7rem;padding:.6rem;background:rgba(255,255,255,.02);width:100%;max-width:19rem}
.cl-cal__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.4rem}
.cl-cal__title{font-family:var(--display);font-weight:600;color:#fff;font-size:.92rem;text-transform:capitalize}
.cl-cal__nav{width:2rem;height:2rem;border-radius:.5rem;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.03);
  color:#fff;cursor:pointer;font-size:1.1rem;line-height:1;display:grid;place-items:center;transition:all .2s}
.cl-cal__nav:hover{border-color:var(--amber);color:var(--amber);background:rgba(255,180,71,.08)}
.cl-cal__dow{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:.2rem}
.cl-cal__dow span{text-align:center;font-size:.7rem;color:var(--muted);padding:.25rem 0}
.cl-cal__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.cl-cal__day{position:relative;aspect-ratio:1;border:1px solid transparent;border-radius:.5rem;background:none;cursor:pointer;
  color:rgba(244,241,234,.9);font:inherit;font-size:.82rem;display:grid;place-items:center;transition:background .15s,color .15s,border-color .15s}
.cl-cal__day.is-empty{cursor:default}
.cl-cal__day:not(.is-empty):not(.is-past):hover{background:rgba(255,180,71,.12);color:#fff}
.cl-cal__day.is-today::after{content:"";position:absolute;bottom:4px;left:50%;transform:translateX(-50%);width:3px;height:3px;border-radius:50%;background:var(--amber)}
.cl-cal__day.is-sel{background:linear-gradient(135deg,var(--orange),var(--amber));color:#0a0a0a;font-weight:700;border-color:transparent}
.cl-cal__day.is-sel.is-today::after{background:#0a0a0a}
.cl-cal__day.is-past{color:rgba(255,255,255,.22);cursor:not-allowed}

/* Journal d'activité */
.cl-log{margin-top:0}
.cl-logs{list-style:none;display:flex;flex-direction:column;gap:.5rem;max-height:18rem;overflow:auto}
.cl-logitem{display:flex;align-items:baseline;justify-content:space-between;gap:.7rem;padding:.5rem .6rem;border-radius:.55rem;
  background:rgba(255,255,255,.025);border-left:2px solid rgba(255,255,255,.15)}
.cl-logitem--add{border-left-color:#5ad17a}
.cl-logitem--edit{border-left-color:var(--amber)}
.cl-logitem--del{border-left-color:#ff7a7a}
.cl-logitem__txt{font-size:.83rem;color:rgba(244,241,234,.85);line-height:1.4}
.cl-logitem__txt strong{color:#fff;font-weight:600}
.cl-logitem__time{flex:none;font-size:.72rem;color:var(--muted);white-space:nowrap}

/* =====================================================================
   DASHBOARD CLOSER
   ===================================================================== */
/* Switch de rôle (closer ↔ cold caller) */
.role-switch{display:flex;gap:.25rem;padding:.25rem;margin:0 0 1rem;border-radius:.6rem;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08)}
.role-switch__opt{flex:1;text-align:center;padding:.4rem .2rem;border-radius:.45rem;font-size:.8rem;font-weight:600;
  text-decoration:none;color:var(--muted);transition:all .2s}
.role-switch__opt:hover{color:#fff}
.role-switch__opt.is-active{color:#0a0a0a;background:linear-gradient(135deg,var(--orange),var(--amber))}

/* Setter sur une carte RDV */
.cl-rdv__setter{font-size:.78rem;color:var(--muted);margin-top:.25rem}
.cl-rdv__setter strong{color:rgba(244,241,234,.9)}
.cl-rdv.is-handled{opacity:.78}

/* Boutons d'issue (Signé / Replanifié / Perdu) */
.oc-btn{display:inline-flex;align-items:center;justify-content:center;height:2.2rem;padding:0 .85rem;border-radius:.55rem;
  border:1px solid;background:transparent;font:inherit;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .18s}
.oc-btn:hover{transform:translateY(-1px)}
.oc--signe{color:#6ee08c;border-color:rgba(90,209,122,.4);background:rgba(90,209,122,.1)}
.oc--signe:hover{background:rgba(90,209,122,.22);border-color:#5ad17a}
.oc--replan{color:var(--amber);border-color:rgba(255,180,71,.38);background:rgba(255,180,71,.09)}
.oc--replan:hover{background:rgba(255,180,71,.22);border-color:var(--amber)}
.oc--perdu{color:#ff9090;border-color:rgba(255,120,120,.34);background:rgba(255,90,90,.08)}
.oc--perdu:hover{background:rgba(255,90,90,.2);border-color:#ff8a8a}
.oc-badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:999px;font-size:.74rem;font-weight:600;margin-right:auto}
.oc-badge.oc--signe{color:#6ee08c;background:rgba(90,209,122,.14)}
.oc-badge.oc--replan{color:var(--amber);background:rgba(255,180,71,.12)}
.oc-badge.oc--perdu{color:#ff9090;background:rgba(255,90,90,.12)}

/* Clients + médias */
.cli-grid{list-style:none;display:grid;grid-template-columns:1fr;gap:.9rem;margin-top:.4rem}
@media(min-width:760px){.cli-grid{grid-template-columns:1fr 1fr}}
.cli-card{padding:.9rem;border-radius:.8rem;border:1px solid rgba(255,255,255,.09);background:rgba(255,255,255,.03);
  display:flex;flex-direction:column;gap:.6rem}
.cli-card__head{display:flex;align-items:flex-start;justify-content:space-between;gap:.6rem}
.cli-card__name{color:#fff;font-weight:600;font-size:.98rem}
.cli-media-list{display:flex;flex-direction:column;gap:.55rem}
.cli-media{border:1px solid rgba(255,255,255,.08);border-radius:.6rem;padding:.5rem .6rem;background:rgba(0,0,0,.25)}
.cli-media__name{display:flex;align-items:center;gap:.4rem;font-size:.8rem;color:rgba(244,241,234,.85);margin-bottom:.4rem}
.cli-media__del{margin-left:auto;background:none;border:0;color:var(--muted);cursor:pointer;font-size:.8rem;line-height:1}
.cli-media__del:hover{color:#ff7a7a}
.cli-media__a{width:100%;height:34px}
.cli-media__v{width:100%;max-height:220px;border-radius:.4rem;display:block;background:#000}
.cli-media--off .cli-media__off{font-size:.78rem;color:var(--muted);font-style:italic}
.cli-add-media{align-self:flex-start;padding:.4rem .8rem;font-size:.8rem}

/* Classement */
.rank-tabs{display:flex;gap:.3rem;padding:.28rem;margin:0 0 1.1rem;border-radius:.7rem;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08)}
.rank-tab{flex:1;border:0;background:transparent;color:rgba(244,241,234,.7);font:inherit;font-weight:600;
  font-size:.9rem;padding:.55rem .8rem;border-radius:.5rem;cursor:pointer;transition:background .18s,color .18s}
.rank-tab:hover{color:#fff}
.rank-tab.is-active{color:#0a0a0a;background:linear-gradient(135deg,var(--orange),var(--amber))}
.rank-pane{display:none}
.rank-pane.is-active{display:block;animation:rankFade .25s ease}
@keyframes rankFade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.rank-pane.is-active{animation:none}}
.rank-optout{display:inline-flex;align-items:center;gap:.5rem;margin:0 0 1rem;color:rgba(244,241,234,.85);
  font-size:.85rem;cursor:pointer}
.rank-optout input{width:1.05rem;height:1.05rem;accent-color:var(--amber);cursor:pointer}
.rank{list-style:none;counter-reset:none;display:flex;flex-direction:column;gap:.5rem}
.rank__row{display:flex;align-items:center;gap:.85rem;padding:.7rem .85rem;border-radius:.6rem;
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07)}
.rank__row.is-me{border-color:rgba(255,180,71,.45);background:rgba(255,180,71,.07)}
.rank__pos{flex:none;width:1.8rem;height:1.8rem;border-radius:.5rem;display:grid;place-items:center;font-weight:700;
  color:#0a0a0a;background:linear-gradient(135deg,var(--orange),var(--amber));font-size:.85rem}
.rank__row:nth-child(n+4) .rank__pos{color:var(--muted);background:rgba(255,255,255,.06)}
.rank__name{flex:1;color:#fff;font-weight:500;font-size:.92rem}
.rank__name em{color:var(--amber);font-style:normal;font-weight:600}
.rank__masked{font-size:.7rem;color:var(--muted);border:1px solid rgba(255,255,255,.15);border-radius:999px;padding:.1rem .45rem;margin-left:.3rem}
.rank__score{flex:none;color:var(--amber);font-weight:600;font-size:.86rem}

/* Select des paramètres */
.set-select{height:2.6rem;border-radius:.55rem;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.03);
  color:#fff;font:inherit;font-size:.92rem;padding:0 .8rem;color-scheme:dark;cursor:pointer}
.set-select:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 3px rgba(255,180,71,.15)}

/* Soleil central : s'efface quand une planète est ouverte (lecture de la carte) */
.orbital__center{transition:opacity .45s var(--ease)}
.orbital__center.is-dimmed{opacity:.12;animation:none}
.orbital__center.is-dimmed .ring1,.orbital__center.is-dimmed .ring2{opacity:0}

/* =====================================================================
   COLD CALLER : réglage rapide d'objectif + page Paramètres
   ===================================================================== */
/* Stepper objectif (dans le panneau "Objectif du jour") */
.obj-set{display:inline-flex;align-items:center;gap:.3rem}
.obj-step{width:1.8rem;height:1.8rem;border-radius:.5rem;border:1px solid rgba(255,180,71,.3);
  background:rgba(255,180,71,.06);color:var(--amber);font-size:1.1rem;line-height:1;cursor:pointer;
  display:grid;place-items:center;transition:background .2s,transform .1s}
.obj-step:hover{background:rgba(255,180,71,.16)}
.obj-step:active{transform:scale(.92)}
.obj-input{width:2.8rem;height:1.8rem;text-align:center;border-radius:.5rem;border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);color:#fff;font:inherit;font-weight:600;font-size:.9rem;-moz-appearance:textfield}
.obj-input::-webkit-outer-spin-button,.obj-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.obj-input:focus{outline:none;border-color:var(--amber)}

/* Page Paramètres */
.settings{display:flex;flex-direction:column;gap:1.2rem;max-width:46rem}
.set-card{padding:1.4rem}
.set-grid{display:grid;grid-template-columns:1fr 1fr;gap:.9rem;margin:.4rem 0 1.1rem}
.set-field{display:flex;flex-direction:column;gap:.4rem}
.set-field--full{grid-column:1 / -1}
.set-field span{font-size:.78rem;color:var(--muted);font-weight:500}
.set-field input{height:2.7rem;border-radius:.6rem;border:1px solid rgba(255,180,71,.18);background:rgba(255,255,255,.03);
  padding:0 .8rem;color:#fff;font:inherit;font-size:.92rem;transition:border-color .25s,box-shadow .25s,background .25s}
.set-field input::placeholder{color:rgba(255,255,255,.3)}
.set-field input:focus{outline:none;border-color:var(--amber);background:rgba(255,180,71,.05);box-shadow:0 0 0 3px rgba(255,180,71,.14)}
.set-field textarea{border-radius:.6rem;border:1px solid rgba(255,180,71,.18);background:rgba(255,255,255,.03);
  padding:.6rem .8rem;color:#fff;font:inherit;font-size:.92rem;resize:vertical;min-height:3.2rem;line-height:1.5;
  transition:border-color .25s,box-shadow .25s,background .25s}
.set-field textarea::placeholder{color:rgba(255,255,255,.3)}
.set-field textarea:focus{outline:none;border-color:var(--amber);background:rgba(255,180,71,.05);box-shadow:0 0 0 3px rgba(255,180,71,.14)}
.set-field input[type=number]{width:9rem;-moz-appearance:textfield}
.set-field input[type=number]::-webkit-outer-spin-button,.set-field input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.set-save{align-self:flex-start;height:2.7rem;padding:0 1.3rem;border:0;border-radius:.6rem;cursor:pointer;
  font:inherit;font-weight:600;font-size:.88rem;color:#0a0a0a;background:linear-gradient(135deg,var(--orange),var(--amber));
  transition:filter .2s,transform .1s}
.set-save:hover{filter:brightness(1.07)}
.set-save:active{transform:scale(.98)}
@media(max-width:560px){.set-grid{grid-template-columns:1fr}.set-field input[type=number]{width:100%}}

/* Barres du graphe : petit repère même à 0 appel */
.chart.in .chart__bar{min-height:4px}

/* "Se souvenir de moi" (connexion) */
.auth-remember{display:flex;align-items:center;gap:.55rem;cursor:pointer;user-select:none;
  font-size:.85rem;color:var(--muted);margin:-.3rem 0 .2rem}
.auth-remember input{position:absolute;opacity:0;width:0;height:0}
.auth-remember__box{flex:none;width:18px;height:18px;border-radius:5px;border:1.5px solid rgba(255,180,71,.4);
  background:rgba(255,255,255,.03);position:relative;transition:background .2s,border-color .2s}
.auth-remember__box::after{content:"";position:absolute;left:5px;top:1px;width:5px;height:9px;
  border:solid #0a0a0a;border-width:0 2px 2px 0;transform:rotate(45deg) scale(0);transition:transform .2s var(--ease)}
.auth-remember input:checked + .auth-remember__box{background:var(--amber);border-color:var(--amber)}
.auth-remember input:checked + .auth-remember__box::after{transform:rotate(45deg) scale(1)}
.auth-remember input:focus-visible + .auth-remember__box{outline:2px solid var(--amber);outline-offset:2px}

/* ===================================================================
   v finale — Bouton « Lien » (file d'appels + agendas) + onglet Mes setters
   refondu + détail du classement cold caller
   =================================================================== */
/* File d'appels : empile le bouton d'action et le bouton Lien */
.ccrow__cta{display:flex;flex-direction:column;gap:.4rem;flex:none}
.ccrow__link{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.45rem .7rem;border-radius:.6rem;
  font:600 .82rem/1 var(--sans);color:var(--amber);background:rgba(255,180,71,.1);border:1px solid rgba(255,180,71,.32);
  text-decoration:none;transition:background .15s,border-color .15s}
.ccrow__link:hover{background:rgba(255,180,71,.2);border-color:var(--amber)}
.ccrow__link .osvg{width:1rem;height:1rem}

/* Bouton Lien sur les RDV (agenda cold caller = .cl-link, closer = .oc--link) */
.cl-link{color:var(--amber);border-color:rgba(255,180,71,.4);background:rgba(255,180,71,.1)}
.cl-link:hover{background:rgba(255,180,71,.2);border-color:var(--amber)}
.oc--link{color:var(--amber);border-color:rgba(255,180,71,.4);background:rgba(255,180,71,.1);text-decoration:none}
.oc--link:hover{background:rgba(255,180,71,.22);border-color:var(--amber)}

/* Détail du classement (cold callers) : « X appels · Y RDV » */
.rank__detail{flex:none;color:var(--muted);font-size:.78rem;white-space:nowrap}
@media (max-width:520px){.rank__detail{display:none}}

/* ===== Onglet « Mes setters » (cartes par cold caller) ===== */
.setter-cards{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:1.1rem}
.setter-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,180,71,.14);border-radius:1rem;padding:1.2rem}
.setter-card__head{display:flex;align-items:center;gap:.8rem;margin-bottom:1.1rem}
.setter-card__avatar{flex:none;width:2.6rem;height:2.6rem;border-radius:50%;display:grid;place-items:center;
  font-weight:700;color:#0a0a0a;background:linear-gradient(135deg,var(--orange),var(--amber));font-size:1.1rem}
.setter-card__id{flex:1;min-width:0}
.setter-card__name{color:#fff;font-weight:600;font-size:1.02rem;line-height:1.2}
.setter-card__role{color:var(--muted);font-size:.78rem;margin-top:.15rem}
.setter-card__rate{flex:none;text-align:right;line-height:1}
.setter-card__rate span{display:block;color:var(--amber);font-weight:700;font-size:1.25rem}
.setter-card__rate small{color:var(--muted);font-size:.68rem;text-transform:uppercase;letter-spacing:.04em}
.setter-card__sec{margin-top:1rem}
.setter-card__sec h4{margin:0 0 .55rem;font:600 .72rem/1 var(--sans);text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.setter-card__note{margin:0}
.setter-stats{display:grid;gap:.5rem}
.setter-stats--4{grid-template-columns:repeat(4,1fr)}
.setter-stats--3{grid-template-columns:repeat(3,1fr)}
.setter-stat{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:.6rem;
  padding:.55rem .35rem;text-align:center}
.setter-stat__num{display:block;color:#fff;font-weight:700;font-size:1.15rem;line-height:1}
.setter-stat__lbl{display:block;color:var(--muted);font-size:.66rem;margin-top:.25rem;line-height:1.2}
.setter-stat.is-signe{border-color:rgba(90,209,122,.4);background:rgba(90,209,122,.08)}
.setter-stat.is-signe .setter-stat__num{color:#6ee08c}
.setter-stat.is-perdu{border-color:rgba(255,90,90,.32);background:rgba(255,90,90,.07)}
.setter-stat.is-perdu .setter-stat__num{color:#ff8585}
.setter-stat.is-refus{border-color:rgba(232,120,120,.3)}
.setter-stat.is-refus .setter-stat__num{color:#e87878}
.setter-stat.is-absent .setter-stat__num{color:var(--muted)}
.setter-stat.is-rappel{border-color:rgba(255,180,71,.34);background:rgba(255,180,71,.07)}
.setter-stat.is-rappel .setter-stat__num{color:var(--amber)}
@media (max-width:560px){.setter-cards{grid-template-columns:1fr}.setter-stat__lbl{font-size:.6rem}}

/* Bouton « Revenir à mon espace closer » (dashboard cold caller, closers only) */
.role-back{display:flex;align-items:center;gap:.5rem;margin:0 0 1rem;padding:.55rem .75rem;border-radius:.6rem;
  font:600 .82rem/1.1 var(--sans);color:var(--amber);text-decoration:none;
  background:rgba(255,180,71,.08);border:1px solid rgba(255,180,71,.3);transition:background .15s,border-color .15s}
.role-back:hover{background:rgba(255,180,71,.18);border-color:var(--amber)}
.role-back .osvg{width:1.05rem;height:1.05rem;flex:none}

/* ===== Pages légales (mentions / confidentialité) ===== */
.legal-body{background:#0a0a0a;background-image:radial-gradient(70% 50% at 80% 0%,rgba(255,122,47,.12),transparent 60%);
  color:#F4F1EA;font-family:var(--sans,'Segoe UI',sans-serif);min-height:100vh}
.legal{max-width:760px;margin:0 auto;padding:5.5rem 1.5rem 5rem}
.legal__brand{display:inline-block;font-weight:800;font-size:1.25rem;color:#F4F1EA;text-decoration:none;margin-bottom:.4rem}
.legal__brand span{color:#FFB347}
.legal h1{font-size:2rem;font-weight:800;margin:.8rem 0 .3rem;line-height:1.15}
.legal__updated{color:rgba(244,241,234,.5);font-size:.85rem;margin-bottom:2.4rem}
.legal h2{font-size:1.15rem;font-weight:700;color:#FFB347;margin:2.2rem 0 .6rem}
.legal h3{font-size:1rem;font-weight:600;margin:1.4rem 0 .3rem}
.legal p,.legal li{color:rgba(244,241,234,.82);line-height:1.7;font-size:.96rem}
.legal ul{margin:.4rem 0 .4rem 1.1rem;padding:0}
.legal li{margin:.25rem 0}
.legal a{color:#FFD27A}
.legal strong{color:#F4F1EA}
.legal__todo{background:rgba(255,122,47,.12);border:1px dashed rgba(255,180,71,.5);border-radius:.4rem;
  padding:.05rem .4rem;color:#FFD27A;font-size:.9em}
.legal__back{position:fixed;top:1.3rem;left:1.4rem;color:rgba(244,241,234,.8);text-decoration:none;font-size:.9rem;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:.5rem;padding:.45rem .8rem}
.legal__back:hover{color:#fff;border-color:rgba(255,180,71,.5)}
.legal__foot{margin-top:3rem;padding-top:1.4rem;border-top:1px solid rgba(255,255,255,.1);
  display:flex;gap:1.2rem;flex-wrap:wrap;font-size:.88rem}
.legal__foot a{color:rgba(244,241,234,.7);text-decoration:none}
.legal__foot a:hover{color:#FFB347}

/* ===== Bandeau cookies ===== */
.cookiebar{position:fixed;left:50%;bottom:1rem;transform:translate(-50%,140%);z-index:9999;
  width:min(680px,calc(100vw - 1.6rem));display:flex;align-items:center;gap:1rem;flex-wrap:wrap;justify-content:space-between;
  padding:.85rem 1.1rem;border-radius:.9rem;background:rgba(18,16,14,.92);backdrop-filter:blur(10px);
  border:1px solid rgba(255,180,71,.25);box-shadow:0 18px 50px rgba(0,0,0,.5);opacity:0;transition:transform .32s var(--ease,cubic-bezier(.2,.8,.2,1)),opacity .32s}
.cookiebar.is-in{transform:translate(-50%,0);opacity:1}
.cookiebar.is-out{transform:translate(-50%,140%);opacity:0}
.cookiebar__txt{margin:0;flex:1;min-width:240px;font-size:.85rem;line-height:1.5;color:rgba(244,241,234,.82)}
.cookiebar__txt a{color:#FFD27A}
.cookiebar__btn{flex:none;padding:.55rem 1.1rem;border:0;border-radius:.6rem;font:600 .85rem/1 var(--sans,sans-serif);
  cursor:pointer;color:#0a0a0a;background:linear-gradient(135deg,var(--orange,#FF7A2F),var(--amber,#FFB347))}
.cookiebar__btn:hover{filter:brightness(1.08)}
@media (max-width:520px){.cookiebar{flex-direction:column;align-items:stretch;text-align:center}.cookiebar__btn{width:100%}}

/* Liens légaux du footer */
.foot__legal a{color:rgba(244,241,234,.6);text-decoration:none}
.foot__legal a:hover{color:#FFB347}
/* Honeypot anti-spam (Netlify Forms) — masqué */
.hp-field{position:absolute;left:-9999px;height:0;overflow:hidden}

/* ===== Fiche profil (modale) — classements / setters ===== */
.wp-lock{overflow:hidden}
.wp-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:1.2rem;
  background:rgba(6,6,8,.72);backdrop-filter:blur(6px);opacity:0;pointer-events:none;transition:opacity .25s}
.wp-overlay.show{opacity:1;pointer-events:auto}
.wp-card{position:relative;width:100%;max-width:420px;background:linear-gradient(180deg,#16110a,#0c0b0d);
  border:1px solid rgba(255,180,71,.28);border-radius:1.1rem;padding:1.6rem;color:#f4f1ea;
  box-shadow:0 40px 90px -40px rgba(0,0,0,.8);transform:translateY(14px) scale(.97);transition:transform .3s cubic-bezier(.22,1,.36,1)}
.wp-overlay.show .wp-card{transform:none}
.wp-close{position:absolute;top:.7rem;right:.9rem;background:none;border:0;color:rgba(244,241,234,.5);font-size:1.7rem;line-height:1;cursor:pointer;transition:color .2s}
.wp-close:hover{color:#fff}
.wp-head{display:flex;align-items:center;gap:1rem}
.wp-avatar{flex:none;width:4rem;height:4rem;border-radius:50%;display:grid;place-items:center;font-family:var(--display);
  font-weight:600;font-size:1.5rem;color:#1a1206;background:linear-gradient(135deg,#ffd27a,#ff7a2f);background-size:cover;background-position:center}
.wp-avatar.has-img{color:transparent}
.wp-name{font-family:var(--display);font-weight:600;font-size:1.3rem;color:#fff}
.wp-role{font-size:.82rem;color:var(--amber);margin-top:.15rem}
.wp-bio{margin-top:1rem;font-size:.9rem;line-height:1.55;color:rgba(244,241,234,.72)}
.wp-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:.7rem;margin-top:1.2rem}
.wp-stat{background:rgba(255,255,255,.04);border:1px solid rgba(255,180,71,.14);border-radius:.8rem;padding:.8rem;text-align:center}
.wp-stat--accent{border-color:rgba(255,180,71,.4);background:rgba(255,180,71,.08)}
.wp-stat__n{font-family:var(--display);font-weight:600;font-size:1.6rem;color:#fff;line-height:1}
.wp-stat--accent .wp-stat__n{color:var(--amber)}
.wp-stat__l{font-size:.72rem;color:rgba(244,241,234,.55);margin-top:.3rem}
.wp-actions{display:flex;gap:.7rem;margin-top:1.4rem}
.wp-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;height:2.8rem;border-radius:.7rem;
  font-weight:600;font-size:.9rem;text-decoration:none;transition:.25s}
.wp-btn--wa{background:#25d366;color:#06301a}
.wp-btn--wa:hover{background:#1eb456;transform:translateY(-2px)}
.wp-btn--mail{background:rgba(255,180,71,.12);color:var(--amber);border:1px solid rgba(255,180,71,.4)}
.wp-btn--mail:hover{background:rgba(255,180,71,.2);transform:translateY(-2px)}
.wp-nocontact{flex:1;font-size:.84rem;color:rgba(244,241,234,.45);text-align:center;margin-top:1.4rem}
.rank__row{cursor:pointer}
.rank__row:hover{background:rgba(255,180,71,.06)}
.setter-card{cursor:pointer;transition:transform .2s,border-color .2s}
.setter-card:hover{transform:translateY(-3px);border-color:rgba(255,180,71,.4)}
@media(prefers-reduced-motion:reduce){.wp-overlay,.wp-card,.wp-btn{transition:none}}
