/* ═══════════════════════════════════════════════════════
   VCom'Stratégie — CSS Dark Agency
   Yann Vernhes · Avignon · 2026
═══════════════════════════════════════════════════════ */

/* ── Variables ─────────────────────────────────────── */
:root {
  --bg:          #09090F;
  --surface:     #111118;
  --surface2:    #1A1A26;
  --surface3:    #22222E;
  --orange:      #94c01f;
  --orange-dim:  rgba(148,192,31,.1);
  --orange-glow: rgba(148,192,31,.22);
  --green:       #94c01f;
  --green-dark:  #78921b;
  --green-dim:   rgba(148,192,31,.1);
  --text:        #F0EEE8;
  --text-mid:    #A8A8C0;
  --text-muted:  #60607A;
  --border:      rgba(255,255,255,.07);
  --border-o:    rgba(148,192,31,.25);
  --nav-h:       72px;
  --radius:      6px;
  --ease:        cubic-bezier(.4,0,.2,1);
  --ease-out:    cubic-bezier(0,0,.2,1);
}

/* ── Reset ─────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{
  background:var(--bg);
  color:var(--text);
  font-family:'Inter',system-ui,sans-serif;
  font-size:1rem;
  line-height:1.65;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font:inherit}

/* ── Typography ────────────────────────────────────── */
h1,h2,h3,h4,h5{
  font-family:'Syne',sans-serif;
  font-weight:700;
  line-height:1.1;
  letter-spacing:-.02em;
  color:var(--text);
}
h1{font-size:clamp(2.6rem,7vw,5.5rem)}
h2{font-size:clamp(2rem,4.5vw,3.5rem)}
h3{font-size:clamp(1.3rem,2.5vw,1.8rem)}
h4{font-size:1.1rem}
p{color:var(--text-mid);line-height:1.75}

.label{
  display:inline-block;
  font-size:.68rem;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--orange);
  font-family:'Inter',sans-serif;
  margin-bottom:1rem;
}
.label-green{color:var(--green)}

em{font-style:normal;color:var(--orange)}

/* ── Layout ────────────────────────────────────────── */
.container    {width:100%;max-width:1280px;margin:0 auto;padding:0 2rem}
.container-sm {width:100%;max-width:860px; margin:0 auto;padding:0 2rem}
.container-xs {width:100%;max-width:640px; margin:0 auto;padding:0 2rem}

.section      {padding:7rem 0}
.section-sm   {padding:4rem 0}
.section-alt  {background:var(--surface)}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}

/* ── Buttons ───────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:'Syne',sans-serif;font-weight:600;font-size:.88rem;
  letter-spacing:.04em;text-transform:uppercase;
  padding:.85rem 2rem;border-radius:var(--radius);
  transition:all .28s var(--ease);white-space:nowrap;cursor:pointer;
}
.btn-orange{
  background:var(--orange);color:#fff;
}
.btn-orange:hover{background:#78921b;transform:translateY(-2px);box-shadow:0 8px 28px var(--orange-glow)}
.btn-outline{
  border:1px solid var(--border-o);color:var(--orange);background:transparent;
}
.btn-outline:hover{background:var(--orange-dim);border-color:var(--orange);transform:translateY(-2px)}
.btn-ghost{
  border:1px solid var(--border);color:var(--text-mid);background:transparent;
}
.btn-ghost:hover{border-color:rgba(255,255,255,.2);color:var(--text)}

/* ── Custom Cursor ─────────────────────────────────── */
.cursor{
  position:fixed;top:0;left:0;pointer-events:none;z-index:9999;
  width:10px;height:10px;
  background:var(--orange);border-radius:50%;
  transform:translate(-50%,-50%);
  transition:transform .1s var(--ease),width .3s,height .3s,background .3s;
  mix-blend-mode:normal;
}
.cursor-ring{
  position:fixed;top:0;left:0;pointer-events:none;z-index:9998;
  width:36px;height:36px;
  border:1px solid rgba(148,192,31,.4);border-radius:50%;
  transform:translate(-50%,-50%);
  transition:transform .18s var(--ease-out),width .3s,height .3s,opacity .3s;
}
.cursor-ring.hover{width:56px;height:56px;opacity:.6}
body.no-cursor .cursor,body.no-cursor .cursor-ring{display:none}

/* ── Navigation ────────────────────────────────────── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:var(--nav-h);
  background:transparent;
  transition:background .4s var(--ease),backdrop-filter .4s,border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{border-bottom-color:var(--border)}
.nav.scrolled::before{
  content:'';position:absolute;inset:0;z-index:-1;
  background:rgba(9,9,15,.88);
  backdrop-filter:blur(20px);
}
.nav-inner{
  height:100%;
  display:flex;align-items:center;justify-content:space-between;
  gap:2rem;
}
.nav-logo{display:flex;align-items:center;gap:0}
.nav-logo-img{height:42px;width:auto;display:block}
.nav-logo-main{
  font-family:'Syne',sans-serif;font-weight:800;font-size:1.15rem;
  letter-spacing:-.01em;color:var(--text);line-height:1;
}
.nav-logo-main span{color:var(--orange)}
.nav-logo-sub{
  font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--text-muted);font-weight:500;
}
.nav-menu{display:flex;align-items:center;gap:.4rem}
.nav-link{
  font-family:'Inter',sans-serif;font-size:.875rem;font-weight:500;
  color:var(--text-mid);letter-spacing:.02em;
  padding:.55rem .9rem;border-radius:var(--radius);
  transition:color .2s,background .2s;position:relative;
}
.nav-link:hover,.nav-link.active{color:var(--text);background:rgba(255,255,255,.05)}
.nav-link.active::after{
  content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  width:18px;height:2px;background:var(--orange);border-radius:2px;
}
.nav-item{position:relative}
/* pont transparent pour que la souris puisse atteindre le dropdown (desktop) */
.nav-item::after{content:'';position:absolute;top:100%;left:-8px;right:-8px;height:14px}
.nav-item:hover .nav-drop{opacity:1;pointer-events:all;transform:translateY(0)}
.nav-caret{width:10px;height:10px;margin-left:3px;vertical-align:middle;transition:transform .2s}
.nav-item:hover .nav-caret{transform:rotate(180deg)}
/* Dropdown régulier — aligné à gauche du nav-item */
.nav-drop{
  position:absolute;top:calc(100% + 8px);left:0;transform:translateY(8px);
  min-width:270px;
  background:var(--surface2);border:1px solid var(--border);
  border-radius:var(--radius);padding:.5rem;
  opacity:0;pointer-events:none;
  transition:opacity .22s,transform .22s;
  box-shadow:0 20px 60px rgba(0,0,0,.5);
  z-index:200;
}
/* léger délai avant fermeture → plus facile à atteindre */
.nav-item:not(:hover)>.nav-drop{transition-delay:.12s}
.nav-item:hover>.nav-drop{transition-delay:0s}
/* Mega menu — pleine largeur de la nav (ancré à .nav qui est position:fixed) */
.nav-item:has(.mega){position:static}
.nav-item:has(.mega)::after{display:none}
.nav-drop.mega{
  left:0;right:0;top:100%;
  transform:translateY(-4px);
  min-width:0;
  border-radius:0 0 var(--radius) var(--radius);
  display:flex;flex-direction:row;gap:0;
  padding:.6rem clamp(1.5rem,calc(50% - 610px),8rem);
}
.nav-item:hover .nav-drop.mega{transform:translateY(0)}
.mega-group{flex:1;padding:.25rem .75rem}
.mega-group+.mega-group{border-top:none;border-left:1px solid var(--border);padding-top:.25rem;margin-top:0;padding-left:.75rem;margin-left:0}
.mega-group-label{
  display:block;font-size:.6rem;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;color:var(--green);
  padding:.2rem .5rem .4rem;
}
.nav-drop-link{
  display:block;padding:.55rem .75rem;font-size:.83rem;color:var(--text-mid);
  border-radius:4px;transition:color .15s,background .15s;
}
.nav-drop-link:hover{color:var(--text);background:rgba(255,255,255,.05)}
.nav-cta{margin-left:1rem}
/* Burger — plus grand pour le tactile */
.nav-burger{
  display:none;flex-direction:column;gap:5px;padding:.6rem;
  width:48px;height:48px;justify-content:center;cursor:pointer;
}
.nav-burger span{
  display:block;height:2px;background:var(--text);border-radius:2px;
  transition:transform .3s,opacity .3s;width:100%;
}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
/* ── Menu mobile ouvert ───────────────────────────────────────── */
.nav-menu.open{display:flex!important;flex-direction:column;
  position:fixed;top:var(--nav-h);left:0;right:0;
  height:calc(100dvh - var(--nav-h));
  background:var(--bg);border-top:1px solid var(--border);
  align-items:flex-start;padding:1rem 0;gap:0;overflow-y:auto;
  z-index:1001;
}
.nav-menu.open .nav-link{
  font-size:1.2rem;font-weight:600;letter-spacing:.01em;
  padding:1rem 1.5rem;width:100%;
  border-bottom:1px solid var(--border);
}
/* Mobile : dropdowns repliés par défaut, accordéon via .open sur nav-item */
.nav-menu.open .nav-drop{
  position:static;transform:none;
  max-height:0;overflow:hidden;
  opacity:0;pointer-events:none;
  background:var(--surface);margin:0;
  border-radius:0;
  transition:max-height .35s ease,opacity .25s,margin .2s;
  box-shadow:none;border:none;z-index:auto;
  display:block;flex-direction:unset;padding:0;
  min-width:0;
}
.nav-menu.open .nav-item.open>.nav-drop{
  max-height:900px;overflow-y:auto;
  opacity:1;pointer-events:all;
  margin:0 0 .25rem;
}
.nav-menu.open .nav-item.open>.nav-link .nav-caret{transform:rotate(180deg)}
/* Mega menu mobile : colonne simple */
.nav-menu.open .nav-drop.mega{flex-direction:column;left:auto;right:auto}
.nav-menu.open .mega-group{flex:unset;border-left:none!important;border-top:1px solid var(--border);padding:.25rem 0}
.nav-menu.open .mega-group:first-child{border-top:none}
.nav-menu.open .mega-group-label{font-size:.65rem;padding:.5rem 1.5rem .2rem}
.nav-menu.open .nav-drop-link{padding:.75rem 1.75rem;font-size:1rem;border-radius:0}

/* ── Hero ──────────────────────────────────────────── */
.hero{
  position:relative;min-height:100vh;
  display:flex;align-items:center;
  overflow:hidden;padding-top:var(--nav-h);
}
.hero-bg{
  position:absolute;inset:0;
  background:var(--bg);
  z-index:0;
}
.hero-mesh{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 700px 500px at 15% 55%, rgba(148,192,31,.13) 0%, transparent 65%),
    radial-gradient(ellipse 500px 700px at 85% 15%, rgba(148,192,31,.07) 0%, transparent 65%),
    radial-gradient(ellipse 600px 400px at 65% 85%, rgba(148,192,31,.06) 0%, transparent 60%);
  animation:meshDrift 16s ease-in-out infinite alternate;
}
@keyframes meshDrift{
  0%  {transform:translate(0,0) scale(1)}
  50% {transform:translate(2%,1.5%) scale(1.02)}
  100%{transform:translate(-1%,3%) scale(1.01)}
}
.hero-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse 90% 80% at 50% 50%,black 30%,transparent 100%);
  z-index:1;
}
.hero-content{
  position:relative;z-index:2;
  width:100%;max-width:1280px;margin:0 auto;padding:4rem 2rem;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:.75rem;
  font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--text-muted);font-weight:500;margin-bottom:2rem;
}
.hero-eyebrow::before{
  content:'';width:30px;height:1px;background:var(--orange);flex-shrink:0;
}
.hero-title{
  max-width:850px;
  margin-bottom:1.25rem;
}
.hero-title .line{display:block;overflow:hidden}
.hero-typewriter-wrap{
  display:flex;align-items:center;gap:.75rem;
  margin-bottom:2rem;
  font-family:'Syne',sans-serif;font-weight:700;
  font-size:clamp(1.5rem,3.5vw,2.8rem);
  color:var(--text-mid);letter-spacing:-.02em;
}
.hero-typewriter-label{color:var(--text-muted);font-size:.9em}
.hero-typewriter{color:var(--orange);border-right:2px solid var(--orange);padding-right:4px;min-width:2ch}
.hero-sub{
  font-family:'Inter',sans-serif;
  font-size:1.05rem;color:var(--text-mid);
  max-width:520px;line-height:1.8;margin-bottom:3rem;
}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap}
.hero-scroll{
  position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  color:var(--text-muted);font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;
  animation:heroScrollBounce 2s ease-in-out infinite;z-index:2;
}
.hero-scroll-line{
  width:1px;height:48px;
  background:linear-gradient(to bottom,transparent,var(--orange));
}
@keyframes heroScrollBounce{
  0%,100%{transform:translateX(-50%) translateY(0)}
  50%    {transform:translateX(-50%) translateY(6px)}
}

/* ── Ticker ────────────────────────────────────────── */
.ticker{
  padding:1.1rem 0;
  background:var(--surface);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  overflow:hidden;white-space:nowrap;
}
.ticker-track{
  display:inline-flex;
  animation:tickerScroll 32s linear infinite;
  gap:0;
}
.ticker-track:hover{animation-play-state:paused}
.ticker-item{
  display:inline-flex;align-items:center;gap:2rem;
  padding:0 2rem;
  font-family:'Syne',sans-serif;font-size:.78rem;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);
}
.ticker-dot{
  display:inline-block;width:5px;height:5px;
  background:var(--orange);border-radius:50%;flex-shrink:0;
}
@keyframes tickerScroll{
  0%  {transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

/* ── Section Head ──────────────────────────────────── */
.section-head{margin-bottom:4rem}
.section-head.center{text-align:center}
.section-head .section-lead{
  font-size:1.05rem;color:var(--text-mid);
  max-width:580px;margin-top:1rem;line-height:1.8;
}
.section-head.center .section-lead{margin:1rem auto 0}

/* ── Service Cards ─────────────────────────────────── */
.service-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  border:1px solid var(--border);
  overflow:hidden;
  border-radius:var(--radius);
}
.s-card{
  position:relative;overflow:hidden;
  background:var(--surface);
  padding:2.5rem 2rem;
  transition:background .35s var(--ease);
}
.s-card::before{
  content:'';position:absolute;
  bottom:0;left:0;right:0;height:0;
  background:var(--orange);
  transition:height .42s var(--ease);
  z-index:0;
}
.s-card:hover::before{height:100%}
.s-card:hover .s-card-ico,
.s-card:hover .s-card-title,
.s-card:hover .s-card-text,
.s-card:hover .s-card-link{color:#fff!important}
.s-card-inner{position:relative;z-index:1}
.s-card-ico{
  font-size:2rem;margin-bottom:1.25rem;
  display:block;
  transition:color .35s;
}
.s-card-num{
  font-family:'Syne',sans-serif;font-size:.65rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted);
  margin-bottom:1rem;transition:color .35s;
}
.s-card-title{
  font-family:'Syne',sans-serif;font-size:1.2rem;font-weight:700;
  color:var(--text);margin-bottom:.75rem;letter-spacing:-.01em;
  transition:color .35s;
}
.s-card-text{
  font-size:.88rem;color:var(--text-muted);line-height:1.7;
  transition:color .35s;
}
.s-card-link{
  display:inline-flex;align-items:center;gap:.4rem;
  margin-top:1.5rem;font-size:.78rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--orange);transition:color .35s,gap .2s;
}
.s-card:hover .s-card-link{gap:.8rem}
.s-card-link svg{width:14px;height:14px;flex-shrink:0}

/* ── About ─────────────────────────────────────────── */
.about-layout{
  display:grid;grid-template-columns:1fr 480px;
  gap:6rem;align-items:center;
}
.about-img{
  position:relative;
  aspect-ratio:3/4;
  background:var(--surface2);
  border-radius:2px;
  overflow:hidden;
}
.about-img-shape{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 30% 70%, rgba(148,192,31,.25) 0%, transparent 70%),
    radial-gradient(ellipse 60% 80% at 70% 30%, rgba(148,192,31,.12) 0%, transparent 70%);
}
.about-img-label{
  position:absolute;bottom:2rem;left:2rem;right:2rem;
  background:rgba(9,9,15,.85);backdrop-filter:blur(12px);
  border:1px solid var(--border);border-radius:var(--radius);
  padding:1.25rem 1.5rem;
}
.about-img-label strong{
  font-family:'Syne',sans-serif;font-size:1.1rem;font-weight:700;
  display:block;color:var(--text);margin-bottom:.25rem;
}
.about-img-label span{font-size:.8rem;color:var(--text-muted)}
.about-text .about-lead{
  font-size:1.15rem;color:var(--text);line-height:1.75;
  margin-bottom:2rem;
}
.about-vals{display:flex;flex-direction:column;gap:1rem;margin-top:2.5rem}
.about-val{
  display:flex;align-items:flex-start;gap:1rem;
  padding:1.25rem 1.5rem;
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);border-left:3px solid var(--orange);
  transition:border-left-color .2s,background .2s;
}
.about-val:hover{background:var(--surface2);border-left-color:var(--green)}
.about-val-ico{font-size:1.4rem;flex-shrink:0;line-height:1}
.about-val-body strong{
  display:block;font-family:'Syne',sans-serif;font-weight:700;
  font-size:.9rem;color:var(--text);margin-bottom:.2rem;
}
.about-val-body span{font-size:.83rem;color:var(--text-muted)}

/* ── Stats ─────────────────────────────────────────── */
.stats-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;
}
.stat-item{
  background:var(--surface);padding:3rem 2.5rem;text-align:center;
  transition:background .3s;
}
.stat-item:hover{background:var(--surface2)}
.stat-num{
  font-family:'Syne',sans-serif;font-size:clamp(2.5rem,5vw,4rem);
  font-weight:800;color:var(--text);letter-spacing:-.04em;
  display:block;line-height:1;margin-bottom:.5rem;
}
.stat-num span{color:var(--orange)}
.stat-label{font-size:.82rem;color:var(--text-muted);letter-spacing:.05em}

/* ── Process ───────────────────────────────────────── */
.process-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  position:relative;
}
.process-grid::before{
  content:'';position:absolute;top:2rem;left:12.5%;right:12.5%;height:1px;
  background:linear-gradient(90deg,var(--orange),var(--green),var(--orange));
  opacity:.3;z-index:0;
}
.process-step{
  text-align:center;padding:2rem 1.5rem;position:relative;z-index:1;
}
.process-num{
  width:48px;height:48px;border-radius:50%;
  border:1px solid var(--border-o);
  background:var(--surface);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 1.5rem;
  font-family:'Syne',sans-serif;font-weight:800;font-size:.9rem;
  color:var(--orange);
  transition:background .3s,border-color .3s;
}
.process-step:hover .process-num{background:var(--orange);border-color:var(--orange);color:#fff}
.process-step h4{
  font-size:1rem;margin-bottom:.5rem;color:var(--text);
  font-family:'Syne',sans-serif;font-weight:700;
}
.process-step p{font-size:.83rem;color:var(--text-muted)}

/* ── CTA Banner ────────────────────────────────────── */
.cta-band{
  position:relative;overflow:hidden;
  padding:6rem 0;
  background:var(--surface);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.cta-band::before{
  content:'';position:absolute;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(148,192,31,.12) 0%,transparent 70%);
  top:50%;left:50%;transform:translate(-50%,-50%);
  pointer-events:none;
}
.cta-band-inner{
  position:relative;z-index:1;
  display:flex;align-items:center;justify-content:space-between;gap:3rem;flex-wrap:wrap;
}
.cta-band-title{font-size:clamp(1.6rem,3.5vw,2.8rem);max-width:600px}
.cta-band-sub{font-size:1rem;color:var(--text-mid);margin-top:.75rem;max-width:480px}
.cta-band-btns{display:flex;gap:1rem;flex-shrink:0;flex-wrap:wrap}

/* ── Contact Quick ─────────────────────────────────── */
.contact-strip{
  display:flex;gap:1.5rem;flex-wrap:wrap;
}
.contact-chip{
  display:flex;align-items:center;gap:1.25rem;
  flex:1;min-width:260px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:1.5rem;
  transition:border-color .25s,background .25s,transform .25s;
}
.contact-chip:hover{border-color:var(--border-o);background:var(--surface2);transform:translateY(-3px)}
.contact-chip-ico{
  width:44px;height:44px;border-radius:var(--radius);
  background:var(--orange-dim);border:1px solid var(--border-o);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  color:var(--orange);
}
.contact-chip-body strong{display:block;font-size:.95rem;color:var(--text);font-weight:600}
.contact-chip-body span{font-size:.78rem;color:var(--text-muted)}

/* ── Footer ────────────────────────────────────────── */
.footer{
  background:var(--bg);
  border-top:1px solid var(--border);
  padding:5rem 0 2rem;
}
.footer-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:3rem;margin-bottom:4rem;
}
.footer-brand-name{
  font-family:'Syne',sans-serif;font-weight:800;font-size:1.2rem;
  color:var(--text);margin-bottom:.25rem;letter-spacing:-.01em;
}
.footer-brand-name span{color:var(--orange)}
.footer-brand-sub{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:1rem}
.footer-brand-p{font-size:.83rem;color:var(--text-muted);line-height:1.7;max-width:280px}
.footer-col-h{
  font-family:'Syne',sans-serif;font-weight:700;font-size:.7rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--text-muted);
  margin-bottom:1.25rem;
}
.footer-links li{margin-bottom:.6rem}
.footer-links a{font-size:.85rem;color:var(--text-muted);transition:color .2s}
.footer-links a:hover{color:var(--orange)}
.footer-contact-row{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.9rem}
.footer-contact-ico{color:var(--orange);flex-shrink:0;margin-top:2px}
.footer-contact-txt{font-size:.85rem;color:var(--text-muted)}
.footer-contact-txt a{color:var(--text-mid);transition:color .2s}
.footer-contact-txt a:hover{color:var(--orange)}
.footer-note{font-size:.75rem;color:var(--text-muted);margin-top:.1rem}
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;
  padding-top:2rem;border-top:1px solid var(--border);
}
.footer-copy{font-size:.78rem;color:var(--text-muted)}
.footer-legals{display:flex;gap:1.5rem}
.footer-legals a{font-size:.78rem;color:var(--text-muted);transition:color .2s}
.footer-legals a:hover{color:var(--orange)}

/* ── Page Hero ─────────────────────────────────────── */
.page-hero{
  position:relative;
  padding:calc(var(--nav-h) + 5rem) 0 5rem;
  overflow:hidden;
}
.page-hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 600px 400px at 10% 50%, rgba(148,192,31,.1) 0%, transparent 65%),
    radial-gradient(ellipse 400px 600px at 90% 20%, rgba(148,192,31,.06) 0%, transparent 65%);
  z-index:0;
}
.page-hero-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 20%,transparent 100%);
  z-index:1;
}
.page-hero-content{position:relative;z-index:2}
.breadcrumb{
  display:flex;align-items:center;gap:.5rem;
  font-size:.75rem;color:var(--text-muted);
  letter-spacing:.06em;text-transform:uppercase;margin-bottom:1.5rem;
}
.breadcrumb a{transition:color .2s}.breadcrumb a:hover{color:var(--orange)}
.breadcrumb span.sep{color:var(--text-muted);opacity:.4}
.page-hero-title{margin-bottom:1rem}
.page-hero-sub{font-size:1.1rem;color:var(--text-mid);max-width:560px;line-height:1.75}

/* ── Rule Box ──────────────────────────────────────── */
.rule-box{
  background:var(--surface);border:1px solid var(--border);
  border-left:3px solid var(--orange);
  border-radius:var(--radius);padding:2rem;
}
.rule-box-green{border-left-color:var(--green)}
.rule-box h3{font-size:1rem;color:var(--text);margin-bottom:1rem;font-family:'Syne',sans-serif}
.rule-box ul{display:flex;flex-direction:column;gap:.5rem}
.rule-box li{font-size:.88rem;color:var(--text-muted);padding-left:1rem;position:relative}
.rule-box li::before{content:'—';position:absolute;left:0;color:var(--orange);opacity:.6}

/* ── Tarif Cards ───────────────────────────────────── */
.tarif-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;
}
.tarif-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:2.5rem 2rem;
  display:flex;flex-direction:column;
  transition:border-color .3s,transform .3s;
  position:relative;overflow:hidden;
}
.tarif-card:hover{border-color:var(--border-o);transform:translateY(-4px)}
.tarif-card-featured{border-color:var(--orange);background:var(--surface2)}
.tarif-card-badge{
  display:inline-block;
  background:var(--orange);color:#fff;
  font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  padding:.35rem .8rem;border-radius:40px;margin-bottom:1.5rem;
  width:fit-content;
}
.tarif-card-name{
  font-family:'Syne',sans-serif;font-size:1.2rem;font-weight:700;
  color:var(--text);margin-bottom:.5rem;
}
.tarif-card-desc{font-size:.85rem;color:var(--text-muted);margin-bottom:2rem;flex:1}
.tarif-card-price{
  font-family:'Syne',sans-serif;font-size:2.5rem;font-weight:800;
  color:var(--text);letter-spacing:-.04em;line-height:1;margin-bottom:.25rem;
}
.tarif-card-price span{font-size:1rem;color:var(--text-muted);font-weight:400}
.tarif-card-note{font-size:.78rem;color:var(--text-muted);margin-bottom:2rem}
.tarif-card-feats{display:flex;flex-direction:column;gap:.6rem;margin-bottom:2rem}
.tarif-card-feat{
  display:flex;align-items:center;gap:.75rem;
  font-size:.85rem;color:var(--text-mid);
}
.tarif-card-feat::before{
  content:'';width:16px;height:16px;border-radius:50%;flex-shrink:0;
  background:var(--orange-dim);border:1px solid var(--border-o);
  background-image:url("data:image/svg+xml,%3Csvg width='10' height='8' viewBox='0 0 10 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 4L3.5 6.5L9 1' stroke='%2394c01f' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;
}

/* ── Contact Form ──────────────────────────────────── */
.contact-layout{display:grid;grid-template-columns:1fr 380px;gap:4rem;align-items:start}
.form-group{margin-bottom:1.5rem}
.form-label{
  display:block;font-size:.75rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--text-muted);margin-bottom:.5rem;
}
.form-input{
  width:100%;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--radius);
  padding:.85rem 1.1rem;color:var(--text);font-size:.92rem;
  font-family:'Inter',sans-serif;
  transition:border-color .2s,box-shadow .2s;
  appearance:none;
}
.form-input:focus{
  outline:none;border-color:var(--orange);
  box-shadow:0 0 0 3px var(--orange-dim);
}
.form-input::placeholder{color:var(--text-muted)}
.form-textarea{min-height:140px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-submit{width:100%;justify-content:center;margin-top:.5rem}
.form-legal{font-size:.75rem;color:var(--text-muted);margin-top:1rem;text-align:center}
.form-input.error{border-color:#e05;box-shadow:0 0 0 3px rgba(238,0,85,.12)}

.contact-aside{display:flex;flex-direction:column;gap:1.5rem}
.contact-info-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:1.5rem;
  display:flex;align-items:center;gap:1.25rem;
  transition:border-color .25s;
}
.contact-info-card:hover{border-color:var(--border-o)}
.contact-info-ico{
  width:44px;height:44px;border-radius:var(--radius);
  background:var(--orange-dim);border:1px solid var(--border-o);
  display:flex;align-items:center;justify-content:center;
  color:var(--orange);flex-shrink:0;
}
.contact-info-label{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);display:block}
.contact-info-value{font-weight:600;font-size:.95rem;color:var(--text);display:block}
.contact-info-note{font-size:.75rem;color:var(--text-muted)}
.map-wrap{
  border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--border);height:320px;
}
.map-wrap iframe{width:100%;height:100%;border:none;filter:grayscale(1) invert(1) hue-rotate(200deg) brightness(.8)}

/* ── Reveal Animations ─────────────────────────────── */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.reveal.in{opacity:1;transform:translateY(0)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}
.d4{transition-delay:.4s}.d5{transition-delay:.5s}

.reveal-left{opacity:0;transform:translateX(-32px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.reveal-left.in{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(32px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.reveal-right.in{opacity:1;transform:translateX(0)}

/* ── Orange line divider ───────────────────────────── */
.o-line{
  display:block;width:48px;height:3px;
  background:linear-gradient(90deg,var(--orange),var(--green));
  border-radius:2px;margin-bottom:1.5rem;
}

/* ── Tag ───────────────────────────────────────────── */
.tag{
  display:inline-block;font-size:.68rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;
  background:var(--orange-dim);border:1px solid var(--border-o);
  color:var(--orange);border-radius:40px;padding:.3rem .9rem;
  margin-bottom:1rem;
}
.tag-green{background:var(--green-dim);border-color:rgba(148,192,31,.25);color:var(--green)}

/* ── Accordion ─────────────────────────────────────── */
.accordion-item{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);margin-bottom:.75rem;overflow:hidden;
}
details.accordion-item summary{
  list-style:none;cursor:pointer;
  padding:1.25rem 1.5rem;
  font-family:'Syne',sans-serif;font-weight:600;font-size:.95rem;
  color:var(--text);display:flex;align-items:center;justify-content:space-between;
  transition:color .2s;
}
details.accordion-item summary::-webkit-details-marker{display:none}
details.accordion-item summary::after{
  content:'+';font-size:1.4rem;color:var(--orange);
  transition:transform .3s;flex-shrink:0;
}
details.accordion-item[open] summary::after{transform:rotate(45deg)}
details.accordion-item[open] summary{color:var(--orange)}
.accordion-body{padding:0 1.5rem 1.5rem;font-size:.88rem;color:var(--text-muted);line-height:1.75}

/* ── Responsive ────────────────────────────────────── */
@media(max-width:1200px){
  .about-layout{grid-template-columns:1fr;gap:3rem}
  .about-img{max-width:400px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2.5rem}
}
@media(max-width:1024px){
  .service-grid{grid-template-columns:1fr 1fr}
  .process-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .process-grid::before{display:none}
  .tarif-grid{grid-template-columns:1fr}
  .contact-layout{grid-template-columns:1fr}
}
@media(max-width:768px){
  .nav-menu{display:none}
  .nav-burger{display:flex}
  .service-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .cta-band-inner{flex-direction:column;text-align:center}
  .cta-band-btns{justify-content:center}
  .footer-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .hero-btns{flex-direction:column}
  h1{font-size:2.4rem}
  h2{font-size:1.9rem}
  .hero-typewriter-wrap{font-size:1.3rem}
}
@media(max-width:480px){
  .container,.container-sm{padding:0 1.25rem}
  .section{padding:4rem 0}
  .btn{padding:.75rem 1.5rem;font-size:.82rem}
  .nav-cta{display:none}
}
