/* ============================================================
   SEOKA — DESIGN SYSTEM v2 CINÉMA (partagé par toutes les pages)
   Source : Home validée le 2026-06-03.
   ============================================================ */

  :root{
    --bg:#0B1220;
    --bg-2:#14202F;
    --bg-deep:#060A14;
    --cream:#E8E4D8;
    --muted:#6E7787;
    --silver:#8A9CA8;
    --paper:#E3DCC9;
    --green:#7C9A7C;
    --amber:#C9B47A;

    --serif:"DM Serif Display", Georgia, serif;
    --sans:"Manrope", system-ui, sans-serif;
    --mono:"Space Mono", "Courier New", monospace;

    --maxw:1200px;
    --gutter:clamp(24px,5vw,80px);
  }

  *{box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{
    margin:0;
    background:var(--bg);
    color:var(--cream);
    font-family:var(--sans);
    font-weight:400;
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
    letter-spacing:.005em;
  }

  /* ===== ATMOSPHERE: grain + vignette (fixed overlays over everything) ===== */
  .grain{
    position:fixed; inset:-150%; z-index:9998; pointer-events:none;
    width:400%; height:400%;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    opacity:.05;
    mix-blend-mode:overlay;
    animation:grain 1s steps(6) infinite;
  }
  @keyframes grain{
    0%{transform:translate(0,0)} 10%{transform:translate(-3%,-2%)}
    20%{transform:translate(2%,3%)} 30%{transform:translate(-2%,2%)}
    40%{transform:translate(3%,-3%)} 50%{transform:translate(-3%,2%)}
    60%{transform:translate(2%,-2%)} 70%{transform:translate(-2%,-3%)}
    80%{transform:translate(3%,2%)} 90%{transform:translate(-3%,-1%)}
    100%{transform:translate(0,0)}
  }
  /* global cursor halo — a lamp moving through the dark across the whole page */
  .page-glow{
    position:fixed; top:0; left:0; width:760px; height:760px; z-index:1; pointer-events:none;
    transform:translate(-50%,-50%); opacity:0; transition:opacity .8s ease;
    background:radial-gradient(circle, rgba(120,150,178,.13) 0%, rgba(120,150,178,.04) 38%, transparent 66%);
    mix-blend-mode:screen; will-change:transform;
  }
  .vignette{
    position:fixed; inset:0; z-index:9997; pointer-events:none;
    background:
      radial-gradient(125% 105% at 50% 42%, transparent 52%, rgba(3,6,12,.55) 86%, rgba(2,4,9,.9) 100%);
    mix-blend-mode:multiply;
  }
  @media (prefers-reduced-motion: reduce){
    .grain{animation:none;}
    html{scroll-behavior:auto;}
  }

  .wrap{ max-width:var(--maxw); margin:0 auto; padding-left:var(--gutter); padding-right:var(--gutter); }

  /* ===== TYPE ===== */
  h1,h2,h3{ margin:0; font-weight:400; }
  .serif{ font-family:var(--serif); }
  .label{
    font-family:var(--mono); text-transform:uppercase; font-size:12.5px;
    letter-spacing:.32em; color:var(--silver);
  }
  .num{ font-family:var(--mono); color:var(--silver); letter-spacing:.18em; }
  p{ margin:0; }
  a{ color:inherit; text-decoration:none; }

  /* ===== BUTTONS ===== */
  .btns{ display:flex; flex-wrap:wrap; gap:16px; }
  .btn{
    font-family:var(--mono); text-transform:uppercase; letter-spacing:.16em;
    font-size:12.5px; padding:16px 30px; border-radius:2px; cursor:pointer;
    display:inline-flex; align-items:center; gap:10px; transition:.35s cubic-bezier(.2,.7,.3,1);
    border:1px solid transparent; position:relative; isolation:isolate;
  }
  .btn-solid{
    background:var(--cream); color:#0B1220; font-weight:700;
    box-shadow:0 14px 40px -16px rgba(232,228,216,.5), 0 2px 0 rgba(0,0,0,.4);
  }
  .btn-solid:hover{ transform:translateY(-2px); box-shadow:0 22px 56px -16px rgba(232,228,216,.65); }
  .btn-ghost{
    background:transparent; color:var(--cream);
    border:1px solid rgba(138,156,168,.38);
  }
  .btn-ghost:hover{
    border-color:rgba(138,156,168,.9);
    box-shadow:0 0 0 1px rgba(138,156,168,.15), 0 0 28px -6px rgba(138,156,168,.35);
    background:rgba(138,156,168,.05);
  }
  .btn .arrow{ transition:transform .35s; }
  .btn:hover .arrow{ transform:translateX(4px); }

  /* hairline rule with faint silver luminescence */
  .rule{ height:1px; border:0; background:linear-gradient(90deg, transparent, rgba(138,156,168,.4) 18%, rgba(138,156,168,.4) 82%, transparent); box-shadow:0 0 12px rgba(138,156,168,.12); }

  /* ===== SECTIONS (soft vertical fades between the three darks, no hard cuts) ===== */
  section{ position:relative; }
  .sec-pad{ padding:clamp(112px,14vh,196px) 0; }
  .eyebrow{ display:flex; align-items:center; gap:18px; margin-bottom:32px; }
  .eyebrow .line{ width:46px; height:1px; background:rgba(138,156,168,.5); }
  .h2{ font-family:var(--serif); font-size:clamp(34px,5vw,60px); line-height:1.04; letter-spacing:-.01em; }
  .lede{ color:var(--silver); font-size:clamp(16px,1.4vw,19px); max-width:48ch; margin-top:26px; line-height:1.7; }

  .reveal{ opacity:0; transform:translateY(26px); transition:opacity 1.1s ease, transform 1.1s cubic-bezier(.2,.7,.3,1); }
  .reveal.in{ opacity:1; transform:none; }
  .no-js .reveal, .reveal.shown{ opacity:1 !important; transform:none !important; transition:none !important; }
  @media (prefers-reduced-motion: reduce){ .reveal{ opacity:1 !important; transform:none !important; transition:none; } }

  /* ================= HEADER ================= */
  header{
    position:fixed; top:0; left:0; right:0; z-index:200;
    transition:background .5s ease, backdrop-filter .5s ease, border-color .5s;
    border-bottom:1px solid transparent;
  }
  header.scrolled{
    background:rgba(6,10,20,.72); backdrop-filter:blur(14px) saturate(.9);
    border-bottom:1px solid rgba(138,156,168,.12);
  }
  .nav{ display:flex; align-items:center; justify-content:space-between; padding:22px 0; }
  .wordmark{ font-family:var(--serif); font-size:25px; letter-spacing:.02em; color:var(--cream); }
  .wordmark::after{ content:"·"; color:var(--silver); margin-left:8px; opacity:.6; }
  .nav-links{ display:flex; gap:30px; align-items:center; }
  .nav-links a{
    font-family:var(--mono); font-size:12px; text-transform:uppercase; letter-spacing:.14em;
    color:var(--muted); transition:color .3s; position:relative;
  }
  .nav-links a::after{ content:""; position:absolute; left:0; bottom:-5px; width:0; height:1px; background:var(--silver); transition:width .35s; }
  .nav-links a:hover{ color:var(--cream); }
  .nav-links a:hover::after{ width:100%; }
  .menu-btn{ display:none; background:none; border:0; color:var(--cream); cursor:pointer; font-family:var(--mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase; }

  /* ================= HERO ================= */
  .hero{
    position:relative; min-height:100vh; display:flex; align-items:center;
    padding-top:120px; padding-bottom:90px; overflow:hidden;
    background:
      linear-gradient(180deg, var(--bg-deep) 0%, #08101D 46%, var(--bg) 100%);
  }
  /* the "desk-lamp" halo behind the hero */
  .hero-light{
    position:absolute; inset:0; pointer-events:none; z-index:0;
    background:
      radial-gradient(60% 50% at 62% 30%, rgba(86,120,150,.30) 0%, rgba(40,64,92,.12) 36%, transparent 68%),
      radial-gradient(40% 60% at 20% 80%, rgba(20,32,47,.7) 0%, transparent 60%);
    mix-blend-mode:screen;
  }
  /* faint suggestion of a room: shelves / fog, all blurred & very dark */
  .hero-room{
    position:absolute; inset:0; z-index:0; pointer-events:none; opacity:.5;
    background:
      repeating-linear-gradient(90deg, transparent 0 78px, rgba(138,156,168,.035) 78px 80px),
      repeating-linear-gradient(0deg, transparent 0 120px, rgba(138,156,168,.03) 120px 122px),
      radial-gradient(80% 60% at 50% 120%, rgba(15,24,38,.9), transparent 70%);
    filter:blur(2px);
    -webkit-mask-image:radial-gradient(70% 70% at 60% 40%, black, transparent 75%);
            mask-image:radial-gradient(70% 70% at 60% 40%, black, transparent 75%);
  }
  /* cursor-following glow */
  .hero-cursor{
    position:absolute; top:0; left:0; width:620px; height:620px; z-index:0; pointer-events:none;
    transform:translate(-50%,-50%); opacity:0; transition:opacity .6s;
    background:radial-gradient(circle, rgba(120,150,178,.16) 0%, rgba(120,150,178,.05) 35%, transparent 68%);
    mix-blend-mode:screen;
  }
  .hero-veil{ position:absolute; inset:0; z-index:1; pointer-events:none;
    background:linear-gradient(180deg, rgba(6,10,20,.25), rgba(6,10,20,0) 30%, rgba(11,18,32,.35)); }

  .hero-inner{ position:relative; z-index:3; display:grid; grid-template-columns:1fr; gap:60px; align-items:center; width:100%; }
  .hero-copy{ max-width:820px; }
  .stamp{
    display:inline-flex; align-items:center; gap:14px; padding:9px 16px; margin-bottom:34px;
    border:1px solid rgba(138,156,168,.32); border-radius:2px;
    font-family:var(--mono); font-size:11.5px; letter-spacing:.26em; text-transform:uppercase; color:var(--silver);
    background:rgba(138,156,168,.04); box-shadow:inset 0 0 22px rgba(138,156,168,.05);
  }
  .stamp .dot{ width:7px; height:7px; border-radius:50%; background:var(--amber); box-shadow:0 0 10px var(--amber); animation:pulse 3.2s ease-in-out infinite; }
  @keyframes pulse{ 0%,100%{opacity:.45} 50%{opacity:1} }
  .surtitle{ font-family:var(--mono); font-size:13px; letter-spacing:.3em; text-transform:uppercase; color:var(--silver); margin-bottom:24px; }
  .hero h1{
    font-family:var(--serif); font-size:clamp(38px,6.3vw,82px); line-height:1.03; letter-spacing:-.015em; color:var(--cream);
    text-shadow:0 2px 40px rgba(0,0,0,.6);
  }
  .hero h1 .glow{ color:#F2EEE2; }
  .hero-sub{ margin-top:30px; font-size:clamp(17px,1.5vw,21px); color:var(--silver); }
  .hero-sub b{ color:var(--cream); font-weight:600; }
  .hero .btns{ margin-top:46px; }

  /* hero footer line (best of both : repère + indicateur de scroll) */
  .hero-foot{
    position:absolute; left:50%; transform:translateX(-50%); bottom:34px; z-index:3;
    width:min(var(--maxw),100%); padding-left:var(--gutter); padding-right:var(--gutter);
    display:flex; justify-content:space-between; align-items:center;
  }
  .hero-foot__meta,
  .hero-foot__scroll{ font-family:var(--mono); font-size:11.5px; letter-spacing:.22em; text-transform:uppercase; color:var(--silver); }
  .hero-foot__scroll{ display:flex; align-items:center; gap:12px; }
  .hero-foot__line{ width:34px; height:1px; background:var(--silver); display:inline-block; position:relative; overflow:hidden; }
  .hero-foot__line::after{ content:""; position:absolute; inset:0; left:-100%; background:var(--cream); animation:scrollpulse 2.4s ease-in-out infinite; }
  @keyframes scrollpulse{ 0%{left:-100%} 60%{left:100%} 100%{left:100%} }

  /* ================= "CE QU'ON FAIT" ================= */
  .s-fait{ background:linear-gradient(180deg, var(--bg) 0%, #101A28 55%, var(--bg-2) 100%); }
  .three{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; margin-top:80px; background:rgba(138,156,168,.14); border:1px solid rgba(138,156,168,.14); }
  .three .cell{ background:linear-gradient(180deg, rgba(11,18,32,.6), rgba(6,10,20,.6)); padding:46px 38px 52px; transition:background .5s; }
  .three .cell:hover{ background:linear-gradient(180deg, rgba(20,32,47,.85), rgba(11,18,32,.85)); }
  .three .num{ font-size:13px; display:block; margin-bottom:30px; }
  .three h3{ font-family:var(--serif); font-size:27px; line-height:1.1; margin-bottom:16px; color:var(--cream); }
  .three p{ color:var(--silver); font-size:16px; line-height:1.72; }

  /* ================= AFFAIRES ================= */
  .s-affaires{ background:linear-gradient(180deg, var(--bg-2) 0%, #101A28 50%, var(--bg) 100%); }
  .cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:32px; margin-top:80px; }
  .card{
    position:relative; padding:34px 32px 36px; border:1px solid rgba(138,156,168,.16); border-radius:3px;
    background:linear-gradient(180deg, rgba(20,32,47,.55), rgba(6,10,20,.65));
    box-shadow:0 30px 60px -34px rgba(0,0,0,.9), inset 0 1px 0 rgba(255,255,255,.02);
    transition:transform .45s cubic-bezier(.2,.7,.3,1), box-shadow .45s, border-color .45s;
    overflow:hidden;
  }
  .card::before{ content:""; position:absolute; inset:0; opacity:0; transition:opacity .5s;
    background:radial-gradient(120% 80% at 50% 0%, rgba(138,156,168,.1), transparent 60%); }
  .card:hover{ transform:translateY(-6px); border-color:rgba(138,156,168,.4);
    box-shadow:0 44px 80px -34px rgba(0,0,0,1), 0 0 40px -10px rgba(138,156,168,.18); }
  .card:hover::before{ opacity:1; }
  .card-status{ display:flex; align-items:center; gap:10px; font-family:var(--mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; margin-bottom:26px; }
  .card-status .s-dot{ width:8px; height:8px; border-radius:50%; }
  .st-green{ color:var(--green); } .st-green .s-dot{ background:var(--green); box-shadow:0 0 10px var(--green); }
  .st-amber{ color:var(--amber); } .st-amber .s-dot{ background:var(--amber); box-shadow:0 0 10px var(--amber); }
  .st-silver{ color:var(--silver); } .st-silver .s-dot{ background:var(--silver); box-shadow:0 0 10px var(--silver); }
  .card h3{ font-family:var(--serif); font-size:23px; color:var(--cream); margin-bottom:14px; line-height:1.15; }
  .card p{ color:var(--silver); font-size:15.5px; line-height:1.7; }
  .card .file-no{ position:absolute; top:30px; right:26px; font-family:var(--mono); font-size:11px; color:rgba(138,156,168,.45); letter-spacing:.12em; }

  /* ================= COMMENT ON TRAVAILLE ================= */
  .s-method{ background:linear-gradient(180deg, var(--bg) 0%, #101A28 52%, var(--bg-2) 100%); }
  .principles{ margin-top:80px; border-top:1px solid rgba(138,156,168,.16); }
  .principle{ display:grid; grid-template-columns:64px minmax(0,.9fr) minmax(0,1.1fr); gap:44px; align-items:start;
    padding:48px 0; border-bottom:1px solid rgba(138,156,168,.16); transition:background .4s; }
  .principle:hover{ background:rgba(138,156,168,.03); }
  .principle .pn{ font-family:var(--mono); color:var(--silver); font-size:13px; padding-top:6px; }
  .principle h3{ font-family:var(--serif); font-size:25px; color:var(--cream); line-height:1.12; }
  .principle p{ color:var(--silver); font-size:16px; line-height:1.72; }

  /* ================= POUR QUI ================= */
  .s-pourqui{ background:linear-gradient(180deg, var(--bg-2) 0%, #101A28 50%, var(--bg) 100%); }
  .crit{ display:grid; grid-template-columns:repeat(2,1fr); gap:36px; margin-top:80px; }
  .crit-item{ display:grid; grid-template-columns:auto 1fr; gap:30px; align-items:start;
    padding:42px 40px; border:1px solid rgba(138,156,168,.14); border-radius:3px;
    background:linear-gradient(180deg, rgba(20,32,47,.4), rgba(6,10,20,.5)); transition:.45s; }
  .crit-item:hover{ border-color:rgba(138,156,168,.34); box-shadow:0 0 36px -12px rgba(138,156,168,.2); }
  .crit-item .cn{ font-family:var(--mono); font-size:30px; color:rgba(138,156,168,.55); line-height:1; }
  .crit-item p{ color:var(--cream); font-size:17px; line-height:1.62; }

  /* ================= CE QU'ON NE FAIT PAS ================= */
  .s-nope{ background:linear-gradient(180deg, var(--bg) 0%, #070C16 60%, var(--bg-deep) 100%); }
  .carton{ position:relative; text-align:center; padding:78px 20px 84px; margin-top:18px;
    border-top:1px solid rgba(138,156,168,.16); border-bottom:1px solid rgba(138,156,168,.16); overflow:hidden; }
  .carton::before{ content:""; position:absolute; inset:0; z-index:0;
    background:radial-gradient(60% 120% at 50% 50%, rgba(86,120,150,.2), transparent 64%); }
  .carton .pull{ position:relative; z-index:1; font-family:var(--serif); font-size:clamp(30px,5.2vw,62px); line-height:1.1; color:var(--cream);
    letter-spacing:-.01em; text-shadow:0 2px 50px rgba(120,150,178,.3); max-width:18ch; margin:0 auto; }
  .nope-table{ margin-top:62px; border-top:1px solid rgba(138,156,168,.16); }
  .nope-head{ display:grid; grid-template-columns:1fr 1.2fr; gap:30px; padding:18px 0; }
  .nope-head span{ font-family:var(--mono); font-size:11px; letter-spacing:.24em; text-transform:uppercase; color:rgba(138,156,168,.6); }
  .nope-row{ display:grid; grid-template-columns:1fr 1.2fr; gap:30px; padding:30px 0; border-top:1px solid rgba(138,156,168,.12); align-items:baseline; transition:background .4s; }
  .nope-row:hover{ background:rgba(138,156,168,.03); }
  .nope-row .refus{ font-family:var(--serif); font-size:23px; color:var(--cream); line-height:1.18; }
  .nope-row .why{ color:var(--silver); font-size:16px; line-height:1.7; }

  /* ================= À PROPOS ================= */
  .s-about{ background:linear-gradient(180deg, var(--bg-deep) 0%, #0C1624 55%, var(--bg-2) 100%); }
  .about-grid{ display:grid; grid-template-columns:1fr; gap:56px; align-items:start; margin-top:64px; max-width:880px; }
  .about-p1{ font-family:var(--serif); font-size:clamp(22px,2.4vw,30px); line-height:1.34; color:var(--cream); max-width:760px; }
  .about-p2{ color:var(--silver); font-size:17px; line-height:1.78; }
  .about-p2 b{ color:var(--cream); font-weight:600; }
  .about-side{ padding-left:40px; border-left:1px solid rgba(138,156,168,.3); margin-left:8px; max-width:680px; }

  /* ================= CTA FINAL ================= */
  .s-cta{ position:relative; background:linear-gradient(180deg, var(--bg-2) 0%, #070C16 55%, var(--bg-deep) 100%); overflow:hidden;
    text-align:left; padding:clamp(120px,15vh,190px) 0; }
  .cta-seal{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:min(620px,82vw); height:min(620px,82vw);
    z-index:0; opacity:.5; }
  .cta-seal svg .ring{ stroke:rgba(138,156,168,.3); }
  .cta-seal svg .cross{ stroke:rgba(232,228,216,.25); }
  .cta-vig{ position:absolute; inset:0; z-index:1; pointer-events:none;
    background:radial-gradient(70% 70% at 50% 50%, transparent 38%, rgba(3,6,12,.7) 88%); }
  .cta-inner{ position:relative; z-index:2; max-width:880px; }
  .cta-line{ font-family:var(--serif); font-size:clamp(34px,5vw,58px); line-height:1.1; color:var(--cream); letter-spacing:-.01em;
    text-shadow:0 2px 60px rgba(0,0,0,.7); }
  .cta-line .l2{ display:block; color:#F2EEE2; }
  .s-cta .btns{ justify-content:flex-start; margin-top:64px; }
  .s-cta .btn-solid{ padding:20px 44px; font-size:13.5px; box-shadow:0 0 60px -10px rgba(232,228,216,.55), 0 18px 50px -16px rgba(232,228,216,.5); }

  /* ================= FOOTER ================= */
  footer{ background:var(--bg-deep); padding:64px 0 42px; }
  .foot-rule{ margin-bottom:44px; }
  .foot-cols{ display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:40px; }
  .foot-brand .foot-mark{ font-family:var(--serif); font-size:30px; color:var(--cream); }
  .foot-base{ font-family:var(--mono); font-size:11.5px; letter-spacing:.22em; text-transform:uppercase; color:var(--silver); margin-top:12px; }
  .foot-col-title{ font-family:var(--mono); font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--silver); margin-bottom:16px; }
  .foot-list{ list-style:none; padding:0; margin:0; }
  .foot-list li{ margin-bottom:10px; }
  .foot-list a{ font-family:var(--sans); font-size:14px; color:var(--muted); transition:color .3s; }
  .foot-list a:hover{ color:var(--cream); }
  .foot-bottom{ display:flex; justify-content:space-between; align-items:center; gap:20px; flex-wrap:wrap;
    margin-top:46px; padding-top:24px; border-top:1px solid rgba(138,156,168,.12);
    font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--silver); }
  .foot-bottom a{ color:inherit; }
  .foot-bottom a:hover{ color:var(--cream); }

  /* ================= CARVE-OUTS SEOKA ================= */
  /* Copywriting repris du prototype A (pull quote méthode, lien affaire, surtitre CTA) */
  .method-quote{ font-family:var(--serif); font-style:italic; font-size:clamp(24px,3vw,36px); line-height:1.25; color:var(--cream); max-width:760px; margin-top:36px; padding-left:26px; border-left:2px solid var(--silver); }
  .method-quote__attr{ display:block; margin-top:18px; font-family:var(--mono); font-style:normal; font-size:12.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--silver); }
  .card .card-link{ display:inline-flex; align-items:center; gap:8px; margin-top:26px; font-family:var(--sans); font-size:14px; font-weight:500; color:var(--cream); }
  .card .card-link .arrow{ transition:transform .35s; }
  .card:hover .card-link{ color:#F2EEE2; }
  .card:hover .card-link .arrow{ transform:translateX(4px); }
  .cta-eyebrow{ font-family:var(--mono); font-size:12.5px; letter-spacing:.3em; text-transform:uppercase; color:var(--silver); margin-bottom:26px; }

  /* À propos : sceau viseur en watermark (sceau conservé hors Hero) */
  .s-about{ overflow:hidden; }
  .about-seal{ position:absolute; right:-90px; top:50%; transform:translateY(-50%); width:360px; height:360px;
    opacity:.05; color:var(--silver); pointer-events:none; z-index:0; }
  .s-about .wrap{ position:relative; z-index:1; }

  /* Section 6 « Ce qu'on ne fait pas » : fond CLAIR (pour la piste d'empreintes) */
  .s-nope--light{ background:linear-gradient(180deg,#ECE8DC 0%, #E3DCC9 55%, #E8E4D8 100%); color:#0B1220; }
  .s-nope--light .label{ color:#5b6470; }
  .s-nope--light .eyebrow .line{ background:rgba(11,18,32,.4); }
  .s-nope--light .h2{ color:#0B1220; }
  .s-nope--light .carton{ border-color:rgba(11,18,32,.18); }
  .s-nope--light .carton::before{ background:radial-gradient(60% 120% at 50% 50%, rgba(86,120,150,.1), transparent 64%); }
  .s-nope--light .carton .pull{ color:#0B1220; text-shadow:none; }
  .s-nope--light .nope-table{ border-color:rgba(11,18,32,.18); }
  .s-nope--light .nope-head span{ color:rgba(11,18,32,.55); }
  .s-nope--light .nope-row{ border-color:rgba(11,18,32,.14); }
  .s-nope--light .nope-row:hover{ background:rgba(11,18,32,.03); }
  .s-nope--light .nope-row .refus{ color:#0B1220; }
  .s-nope--light .nope-row .why{ color:#4a5763; }
  .s-nope--light .btn-ghost{ color:#0B1220; border-color:rgba(11,18,32,.32); }
  .s-nope--light .btn-ghost:hover{ border-color:#0B1220; background:rgba(11,18,32,.05); box-shadow:none; }

  /* Section 6 : traînée d'empreintes de pas (piste de filature) */
  .s-nope{ position:relative; }
  .s-nope .wrap{ position:relative; z-index:2; }
  .fx-steps{ position:absolute; inset:0; z-index:1; pointer-events:none; overflow:hidden; }
  .fx-step{ position:absolute; top:0; left:0; color:rgba(6,9,16,.46); opacity:0; will-change:transform,opacity; }
  .fx-step svg{ display:block; }
  @media (hover:none),(pointer:coarse){ .fx-steps{ display:none; } }

  /* ================= RESPONSIVE ================= */
  @media (max-width:1000px){
    .hero-inner{ grid-template-columns:1fr; }
    .three{ grid-template-columns:1fr; }
    .cards{ grid-template-columns:1fr; }
    .crit{ grid-template-columns:1fr; }
    .principle{ grid-template-columns:48px 1fr; }
    .principle p{ grid-column:1/-1; padding-left:0; }
    .about-grid{ gap:40px; }
    .about-side{ padding-left:24px; }
    .about-seal{ display:none; }
  }
  @media (max-width:720px){
    .nav-links{ display:none; }
    .menu-btn{ display:block; }
    .nav-links.open{ display:flex; position:absolute; top:100%; right:var(--gutter); left:var(--gutter);
      flex-direction:column; gap:18px; padding:24px; background:rgba(6,10,20,.96); backdrop-filter:blur(14px);
      border:1px solid rgba(138,156,168,.18); border-radius:3px; }
    .nope-head, .nope-row{ grid-template-columns:1fr; gap:10px; }
    .carton{ padding:54px 16px 58px; }
    .hero-foot{ display:none; }
    .foot-cols{ grid-template-columns:1fr 1fr; gap:28px; }
    .foot-brand{ grid-column:1/-1; }
    .foot-bottom{ flex-direction:column; align-items:flex-start; gap:10px; }
  }

  /* ================= NAV : état actif ================= */
  .nav-links a.is-active{ color:var(--cream); }
  .nav-links a.is-active::after{ width:100%; }

  /* ================= NAV : dropdown "Le cabinet" ================= */
  .nav-dd{ position:relative; }
  .nav-dd__trigger{
    font-family:var(--mono); font-size:12px; text-transform:uppercase; letter-spacing:.14em;
    color:var(--muted); background:none; border:0; cursor:pointer; padding:0;
    display:inline-flex; align-items:center; gap:7px; transition:color .3s;
  }
  .nav-dd__trigger .caret{ font-size:9px; color:var(--silver); transition:transform .35s, color .3s; }
  .nav-dd:hover .nav-dd__trigger,
  .nav-dd:focus-within .nav-dd__trigger,
  .nav-dd__trigger.is-active{ color:var(--cream); }
  .nav-dd:hover .caret,
  .nav-dd:focus-within .caret{ transform:rotate(180deg); color:var(--cream); }
  .nav-dd__menu{
    position:absolute; top:calc(100% + 16px); left:50%;
    min-width:212px; padding:10px 0;
    background:rgba(6,10,20,.94); backdrop-filter:blur(16px) saturate(.9);
    border:1px solid rgba(138,156,168,.18); border-radius:2px;
    box-shadow:0 24px 60px -20px rgba(0,0,0,.7);
    opacity:0; visibility:hidden; pointer-events:none;
    transform:translateX(-50%) translateY(6px);
    transition:opacity .28s ease, transform .28s ease;
  }
  .nav-dd:hover .nav-dd__menu,
  .nav-dd:focus-within .nav-dd__menu{
    opacity:1; visibility:visible; pointer-events:auto;
    transform:translateX(-50%) translateY(0);
  }
  .nav-dd__menu::before{ content:""; position:absolute; top:-16px; left:0; right:0; height:16px; }
  .nav-dd__menu a{
    display:block; padding:11px 22px;
    font-family:var(--mono); font-size:11.5px; text-transform:uppercase; letter-spacing:.13em;
    color:var(--muted); transition:color .25s, background .25s;
  }
  .nav-dd__menu a:hover,
  .nav-dd__menu a.is-active{ color:var(--cream); background:rgba(138,156,168,.07); }
  .nav-dd__menu a::after{ display:none; }

  /* dropdown sur mobile : déplié en liste statique centrée (pas de survol au tactile) */
  @media (max-width:720px){
    .nav-dd__trigger{ pointer-events:none; }
    .nav-dd__menu{ position:static; transform:none; opacity:1; visibility:visible; pointer-events:auto;
      min-width:0; padding:14px 0 2px; background:none; border:0; box-shadow:none; backdrop-filter:none;
      text-align:center; }
    .nav-dd__menu::before{ display:none; }
    .nav-dd__menu a{ padding:8px 0; }
  }

  /* ================= PAGES INTÉRIEURES ================= */
  /* En-tête de page (bandeau court, pas plein écran) */
  .page-head{ position:relative; overflow:hidden;
    padding:clamp(150px,20vh,232px) 0 clamp(56px,8vh,90px);
    background:linear-gradient(180deg, var(--bg-deep) 0%, #08101D 55%, var(--bg) 100%); }
  .page-head__light{ position:absolute; inset:0; pointer-events:none; z-index:0;
    background:radial-gradient(60% 60% at 70% 18%, rgba(86,120,150,.22) 0%, transparent 66%); mix-blend-mode:screen; }
  .page-head__seal{ position:absolute; right:-100px; top:50%; transform:translateY(-50%);
    width:440px; height:440px; opacity:.06; color:var(--silver); pointer-events:none; z-index:1; }
  .page-head .wrap{ position:relative; z-index:2; }
  .page-head h1{ font-family:var(--serif); font-size:clamp(40px,6vw,76px); line-height:1.04;
    letter-spacing:-.015em; color:var(--cream); margin-top:6px; }
  .page-head__lede{ color:var(--silver); font-size:clamp(17px,1.6vw,21px); line-height:1.6; max-width:60ch; margin-top:28px; }

  /* Blocs de prose (sections de contenu) */
  .prose-sec{ position:relative; }
  .prose-sec--alt{ background:linear-gradient(180deg, var(--bg-2) 0%, #101A28 55%, var(--bg-2) 100%); }
  .prose-sec__inner{ max-width:760px; }
  .prose{ margin-top:44px; }
  .prose p{ font-size:18px; line-height:1.78; color:var(--cream); opacity:.9; margin-bottom:22px; }
  .prose p:last-child{ margin-bottom:0; }
  .prose strong{ font-weight:600; color:var(--cream); opacity:1; }
  .prose em{ font-style:italic; color:var(--cream); }

  /* Pied éditorial + CTA (aligné gauche, aéré) */
  .page-outro{ position:relative; overflow:hidden; padding:clamp(96px,13vh,170px) 0;
    background:linear-gradient(180deg, var(--bg) 0%, #070C16 60%, var(--bg-deep) 100%); }
  .page-outro__seal{ position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
    width:min(560px,80vw); height:min(560px,80vw); opacity:.05; color:var(--silver); pointer-events:none; z-index:0; }
  .page-outro .wrap{ position:relative; z-index:2; }
  .page-outro__text{ font-family:var(--serif); font-size:clamp(28px,3.4vw,40px); line-height:1.2;
    color:var(--cream); max-width:720px; margin-bottom:48px; }
  .page-outro__text em{ display:block; color:#F2EEE2; }

  @media (max-width:900px){
    .page-head__seal{ display:none; }
  }

  /* ================= PAGES LÉGALES ================= */
  .legal__inner{ max-width:760px; }
  .legal h2{ font-family:var(--serif); font-size:28px; color:var(--cream); margin:48px 0 18px; line-height:1.2; }
  .legal h2:first-of-type{ margin-top:0; }
  .legal h3{ font-family:var(--serif); font-size:20px; color:var(--cream); opacity:.92; margin:28px 0 12px; }
  .legal p, .legal li{ font-size:16px; line-height:1.78; color:var(--cream); opacity:.85; margin-bottom:16px; }
  .legal a{ color:var(--cream); text-decoration:underline; text-decoration-color:var(--silver); }
  .legal a:hover{ color:#F2EEE2; }
  .legal ul{ margin:0 0 20px 22px; }
  .legal li{ margin-bottom:8px; }
  .legal strong{ color:var(--cream); opacity:1; font-weight:600; }
  .legal__note{ background:rgba(138,156,168,.06); border:1px solid rgba(138,156,168,.28); border-radius:3px;
    padding:16px 20px; margin-bottom:36px; font-family:var(--mono); font-size:13px; line-height:1.6; color:var(--silver); letter-spacing:.02em; }
  .legal__updated{ margin-top:44px; padding-top:18px; border-top:1px solid rgba(138,156,168,.18);
    font-family:var(--mono); font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--silver); }

  /* ================= FORMULAIRE CONTACT ================= */
  .form{ max-width:560px; }
  .form-group{ margin-bottom:26px; }
  .form-label{ display:block; font-family:var(--sans); font-weight:500; font-size:14px; color:var(--cream); margin-bottom:10px; letter-spacing:.01em; }
  .form-optional{ font-family:var(--mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--silver); margin-left:8px; }
  .form-hint{ display:block; margin-top:8px; font-family:var(--sans); font-size:13px; color:var(--silver); font-style:italic; }
  .form-input, .form-textarea{ width:100%; background:rgba(20,32,47,.5); border:1px solid rgba(138,156,168,.4);
    padding:14px 16px; font-family:var(--sans); font-size:16px; color:var(--cream); border-radius:2px;
    transition:border-color .3s, background .3s; }
  .form-input:focus, .form-textarea:focus{ outline:none; border-color:var(--cream); background:rgba(20,32,47,.75); }
  .form-textarea{ resize:vertical; min-height:150px; }
  .form-actions{ margin-top:32px; display:flex; align-items:center; gap:24px; flex-wrap:wrap; }
  .form-actions__hint{ font-family:var(--sans); font-size:14px; color:var(--silver); }

  /* ================= ALTERNATIVES CONTACT ================= */
  .alts__title{ font-family:var(--serif); font-size:28px; color:var(--cream); margin-bottom:14px; }
  .alts__intro{ font-family:var(--sans); font-size:15px; color:var(--silver); margin-bottom:28px; }
  .alts__list{ list-style:none; padding:0; display:grid; gap:22px; max-width:680px; }
  .alts__row{ display:grid; grid-template-columns:130px 1fr; gap:24px; align-items:baseline; padding-bottom:18px; border-bottom:1px solid rgba(138,156,168,.14); }
  .alts__label{ font-family:var(--mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--silver); }
  .alts__value{ font-family:var(--sans); font-size:16px; color:var(--cream); }
  .alts__value a{ color:var(--cream); }
  .alts__value a:hover{ color:#F2EEE2; }
  .alts__note{ display:block; font-family:var(--sans); font-size:13px; font-style:italic; color:var(--silver); margin-top:4px; }
  @media (max-width:600px){ .alts__row{ grid-template-columns:1fr; gap:6px; } }

  /* ================= PRICING (TARIFS) ================= */
  .pricing{ max-width:980px; }
  .pricing__block{ display:grid; grid-template-columns:200px 1fr; gap:48px; padding:44px 0; border-bottom:1px solid rgba(138,156,168,.16); }
  .pricing__block:last-child{ border-bottom:0; }
  .pricing__label{ font-family:var(--mono); font-size:13px; letter-spacing:.16em; text-transform:uppercase; color:var(--silver); padding-top:6px; }
  .pricing__content{ max-width:640px; }
  .pricing__heading{ font-family:var(--serif); font-size:28px; line-height:1.2; color:var(--cream); margin-bottom:14px; }
  .pricing__text{ font-family:var(--sans); font-size:17px; line-height:1.78; color:var(--silver); margin-bottom:16px; }
  .pricing__price{ font-family:var(--serif); font-size:clamp(40px,5vw,56px); line-height:1; color:var(--cream); margin:18px 0; letter-spacing:-.015em; }
  .pricing__price-unit{ font-family:var(--mono); font-size:13px; letter-spacing:.16em; text-transform:uppercase; color:var(--silver); }
  .pricing__list{ list-style:none; padding:0; margin:0; display:grid; gap:12px; }
  .pricing__list li{ position:relative; padding-left:24px; font-family:var(--sans); font-size:16px; line-height:1.7; color:var(--cream); opacity:.88; }
  .pricing__list li::before{ content:"—"; position:absolute; left:0; color:var(--silver); }
  @media (max-width:768px){ .pricing__block{ grid-template-columns:1fr; gap:16px; } }

  /* ================= BLOG LISTING ================= */
  .blog-grid{ display:grid; grid-template-columns:1fr 1fr; gap:32px; max-width:1080px; }
  .blog-card{ display:flex; flex-direction:column; padding:38px 36px; border:1px solid rgba(138,156,168,.16); border-radius:3px;
    background:linear-gradient(180deg, rgba(20,32,47,.5), rgba(6,10,20,.55)); transition:border-color .4s, transform .4s, box-shadow .4s; min-height:240px; }
  .blog-card:hover{ border-color:rgba(138,156,168,.4); transform:translateY(-5px); box-shadow:0 30px 60px -34px rgba(0,0,0,.9); }
  .blog-card__meta{ font-family:var(--mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--silver); margin-bottom:20px; }
  .blog-card__title{ font-family:var(--serif); font-size:26px; line-height:1.2; color:var(--cream); margin-bottom:12px; }
  .blog-card__date{ font-family:var(--sans); font-size:13px; color:var(--silver); margin-bottom:18px; }
  .blog-card__excerpt{ font-family:var(--sans); font-size:15px; line-height:1.7; color:var(--silver); margin-bottom:24px; flex-grow:1; }
  .blog-card__link{ font-family:var(--sans); font-weight:500; font-size:14px; color:var(--cream); margin-top:auto; display:inline-flex; align-items:center; gap:8px; }
  .blog-card:hover .blog-card__link{ color:#F2EEE2; }
  .blog-outro{ padding:clamp(72px,9vh,110px) 0; border-top:1px solid rgba(138,156,168,.14); }
  .blog-outro__text{ font-family:var(--sans); font-size:18px; color:var(--silver); max-width:640px; }
  .blog-outro__text a{ color:var(--cream); font-weight:500; text-decoration:underline; text-decoration-color:var(--silver); }
  .blog-outro__text a:hover{ color:#F2EEE2; }
  @media (max-width:800px){ .blog-grid{ grid-template-columns:1fr; } }

  /* ================= CONDITIONS (fiches) ================= */
  .chips{ display:flex; flex-wrap:wrap; gap:12px; margin-top:28px; }
  .chip{ font-family:var(--mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--silver);
    padding:8px 16px; border:1px solid rgba(138,156,168,.3); border-radius:2px; }
  .page-head__close{ font-family:var(--sans); font-weight:500; font-size:18px; color:var(--cream); margin-top:26px; max-width:680px; }

  .fiche__list{ display:grid; gap:0; max-width:980px; margin-top:44px; }
  .fiche__row{ display:grid; grid-template-columns:200px 1fr; gap:48px; align-items:start; padding:28px 0; border-bottom:1px solid rgba(138,156,168,.16); }
  .fiche__row:last-child{ border-bottom:0; }
  .fiche__label{ font-family:var(--mono); font-size:13px; letter-spacing:.16em; text-transform:uppercase; color:var(--silver); padding-top:4px; }
  .fiche__content{ font-family:var(--sans); font-size:17px; line-height:1.78; color:var(--cream); opacity:.9; max-width:640px; }
  .fiche__content em{ font-style:italic; color:var(--cream); opacity:1; }

  .blist{ list-style:none; padding:0; margin:44px 0 0; display:grid; gap:16px; max-width:760px; }
  .blist li{ position:relative; padding-left:24px; font-family:var(--sans); font-size:17px; line-height:1.78; color:var(--cream); opacity:.9; }
  .blist li::before{ content:"—"; position:absolute; left:0; color:var(--silver); }

  .mutual{ display:grid; grid-template-columns:1fr 1px 1fr; gap:48px; max-width:1080px; margin-top:44px; }
  .mutual__divider{ background:rgba(138,156,168,.3); width:1px; }
  .mutual__title{ font-family:var(--mono); font-size:13px; letter-spacing:.16em; text-transform:uppercase; color:var(--silver); margin-bottom:24px; }
  .mutual__list{ list-style:none; padding:0; display:grid; gap:16px; }
  .mutual__list li{ position:relative; padding-left:24px; font-family:var(--sans); font-size:15.5px; line-height:1.7; color:var(--cream); opacity:.9; }
  .mutual__list li::before{ content:"—"; position:absolute; left:0; color:var(--silver); }
  .mutual__list em{ font-style:italic; color:var(--cream); opacity:1; }
  @media (max-width:900px){
    .fiche__row{ grid-template-columns:1fr; gap:10px; }
    .mutual{ grid-template-columns:1fr; gap:40px; }
    .mutual__divider{ display:none; }
  }

  /* ================= AFFAIRES (listing) ================= */
  .chip span{ color:var(--cream); margin-right:8px; }
  .band{ border-top:1px solid rgba(138,156,168,.22); border-bottom:1px solid rgba(138,156,168,.22);
    background:linear-gradient(180deg, rgba(20,32,47,.4), rgba(11,18,32,.4)); }
  .band__inner{ display:flex; justify-content:space-between; align-items:flex-start; flex-wrap:wrap; gap:32px; padding:36px 0; }
  .band__legend{ display:flex; gap:40px; flex-wrap:wrap; }
  .band__item{ display:flex; flex-direction:column; gap:6px; }
  .band__label{ display:flex; align-items:center; gap:8px; font-family:var(--mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--silver); }
  .band__dot{ width:8px; height:8px; border-radius:50%; }
  .band__dot--conclue{ background:var(--green); box-shadow:0 0 8px var(--green); }
  .band__dot--instruction{ background:var(--amber); box-shadow:0 0 8px var(--amber); }
  .band__dot--observation{ background:var(--silver); box-shadow:0 0 8px var(--silver); }
  .band__def{ font-family:var(--sans); font-size:14px; color:var(--silver); }
  .band__count{ font-family:var(--mono); font-size:12px; letter-spacing:.16em; color:var(--silver); align-self:center; }
  .card-meta{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--silver);
    margin:0 0 18px; padding-bottom:14px; border-bottom:1px solid rgba(138,156,168,.16); }
  @media (max-width:600px){ .band__legend{ gap:20px; } }

  /* ================= AFFAIRE (template individuel) ================= */
  .aff-hero{ position:relative; overflow:hidden; padding:clamp(150px,20vh,232px) 0 clamp(56px,8vh,90px);
    background:linear-gradient(180deg, var(--bg-deep) 0%, #08101D 55%, var(--bg) 100%); }
  .aff-hero__light{ position:absolute; inset:0; pointer-events:none; z-index:0;
    background:radial-gradient(60% 60% at 72% 22%, rgba(86,120,150,.2) 0%, transparent 66%); mix-blend-mode:screen; }
  .aff-hero .wrap{ position:relative; z-index:2; }
  .aff-hero__grid{ display:grid; grid-template-columns:300px 1fr; gap:64px; align-items:start; }
  .aff-hero__id{ position:relative; padding-right:40px; }
  .aff-hero__id::after{ content:""; position:absolute; right:0; top:4px; bottom:4px; width:1px; background:rgba(138,156,168,.3); }
  .aff-hero__label{ font-family:var(--serif); font-size:30px; color:var(--silver); line-height:1; }
  .aff-hero__num{ font-family:var(--serif); font-size:120px; line-height:.95; color:var(--cream); letter-spacing:-.03em; margin-bottom:24px; }
  .aff-hero__status{ display:flex; align-items:center; gap:8px; font-family:var(--mono); font-size:13px; letter-spacing:.16em; text-transform:uppercase; color:var(--silver); margin-bottom:28px; }
  .aff-hero__status-dot{ width:8px; height:8px; border-radius:50%; }
  .aff-hero__status-dot--conclue{ background:var(--green); box-shadow:0 0 8px var(--green); }
  .aff-hero__status-dot--instruction{ background:var(--amber); box-shadow:0 0 8px var(--amber); }
  .aff-hero__status-dot--observation{ background:var(--silver); box-shadow:0 0 8px var(--silver); }
  .aff-hero__meta{ list-style:none; padding:0; display:grid; gap:10px; }
  .aff-hero__meta li{ font-family:var(--mono); font-size:13px; letter-spacing:.16em; text-transform:uppercase; color:var(--silver); }
  .aff-hero__title{ font-family:var(--serif); font-size:clamp(34px,4.6vw,56px); line-height:1.05; color:var(--cream); letter-spacing:-.015em; }
  .aff-hero__title span{ display:block; }
  .aff-hero__title span:nth-child(2){ color:var(--cream); opacity:.7; }

  .aff-body__inner{ max-width:720px; margin:0 auto; }
  .aff-sec{ margin-bottom:64px; }
  .aff-sec:last-child{ margin-bottom:0; }
  .aff-sec__overline{ font-family:var(--mono); font-size:13px; letter-spacing:.16em; text-transform:uppercase; color:var(--silver); margin-bottom:14px; }
  .aff-sec__rule{ width:96px; height:1px; background:var(--silver); margin-bottom:28px; opacity:.6; }
  .aff-sec__body p{ font-family:var(--sans); font-size:18px; line-height:1.8; color:var(--cream); opacity:.9; margin-bottom:20px; }
  .aff-sec__body p:last-child{ margin-bottom:0; }
  .aff-sec__body strong{ font-weight:600; color:var(--cream); opacity:1; }
  .aff-sec__pull{ font-family:var(--serif); font-style:italic; font-size:clamp(24px,2.8vw,30px); line-height:1.3; color:var(--cream); padding-left:26px; border-left:2px solid var(--silver); }

  .aff-nav{ border-top:1px solid rgba(138,156,168,.16); border-bottom:1px solid rgba(138,156,168,.16); padding:44px 0; }
  .aff-nav__grid{ display:grid; grid-template-columns:1fr 1fr; gap:40px; }
  .aff-nav__next{ text-align:right; }
  .aff-nav__label{ font-family:var(--mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--silver); margin-bottom:8px; transition:color .3s; }
  .aff-nav__sector{ font-family:var(--sans); font-size:15px; color:var(--silver); }
  .aff-nav a:hover .aff-nav__label{ color:var(--cream); }
  @media (max-width:900px){
    .aff-hero__grid{ grid-template-columns:1fr; gap:32px; }
    .aff-hero__id{ padding-right:0; padding-bottom:24px; }
    .aff-hero__id::after{ width:auto; height:1px; left:0; right:0; top:auto; bottom:0; }
    .aff-hero__num{ font-size:84px; }
    .aff-nav__grid{ grid-template-columns:1fr; gap:24px; }
    .aff-nav__next{ text-align:left; }
  }

  /* ================= ARTICLE BLOG ================= */
  .art-head{ position:relative; overflow:hidden; padding:clamp(150px,20vh,224px) 0 clamp(40px,6vh,64px);
    background:linear-gradient(180deg, var(--bg-deep) 0%, #08101D 60%, var(--bg) 100%); border-bottom:1px solid rgba(138,156,168,.14); }
  .art-head__light{ position:absolute; inset:0; pointer-events:none; z-index:0; background:radial-gradient(60% 60% at 70% 18%, rgba(86,120,150,.18), transparent 66%); mix-blend-mode:screen; }
  .art-head .wrap{ position:relative; z-index:2; }
  .art-head__inner{ max-width:760px; }
  .art-head__meta{ font-family:var(--mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--silver); margin-bottom:24px; }
  .art-head__title{ font-family:var(--serif); font-size:clamp(34px,4.8vw,56px); line-height:1.06; color:var(--cream); letter-spacing:-.015em; margin-bottom:24px; }
  .art-head__intro{ font-family:var(--sans); font-size:clamp(17px,1.6vw,20px); line-height:1.6; color:var(--silver); max-width:680px; }

  .toc{ background:linear-gradient(180deg, var(--bg-2) 0%, #101A28 55%, var(--bg-2) 100%); padding:40px 0; border-bottom:1px solid rgba(138,156,168,.14); }
  .toc__inner{ max-width:760px; }
  .toc__label{ font-family:var(--mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--silver); margin-bottom:18px; }
  .toc__list{ list-style:none; padding:0; display:grid; gap:12px; }
  .toc__list li{ display:grid; grid-template-columns:40px 1fr; gap:10px; align-items:baseline; }
  .toc__num{ font-family:var(--mono); font-size:14px; color:var(--silver); }
  .toc__list a{ font-family:var(--sans); font-size:16px; color:var(--cream); }
  .toc__list a:hover{ color:var(--silver); text-decoration:underline; }

  .art-body__inner{ max-width:720px; }
  .art-body h2{ font-family:var(--serif); font-size:clamp(26px,3vw,34px); line-height:1.2; color:var(--cream); margin:56px 0 20px; letter-spacing:-.01em; }
  .art-body h2:first-child{ margin-top:0; }
  .art-body h3{ font-family:var(--serif); font-size:21px; line-height:1.25; color:var(--cream); opacity:.92; margin:36px 0 14px; }
  .art-body p{ font-family:var(--sans); font-size:18px; line-height:1.8; color:var(--cream); opacity:.88; margin-bottom:20px; }
  .art-body strong{ font-weight:600; color:var(--cream); opacity:1; }
  .art-body em{ font-style:italic; }
  .art-body code{ font-family:var(--mono); font-size:15px; background:rgba(20,32,47,.7); color:var(--silver); padding:2px 7px; border-radius:2px; }
  .art-body blockquote{ font-family:var(--serif); font-style:italic; font-size:clamp(22px,2.6vw,28px); line-height:1.3; color:var(--cream); margin:36px 0; padding-left:26px; border-left:2px solid var(--silver); max-width:640px; }

  .author{ border-top:1px solid rgba(138,156,168,.14); }
  .author__inner{ max-width:720px; }
  .author__label{ font-family:var(--mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--silver); margin-bottom:10px; }
  .author__name{ font-family:var(--serif); font-size:22px; color:var(--cream); margin-bottom:12px; }
  .author__bio{ font-family:var(--sans); font-size:15px; line-height:1.7; color:var(--silver); margin-bottom:16px; max-width:600px; }
  .author__link{ font-family:var(--sans); font-weight:500; font-size:14px; color:var(--cream); }
  .author__link:hover{ color:#F2EEE2; }

  .related{ background:linear-gradient(180deg, var(--bg-2) 0%, #101A28 55%, var(--bg-2) 100%); }
  .related__label{ font-family:var(--mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--silver); margin-bottom:40px; }
  .related__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
  .related-card{ display:flex; flex-direction:column; padding:30px 28px; border:1px solid rgba(138,156,168,.18); border-radius:3px; transition:border-color .35s, transform .35s; }
  .related-card:hover{ border-color:rgba(138,156,168,.4); transform:translateY(-4px); }
  .related-card__cat{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--silver); margin-bottom:16px; }
  .related-card__title{ font-family:var(--serif); font-size:19px; line-height:1.25; color:var(--cream); margin-bottom:20px; flex-grow:1; }
  .related-card__link{ font-family:var(--sans); font-weight:500; font-size:13px; color:var(--cream); margin-top:auto; }
  .related-card:hover .related-card__link{ color:#F2EEE2; }
  @media (max-width:900px){ .related__grid{ grid-template-columns:1fr; } }

  /* ================= MÉTHODE ================= */
  .m-case{ font-family:var(--mono); font-size:13px; letter-spacing:.14em; text-transform:uppercase; color:var(--silver); margin-right:6px; }
  .m-intro{ font-family:var(--sans); font-size:clamp(17px,1.6vw,20px); line-height:1.7; color:var(--cream); opacity:.9; max-width:680px; margin-top:28px; }
  .m-intro--sec{ color:var(--silver); opacity:1; }
  .m-pivot{ font-family:var(--serif); font-style:italic; font-size:clamp(28px,3.6vw,42px); line-height:1.2; color:var(--cream); max-width:720px; margin:36px 0; padding:24px 0; border-top:1px solid var(--silver); border-bottom:1px solid var(--silver); }

  .parg{ border-top:1px solid rgba(138,156,168,.16); max-width:980px; margin-top:56px; }
  .parg__item{ display:grid; grid-template-columns:80px 1fr; gap:40px; padding:44px 0; border-bottom:1px solid rgba(138,156,168,.16); align-items:start; }
  .parg__num{ font-family:var(--mono); font-size:14px; letter-spacing:.1em; color:var(--silver); padding-top:8px; }
  .parg__body{ max-width:720px; }
  .parg__heading{ font-family:var(--serif); font-size:clamp(24px,2.8vw,30px); line-height:1.2; color:var(--cream); margin-bottom:16px; letter-spacing:-.01em; }
  .parg__text{ font-family:var(--sans); font-size:18px; line-height:1.8; color:var(--silver); }

  .ptable{ width:100%; border-collapse:collapse; max-width:1080px; margin-top:48px; }
  .ptable thead th{ font-family:var(--mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--silver); text-align:left; padding:14px 24px 14px 0; border-bottom:1px solid var(--silver); font-weight:400; }
  .ptable tbody td{ padding:24px 24px 24px 0; border-bottom:1px solid rgba(138,156,168,.18); vertical-align:top; }
  .ptable__num{ font-family:var(--mono); font-size:13px; color:var(--silver); width:60px; }
  .ptable__name{ font-family:var(--serif); font-size:22px; color:var(--cream); width:40%; }
  .ptable__name a{ color:inherit; transition:color .3s; }
  .ptable__name a:hover{ color:var(--silver); }
  .ptable__dur, .ptable__liv{ font-family:var(--sans); font-size:15px; color:var(--cream); opacity:.85; }
  .ptable__outro{ margin-top:32px; font-family:var(--sans); font-size:15px; color:var(--silver); font-style:italic; }

  .phase{ position:relative; overflow:hidden; }
  .phase--alt{ background:linear-gradient(180deg, var(--bg-2) 0%, #101A28 55%, var(--bg-2) 100%); }
  .phase__bgnum{ position:absolute; left:var(--gutter); top:50%; transform:translateY(-50%); font-family:var(--serif); font-size:clamp(160px,28vw,340px); line-height:1; color:var(--silver); opacity:.06; pointer-events:none; letter-spacing:-.03em; z-index:0; }
  .phase__inner{ position:relative; z-index:2; max-width:880px; margin-left:auto; }
  .phase__overline{ font-family:var(--mono); font-size:13px; letter-spacing:.16em; text-transform:uppercase; color:var(--silver); margin-bottom:18px; }
  .phase__head{ display:flex; align-items:baseline; justify-content:space-between; gap:24px; margin-bottom:28px; padding-bottom:18px; border-bottom:1px solid rgba(138,156,168,.2); flex-wrap:wrap; }
  .phase__name{ font-family:var(--serif); font-size:clamp(30px,4vw,44px); line-height:1.05; color:var(--cream); letter-spacing:-.015em; }
  .phase__dur{ font-family:var(--mono); font-size:13px; letter-spacing:.14em; text-transform:uppercase; color:var(--silver); }
  .phase__intro{ font-family:var(--sans); font-size:18px; line-height:1.8; color:var(--cream); opacity:.9; max-width:680px; margin-bottom:40px; }
  .phase__block{ margin-bottom:32px; }
  .phase__block--client{ padding-left:32px; border-left:1px solid rgba(138,156,168,.3); margin-left:24px; }
  .phase__btitle{ font-family:var(--mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--silver); margin-bottom:18px; }
  .phase__list{ list-style:none; padding:0; margin:0; display:grid; gap:12px; }
  .phase__list li{ position:relative; padding-left:24px; font-family:var(--sans); font-size:15.5px; line-height:1.7; color:var(--cream); opacity:.88; }
  .phase__list li::before{ content:"—"; position:absolute; left:0; color:var(--silver); }
  .phase__liv{ display:grid; grid-template-columns:auto 1fr; gap:24px; padding:28px; border:1px solid rgba(138,156,168,.28); background:rgba(138,156,168,.04); border-radius:3px; margin-top:24px; align-items:start; }
  .phase__liv-mark{ font-family:var(--mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--silver); padding-top:4px; }
  .phase__liv-name{ font-family:var(--serif); font-size:24px; color:var(--cream); margin-bottom:10px; }
  .phase__liv-desc{ font-family:var(--sans); font-size:15.5px; line-height:1.7; color:var(--silver); }
  .phase__liv-desc em{ color:var(--cream); font-style:italic; }
  @media (max-width:1100px){ .phase__bgnum{ font-size:200px; } .phase__inner{ margin-left:0; } }
  @media (max-width:768px){
    .phase__bgnum{ font-size:120px; }
    .phase__head{ flex-direction:column; gap:6px; align-items:flex-start; }
    .phase__block--client{ margin-left:0; padding-left:20px; }
    .phase__liv{ grid-template-columns:1fr; gap:12px; }
    .parg__item{ grid-template-columns:1fr; gap:10px; }
    .ptable thead{ display:none; }
    .ptable tbody tr{ display:block; padding:20px 0; border-bottom:1px solid rgba(138,156,168,.18); }
    .ptable tbody td{ display:block; padding:0 0 8px; border:0; }
    .ptable__dur::before{ content:"Durée : "; color:var(--silver); }
    .ptable__liv::before{ content:"Livrable : "; color:var(--silver); }
  }
