/* =========================================================================
   SOS DÉBOUCHAGE — DESIGN SYSTEM « ARCHITECTURE DU FUTUR »
   Cyber / HUD nocturne — glassmorphism, néons cyan/magenta, mission-control
   ========================================================================= */

/* ------------------------------ TOKENS ----------------------------------- */
:root{
  /* Couleurs de base imposées */
  --bg:#05060A;
  --surface:#0C0F18;
  --text:#E8ECF6;

  /* Accents néon */
  --cyan:#22D3EE;
  --magenta:#C026D3;

  /* Nuances dérivées */
  --bg-2:#080A12;
  --surface-2:#10141F;
  --surface-3:#161B29;
  --line:rgba(232,236,246,.10);
  --line-strong:rgba(232,236,246,.18);
  --muted:#9AA4BF;
  --muted-2:#6F7A96;
  --cyan-dim:rgba(34,211,238,.14);
  --cyan-soft:rgba(34,211,238,.30);
  --magenta-dim:rgba(192,38,211,.14);
  --magenta-soft:rgba(192,38,211,.34);

  /* Dégradés aurora */
  --grad-aurora:linear-gradient(120deg,var(--cyan),var(--magenta));
  --grad-aurora-soft:linear-gradient(120deg,rgba(34,211,238,.85),rgba(192,38,211,.85));
  --grad-text:linear-gradient(120deg,#67E8F9,#22D3EE 40%,#E879F9 90%);
  --grad-panel:linear-gradient(160deg,rgba(34,211,238,.06),rgba(192,38,211,.05));
  --grad-cta:linear-gradient(120deg,rgba(34,211,238,.16),rgba(192,38,211,.18));

  /* Verre */
  --glass:rgba(12,15,24,.55);
  --glass-2:rgba(18,22,34,.62);
  --glass-border:rgba(232,236,246,.12);
  --glass-blur:18px;

  /* Ombres / glow */
  --shadow:0 18px 50px -22px rgba(0,0,0,.85);
  --shadow-lg:0 40px 90px -32px rgba(0,0,0,.9);
  --glow-cyan:0 0 0 1px rgba(34,211,238,.20), 0 0 34px -6px rgba(34,211,238,.45);
  --glow-magenta:0 0 0 1px rgba(192,38,211,.22), 0 0 36px -6px rgba(192,38,211,.45);
  --glow-mix:0 0 40px -10px rgba(34,211,238,.40), 0 0 40px -10px rgba(192,38,211,.30);

  /* Typo */
  --font-head:"Chakra Petch",system-ui,sans-serif;
  --font-body:"Space Grotesk",system-ui,sans-serif;

  /* Espacement */
  --sp-1:.4rem; --sp-2:.8rem; --sp-3:1.2rem; --sp-4:1.8rem;
  --sp-5:2.6rem; --sp-6:3.6rem; --sp-7:5rem; --sp-8:7rem;

  /* Radius */
  --r-sm:10px; --r-md:16px; --r-lg:22px; --r-xl:30px; --r-pill:999px;

  --container:1200px;
  --header-h:74px;
}

/* ------------------------------ RESET ------------------------------------ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.65;
  font-size:16px;
  overflow-x:hidden;
  min-height:100vh;
  position:relative;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
h1,h2,h3,h4{font-family:var(--font-head);font-weight:700;line-height:1.1;letter-spacing:-.01em}
:focus-visible{outline:2px solid var(--cyan);outline-offset:3px;border-radius:4px}
::selection{background:rgba(34,211,238,.30);color:#fff}

/* ----------------------- FOND ANIMÉ SIGNATURE ---------------------------- */
#bg-canvas{
  position:fixed;inset:0;width:100%;height:100%;
  z-index:-3;display:block;pointer-events:none;
}
.bg-static{
  position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(60vw 50vh at 15% -5%, rgba(34,211,238,.16), transparent 60%),
    radial-gradient(55vw 50vh at 92% 8%, rgba(192,38,211,.16), transparent 60%),
    radial-gradient(70vw 60vh at 50% 115%, rgba(34,211,238,.10), transparent 60%),
    var(--bg);
}
/* fines lignes de scan */
.bg-scan{
  position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  background-image:repeating-linear-gradient(
    to bottom, rgba(232,236,246,.025) 0 1px, transparent 1px 4px);
  mix-blend-mode:overlay;
  animation:scanDrift 12s linear infinite;
}
@keyframes scanDrift{from{background-position:0 0}to{background-position:0 8px}}

/* ------------------------------ LAYOUT ----------------------------------- */
.container{width:min(100% - 2.4rem,var(--container));margin-inline:auto}
.container-wide{width:min(100% - 2rem,1380px);margin-inline:auto}
section{position:relative}
.section{padding-block:var(--sp-8)}
.section-sm{padding-block:var(--sp-6)}
main{position:relative;z-index:1}

/* HUD étiquettes / kicker */
.kicker{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--font-head);font-weight:600;
  font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--cyan);
  padding:.42rem .85rem;border-radius:var(--r-pill);
  background:var(--cyan-dim);border:1px solid var(--cyan-soft);
  box-shadow:inset 0 0 12px -4px rgba(34,211,238,.5);
}
.kicker::before{content:"";width:7px;height:7px;border-radius:50%;
  background:var(--cyan);box-shadow:0 0 10px var(--cyan)}
.kicker.magenta{color:#E879F9;background:var(--magenta-dim);border-color:var(--magenta-soft)}
.kicker.magenta::before{background:#E879F9;box-shadow:0 0 10px #E879F9}

.section-head{max-width:680px;margin-bottom:var(--sp-5)}
.section-head.center{margin-inline:auto;text-align:center}
.section-head h2{
  font-size:clamp(1.9rem,4.4vw,3rem);margin:.9rem 0 .8rem;
}
.section-head p{color:var(--muted);font-size:1.05rem}
.gradient-text{
  background:var(--grad-text);-webkit-background-clip:text;
  background-clip:text;color:transparent;
}

/* HUD label mono */
.hud-label{
  font-family:var(--font-head);font-weight:600;
  font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted-2);display:inline-flex;align-items:center;gap:.45rem;
}
.hud-label::before{content:"//";color:var(--cyan);font-weight:700}

/* ------------------------------ HEADER ----------------------------------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;height:var(--header-h);
  display:flex;align-items:center;
  transition:background .35s ease,box-shadow .35s ease,border-color .35s ease;
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(5,6,10,.72);backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--line);
  box-shadow:0 10px 40px -20px rgba(0,0,0,.9);
}
.header-inner{display:flex;align-items:center;gap:1.4rem;width:100%}
.brand{display:flex;align-items:center;gap:.7rem;font-family:var(--font-head);
  font-weight:700;font-size:1.18rem;letter-spacing:.02em;white-space:nowrap}
.brand .logo-mark{width:38px;height:38px;flex-shrink:0;filter:drop-shadow(0 0 10px rgba(34,211,238,.5))}
.brand b{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}
.brand small{display:block;font-family:var(--font-body);font-weight:500;
  font-size:.6rem;letter-spacing:.24em;color:var(--muted-2);text-transform:uppercase;margin-top:-2px}

.main-nav{margin-left:auto}
.main-nav ul{display:flex;align-items:center;gap:.25rem}
.main-nav a{
  display:block;padding:.5rem .72rem;border-radius:var(--r-sm);
  font-size:.86rem;font-weight:500;color:var(--muted);position:relative;
  transition:color .2s ease,background .2s ease;white-space:nowrap;
}
.main-nav a:hover{color:var(--text);background:rgba(232,236,246,.05)}
.main-nav a.active{color:var(--text)}
.main-nav a.active::after{
  content:"";position:absolute;left:.72rem;right:.72rem;bottom:.28rem;height:2px;
  background:var(--grad-aurora);border-radius:2px;box-shadow:0 0 10px rgba(34,211,238,.7);
}
.header-cta{display:flex;align-items:center;gap:.7rem;flex-shrink:0}

/* burger */
.burger{display:none;width:46px;height:46px;border-radius:var(--r-sm);
  border:1px solid var(--line-strong);background:var(--glass);
  backdrop-filter:blur(10px);flex-direction:column;align-items:center;justify-content:center;gap:5px}
.burger span{width:20px;height:2px;background:var(--text);border-radius:2px;transition:.3s}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile nav panel */
.mobile-nav{
  position:fixed;inset:0;z-index:99;
  background:rgba(5,6,10,.92);backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  padding:calc(var(--header-h) + 1.5rem) 1.4rem 2rem;
  transform:translateY(-100%);opacity:0;visibility:hidden;
  transition:transform .4s cubic-bezier(.22,1,.36,1),opacity .3s,visibility .4s;
  overflow-y:auto;
}
.mobile-nav.open{transform:translateY(0);opacity:1;visibility:visible}
.mobile-nav ul{display:flex;flex-direction:column;gap:.3rem}
.mobile-nav a{
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem 1.1rem;border-radius:var(--r-md);font-family:var(--font-head);
  font-size:1.15rem;font-weight:600;color:var(--text);
  border:1px solid var(--line);background:var(--glass);
}
.mobile-nav a.active{border-color:var(--cyan-soft);box-shadow:var(--glow-cyan);color:var(--cyan)}
.mobile-nav a::after{content:"→";color:var(--cyan);opacity:.6}
.mobile-nav .btn{margin-top:1.2rem;width:100%}

/* ------------------------------ BUTTONS ---------------------------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  white-space:nowrap;font-family:var(--font-head);font-weight:600;
  font-size:.92rem;letter-spacing:.02em;
  padding:.85rem 1.5rem;border-radius:var(--r-pill);
  transition:transform .2s ease,box-shadow .3s ease,background .3s ease,border-color .3s;
  position:relative;cursor:pointer;
}
.btn svg{width:18px;height:18px;flex-shrink:0}
.btn:active{transform:scale(.97)}
.btn-primary{
  color:#04121A;background:var(--grad-aurora);
  box-shadow:var(--glow-mix),0 14px 30px -14px rgba(34,211,238,.7);
}
.btn-primary:hover{transform:translateY(-2px);
  box-shadow:0 0 50px -8px rgba(34,211,238,.6),0 0 50px -8px rgba(192,38,211,.5),0 20px 40px -16px rgba(0,0,0,.8)}
.btn-ghost{
  color:var(--text);border:1px solid var(--line-strong);
  background:var(--glass);backdrop-filter:blur(10px);
}
.btn-ghost:hover{border-color:var(--cyan-soft);box-shadow:var(--glow-cyan);transform:translateY(-2px)}
.btn-call{
  color:#04121A;background:var(--grad-aurora);white-space:nowrap;
  box-shadow:var(--glow-mix);
}
.btn-call:hover{transform:translateY(-2px);box-shadow:0 0 44px -8px rgba(34,211,238,.6)}
.btn-lg{padding:1.05rem 2rem;font-size:1.02rem}
.btn-block{width:100%}

/* ------------------------------ GLASS PANEL ------------------------------ */
.glass{
  background:var(--glass);backdrop-filter:blur(var(--glass-blur));
  -webkit-backdrop-filter:blur(var(--glass-blur));
  border:1px solid var(--glass-border);border-radius:var(--r-lg);
  box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.glass::before{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:linear-gradient(160deg,rgba(255,255,255,.06),transparent 40%);
}
.glass-glow{box-shadow:var(--shadow),var(--glow-mix)}

/* ------------------------------ HERO ------------------------------------- */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;
  padding-top:calc(var(--header-h) + 3rem);padding-bottom:4rem;overflow:hidden;
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.42}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(5,6,10,.4),rgba(5,6,10,.7) 55%,var(--bg)),
    radial-gradient(70vw 60vh at 20% 30%,rgba(34,211,238,.22),transparent 55%),
    radial-gradient(60vw 55vh at 88% 65%,rgba(192,38,211,.22),transparent 55%);
}
.hero-bg::before{
  content:"";position:absolute;inset:0;z-index:1;
  background-image:linear-gradient(rgba(34,211,238,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(34,211,238,.05) 1px,transparent 1px);
  background-size:54px 54px;mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,#000,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,#000,transparent 75%);
}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center;width:100%}
.hero-copy h1{font-size:clamp(2.3rem,6vw,4.2rem);margin:1.2rem 0 1.2rem}
.hero-copy h1 em{font-style:normal;background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-sub{font-size:1.12rem;color:var(--muted);max-width:36rem;margin-bottom:1.8rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-bottom:1.8rem}
.hero-badges{display:flex;flex-wrap:wrap;gap:.7rem}
.hero-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.78rem;font-weight:500;color:var(--text);
  padding:.5rem .9rem;border-radius:var(--r-pill);
  background:var(--glass);border:1px solid var(--line-strong);
  backdrop-filter:blur(8px);white-space:nowrap;
}
.hero-badge svg{width:15px;height:15px;color:var(--cyan)}

/* hero side HUD card */
.hero-hud{padding:1.7rem;display:flex;flex-direction:column;gap:1.1rem}
.hero-hud .hud-row{display:flex;justify-content:space-between;align-items:center;
  padding-bottom:1rem;border-bottom:1px dashed var(--line)}
.hero-hud .hud-row:last-child{border:none;padding-bottom:0}
.hero-hud .hud-k{font-family:var(--font-head);font-size:.7rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--muted-2)}
.hero-hud .hud-v{font-family:var(--font-head);font-weight:700;font-size:1.35rem;color:var(--text)}
.hero-hud .hud-v.cy{color:var(--cyan)}
.hero-hud .hud-v.mg{color:#E879F9}
.hero-hud .live{display:inline-flex;align-items:center;gap:.4rem;font-size:.72rem;color:var(--cyan);
  font-family:var(--font-head);letter-spacing:.14em;text-transform:uppercase}
.hero-hud .live .dot{width:8px;height:8px;border-radius:50%;background:var(--cyan);
  box-shadow:0 0 10px var(--cyan);animation:pulse 1.6s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}

/* scroll cue */
.scroll-cue{position:absolute;bottom:1.4rem;left:50%;transform:translateX(-50%);z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:.4rem;
  font-family:var(--font-head);font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted-2)}
.scroll-cue .bar{width:1px;height:34px;background:linear-gradient(var(--cyan),transparent);
  animation:cue 2s ease-in-out infinite}
@keyframes cue{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* ------------------------- REASSURANCE STRIP ----------------------------- */
.reassure{
  border-block:1px solid var(--line);background:var(--bg-2);
  padding-block:1.3rem;
}
.reassure-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;align-items:center}
.reassure-item{display:flex;align-items:center;gap:.75rem;font-size:.92rem;font-weight:500}
.reassure-item svg{width:24px;height:24px;color:var(--cyan);flex-shrink:0;
  filter:drop-shadow(0 0 8px rgba(34,211,238,.5))}
.reassure-item b{display:block;font-family:var(--font-head);font-size:1rem;color:var(--text)}
.reassure-item span{color:var(--muted);font-size:.78rem}

/* ------------------------------ GRIDS ------------------------------------ */
.grid{display:grid;gap:1.4rem}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}

/* SERVICE CARD */
.card{
  background:var(--grad-panel),var(--glass);
  backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));
  border:1px solid var(--glass-border);border-radius:var(--r-lg);
  padding:1.8rem;position:relative;overflow:hidden;
  transition:border-color .3s ease,box-shadow .3s ease,transform .3s ease;
  transform-style:preserve-3d;
}
.card::after{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;opacity:0;
  transition:opacity .35s ease;
  background:radial-gradient(420px circle at var(--mx,50%) var(--my,0%),rgba(34,211,238,.16),transparent 45%);
}
.card:hover{border-color:var(--cyan-soft);box-shadow:var(--shadow),var(--glow-cyan)}
.card:hover::after{opacity:1}
.card .card-num{position:absolute;top:1.2rem;right:1.4rem;font-family:var(--font-head);
  font-weight:700;font-size:1rem;color:var(--muted-2);letter-spacing:.1em}
.card-icon{
  width:54px;height:54px;border-radius:var(--r-md);display:grid;place-items:center;margin-bottom:1.2rem;
  background:var(--cyan-dim);border:1px solid var(--cyan-soft);box-shadow:inset 0 0 20px -8px rgba(34,211,238,.7);
}
.card-icon svg{width:26px;height:26px;color:var(--cyan)}
.card.mg .card-icon{background:var(--magenta-dim);border-color:var(--magenta-soft);box-shadow:inset 0 0 20px -8px rgba(192,38,211,.7)}
.card.mg .card-icon svg{color:#E879F9}
.card.mg:hover{border-color:var(--magenta-soft);box-shadow:var(--shadow),var(--glow-magenta)}
.card h3{font-size:1.28rem;margin-bottom:.6rem}
.card p{color:var(--muted);font-size:.95rem;margin-bottom:1rem}
.card .card-link{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--font-head);
  font-weight:600;font-size:.85rem;color:var(--cyan);letter-spacing:.04em}
.card .card-link svg{width:16px;height:16px;transition:transform .25s}
.card:hover .card-link svg{transform:translateX(4px)}

/* FEATURE CARD (engagements) */
.feature{padding:1.6rem;display:flex;gap:1rem;align-items:flex-start}
.feature .f-ic{width:46px;height:46px;border-radius:var(--r-md);display:grid;place-items:center;flex-shrink:0;
  background:var(--magenta-dim);border:1px solid var(--magenta-soft)}
.feature .f-ic svg{width:22px;height:22px;color:#E879F9}
.feature h4{font-size:1.1rem;margin-bottom:.35rem}
.feature p{color:var(--muted);font-size:.9rem}

/* ----------------------- SPLIT IMAGE BLOCKS ------------------------------ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.split.rev .split-media{order:2}
.split-media{position:relative;border-radius:var(--r-xl);overflow:hidden;
  border:1px solid var(--glass-border);box-shadow:var(--shadow-lg),var(--glow-mix)}
.split-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:3/2;transition:transform .8s ease}
.split-media:hover img{transform:scale(1.05)}
.split-media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(140deg,transparent 40%,rgba(34,211,238,.12),rgba(192,38,211,.14))}
.split-media .media-tag{position:absolute;left:1rem;bottom:1rem;z-index:2;
  font-family:var(--font-head);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--text);padding:.45rem .8rem;border-radius:var(--r-pill);
  background:rgba(5,6,10,.6);backdrop-filter:blur(8px);border:1px solid var(--line-strong)}
.split-list{display:flex;flex-direction:column;gap:.9rem;margin-top:1.4rem}
.split-list li{display:flex;gap:.7rem;align-items:flex-start;color:var(--muted);font-size:.96rem}
.split-list li svg{width:20px;height:20px;color:var(--cyan);flex-shrink:0;margin-top:2px}
.split-list li b{color:var(--text)}

.detail-media img{aspect-ratio:3/4}

/* ----------------------------- PROCESS ----------------------------------- */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;counter-reset:step}
.step{padding:1.7rem;position:relative;counter-increment:step}
.step::before{
  content:"0" counter(step);position:absolute;top:1.2rem;right:1.4rem;
  font-family:var(--font-head);font-weight:700;font-size:2.4rem;
  background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent;opacity:.55;
}
.step .step-ic{width:46px;height:46px;border-radius:var(--r-md);display:grid;place-items:center;margin-bottom:1rem;
  background:var(--cyan-dim);border:1px solid var(--cyan-soft)}
.step .step-ic svg{width:22px;height:22px;color:var(--cyan)}
.step h4{font-size:1.12rem;margin-bottom:.4rem}
.step p{color:var(--muted);font-size:.9rem}

/* ----------------------------- STATS ------------------------------------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.stat{padding:1.8rem;text-align:center}
.stat .num{font-family:var(--font-head);font-weight:700;
  font-size:clamp(2.4rem,5vw,3.4rem);line-height:1;
  background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 0 40px rgba(34,211,238,.3)}
.stat .num .suffix{font-size:.55em}
.stat .lbl{margin-top:.6rem;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}

/* --------------------------- BANDE TECH (parallax) ----------------------- */
.tech-band{position:relative;overflow:hidden;border-block:1px solid var(--line)}
.tech-band-bg{position:absolute;inset:-15% 0;z-index:0}
.tech-band-bg img{width:100%;height:130%;object-fit:cover;opacity:.3}
.tech-band-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,var(--bg),rgba(5,6,10,.6) 50%,var(--bg)),
    radial-gradient(50vw 50vh at 30% 50%,rgba(192,38,211,.2),transparent 60%)}
.tech-band-inner{position:relative;z-index:1;text-align:center;max-width:760px;margin-inline:auto}
.tech-band-inner h2{font-size:clamp(1.8rem,4.4vw,2.9rem);margin:1rem 0}
.tech-band-inner p{color:var(--muted);font-size:1.08rem}

/* ----------------------------- ZONES ------------------------------------- */
.zones-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem}
.zone-chip{
  display:flex;align-items:center;gap:.5rem;
  padding:.8rem 1rem;border-radius:var(--r-md);font-size:.9rem;font-weight:500;
  background:var(--glass);border:1px solid var(--line);
  transition:border-color .25s,box-shadow .25s,transform .25s;
}
.zone-chip:hover{border-color:var(--cyan-soft);box-shadow:var(--glow-cyan);transform:translateY(-2px)}
.zone-chip svg{width:16px;height:16px;color:var(--cyan);flex-shrink:0}

/* ----------------------------- TARIFS ------------------------------------ */
.price-table-wrap{overflow:hidden;border-radius:var(--r-lg);border:1px solid var(--glass-border)}
.price-table{width:100%;border-collapse:collapse;background:var(--glass);
  backdrop-filter:blur(var(--glass-blur))}
.price-table thead th{
  font-family:var(--font-head);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--cyan);text-align:left;padding:1.1rem 1.4rem;background:var(--cyan-dim);
  border-bottom:1px solid var(--cyan-soft)}
.price-table tbody td{padding:1.1rem 1.4rem;border-bottom:1px solid var(--line);font-size:.95rem;vertical-align:middle}
.price-table tbody tr:last-child td{border-bottom:none}
.price-table tbody tr:hover{background:rgba(34,211,238,.05)}
.price-table .svc{font-family:var(--font-head);font-weight:600;color:var(--text)}
.price-table .svc small{display:block;font-family:var(--font-body);font-weight:400;color:var(--muted);font-size:.82rem}
.price-table .amount{font-family:var(--font-head);font-weight:700;font-size:1.15rem;color:var(--cyan);white-space:nowrap}
.price-note{margin-top:.9rem;font-size:.8rem;color:var(--muted-2)}

/* PRICING CARDS */
.price-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.price-card{padding:2rem;display:flex;flex-direction:column;position:relative}
.price-card.featured{border-color:var(--magenta-soft);box-shadow:var(--shadow),var(--glow-magenta)}
.price-card .tier{font-family:var(--font-head);font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  font-size:.78rem;color:var(--cyan)}
.price-card.featured .tier{color:#E879F9}
.price-card .price{font-family:var(--font-head);font-weight:700;font-size:2.6rem;margin:.6rem 0;line-height:1}
.price-card .price small{font-size:.9rem;color:var(--muted);font-weight:400}
.price-card ul{display:flex;flex-direction:column;gap:.7rem;margin:1.2rem 0 1.6rem}
.price-card li{display:flex;gap:.5rem;align-items:flex-start;color:var(--muted);font-size:.9rem}
.price-card li svg{width:18px;height:18px;color:var(--cyan);flex-shrink:0;margin-top:2px}
.price-card .btn{margin-top:auto}
.price-tag{position:absolute;top:-12px;right:1.5rem;font-family:var(--font-head);font-size:.66rem;
  letter-spacing:.14em;text-transform:uppercase;padding:.35rem .8rem;border-radius:var(--r-pill);
  background:var(--grad-aurora);color:#04121A;box-shadow:var(--glow-mix)}

/* ----------------------------- FAQ --------------------------------------- */
.faq{display:flex;flex-direction:column;gap:.8rem;max-width:820px;margin-inline:auto}
.faq details{
  background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--r-md);
  padding:0 1.4rem;transition:border-color .3s,box-shadow .3s;overflow:hidden;
}
.faq details[open]{border-color:var(--cyan-soft);box-shadow:var(--glow-cyan)}
.faq summary{
  list-style:none;cursor:pointer;padding:1.2rem 2.2rem 1.2rem 0;position:relative;
  font-family:var(--font-head);font-weight:600;font-size:1.05rem;color:var(--text);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";position:absolute;right:0;top:50%;transform:translateY(-50%);
  font-size:1.5rem;color:var(--cyan);transition:transform .3s;font-family:var(--font-head)}
.faq details[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.faq details p{color:var(--muted);padding-bottom:1.3rem;font-size:.96rem}

/* ----------------------------- AVIS -------------------------------------- */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.review{padding:1.7rem;display:flex;flex-direction:column;gap:1rem}
.review .stars{display:flex;gap:.18rem;color:var(--cyan)}
.review .stars svg{width:18px;height:18px;filter:drop-shadow(0 0 6px rgba(34,211,238,.5))}
.review p{color:var(--text);font-size:.98rem;font-style:italic;flex:1}
.review .who{display:flex;align-items:center;gap:.75rem}
.review .av{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;
  font-family:var(--font-head);font-weight:700;color:#04121A;background:var(--grad-aurora);flex-shrink:0}
.review .who b{font-family:var(--font-head);font-size:.95rem;display:block}
.review .who span{font-size:.78rem;color:var(--muted-2)}

/* ----------------------------- CTA BAND ---------------------------------- */
.cta-band{position:relative;overflow:hidden}
.cta-panel{
  padding:clamp(2.4rem,5vw,4rem);text-align:center;position:relative;overflow:hidden;
  background:var(--grad-cta),var(--glass);
  border:1px solid var(--glass-border);border-radius:var(--r-xl);
  box-shadow:var(--shadow-lg),var(--glow-mix);
}
.cta-panel::before{content:"";position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(rgba(34,211,238,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(192,38,211,.06) 1px,transparent 1px);background-size:40px 40px}
.cta-panel>*{position:relative;z-index:1}
.cta-panel h2{font-size:clamp(2rem,5vw,3.2rem);margin:1rem 0}
.cta-panel p{color:var(--muted);font-size:1.1rem;max-width:560px;margin:0 auto 1.8rem}
.cta-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}
.cta-phone{font-family:var(--font-head);font-weight:700;font-size:clamp(1.6rem,4vw,2.4rem);
  background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent;
  display:inline-block;margin-bottom:.4rem}

/* --------------------------- BREADCRUMB ---------------------------------- */
.breadcrumb{padding-top:calc(var(--header-h) + 2rem);padding-bottom:1rem}
.breadcrumb ol{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;font-size:.82rem;color:var(--muted-2)}
.breadcrumb a:hover{color:var(--cyan)}
.breadcrumb li::after{content:"/";margin-left:.5rem;color:var(--line-strong)}
.breadcrumb li:last-child::after{display:none}
.breadcrumb li:last-child{color:var(--text)}

/* page hero (internal) */
.page-hero{padding-top:calc(var(--header-h) + 2rem);padding-bottom:var(--sp-6);position:relative}
.page-hero h1{font-size:clamp(2.1rem,5.5vw,3.6rem);margin:1.1rem 0 1rem;max-width:18ch}
.page-hero p{color:var(--muted);font-size:1.12rem;max-width:46rem}
.page-hero .hero-actions{margin-top:1.8rem}

/* ----------------------------- FORM -------------------------------------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field{display:flex;flex-direction:column;gap:.45rem}
.field.full{grid-column:1/-1}
.field label{font-family:var(--font-head);font-size:.78rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--muted)}
.field input,.field select,.field textarea{
  background:var(--bg-2);border:1px solid var(--line-strong);border-radius:var(--r-sm);
  padding:.85rem 1rem;color:var(--text);font:inherit;font-size:.95rem;transition:border-color .25s,box-shadow .25s}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px rgba(34,211,238,.18)}
.field textarea{resize:vertical;min-height:120px}
.form-note{font-size:.78rem;color:var(--muted-2);margin-top:.4rem}

/* contact info list */
.contact-list{display:flex;flex-direction:column;gap:1.2rem}
.contact-item{display:flex;gap:1rem;align-items:flex-start}
.contact-item .ci-ic{width:46px;height:46px;border-radius:var(--r-md);display:grid;place-items:center;flex-shrink:0;
  background:var(--cyan-dim);border:1px solid var(--cyan-soft)}
.contact-item .ci-ic svg{width:22px;height:22px;color:var(--cyan)}
.contact-item h4{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.2rem}
.contact-item a,.contact-item p{font-family:var(--font-head);font-weight:600;font-size:1.1rem;color:var(--text)}

/* ----------------------------- FOOTER ------------------------------------ */
.site-footer{border-top:1px solid var(--line);background:var(--bg-2);padding-block:var(--sp-7) var(--sp-4);margin-top:var(--sp-8);position:relative}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:2.5rem;margin-bottom:3rem}
.footer-brand .brand{margin-bottom:1rem}
.footer-brand p{color:var(--muted);font-size:.9rem;max-width:30ch}
.footer-col h4{font-family:var(--font-head);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--cyan);margin-bottom:1.1rem}
.footer-col ul{display:flex;flex-direction:column;gap:.6rem}
.footer-col a,.footer-col p{color:var(--muted);font-size:.9rem;transition:color .2s}
.footer-col a:hover{color:var(--text)}
.footer-col .fphone{font-family:var(--font-head);font-weight:700;font-size:1.25rem;
  background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}
.footer-bottom{border-top:1px solid var(--line);padding-top:1.6rem;display:flex;flex-wrap:wrap;gap:1rem;
  justify-content:space-between;align-items:center;font-size:.8rem;color:var(--muted-2)}
.footer-bottom a{color:var(--muted-2)}
.footer-bottom a:hover{color:var(--cyan)}
.footer-legal{display:flex;gap:1.2rem;flex-wrap:wrap}

/* --------------------- STICKY MOBILE CALL BAR ---------------------------- */
.call-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:95;display:none;
  padding:.6rem .8rem calc(.6rem + env(safe-area-inset-bottom,0));
  background:rgba(5,6,10,.86);backdrop-filter:blur(16px);
  border-top:1px solid var(--line-strong);gap:.6rem;
}
.call-bar .btn{flex:1}
.call-bar .btn-ghost{flex:0 0 auto;width:52px;padding:0}

/* ---------------------- REVEAL / TILT ANIMATIONS ------------------------- */
[data-reveal]{opacity:0;transform:translateY(28px);
  transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1);
  will-change:opacity,transform}
[data-reveal].in{opacity:1;transform:none}
[data-reveal][data-delay="1"]{transition-delay:.08s}
[data-reveal][data-delay="2"]{transition-delay:.16s}
[data-reveal][data-delay="3"]{transition-delay:.24s}
[data-reveal][data-delay="4"]{transition-delay:.32s}
[data-tilt]{transition:transform .25s ease,box-shadow .3s ease;transform-style:preserve-3d;will-change:transform}

/* cursor halo */
.cursor-halo{position:fixed;top:0;left:0;width:480px;height:480px;border-radius:50%;
  pointer-events:none;z-index:0;transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(34,211,238,.10),transparent 65%);
  mix-blend-mode:screen;transition:opacity .4s;opacity:0}

/* ----------------------------- RESPONSIVE -------------------------------- */
@media (max-width:1080px){
  .hero-inner{grid-template-columns:1fr;gap:2.2rem}
  .hero-hud{max-width:480px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .grid-4,.process,.stats,.zones-grid,.price-cards,.reviews{grid-template-columns:repeat(2,1fr)}
  .reassure-grid{grid-template-columns:repeat(2,1fr);gap:1.2rem}
}
@media (max-width:860px){
  .main-nav,.header-cta .btn-ghost{display:none}
  .burger{display:flex}
  .header-cta .btn-call{padding:.7rem 1.1rem;font-size:.84rem}
  .split,.split.rev{grid-template-columns:1fr;gap:1.8rem}
  .split.rev .split-media{order:0}
  .form-grid{grid-template-columns:1fr}
  .call-bar{display:flex}
  body{padding-bottom:74px}
  .section{padding-block:var(--sp-7)}
}
@media (max-width:600px){
  .grid-2,.grid-3,.grid-4,.process,.stats,.zones-grid,.price-cards,.reviews,.reassure-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero-actions{flex-direction:column;align-items:stretch}
  .hero-actions .btn{width:100%}
  :root{--container:1200px}
  .price-table thead{display:none}
  .price-table tbody td{display:flex;justify-content:space-between;gap:1rem;padding:.7rem 1.1rem;border:none}
  .price-table tbody tr{display:block;border-bottom:1px solid var(--line);padding-block:.5rem}
}

/* --------------------- PREFERS REDUCED MOTION ---------------------------- */
@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important;scroll-behavior:auto !important}
  [data-reveal]{opacity:1;transform:none}
  [data-tilt]{transform:none !important}
  #bg-canvas{display:none}
  .bg-scan{display:none}
  .cursor-halo{display:none}
  .split-media:hover img{transform:none}
}
