/* ==========================================================================
   DOMAINES PRIVILÈGE — Styles partagés
   ========================================================================== */

:root{
  --ink:#0A0E1A;
  --ink-2:#141A2B;
  --ink-3:#1D2638;
  --ink-soft:#4A5670;
  --line:#E8EBF2;
  --muted:#7B8699;
  --white:#FFFFFF;
  --cream:#F8F6F1;
  --gold:#B8935A;
  --gold-light:#D4B681;
  --gold-dark:#8C6D3A;
  --accent:#1C3552;
  --radius:10px;
  --shadow:0 30px 60px -15px rgba(10,14,26,.25);
  --shadow-sm:0 10px 30px -10px rgba(10,14,26,.15);
  --ease-out:cubic-bezier(0.22, 1, 0.36, 1);
  --ease-in-out:cubic-bezier(0.65, 0, 0.35, 1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',sans-serif;
  color:var(--ink);background:var(--white);
  line-height:1.65;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:'Playfair Display',serif;letter-spacing:-0.02em;line-height:1.15;font-weight:600}
.container{max-width:1200px;margin:0 auto;padding:0 28px}

/* ==========================================================================
   PAGE ENTRY (transition entre pages)
   ========================================================================== */
/* Body fade-in léger au chargement (rapide) */
body{
  animation:pageEnter .35s var(--ease-out) backwards;
}
@keyframes pageEnter{
  from{opacity:0}
  to{opacity:1}
}
/* Trait doré qui se trace en haut de la page lors de l'arrivée — court */
.page-line{
  position:fixed;top:0;left:0;height:2px;width:0;
  background:linear-gradient(90deg, transparent, var(--gold) 30%, var(--gold-light) 50%, var(--gold) 70%, transparent);
  z-index:9999;pointer-events:none;
  animation:drawLine .7s var(--ease-out) forwards;
}
@keyframes drawLine{
  0%{width:0;opacity:1}
  60%{width:100%;opacity:1}
  100%{width:100%;opacity:0}
}
/* Voile de transition à la sortie (page exit) — fade simple, rapide */
body.page-exit{
  opacity:0;
  transition:opacity .18s var(--ease-out);
}

/* ==========================================================================
   COMMUN UI
   ========================================================================== */
.eyebrow{
  font-family:'Inter',sans-serif;
  font-size:12px;font-weight:600;letter-spacing:.22em;
  color:var(--gold-dark);text-transform:uppercase;
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold);transition:width .4s var(--ease-out)}
.reveal.in .eyebrow::before, .in.eyebrow::before{width:26px}
.reveal:not(.in) .eyebrow::before{width:0}

.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 32px;font-weight:500;font-size:14px;
  letter-spacing:.08em;text-transform:uppercase;
  transition:all .35s var(--ease-out);cursor:pointer;border:none;font-family:inherit;
  position:relative;overflow:hidden;
}
.btn::after{
  content:"";position:absolute;top:50%;left:50%;
  width:0;height:0;border-radius:50%;
  background:rgba(255,255,255,.15);
  transform:translate(-50%,-50%);transition:width .6s var(--ease-out), height .6s var(--ease-out);
  pointer-events:none;
}
.btn:hover::after{width:300px;height:300px}
.btn-primary{background:var(--ink);color:#fff}
.btn-primary:hover{background:var(--ink-3);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{background:var(--gold-dark);transform:translateY(-2px);box-shadow:0 14px 30px -10px rgba(184,147,90,.5)}
.btn-outline{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.btn-outline:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.btn-outline-gold{background:transparent;color:var(--gold);border:1px solid var(--gold)}
.btn-outline-gold:hover{background:var(--gold);color:#fff}
.btn-outline-white{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.4)}
.btn-outline-white:hover{background:#fff;color:var(--ink);transform:translateY(-2px)}

/* ==========================================================================
   TOP BAR + NAV
   ========================================================================== */
.top-bar{
  background:var(--ink);color:rgba(255,255,255,.6);font-size:12px;
  letter-spacing:.06em;padding:10px 0;text-align:center;
}
.top-bar b{color:var(--gold-light);font-weight:500}

header.nav{
  background:rgba(255,255,255,.92);backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:50;
  transition:padding .3s var(--ease-out), box-shadow .3s var(--ease-out);
}
header.nav.scrolled{box-shadow:0 6px 24px -10px rgba(10,14,26,.12)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:22px 0;transition:padding .3s var(--ease-out)}
header.nav.scrolled .nav-inner{padding:14px 0}
.logo{display:flex;align-items:center;gap:14px;font-family:'Playfair Display',serif;font-weight:700;font-size:24px;color:var(--ink);transition:transform .3s var(--ease-out)}
.logo:hover{transform:translateY(-1px)}
.logo-mark{
  width:42px;height:42px;border:1.5px solid var(--gold);
  display:grid;place-items:center;color:var(--gold);font-family:'Playfair Display',serif;
  font-weight:700;font-size:20px;letter-spacing:.02em;
  transition:all .4s var(--ease-out);position:relative;overflow:hidden;
}
.logo:hover .logo-mark{background:var(--gold);color:#fff;transform:rotate(-6deg)}
nav ul{display:flex;gap:38px;list-style:none}
nav a{
  font-size:14px;color:var(--ink-soft);font-weight:500;
  transition:color .15s;position:relative;padding:6px 0;
}
nav a::after{
  content:"";position:absolute;bottom:0;left:0;width:0;height:1px;
  background:var(--gold);transition:width .35s var(--ease-out);
}
nav a:hover{color:var(--ink)}
nav a:hover::after, nav a.active::after{width:100%}
nav a.active{color:var(--ink)}
.nav-cta{display:flex;gap:12px;align-items:center}

/* Burger menu */
.burger{
  display:none;background:transparent;border:none;cursor:pointer;
  width:40px;height:40px;position:relative;flex-direction:column;
  gap:6px;align-items:center;justify-content:center;
}
.burger span{
  display:block;width:22px;height:1.5px;background:var(--ink);
  transition:all .35s var(--ease-out);
}
.burger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

@media(max-width:1000px){
  nav ul{
    display:flex;flex-direction:column;gap:0;
    position:fixed;top:0;right:0;width:min(320px,80vw);height:100vh;
    background:#fff;padding:90px 32px 40px;
    transform:translateX(100%);transition:transform .5s var(--ease-out);
    box-shadow:-10px 0 40px rgba(10,14,26,.1);
  }
  nav ul.open{transform:translateX(0)}
  nav ul li{border-bottom:1px solid var(--line)}
  nav ul a{display:block;padding:18px 0;font-size:16px}
  .burger{display:flex;z-index:60}
  .nav-cta .btn{display:none}
}

/* ==========================================================================
   HERO
   ========================================================================== */
.hero{
  position:relative;overflow:hidden;
  background:linear-gradient(160deg, var(--ink) 0%, var(--ink-2) 60%, var(--ink-3) 100%);
  color:#fff;padding:110px 0 130px;
}
/* Plus aucun effet de lumière en surcouche : le bleu reste plat et net */
.hero-inner{position:relative;max-width:880px;margin:0 auto;text-align:center;z-index:2}
.hero h1{
  font-size:clamp(44px,5.8vw,74px);font-weight:600;
  margin:22px 0 26px;color:#fff;
}
.hero h1 em{font-style:italic;color:var(--gold-light)}
.hero .lead{font-size:18px;color:rgba(255,255,255,.75);max-width:640px;margin:0 auto 38px}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
  max-width:1000px;margin:64px auto 0;padding-top:40px;
  border-top:1px solid rgba(255,255,255,.1);
}
.hero-stats div{text-align:center}
.hero-stats strong{
  font-family:'Playfair Display',serif;font-size:clamp(72px,8vw,120px);font-weight:600;
  color:var(--gold-light);display:block;line-height:1;
}
.hero-stats span{font-size:12.5px;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.65);display:block;margin-top:10px}
@media(max-width:700px){.hero-stats{grid-template-columns:repeat(2,1fr)}}

/* Hero variantes : interne (plus court) */
.hero-page{padding:90px 0 90px}
.hero-page h1{font-size:clamp(36px,4.6vw,58px);margin:18px 0 18px}
.hero-page .lead{margin-bottom:0;font-size:17px}

/* SEARCH BAR */
.search-wrap{
  max-width:640px;margin:34px auto 0;
  background:rgba(255,255,255,.06);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.14);padding:8px;
  display:flex;gap:8px;border-radius:8px;
  transition:border-color .3s, background .3s;
}
.search-wrap:focus-within{border-color:var(--gold-light);background:rgba(255,255,255,.1)}
.search-wrap input{
  flex:1;background:transparent;border:none;outline:none;
  color:#fff;padding:14px 16px;font-size:15px;font-family:inherit;
}
.search-wrap input::placeholder{color:rgba(255,255,255,.4)}
.search-wrap button{padding:14px 28px;font-size:13px}

/* ==========================================================================
   SECTIONS COMMUNES
   ========================================================================== */
section{padding:110px 0}
.section-head{text-align:center;max-width:760px;margin:0 auto 72px}
.section-head h2{font-size:clamp(32px,4vw,48px);margin:20px 0 16px}
.section-head p{color:var(--ink-soft);font-size:17px}

/* VALUES */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.value{text-align:center;padding:10px;transition:transform .4s var(--ease-out)}
.value:hover{transform:translateY(-6px)}
.value-ico{
  width:64px;height:64px;margin:0 auto 22px;
  border:1.5px solid var(--gold);display:grid;place-items:center;
  color:var(--gold);transition:all .4s var(--ease-out);
}
.value:hover .value-ico{background:var(--gold);color:#fff;transform:rotate(-6deg) scale(1.05)}
.value h3{font-size:23px;margin-bottom:12px}
.value p{color:var(--ink-soft);font-size:15.5px}
@media(max-width:900px){.values{grid-template-columns:1fr}}

/* PORTFOLIO */
.portfolio-bg{background:var(--cream)}
.tabs{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:48px}
.tab{
  padding:12px 22px;border:1px solid var(--line);
  background:#fff;font-size:13px;font-weight:500;letter-spacing:.08em;
  text-transform:uppercase;cursor:pointer;transition:all .3s var(--ease-out);font-family:inherit;
  color:var(--ink-soft);
}
.tab.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.tab:hover:not(.active){border-color:var(--ink);transform:translateY(-1px)}
.domains{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.domain-card{
  background:#fff;border:1px solid var(--line);padding:32px;
  transition:all .45s var(--ease-out);position:relative;overflow:hidden;
  cursor:pointer;
}
.domain-card::before{
  content:"";position:absolute;top:0;left:0;width:3px;height:0;
  background:var(--gold);transition:height .45s var(--ease-out);
}
.domain-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
.domain-card:hover::before{height:100%}
.domain-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.domain-sector{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-dark);font-weight:600}
.domain-status{
  font-size:11px;padding:4px 10px;border:1px solid var(--gold);
  color:var(--gold);letter-spacing:.08em;text-transform:uppercase;
}
.domain-name{
  font-family:'Playfair Display',serif;font-size:26px;font-weight:600;
  margin-bottom:8px;color:var(--ink);
}
.domain-desc{color:var(--ink-soft);font-size:14.5px;margin-bottom:22px;min-height:58px}
.domain-metrics{display:flex;gap:22px;padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-bottom:22px}
.metric{flex:1}
.metric small{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:4px}
.metric strong{font-family:'Playfair Display',serif;font-size:20px;font-weight:600;color:var(--ink)}
.domain-price{display:flex;justify-content:space-between;align-items:flex-end}
.domain-price .amt{font-family:'Playfair Display',serif;font-size:22px;font-weight:600;color:var(--ink)}
.domain-price .amt small{font-size:13px;font-weight:400;color:var(--muted);font-family:'Inter',sans-serif}
.domain-price .buy-opt{font-size:11.5px;color:var(--gold-dark);letter-spacing:.08em;text-transform:uppercase;transition:transform .3s}
.domain-card:hover .domain-price .buy-opt{transform:translateX(4px)}
@media(max-width:900px){.domains{grid-template-columns:1fr}}

/* PROCESS */
.process{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.process::before{
  content:"";position:absolute;top:30px;left:12%;right:12%;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold) 20%,var(--gold) 80%,transparent);
  z-index:0;
  transform:scaleX(0);transform-origin:left center;
  transition:transform 1.4s var(--ease-out);
}
.process.in::before{transform:scaleX(1)}
.proc{text-align:center;position:relative;z-index:1;transition:transform .4s var(--ease-out)}
.proc:hover{transform:translateY(-6px)}
.proc-num{
  width:62px;height:62px;border-radius:50%;background:#fff;
  border:1px solid var(--gold);color:var(--gold);
  display:grid;place-items:center;margin:0 auto 22px;
  font-family:'Playfair Display',serif;font-size:22px;font-weight:600;
  transition:all .45s var(--ease-out);
}
.proc:hover .proc-num{background:var(--gold);color:#fff;transform:scale(1.08) rotate(-8deg)}
.proc h3{font-size:19px;margin-bottom:8px}
.proc p{color:var(--ink-soft);font-size:14px}
@media(max-width:900px){.process{grid-template-columns:1fr 1fr;gap:40px}.process::before{display:none}}

/* MODEL / BENEFITS */
.model-bg{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.model-bg .section-head h2{color:#fff}
.model-bg .section-head p{color:rgba(255,255,255,.7)}
.benefits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:980px;margin:0 auto;position:relative;z-index:1}
.benefit-item{
  border:1px solid rgba(255,255,255,.12);padding:28px 30px;
  background:rgba(255,255,255,.03);display:flex;gap:18px;align-items:flex-start;
  transition:all .4s var(--ease-out);
}
.benefit-item:hover{background:rgba(184,147,90,.08);border-color:rgba(184,147,90,.5);transform:translateY(-4px)}
.benefit-item .check{width:36px;height:36px;flex:none;border:1px solid var(--gold);display:grid;place-items:center;color:var(--gold-light);transition:all .4s var(--ease-out)}
.benefit-item:hover .check{background:var(--gold);color:#fff;transform:rotate(360deg)}
.benefit-item h4{color:#fff;font-size:16px;margin-bottom:5px;font-family:'Inter',sans-serif;font-weight:600}
.benefit-item p{color:rgba(255,255,255,.65);font-size:14px;margin:0}
@media(max-width:900px){.benefits-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.benefits-grid{grid-template-columns:1fr}}

/* WHY */
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.why-visual{
  aspect-ratio:4/5;background:var(--cream);position:relative;overflow:hidden;
  border:1px solid var(--line);
}
.why-visual-inner{
  position:absolute;inset:40px;display:grid;grid-template-columns:repeat(2,1fr);gap:14px;
}
.domain-chip{
  background:#fff;padding:18px;border:1px solid var(--line);
  display:flex;flex-direction:column;justify-content:center;
  transition:all .4s var(--ease-out);
}
.domain-chip:hover{border-color:var(--gold);transform:translateY(-2px) scale(1.02);box-shadow:var(--shadow-sm)}
.domain-chip b{font-family:'Playfair Display',serif;font-size:16px;color:var(--ink);display:block;margin-bottom:4px}
.domain-chip small{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-dark)}
.why-copy .eyebrow{margin-bottom:20px}
.why-copy h2{font-size:clamp(32px,3.8vw,44px);margin-bottom:20px}
.why-copy p{color:var(--ink-soft);font-size:16px;margin-bottom:20px}
.why-list{list-style:none;display:flex;flex-direction:column;gap:18px;margin-top:28px}
.why-list li{display:flex;gap:18px;transition:transform .3s var(--ease-out)}
.why-list li:hover{transform:translateX(6px)}
.why-list .num{font-family:'Playfair Display',serif;font-size:22px;color:var(--gold);flex:none;line-height:1}
.why-list h4{font-size:17px;margin-bottom:4px;font-family:'Inter',sans-serif;font-weight:600}
.why-list p{font-size:14.5px;margin:0}
@media(max-width:900px){.why-grid{grid-template-columns:1fr}}

/* TESTIMONIAL */
.testi-bg{background:var(--cream)}
.testi{max-width:860px;margin:0 auto;text-align:center}
.testi blockquote{
  font-family:'Playfair Display',serif;font-size:clamp(26px,3.2vw,38px);
  font-weight:500;line-height:1.3;font-style:italic;color:var(--ink);
  margin:30px 0;
}
.testi blockquote::before{content:"“";font-size:80px;color:var(--gold);line-height:0;vertical-align:-20px;margin-right:8px}
.testi cite{font-style:normal;color:var(--ink-soft);font-size:14px;letter-spacing:.1em;text-transform:uppercase}

/* CTA */
.cta-bg{background:var(--ink);color:#fff;text-align:center;position:relative;overflow:hidden}
.cta-bg .container{position:relative;z-index:1}
.cta-bg h2{color:#fff;font-size:clamp(32px,4vw,48px);margin-bottom:16px}
.cta-bg p{color:rgba(255,255,255,.7);max-width:580px;margin:0 auto 32px}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.contact-info h2{font-size:clamp(30px,3.6vw,42px);margin:20px 0 18px}
.contact-info p{color:var(--ink-soft);margin-bottom:30px}
.contact-info .row{padding:18px 0;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;gap:20px;font-size:14.5px;transition:padding-left .3s var(--ease-out)}
.contact-info .row:hover{padding-left:8px}
.contact-info .row small{color:var(--muted);letter-spacing:.08em;text-transform:uppercase;font-size:11.5px;font-weight:600}
.contact-info .row b{color:var(--ink);font-weight:500}
.contact-form{background:var(--cream);padding:48px;position:relative;overflow:hidden}
.contact-form::before{
  content:"";position:absolute;top:0;left:0;width:0;height:3px;background:var(--gold);
  animation:fillTop 1.4s var(--ease-out) forwards;animation-delay:.3s;
}
@keyframes fillTop{to{width:100%}}
.contact-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:18px}
.contact-form .form-row.full{grid-template-columns:1fr}
.contact-form label{display:block;font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);font-weight:600;margin-bottom:6px}
.contact-form input,.contact-form select,.contact-form textarea{
  width:100%;padding:13px 0;border:none;border-bottom:1px solid var(--ink);
  background:transparent;font-family:inherit;font-size:15px;color:var(--ink);
  transition:border-color .3s, padding .3s;
}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{outline:none;border-color:var(--gold);padding-left:6px}
.contact-form button{margin-top:16px;width:100%;padding:18px}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr}.contact-form .form-row{grid-template-columns:1fr}}

/* FOOTER */
footer{background:var(--ink);color:rgba(255,255,255,.6);padding:72px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}
footer h4{color:#fff;margin-bottom:20px;font-family:'Inter',sans-serif;font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:600}
footer ul{list-style:none;display:flex;flex-direction:column;gap:12px;font-size:14px}
footer a{transition:color .2s, padding-left .2s}
footer a:hover{color:var(--gold-light);padding-left:4px}
.foot-brand p{max-width:320px;margin-top:16px;font-size:14px}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:12.5px;letter-spacing:.04em}
@media(max-width:900px){.foot-grid{grid-template-columns:1fr 1fr}}

/* ==========================================================================
   ANIMATIONS — Reveal on scroll
   ========================================================================== */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .55s var(--ease-out), transform .55s var(--ease-out)}
.reveal.in{opacity:1;transform:none}
.reveal-left{opacity:0;transform:translateX(-24px);transition:opacity .55s var(--ease-out), transform .55s var(--ease-out)}
.reveal-left.in{opacity:1;transform:none}
.reveal-right{opacity:0;transform:translateX(24px);transition:opacity .55s var(--ease-out), transform .55s var(--ease-out)}
.reveal-right.in{opacity:1;transform:none}
.reveal-scale{opacity:0;transform:scale(.96);transition:opacity .55s var(--ease-out), transform .55s var(--ease-out)}
.reveal-scale.in{opacity:1;transform:none}

/* Stagger delays (plus court) */
.stagger > *{transition-delay:0s}
.stagger > *:nth-child(1){transition-delay:.03s}
.stagger > *:nth-child(2){transition-delay:.08s}
.stagger > *:nth-child(3){transition-delay:.13s}
.stagger > *:nth-child(4){transition-delay:.18s}
.stagger > *:nth-child(5){transition-delay:.23s}
.stagger > *:nth-child(6){transition-delay:.28s}
.stagger > *:nth-child(7){transition-delay:.33s}
.stagger > *:nth-child(8){transition-delay:.38s}
.stagger > *:nth-child(9){transition-delay:.43s}

/* Animation entrée hero */
.hero-inner > *{animation:heroFadeUp 1s var(--ease-out) backwards}
.hero-inner > *:nth-child(1){animation-delay:.1s}
.hero-inner > *:nth-child(2){animation-delay:.25s}
.hero-inner > *:nth-child(3){animation-delay:.4s}
.hero-inner > *:nth-child(4){animation-delay:.55s}
.hero-inner > *:nth-child(5){animation-delay:.7s}
.hero-inner > *:nth-child(6){animation-delay:.85s}
@keyframes heroFadeUp{
  from{opacity:0;transform:translateY(30px)}
  to{opacity:1;transform:none}
}

/* Float subtle */
.float{animation:floatY 4s ease-in-out infinite}
@keyframes floatY{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-8px)}
}

/* Transitions douces sur cartes (sans animation au reveal) */
.value, .proc{transition:transform .35s var(--ease-out), box-shadow .35s var(--ease-out)}

/* Counter animation hint */
.counter[data-target]{display:inline-block}

/* Scroll progress bar */
.scroll-progress{
  position:fixed;top:0;left:0;height:2px;width:0;
  background:linear-gradient(90deg,var(--gold),var(--gold-light));
  z-index:100;transition:width .1s linear;
}

/* Page transition fade */
.page-transition{
  position:fixed;inset:0;background:var(--ink);
  z-index:9998;pointer-events:none;
  transform:scaleY(0);transform-origin:top;
  transition:transform .5s var(--ease-in-out);
}
.page-transition.active{transform:scaleY(1);transform-origin:bottom}

/* MODAL */
#modal-overlay{
  display:none;position:fixed;inset:0;background:rgba(10,14,26,.75);
  z-index:200;padding:20px;overflow-y:auto;backdrop-filter:blur(6px);
  align-items:center;justify-content:center;
  opacity:0;transition:opacity .3s ease;
}
#modal-overlay.open{display:flex;opacity:1}
.modal-box{
  background:#fff;max-width:640px;width:100%;padding:0;
  position:relative;max-height:90vh;overflow-y:auto;
  transform:translateY(30px) scale(.96);transition:transform .45s var(--ease-out);
}
#modal-overlay.open .modal-box{transform:translateY(0) scale(1)}
.modal-head{padding:36px 40px 24px;border-bottom:1px solid var(--line)}
.modal-body{padding:32px 40px 40px}
.modal-close{
  position:absolute;top:18px;right:18px;width:36px;height:36px;
  background:var(--cream);border:none;cursor:pointer;font-size:18px;color:var(--ink);
  display:grid;place-items:center;transition:all .3s var(--ease-out);
}
.modal-close:hover{background:var(--ink);color:#fff;transform:rotate(90deg)}
.modal-domain-name{font-family:'Playfair Display',serif;font-size:34px;font-weight:600;color:var(--ink);margin:12px 0 6px}
.modal-metrics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:24px 0;padding:20px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.modal-metric small{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:4px}
.modal-metric strong{font-family:'Playfair Display',serif;font-size:22px;color:var(--ink)}
.modal-price-row{display:flex;justify-content:space-between;align-items:center;margin:24px 0}
.modal-price-big{font-family:'Playfair Display',serif;font-size:30px;font-weight:600}
.modal-cta{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
  .reveal,.reveal-left,.reveal-right,.reveal-scale{opacity:1;transform:none}
}

/* ==========================================================================
   BREADCRUMB (visible) — ajouté en Phase 5
   ========================================================================== */
.breadcrumb{
  background:var(--cream);
  border-bottom:1px solid var(--line);
  padding:14px 0;
  font-size:13px;color:var(--ink-soft);
}
.breadcrumb ol{list-style:none;display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.breadcrumb li{display:flex;align-items:center;gap:8px}
.breadcrumb li:not(:last-child)::after{content:"›";color:var(--gold);font-weight:600;margin-left:8px}
.breadcrumb a{color:var(--ink-soft)}
.breadcrumb a:hover{color:var(--gold-dark)}
.breadcrumb [aria-current="page"]{color:var(--ink);font-weight:500}

/* ==========================================================================
   PAGE SECTEUR
   ========================================================================== */
.sector-hero{
  background:linear-gradient(180deg,#0A0E1A 0%,#141A2B 100%);
  color:#fff;padding:96px 0 72px;text-align:center;
}
.sector-hero .eyebrow{color:var(--gold-light)}
.sector-hero h1{font-size:clamp(36px,5vw,60px);margin:18px 0;color:#fff}
.sector-hero p{max-width:720px;margin:0 auto;color:#cfd5e3;font-size:18px}
.sector-stats{display:flex;justify-content:center;gap:60px;margin-top:48px;flex-wrap:wrap}
.sector-stats .stat{text-align:center}
.sector-stats .stat strong{display:block;font-family:'Playfair Display',serif;font-size:48px;color:var(--gold-light)}
.sector-stats .stat span{font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:#a8b0c4}

.sector-intro{padding:72px 0;background:var(--white)}
.sector-intro p{font-size:17px;color:var(--ink-soft);max-width:760px;margin:0 auto 18px;text-align:center}

.sector-domains{padding:48px 0 96px;background:var(--cream)}
.sector-domains-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;margin-top:32px}
.sector-domain-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:28px;transition:all .3s var(--ease-out)}
.sector-domain-card:hover{border-color:var(--gold);box-shadow:var(--shadow-sm);transform:translateY(-3px)}
.sector-domain-card .name{font-family:'Playfair Display',serif;font-size:22px;color:var(--ink);margin-bottom:8px;word-break:break-word}
.sector-domain-card .desc{color:var(--ink-soft);font-size:14px;margin-bottom:18px;line-height:1.55}
.sector-domain-card .meta{display:flex;gap:16px;font-size:12px;color:var(--muted);margin-bottom:18px;flex-wrap:wrap}
.sector-domain-card .meta b{color:var(--ink);font-weight:600}
.sector-domain-card .price{display:flex;justify-content:space-between;align-items:center;padding-top:16px;border-top:1px solid var(--line)}
.sector-domain-card .price strong{font-family:'Playfair Display',serif;color:var(--gold-dark);font-size:20px}

.sector-why{padding:96px 0;background:var(--white)}
.sector-why h2{font-size:clamp(28px,4vw,40px);text-align:center;margin-bottom:18px}
.sector-why .lead{text-align:center;max-width:720px;margin:0 auto 48px;color:var(--ink-soft)}
.sector-why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:28px}
.sector-why-card{padding:28px;border-left:3px solid var(--gold);background:var(--cream);border-radius:0 var(--radius) var(--radius) 0}
.sector-why-card h3{font-size:18px;margin-bottom:10px}
.sector-why-card p{color:var(--ink-soft);font-size:14px}

.sector-related{padding:72px 0;background:var(--cream);text-align:center}
.sector-related h2{margin-bottom:24px}
.sector-related-tags{display:flex;justify-content:center;flex-wrap:wrap;gap:12px;margin-top:24px}
.sector-related-tags a{display:inline-block;padding:10px 22px;border:1px solid var(--gold);border-radius:99px;color:var(--gold-dark);font-size:14px;font-weight:500;transition:all .25s}
.sector-related-tags a:hover{background:var(--gold);color:#fff}

/* ==========================================================================
   FAQ (Schema FAQPage)
   ========================================================================== */
.faq{padding:72px 0;background:var(--white)}
.faq h2{text-align:center;margin-bottom:32px;font-size:clamp(26px,3.5vw,36px)}
.faq-list{max-width:820px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line);padding:20px 0}
.faq-item summary{cursor:pointer;font-weight:600;font-size:17px;color:var(--ink);display:flex;justify-content:space-between;align-items:center;list-style:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:24px;color:var(--gold);transition:transform .25s}
.faq-item[open] summary::after{content:"−"}
.faq-item p{margin-top:14px;color:var(--ink-soft);line-height:1.7}

/* ==========================================================================
   BLOG
   ========================================================================== */
.blog-hero{background:var(--ink);color:#fff;padding:96px 0;text-align:center}
.blog-hero h1{color:#fff;font-size:clamp(36px,5vw,56px);margin-bottom:14px}
.blog-hero p{color:#cfd5e3;max-width:640px;margin:0 auto;font-size:17px}

.blog-grid{padding:72px 0;background:var(--cream)}
.blog-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:28px;margin-top:32px}
.blog-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:all .3s var(--ease-out);display:flex;flex-direction:column}
.blog-card:hover{border-color:var(--gold);box-shadow:var(--shadow-sm);transform:translateY(-3px)}
.blog-card .thumb{height:160px;background:linear-gradient(135deg,var(--ink) 0%,var(--ink-3) 100%);display:flex;align-items:center;justify-content:center;color:var(--gold-light);font-family:'Playfair Display',serif;font-size:42px;font-weight:700;letter-spacing:-.02em}
.blog-card .body{padding:24px;flex:1;display:flex;flex-direction:column}
.blog-card .cat{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-dark);margin-bottom:10px;font-weight:600}
.blog-card h3{font-size:19px;line-height:1.3;margin-bottom:10px;color:var(--ink)}
.blog-card p{font-size:14px;color:var(--ink-soft);line-height:1.55;margin-bottom:14px;flex:1}
.blog-card .read{color:var(--gold-dark);font-weight:600;font-size:13px;letter-spacing:.05em}

/* ==========================================================================
   ARTICLE (lecture)
   ========================================================================== */
.article{padding:48px 0 96px;background:var(--white)}
.article .container{max-width:760px}
.article .meta{font-size:13px;color:var(--muted);margin-bottom:14px}
.article .meta b{color:var(--ink)}
.article h1{font-size:clamp(30px,4vw,46px);line-height:1.15;margin-bottom:18px}
.article .lead{font-size:19px;color:var(--ink-soft);margin-bottom:32px;font-style:italic;line-height:1.55}
.article .toc{background:var(--cream);border-left:3px solid var(--gold);padding:20px 24px;margin:32px 0;border-radius:0 var(--radius) var(--radius) 0}
.article .toc h4{font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:12px;font-weight:600}
.article .toc ol{list-style:none;counter-reset:toc}
.article .toc li{counter-increment:toc;padding:6px 0;font-size:15px}
.article .toc li::before{content:counter(toc) ". ";color:var(--gold);font-weight:600;margin-right:6px}
.article .toc a{color:var(--ink)}
.article .toc a:hover{color:var(--gold-dark)}
.article h2{font-size:28px;margin:48px 0 18px;color:var(--ink);scroll-margin-top:90px}
.article h3{font-size:21px;margin:32px 0 14px;color:var(--ink)}
.article p{margin-bottom:18px;color:var(--ink);font-size:17px;line-height:1.75}
.article ul,.article ol{margin:0 0 22px 22px;color:var(--ink);font-size:17px;line-height:1.75}
.article ul li,.article ol li{margin-bottom:8px}
.article blockquote{border-left:3px solid var(--gold);padding:14px 22px;margin:28px 0;font-style:italic;color:var(--ink-soft);background:var(--cream)}
.article a.inline{color:var(--gold-dark);text-decoration:underline;text-decoration-color:rgba(184,147,90,.4);text-underline-offset:3px}
.article a.inline:hover{text-decoration-color:var(--gold-dark)}
.article .article-cta{background:linear-gradient(135deg,var(--ink) 0%,var(--ink-3) 100%);color:#fff;padding:32px;border-radius:var(--radius);margin:40px 0;text-align:center}
.article .article-cta h3{color:#fff;margin-bottom:10px}
.article .article-cta p{color:#cfd5e3;margin-bottom:20px}
.article .article-cta .btn{margin:0 6px}

/* ==========================================================================
   PAGES LEGALES (mentions, RGPD, CGV, à propos)
   ========================================================================== */
.legal-page{padding:64px 0 96px;background:var(--white)}
.legal-page .container{max-width:780px}
.legal-page h1{font-size:clamp(30px,4vw,42px);margin-bottom:24px}
.legal-page h2{font-size:22px;margin:36px 0 14px;color:var(--ink)}
.legal-page p,.legal-page li{color:var(--ink);line-height:1.7;margin-bottom:14px}
.legal-page ul{margin:0 0 18px 22px}
.legal-page strong{color:var(--ink)}
