    /* ════════════════════════════════════════════════
       DESIGN SYSTEM — GEORANK MEDIA
       Thème : Editorial Tech Sombre
       Palette : Rouge #C0272D + Noir #080808
       Typo : Syne (display) + Outfit (corps)
    ════════════════════════════════════════════════ */
    :root{
      --r:#C0272D; --r2:#E63946; --r3:#8B0000;
      --n:#080808; --n1:#111; --n2:#1A1A1A; --n3:#242424; --n4:#2E2E2E;
      --w:#F4F4F4; --w2:#C8C8C8; --w3:rgba(200,200,200,.45);
      --accent:#FF6B35;
      --font-head:'Syne',system-ui,sans-serif;
      --font-body:'Outfit',system-ui,sans-serif;
      --ease:cubic-bezier(.4,0,.2,1);
    }
    *{margin:0;padding:0;box-sizing:border-box}
    html{scroll-behavior:smooth}
    body{
      background:var(--n);color:var(--w2);
      font-family:var(--font-body);font-weight:300;
      overflow-x:hidden;contain:paint;
      line-height:1.6;
    }
    @font-face{font-family:'Syne';font-display:swap;src:local('Syne Bold');font-weight:700 800}
    @font-face{font-family:'Outfit';font-display:swap;src:local('Outfit');font-weight:300 600}

    /* ── SCROLLBAR ─── */
    ::-webkit-scrollbar{width:4px}
    ::-webkit-scrollbar-track{background:var(--n)}
    ::-webkit-scrollbar-thumb{background:var(--r);border-radius:2px}

    /* ════════════════════════════════════════════
       NAVBAR
    ════════════════════════════════════════════ */
    .navbar{
      background:rgba(8,8,8,.96)!important;
      border-bottom:1px solid rgba(192,39,45,.3);
      padding:.85rem 0;position:sticky;top:0;z-index:200;
      backdrop-filter:blur(10px);min-height:58px;
      will-change:transform;
    }
    .brand{
      font-family:var(--font-head);font-weight:800;
      font-size:1.35rem;letter-spacing:-.5px;color:var(--w)!important;
      text-decoration:none;display:flex;align-items:center;gap:8px;
    }
    .brand-icon{
      width:28px;height:28px;background:var(--r);
      display:flex;align-items:center;justify-content:center;
      font-size:.65rem;font-weight:800;color:#fff;letter-spacing:.5px;
      flex-shrink:0;
    }
    .brand em{font-style:normal;color:var(--r2)}
    .nav-link{
      color:var(--w2)!important;font-size:.78rem;font-weight:500;
      letter-spacing:1.2px;text-transform:uppercase;
      transition:color .2s;position:relative;padding:.4rem .6rem!important;
    }
    .nav-link::after{
      content:'';position:absolute;bottom:-1px;left:.6rem;right:.6rem;
      height:1px;background:var(--r2);transform:scaleX(0);
      transition:transform .25s var(--ease);transform-origin:left;
    }
    .nav-link:hover{color:var(--r2)!important}
    .nav-link:hover::after{transform:scaleX(1)}
    .nav-badge{
      background:var(--r);color:#fff;font-size:.58rem;
      padding:1px 5px;letter-spacing:.5px;margin-left:4px;
      vertical-align:middle;font-weight:600;
    }
    .navbar-toggler{border-color:var(--r);padding:.3rem .6rem}
    .navbar-toggler-icon{filter:invert(1)}
    .btn-nav{
      background:var(--r);color:#fff!important;
      font-size:.72rem;letter-spacing:1px;text-transform:uppercase;
      font-weight:600;padding:.45rem 1.1rem;border-radius:0;
      text-decoration:none;transition:background .2s;
      min-height:36px;display:inline-flex;align-items:center;
    }
    .btn-nav:hover{background:var(--r3);color:#fff!important}

    /* ════════════════════════════════════════════
       HERO — EDITORIAL SPLIT
    ════════════════════════════════════════════ */
    .hero{
      min-height:90vh;position:relative;
      display:grid;grid-template-columns:1fr 1fr;
      overflow:hidden;
    }
    @media(max-width:991px){.hero{grid-template-columns:1fr;min-height:auto}}

    /* Colonne gauche — texte */
    .hero-left{
      background:var(--n1);
      padding:5rem 3rem 4rem;
      display:flex;flex-direction:column;justify-content:center;
      position:relative;z-index:2;
    }
    .hero-left::after{
      content:'';position:absolute;top:0;right:-1px;bottom:0;width:3px;
      background:linear-gradient(180deg,transparent,var(--r),transparent);
    }

    /* Colonne droite — image LCP -->
    .hero-right{
      position:relative;overflow:hidden;
      background:var(--n2);
    }
    @media(max-width:991px){.hero-right{height:50vw;min-height:280px}}

    .hero-img{
      width:100%;height:100%;object-fit:cover;
      object-position:center;display:block;
    }
    .hero-img-overlay{
      position:absolute;inset:0;
      background:linear-gradient(90deg,rgba(8,8,8,.8) 0%,rgba(8,8,8,.15) 60%,transparent 100%);
    }

    /* Déco grille en fond hero-left */
    .hero-grid{
      position:absolute;inset:0;pointer-events:none;
      background-image:
        linear-gradient(rgba(192,39,45,.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(192,39,45,.06) 1px, transparent 1px);
      background-size:48px 48px;
    }

    .hero-kicker{
      display:inline-flex;align-items:center;gap:8px;
      font-size:.68rem;letter-spacing:2.5px;text-transform:uppercase;
      color:var(--r2);font-weight:600;margin-bottom:1.4rem;
    }
    .hero-kicker-dot{
      width:6px;height:6px;background:var(--r2);
      border-radius:50%;animation:pulse-dot 2s ease infinite;
    }
    @keyframes pulse-dot{
      0%,100%{box-shadow:0 0 0 0 rgba(230,57,70,.5)}
      50%{box-shadow:0 0 0 6px rgba(230,57,70,0)}
    }
    .hero h1{
      font-family:var(--font-head);font-weight:800;
      font-size:clamp(2.2rem,4.5vw,3.8rem);
      line-height:1.05;color:var(--w);margin-bottom:1.4rem;
      letter-spacing:-.5px;
    }
    .hero h1 .highlight{
      color:transparent;
      -webkit-text-stroke:1.5px var(--r2);
    }
    .hero-desc{
      font-size:.97rem;color:var(--w3);line-height:1.72;
      max-width:440px;margin-bottom:2rem;
    }
    .hero-cta{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
    .btn-primary-r{
      background:var(--r);color:#fff;border:none;
      padding:.72rem 1.8rem;font-size:.78rem;letter-spacing:1.2px;
      text-transform:uppercase;font-weight:600;
      transition:background .2s,transform .18s;
      border-radius:0;text-decoration:none;
      display:inline-flex;align-items:center;gap:8px;min-height:44px;
    }
    .btn-primary-r:hover{background:var(--r3);color:#fff;transform:translateY(-2px)}
    .btn-ghost{
      background:transparent;color:var(--w2);
      border:1px solid rgba(200,200,200,.2);
      padding:.7rem 1.6rem;font-size:.78rem;letter-spacing:1.2px;
      text-transform:uppercase;font-weight:500;
      transition:all .2s;border-radius:0;text-decoration:none;
      display:inline-flex;align-items:center;min-height:44px;
    }
    .btn-ghost:hover{border-color:var(--r);color:var(--r2)}

    /* Stats hero */
    .hero-stats{
      display:flex;gap:2rem;margin-top:2.5rem;
      padding-top:2rem;border-top:1px solid rgba(200,200,200,.08);
    }
    .hstat-n{
      font-family:var(--font-head);font-size:1.7rem;font-weight:800;
      color:var(--r2);line-height:1;
    }
    .hstat-l{
      font-size:.65rem;letter-spacing:1.5px;text-transform:uppercase;
      color:var(--w3);margin-top:3px;
    }

    /* Floating badge hero-right */
    .hero-badge{
      position:absolute;bottom:2rem;left:2rem;z-index:10;
      background:rgba(8,8,8,.88);border:1px solid var(--r);
      padding:.7rem 1rem;max-width:240px;
      backdrop-filter:blur(6px);
    }
    .hero-badge-tag{
      font-size:.6rem;letter-spacing:2px;text-transform:uppercase;
      color:var(--r2);font-weight:600;margin-bottom:.3rem;
    }
    .hero-badge-text{
      font-size:.82rem;color:var(--w);font-weight:500;line-height:1.35;
    }

    /* ════════════════════════════════════════════
       TICKER
    ════════════════════════════════════════════ */
    .ticker-wrap{
      background:var(--r);padding:7px 0;
      overflow:hidden;white-space:nowrap;
      contain:strict;height:32px;
    }
    .ticker-inner{display:inline-block;animation:ticker 35s linear infinite}
    @media(prefers-reduced-motion:reduce){.ticker-inner{animation:none}}
    .ticker-inner span{
      font-size:.68rem;letter-spacing:2px;text-transform:uppercase;
      color:rgba(255,255,255,.88);margin-right:2.5rem;font-weight:500;
    }
    .ticker-inner span::before{content:'◆ ';color:rgba(255,255,255,.4)}
    @keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

    /* ════════════════════════════════════════════
       SECTION COMMUNE
    ════════════════════════════════════════════ */
    section{padding:5rem 0}
    .bg-n1{background:var(--n1)}
    .bg-n2{background:var(--n2)}

    .s-label{
      font-size:.65rem;letter-spacing:3px;text-transform:uppercase;
      color:var(--r2);font-weight:600;margin-bottom:.5rem;
      display:flex;align-items:center;gap:8px;
    }
    .s-label::before{content:'';width:20px;height:1px;background:var(--r2)}
    .s-title{
      font-family:var(--font-head);font-weight:800;
      font-size:clamp(1.6rem,3vw,2.4rem);color:var(--w);
      line-height:1.15;letter-spacing:-.3px;margin-bottom:.4rem;
    }
    .s-div{width:40px;height:2px;background:var(--r);margin:1rem 0 2.5rem}

    /* ════════════════════════════════════════════
       CARDS ARTICLES
    ════════════════════════════════════════════ */
    .acard{
      background:var(--n2);border:1px solid rgba(255,255,255,.05);
      display:flex;flex-direction:column;height:100%;
      transition:border-color .25s,transform .25s var(--ease);
      contain:layout;
    }
    .acard:hover{border-color:var(--r);transform:translateY(-4px)}

    .acard-img{
      aspect-ratio:16/9;overflow:hidden;position:relative;
      background:var(--n3);flex-shrink:0;
    }
    .acard-img img{
      width:100%;height:100%;object-fit:cover;display:block;
      transition:transform .45s var(--ease);
    }
    .acard:hover .acard-img img{transform:scale(1.04)}

    .acard-cat{
      position:absolute;top:10px;left:10px;
      background:var(--r);color:#fff;font-size:.58rem;
      font-weight:600;letter-spacing:1.5px;text-transform:uppercase;
      padding:3px 8px;
    }
    .acard-reading{
      position:absolute;bottom:10px;right:10px;
      background:rgba(8,8,8,.75);color:var(--w2);
      font-size:.6rem;padding:3px 7px;letter-spacing:.5px;
      backdrop-filter:blur(4px);
    }

    .acard-body{padding:1.25rem;flex:1;display:flex;flex-direction:column}
    .acard-meta{font-size:.65rem;color:var(--w3);margin-bottom:.55rem;display:flex;gap:10px}
    .acard-title{
      font-family:var(--font-head);font-size:1.05rem;font-weight:700;
      color:var(--w);line-height:1.32;margin-bottom:.65rem;
    }
    .acard-excerpt{font-size:.83rem;color:var(--w3);line-height:1.65;flex:1}
    .acard-link{
      margin-top:1rem;font-size:.68rem;letter-spacing:1.5px;text-transform:uppercase;
      color:var(--r2);text-decoration:none;font-weight:600;
      display:inline-flex;align-items:center;gap:5px;
      transition:gap .2s,color .2s;
    }
    .acard-link:hover{color:var(--w);gap:10px}
    .acard-link::after{content:'→'}

    /* ════════════════════════════════════════════
       CARD FEATURED (grande)
    ════════════════════════════════════════════ */
    .fcard{
      background:var(--n2);border:1px solid rgba(255,255,255,.05);
      overflow:hidden;display:grid;
      grid-template-columns:1fr 1fr;
      transition:border-color .25s;
    }
    .fcard:hover{border-color:var(--r)}
    @media(max-width:767px){.fcard{grid-template-columns:1fr}}
    .fcard-img{
      aspect-ratio:4/3;overflow:hidden;background:var(--n3);position:relative;
    }
    .fcard-img img{
      width:100%;height:100%;object-fit:cover;display:block;
      transition:transform .5s var(--ease);
    }
    .fcard:hover .fcard-img img{transform:scale(1.03)}
    .fcard-body{
      padding:2rem 1.8rem;display:flex;flex-direction:column;
      justify-content:center;border-left:2px solid var(--r);
    }
    @media(max-width:767px){.fcard-body{border-left:none;border-top:2px solid var(--r)}}
    .fcard-cat{
      display:inline-block;background:var(--r);color:#fff;
      font-size:.58rem;font-weight:600;letter-spacing:1.5px;
      text-transform:uppercase;padding:3px 9px;margin-bottom:.9rem;
    }
    .fcard-title{
      font-family:var(--font-head);font-size:1.5rem;font-weight:800;
      color:var(--w);line-height:1.2;margin-bottom:.8rem;letter-spacing:-.2px;
    }
    .fcard-excerpt{font-size:.88rem;color:var(--w3);line-height:1.7;margin-bottom:1.2rem}
    .fcard-meta{font-size:.65rem;color:var(--w3);display:flex;gap:12px;margin-bottom:1.2rem}

    /* ════════════════════════════════════════════
       SECTION GEO EXPLAINER
       Bloc pédagogique : qu'est-ce que le GEO ?
    ════════════════════════════════════════════ */
    .geo-section{background:var(--n1);position:relative;overflow:hidden}
    .geo-section::before{
      content:'GEO';position:absolute;right:-2rem;top:50%;
      transform:translateY(-50%);font-family:var(--font-head);
      font-size:18rem;font-weight:800;color:rgba(192,39,45,.04);
      line-height:1;pointer-events:none;user-select:none;
    }

    .geo-card{
      background:var(--n2);border:1px solid rgba(255,255,255,.05);
      padding:1.6rem;height:100%;
      border-top:2px solid transparent;
      transition:border-top-color .25s,transform .25s var(--ease);
    }
    .geo-card:hover{border-top-color:var(--r);transform:translateY(-3px)}
    .geo-card-icon{
      width:44px;height:44px;background:rgba(192,39,45,.12);
      display:flex;align-items:center;justify-content:center;
      font-size:1.2rem;margin-bottom:1rem;flex-shrink:0;
    }
    .geo-card-title{
      font-family:var(--font-head);font-size:1rem;font-weight:700;
      color:var(--w);margin-bottom:.55rem;
    }
    .geo-card-text{font-size:.82rem;color:var(--w3);line-height:1.65}

    /* ════════════════════════════════════════════
       SECTION : MOTEURS IA (grid des plateformes)
    ════════════════════════════════════════════ */
    .ai-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:1px;background:rgba(255,255,255,.05)}
    .ai-item{
      background:var(--n2);padding:1.5rem 1rem;text-align:center;
      transition:background .2s;
    }
    .ai-item:hover{background:var(--n3)}
    .ai-logo{
      width:48px;height:48px;border-radius:50%;margin:0 auto .7rem;
      display:flex;align-items:center;justify-content:center;
      font-family:var(--font-head);font-size:.85rem;font-weight:800;
      color:#fff;border:1px solid rgba(255,255,255,.1);
    }
    .ai-name{font-size:.72rem;font-weight:600;color:var(--w);letter-spacing:.5px}
    .ai-stat{font-size:.62rem;color:var(--r2);margin-top:.2rem;letter-spacing:.5px}

    /* ════════════════════════════════════════════
       SIDEBAR
    ════════════════════════════════════════════ */
    .widget{
      background:var(--n2);border:1px solid rgba(255,255,255,.05);
      padding:1.35rem;margin-bottom:1.3rem;
    }
    .widget-title{
      font-family:var(--font-head);font-size:.9rem;font-weight:700;
      color:var(--w);border-left:2px solid var(--r);
      padding-left:10px;margin-bottom:1.1rem;
    }
    .mini-post{display:flex;gap:10px;margin-bottom:.85rem;padding-bottom:.85rem;border-bottom:1px solid rgba(255,255,255,.04)}
    .mini-post:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
    .mini-img{width:58px;height:58px;flex-shrink:0;overflow:hidden;background:var(--n3)}
    .mini-img img{width:58px;height:58px;object-fit:cover;display:block}
    .mini-title{font-size:.8rem;color:var(--w2);line-height:1.35;font-weight:500}
    .mini-date{font-size:.62rem;color:var(--w3);margin-top:3px}
    .mini-cat{
      display:inline-block;background:rgba(192,39,45,.15);
      color:var(--r2);font-size:.58rem;letter-spacing:1px;
      text-transform:uppercase;padding:2px 6px;margin-bottom:3px;
    }

    /* Glossaire GEO widget */
    .glossary-item{
      padding:.55rem 0;border-bottom:1px solid rgba(255,255,255,.04);
      cursor:pointer;
    }
    .glossary-item:last-child{border-bottom:none}
    .glossary-term{font-size:.78rem;font-weight:600;color:var(--w);display:flex;justify-content:space-between}
    .glossary-term::after{content:'→';color:var(--r2);font-size:.7rem}
    .glossary-def{font-size:.7rem;color:var(--w3);margin-top:.2rem;line-height:1.4;display:none}
    .glossary-item.open .glossary-def{display:block}
    .glossary-item.open .glossary-term{color:var(--r2)}

    /* Tags */
    .tag-cloud{display:flex;flex-wrap:wrap;gap:6px}
    .tag{
      background:var(--n3);color:var(--w3);font-size:.65rem;
      letter-spacing:.8px;text-transform:uppercase;
      padding:4px 10px;cursor:pointer;
      transition:background .18s,color .18s;text-decoration:none;
      min-height:30px;display:flex;align-items:center;
    }
    .tag:hover{background:var(--r);color:#fff}

    /* Search widget */
    .s-box{display:flex}
    .s-box input{
      flex:1;background:var(--n3);border:1px solid rgba(255,255,255,.07);
      border-right:none;color:var(--w2);padding:.55rem .85rem;
      font-size:.82rem;outline:none;height:40px;
      font-family:var(--font-body);
    }
    .s-box input::placeholder{color:var(--w3)}
    .s-box button{
      background:var(--r);border:none;color:#fff;
      padding:0 .9rem;cursor:pointer;font-size:.9rem;
      height:40px;min-width:40px;
    }

    /* Stat widget */
    .stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,.04)}
    .stat-box{
      background:var(--n2);padding:.9rem;text-align:center;
    }
    .stat-num{
      font-family:var(--font-head);font-size:1.4rem;font-weight:800;
      color:var(--r2);line-height:1;
    }
    .stat-lbl{font-size:.6rem;letter-spacing:1.2px;text-transform:uppercase;color:var(--w3);margin-top:.2rem}

    /* ════════════════════════════════════════════
       NEWSLETTER
    ════════════════════════════════════════════ */
    .nl-section{
      background:linear-gradient(135deg,var(--r3) 0%,#3a0a0a 100%);
      border-top:1px solid rgba(192,39,45,.4);
      border-bottom:1px solid rgba(192,39,45,.4);
      position:relative;overflow:hidden;
    }
    .nl-section::after{
      content:'';position:absolute;inset:0;pointer-events:none;
      background:
        linear-gradient(rgba(192,39,45,.07) 1px,transparent 1px),
        linear-gradient(90deg,rgba(192,39,45,.07) 1px,transparent 1px);
      background-size:40px 40px;
    }
    .nl-inner{position:relative;z-index:1}
    .nl-title{font-family:var(--font-head);font-size:1.8rem;font-weight:800;color:var(--w);letter-spacing:-.2px}
    .nl-sub{font-size:.88rem;color:rgba(255,255,255,.5);margin-top:.5rem;line-height:1.6}
    .nl-form{display:flex;max-width:460px;margin-top:1.5rem}
    .nl-input{
      flex:1;background:rgba(255,255,255,.08);
      border:1px solid rgba(255,255,255,.15);border-right:none;
      color:#fff;padding:.7rem 1rem;font-size:.88rem;outline:none;
      border-radius:0;height:44px;font-family:var(--font-body);
    }
    .nl-input::placeholder{color:rgba(255,255,255,.38)}
    .nl-btn{
      background:#fff;color:var(--r3);border:none;padding:0 1.5rem;
      font-size:.75rem;letter-spacing:1.2px;text-transform:uppercase;
      font-weight:700;cursor:pointer;transition:background .18s;
      min-height:44px;font-family:var(--font-body);
    }
    .nl-btn:hover{background:var(--w2)}
    .nl-notice{font-size:.68rem;color:rgba(255,255,255,.28);margin-top:.55rem}
    .nl-notice a{color:rgba(255,255,255,.45)}

    /* ════════════════════════════════════════════
       FOOTER
    ════════════════════════════════════════════ */
    .site-footer{background:#000;border-top:1px solid rgba(255,255,255,.06)}
    .f-brand{font-family:var(--font-head);font-size:1.3rem;font-weight:800;color:var(--w)}
    .f-brand em{font-style:normal;color:var(--r2)}
    .f-desc{font-size:.82rem;color:var(--w3);line-height:1.65;margin-top:.6rem}
    .f-heading{font-size:.62rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--r2);margin-bottom:1rem;font-weight:600}
    .f-links{list-style:none;padding:0}
    .f-links li{margin-bottom:.5rem}
    .f-links a{color:rgba(200,200,200,.38);text-decoration:none;font-size:.83rem;transition:color .18s}
    .f-links a:hover{color:var(--r2)}
    .f-bottom{border-top:1px solid rgba(255,255,255,.05);padding:1rem 0;font-size:.73rem;color:rgba(200,200,200,.2)}
    .social-row{display:flex;gap:8px;margin-top:1rem}
    .soc{
      width:34px;height:34px;border:1px solid rgba(255,255,255,.1);
      display:flex;align-items:center;justify-content:center;
      color:rgba(200,200,200,.4);text-decoration:none;font-size:.78rem;
      transition:all .2s;
    }
    .soc:hover{background:var(--r);border-color:var(--r);color:#fff}

    /* ════════════════════════════════════════════
       POPUP
    ════════════════════════════════════════════ */
    .pop-overlay{
      position:fixed;inset:0;background:rgba(0,0,0,.78);z-index:9000;
      display:flex;align-items:center;justify-content:center;
      opacity:0;pointer-events:none;transition:opacity .3s;
      visibility:hidden;padding:1rem;
    }
    .pop-overlay.active{opacity:1;pointer-events:all;visibility:visible}
    .pop-box{
      background:var(--n2);border:1px solid var(--r);
      max-width:480px;width:100%;
      transform:scale(.96) translateY(16px);
      transition:transform .3s var(--ease);
    }
    .pop-overlay.active .pop-box{transform:scale(1) translateY(0)}
    .pop-head{
      background:var(--n3);border-bottom:2px solid var(--r);
      padding:1rem 1.3rem;display:flex;justify-content:space-between;align-items:center;
    }
    .pop-head h2{font-family:var(--font-head);font-size:1rem;font-weight:800;color:var(--w);margin:0}
    .pop-close{
      background:none;border:none;color:var(--w3);font-size:1.1rem;
      cursor:pointer;transition:color .18s;
      min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center;
    }
    .pop-close:hover{color:var(--r2)}
    .pop-body{padding:1.4rem 1.3rem}
    .pop-tag{
      display:inline-flex;align-items:center;gap:6px;
      background:rgba(192,39,45,.12);color:var(--r2);
      font-size:.62rem;letter-spacing:1.5px;text-transform:uppercase;
      padding:3px 9px;font-weight:600;margin-bottom:.9rem;
    }
    .pop-body p{font-size:.87rem;color:var(--w3);line-height:1.65;margin-bottom:1.1rem}
    .pop-input{
      width:100%;background:var(--n3);border:1px solid rgba(255,255,255,.08);
      color:var(--w2);padding:.65rem .9rem;font-size:.86rem;margin-bottom:.65rem;
      outline:none;border-radius:0;height:42px;
      font-family:var(--font-body);transition:border-color .18s;
    }
    .pop-input:focus{border-color:var(--r)}
    .pop-footer{padding:0 1.3rem 1.3rem;display:flex;gap:8px;justify-content:flex-end}

    /* ════════════════════════════════════════════
       COOKIE BANNER
    ════════════════════════════════════════════ */
    .ck-banner{
      position:fixed;bottom:0;left:0;right:0;
      background:var(--n1);border-top:2px solid var(--r);
      z-index:9100;padding:1rem 1.4rem;
      display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;
      transform:translateY(100%);transition:transform .4s var(--ease);
      box-shadow:0 -4px 24px rgba(0,0,0,.5);
    }
    .ck-banner.show{transform:translateY(0)}
    .ck-icon{font-size:1.6rem;flex-shrink:0}
    .ck-text{flex:1;min-width:200px}
    .ck-text h6{color:var(--w);font-weight:600;font-size:.86rem;margin-bottom:.22rem}
    .ck-text p{font-size:.73rem;color:var(--w3);margin:0;line-height:1.45}
    .ck-text a{color:var(--r2);text-decoration:none}
    .ck-actions{display:flex;gap:7px;flex-shrink:0;flex-wrap:wrap}
    .ck-accept{
      background:var(--r);color:#fff;border:none;
      padding:.48rem 1.15rem;font-size:.72rem;letter-spacing:.8px;
      text-transform:uppercase;font-weight:600;cursor:pointer;
      transition:background .18s;min-height:38px;
    }
    .ck-accept:hover{background:var(--r3)}
    .ck-decline{
      background:transparent;color:var(--w3);
      border:1px solid rgba(255,255,255,.1);
      padding:.46rem 1rem;font-size:.72rem;letter-spacing:.8px;
      text-transform:uppercase;cursor:pointer;transition:all .18s;
      min-height:38px;
    }
    .ck-decline:hover{border-color:rgba(255,255,255,.25);color:var(--w2)}

    /* ════════════════════════════════════════════
       RESPONSIVE
    ════════════════════════════════════════════ */
    @media(max-width:991px){
      .hero-left{padding:3.5rem 1.5rem 2.5rem}
      section{padding:3.5rem 0}
    }
    @media(max-width:768px){
      .fcard{grid-template-columns:1fr}
      .nl-form{flex-direction:column}
      .nl-input{border-right:1px solid rgba(255,255,255,.15);border-bottom:none}
      .nl-btn{padding:.75rem}
    }

    /* Accessibilité */
    .visually-hidden{
      position:absolute;width:1px;height:1px;padding:0;margin:-1px;
      overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
    }
    @media(prefers-reduced-motion:reduce){
      *{animation-duration:.01ms!important;transition-duration:.01ms!important}
    }
    /* ════════════════════════════════════════════
       POPUP AUDIT GEO — nouveau design
    ════════════════════════════════════════════ */
    .pop-audit {
      max-width: 560px;
      background: linear-gradient(135deg, var(--n2) 0%, #1a0505 100%);
      border: 1px solid rgba(192,39,45,.5);
      position: relative;
      overflow: hidden;
    }
    .pop-audit::before {
      content: '';
      position: absolute;
      inset: 0;
      background:
        linear-gradient(rgba(192,39,45,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(192,39,45,.04) 1px, transparent 1px);
      background-size: 32px 32px;
      pointer-events: none;
    }
    .pop-audit .pop-close {
      position: absolute;
      top: 1rem;
      right: 1rem;
      z-index: 2;
      background: rgba(255,255,255,.06);
      border: 1px solid rgba(255,255,255,.1);
      border-radius: 50%;
      width: 30px;
      height: 30px;
      display: flex;
      align-items: center;
      justify-content: center;
      color: var(--w3);
      font-size: .85rem;
      cursor: pointer;
      transition: all .18s;
    }
    .pop-audit .pop-close:hover { background: var(--r); border-color: var(--r); color: #fff; }
    .pop-audit-left {
      padding: 2.5rem 2rem 2rem;
      position: relative;
      z-index: 1;
    }
    .pop-audit-badge {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      background: rgba(192,39,45,.15);
      border: 1px solid rgba(192,39,45,.3);
      color: var(--r2);
      font-size: .62rem;
      letter-spacing: 1.5px;
      text-transform: uppercase;
      padding: 4px 10px;
      font-weight: 700;
      margin-bottom: 1.2rem;
    }
    .pop-audit-title {
      font-family: var(--font-head);
      font-weight: 800;
      font-size: clamp(1.3rem, 3vw, 1.7rem);
      color: var(--w);
      line-height: 1.15;
      margin-bottom: .7rem;
      letter-spacing: -.3px;
    }
    .pop-audit-desc {
      font-size: .95rem;
      color: var(--w3);
      margin-bottom: 1.3rem;
      line-height: 1.5;
    }
    .pop-audit-free {
      color: #4ade80;
      font-weight: 700;
      font-size: 1.05rem;
    }
    .pop-audit-list {
      list-style: none;
      padding: 0;
      margin-bottom: 1.6rem;
    }
    .pop-audit-list li {
      font-size: .83rem;
      color: var(--w2);
      padding: .35rem 0;
      border-bottom: 1px solid rgba(255,255,255,.05);
      line-height: 1.5;
    }
    .pop-audit-list li:last-child { border-bottom: none; }
    .pop-cta-btn {
      width: 100%;
      background: var(--r);
      color: #fff;
      border: none;
      padding: .85rem 1.5rem;
      font-family: var(--font-head);
      font-size: .88rem;
      font-weight: 800;
      letter-spacing: .5px;
      cursor: pointer;
      transition: background .2s, transform .15s;
      text-align: center;
      display: block;
    }
    .pop-cta-btn:hover { background: var(--r2); transform: translateY(-1px); }
    .pop-skip {
      width: 100%;
      background: transparent;
      border: none;
      color: rgba(200,200,200,.25);
      font-size: .65rem;
      cursor: pointer;
      padding: .8rem;
      text-align: center;
      transition: color .18s;
      letter-spacing: .5px;
    }
    .pop-skip:hover { color: var(--w3); }

    /* ════════════════════════════════════════════
       COOKIE BANNER — version flottante élégante
    ════════════════════════════════════════════ */
    .ck-banner {
      position: fixed;
      bottom: 1.5rem;
      left: 50%;
      transform: translateX(-50%) translateY(120%);
      width: min(860px, calc(100vw - 2rem));
      background: rgba(17,17,17,.97);
      border: 1px solid rgba(192,39,45,.35);
      border-radius: 4px;
      z-index: 9100;
      padding: 0;
      transition: transform .45s cubic-bezier(.34,1.56,.64,1);
      box-shadow: 0 8px 40px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.04);
      backdrop-filter: blur(16px);
    }
    .ck-banner.show {
      transform: translateX(-50%) translateY(0);
    }
    .ck-inner {
      display: flex;
      align-items: center;
      gap: 1.5rem;
      padding: 1.1rem 1.5rem;
    }
    .ck-left { flex: 1; min-width: 0; }
    .ck-title {
      display: flex;
      align-items: center;
      gap: .5rem;
      font-family: var(--font-head);
      font-weight: 800;
      font-size: .88rem;
      color: var(--w);
      margin-bottom: .3rem;
    }
    .ck-emoji { font-size: 1.1rem; flex-shrink: 0; }
    .ck-desc {
      font-size: .72rem;
      color: var(--w3);
      margin: 0;
      line-height: 1.5;
    }
    .ck-link {
      color: var(--r2);
      text-decoration: none;
      font-weight: 500;
    }
    .ck-link:hover { text-decoration: underline; }
    .ck-actions {
      display: flex;
      gap: 8px;
      flex-shrink: 0;
      align-items: center;
    }
    .ck-accept {
      background: var(--r);
      color: #fff;
      border: none;
      padding: .55rem 1.3rem;
      font-size: .72rem;
      letter-spacing: .8px;
      text-transform: uppercase;
      font-weight: 700;
      cursor: pointer;
      transition: background .18s;
      min-height: 38px;
      white-space: nowrap;
    }
    .ck-accept:hover { background: var(--r2); }
    .ck-decline {
      background: transparent;
      color: var(--w3);
      border: 1px solid rgba(255,255,255,.12);
      padding: .53rem 1rem;
      font-size: .72rem;
      letter-spacing: .8px;
      text-transform: uppercase;
      cursor: pointer;
      transition: all .18s;
      min-height: 38px;
      white-space: nowrap;
    }
    .ck-decline:hover { border-color: rgba(255,255,255,.28); color: var(--w2); }

    @media(max-width: 640px) {
      .ck-banner { bottom: 0; width: 100%; border-radius: 0; border-left: none; border-right: none; }
      .ck-banner.show { transform: translateX(-50%) translateY(0); }
      .ck-inner { flex-direction: column; align-items: flex-start; gap: 1rem; padding: 1.2rem; }
      .ck-actions { width: 100%; }
      .ck-accept, .ck-decline { flex: 1; text-align: center; }
    }

    /* ════════════════════════════════════════════
       PAGES LÉGALES
    ════════════════════════════════════════════ */
    .legal-body {
      color: var(--w2);
      line-height: 1.8;
      font-size: .95rem;
    }
    .legal-body h2 {
      font-family: var(--font-head);
      font-size: 1.15rem;
      font-weight: 800;
      color: var(--w);
      margin: 2.5rem 0 .8rem;
      padding-bottom: .5rem;
      border-bottom: 1px solid rgba(192,39,45,.3);
    }
    .legal-body h3 {
      font-family: var(--font-head);
      font-size: .95rem;
      font-weight: 700;
      color: var(--w);
      margin: 1.5rem 0 .5rem;
    }
    .legal-body p { margin-bottom: 1rem; color: var(--w3); }
    .legal-body ul { padding-left: 1.2rem; margin-bottom: 1rem; }
    .legal-body li { color: var(--w3); margin-bottom: .4rem; line-height: 1.65; }
    .legal-body a { color: var(--r2); text-decoration: none; }
    .legal-body a:hover { text-decoration: underline; }
    .legal-body strong { color: var(--w); font-weight: 600; }
