/*
Theme Name: Verdict RP
Theme URI: https://verdict-rp.fr
Author: Verdict RP
Author URI: https://verdict-rp.fr
Description: Thème WordPress pour le serveur GTA RP "Verdict RP". Page d'accueil cinématique sur le thème du tribunal et du roleplay sérieux. 100% éditable depuis l'admin (Apparence → Personnaliser et menu Métiers) — aucun code à modifier. Inclut bande-annonce vidéo, gestion des rôles, et template pour pages additionnelles (Règlement, Code pénal, FAQ, etc.).
Version: 1.1.0
Requires at least: 5.8
Tested up to: 6.5
Requires PHP: 7.4
License: GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: verdict-rp
Tags: dark, gaming, landing-page, one-column, custom-colors, custom-menu, video, fr_FR
*/


  :root{
    --bg:#08070a;
    --bg-2:#100d14;
    --ink:#f5f1ea;
    --ink-dim:#a39c91;
    --violet:#8B5CF6;
    --violet-bright:#A78BFA;
    --violet-deep:#5B21B6;
    --gold:#D4AF37;
    --gold-soft:#E8C76A;
    --blood:#7f1d1d;
    --line:rgba(245,241,234,0.08);
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html,body{background:var(--bg);color:var(--ink);font-family:'Manrope',sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden}
  body{line-height:1.5}
  a{color:inherit;text-decoration:none}
  button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

  /* film grain overlay */
  body::before{
    content:"";position:fixed;inset:0;pointer-events:none;z-index:200;opacity:.06;mix-blend-mode:overlay;
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='3'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/></svg>");
  }
  /* vignette */
  body::after{
    content:"";position:fixed;inset:0;pointer-events:none;z-index:199;
    background:radial-gradient(ellipse at center, transparent 40%, rgba(0,0,0,0.75) 100%);
  }

  /* ==========  TOP TICKER  ========== */
  .ticker{
    background:var(--violet);color:#0a0a0a;font-family:'JetBrains Mono',monospace;
    font-size:11px;letter-spacing:.2em;text-transform:uppercase;
    padding:8px 0;overflow:hidden;white-space:nowrap;position:relative;z-index:50;
    border-bottom:1px solid rgba(0,0,0,.2);
  }
  .ticker-track{display:inline-flex;gap:48px;animation:scroll 40s linear infinite;font-weight:700}
  .ticker-track span::before{content:"◆ ";color:#0a0a0a;opacity:.6;margin-right:6px}
  @keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

  /* ==========  NAV  ========== */
  nav{
    position:sticky;top:0;z-index:100;backdrop-filter:blur(14px);background:rgba(8,7,10,.7);
    border-bottom:1px solid var(--line);
  }
  .nav-inner{
    max-width:1400px;margin:0 auto;padding:18px 32px;
    display:flex;align-items:center;justify-content:space-between;gap:32px;
  }
  .brand{display:flex;align-items:center;gap:12px}
  .brand-mark{
    width:38px;height:38px;display:flex;align-items:center;justify-content:center;
    background:var(--violet);border-radius:4px;transform:rotate(-3deg);
    box-shadow:0 0 24px rgba(139,92,246,.4), inset 0 0 0 1px rgba(255,255,255,.1);
  }
  .brand-mark svg{width:22px;height:22px;fill:#0a0a0a}
  .brand-text{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:.12em;line-height:1}
  .brand-text small{display:block;font-family:'JetBrains Mono',monospace;font-size:8px;letter-spacing:.3em;color:var(--ink-dim);margin-top:3px}
  .nav-links{display:flex;gap:36px;font-size:13px;font-weight:500;letter-spacing:.05em;text-transform:uppercase}
  .nav-links a{position:relative;padding:6px 0;color:var(--ink-dim);transition:color .2s}
  .nav-links a:hover{color:var(--ink)}
  .nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--violet);transition:width .3s}
  .nav-links a:hover::after{width:100%}
  .nav-cta{
    background:var(--ink);color:#0a0a0a;padding:11px 22px;font-weight:800;font-size:12px;
    letter-spacing:.12em;text-transform:uppercase;display:flex;align-items:center;gap:8px;
    transition:transform .2s, background .2s;border:1px solid var(--ink);
  }
  .nav-cta:hover{background:var(--violet);border-color:var(--violet);color:#0a0a0a;transform:translateY(-1px)}
  .nav-cta .dot{width:7px;height:7px;background:#22c55e;border-radius:50%;box-shadow:0 0 8px #22c55e}
  @media(max-width:800px){.nav-links{display:none}}

  /* ==========  HERO  ========== */
  .hero{
    position:relative;min-height:92vh;display:flex;align-items:center;
    padding:80px 32px;overflow:hidden;
  }
  /* moving courthouse silhouette + spotlight */
  .hero-bg{
    position:absolute;inset:0;
    background:
      radial-gradient(ellipse 60% 40% at 70% 35%, rgba(139,92,246,.18), transparent 70%),
      radial-gradient(ellipse 40% 60% at 20% 80%, rgba(212,175,55,.08), transparent 70%),
      linear-gradient(180deg, var(--bg) 0%, var(--bg-2) 100%);
    z-index:-2;
  }
  .hero-grid{
    position:absolute;inset:0;z-index:-1;opacity:.18;
    background-image:
      linear-gradient(var(--line) 1px, transparent 1px),
      linear-gradient(90deg, var(--line) 1px, transparent 1px);
    background-size:60px 60px;
    mask-image:radial-gradient(ellipse 80% 60% at 50% 40%, black, transparent 80%);
  }
  /* big rotated text in background */
  .hero-ghost{
    position:absolute;right:-60px;top:50%;transform:translateY(-50%) rotate(90deg);
    transform-origin:right center;font-family:'Bebas Neue',sans-serif;
    font-size:14vw;letter-spacing:.05em;color:transparent;-webkit-text-stroke:1px rgba(139,92,246,.15);
    white-space:nowrap;pointer-events:none;z-index:-1;line-height:.9;
  }
  .hero-inner{max-width:1400px;width:100%;margin:0 auto;position:relative}
  .hero-meta{
    display:flex;align-items:center;gap:14px;font-family:'JetBrains Mono',monospace;
    font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-dim);
    margin-bottom:32px;animation:fadeUp .8s ease both;
  }
  .hero-meta .bar{height:1px;width:48px;background:var(--violet)}
  .hero-meta .live{
    color:#22c55e;display:flex;align-items:center;gap:6px;
  }
  .hero-meta .live::before{content:"";width:6px;height:6px;background:#22c55e;border-radius:50%;animation:pulse 1.8s ease infinite}
  @keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(34,197,94,.5)}50%{opacity:.6;box-shadow:0 0 0 8px rgba(34,197,94,0)}}

  h1.hero-title{
    font-family:'Bebas Neue',sans-serif;font-size:clamp(72px,14vw,220px);line-height:.85;
    letter-spacing:.005em;font-weight:400;
    animation:fadeUp 1s ease .1s both;
  }
  h1.hero-title .v{color:var(--violet);display:inline-block;position:relative}
  h1.hero-title .v::after{
    content:"";position:absolute;left:-4px;right:-4px;top:0;bottom:0;
    background:var(--violet);mix-blend-mode:multiply;opacity:0;animation:glitch 6s ease-in-out infinite;
  }
  h1.hero-title .rp{
    font-family:'JetBrains Mono',monospace;font-size:.18em;letter-spacing:.2em;
    vertical-align:super;color:var(--gold);margin-left:14px;font-weight:700;
  }
  @keyframes glitch{
    0%,90%,100%{opacity:0;transform:translateX(0)}
    92%{opacity:.6;transform:translateX(3px)}
    94%{opacity:.3;transform:translateX(-2px)}
    96%{opacity:.5;transform:translateX(1px)}
  }
  .hero-lead{
    max-width:560px;margin-top:36px;font-size:18px;line-height:1.55;color:var(--ink-dim);
    animation:fadeUp 1s ease .25s both;
  }
  .hero-lead strong{color:var(--ink);font-weight:700}
  @keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

  .hero-actions{display:flex;gap:14px;margin-top:44px;flex-wrap:wrap;animation:fadeUp 1s ease .4s both}
  .btn-primary{
    background:var(--violet);color:#0a0a0a;padding:18px 32px;font-weight:800;
    font-size:13px;letter-spacing:.15em;text-transform:uppercase;
    display:inline-flex;align-items:center;gap:10px;position:relative;overflow:hidden;
    transition:transform .15s;
  }
  .btn-primary:hover{transform:translateY(-2px)}
  .btn-primary::before{
    content:"";position:absolute;inset:0;background:var(--violet-bright);
    transform:translateY(100%);transition:transform .3s ease;z-index:-1;
  }
  .btn-primary:hover::before{transform:translateY(0)}
  .btn-ghost{
    padding:18px 28px;font-weight:600;font-size:13px;letter-spacing:.15em;text-transform:uppercase;
    border:1px solid var(--line);transition:all .2s;display:inline-flex;align-items:center;gap:10px;
  }
  .btn-ghost:hover{border-color:var(--violet);color:var(--violet-bright)}

  .hero-stats{
    display:flex;gap:48px;margin-top:80px;flex-wrap:wrap;
    animation:fadeUp 1s ease .55s both;
  }
  .stat-num{font-family:'Bebas Neue',sans-serif;font-size:42px;line-height:1;color:var(--ink)}
  .stat-num .unit{font-size:.5em;color:var(--violet);margin-left:4px}
  .stat-label{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--ink-dim);margin-top:6px}

  /* scroll hint */
  .scroll-hint{
    position:absolute;bottom:32px;left:32px;font-family:'JetBrains Mono',monospace;
    font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-dim);
    writing-mode:vertical-rl;transform:rotate(180deg);
    display:flex;align-items:center;gap:14px;
  }
  .scroll-hint::before{content:"";width:1px;height:60px;background:linear-gradient(to bottom, var(--violet), transparent);animation:scrollLine 2s ease infinite}
  @keyframes scrollLine{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

  /* ==========  SECTION COMMON  ========== */
  section{padding:120px 32px;position:relative}
  .container{max-width:1400px;margin:0 auto}
  .section-tag{
    display:inline-flex;align-items:center;gap:12px;font-family:'JetBrains Mono',monospace;
    font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--violet);
    margin-bottom:24px;
  }
  .section-tag::before{content:"";width:32px;height:1px;background:var(--violet)}
  .section-title{
    font-family:'Bebas Neue',sans-serif;font-size:clamp(48px,7vw,96px);line-height:.9;
    letter-spacing:.005em;max-width:900px;margin-bottom:24px;
  }
  .section-title .accent{color:var(--violet)}
  .section-lead{max-width:620px;color:var(--ink-dim);font-size:17px;line-height:1.6}

  /* ==========  TRAILER / VIDEO  ========== */
  .trailer{
    background:linear-gradient(180deg, var(--bg-2) 0%, var(--bg) 100%);
    position:relative;overflow:hidden;
  }
  .trailer::before{
    content:"BANDE ANNONCE BANDE ANNONCE BANDE ANNONCE";
    position:absolute;top:60px;left:-5%;right:-5%;
    font-family:'Bebas Neue',sans-serif;font-size:8vw;line-height:1;
    color:transparent;-webkit-text-stroke:1px rgba(139,92,246,.08);
    white-space:nowrap;letter-spacing:.05em;pointer-events:none;
    transform:rotate(-2deg);
  }
  .trailer-grid{
    display:grid;grid-template-columns:1fr 380px 1fr;gap:48px;align-items:center;
    margin-top:64px;
  }
  @media(max-width:1100px){.trailer-grid{grid-template-columns:1fr;justify-items:center;gap:48px}}

  .trailer-side{display:flex;flex-direction:column;gap:32px}
  .trailer-side.right{text-align:right;align-items:flex-end}
  @media(max-width:1100px){.trailer-side,.trailer-side.right{text-align:center;align-items:center;max-width:480px}}

  .trailer-stat{
    border-top:1px solid var(--line);padding-top:18px;
  }
  .trailer-stat .big{
    font-family:'Bebas Neue',sans-serif;font-size:64px;line-height:.9;color:var(--ink);
  }
  .trailer-stat .big span{color:var(--violet)}
  .trailer-stat .label{
    font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.25em;
    text-transform:uppercase;color:var(--ink-dim);margin-top:6px;
  }
  .trailer-quote{
    font-family:'Bebas Neue',sans-serif;font-size:28px;line-height:1.15;letter-spacing:.02em;
    max-width:280px;color:var(--ink);
  }
  .trailer-quote::before{content:"« ";color:var(--violet)}
  .trailer-quote::after{content:" »";color:var(--violet)}
  .trailer-quote-author{
    font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink-dim);
    letter-spacing:.2em;text-transform:uppercase;margin-top:8px;
  }

  /* phone frame */
  .phone{
    position:relative;width:340px;aspect-ratio:9/16;
    background:#000;border-radius:38px;padding:10px;
    box-shadow:
      0 0 0 2px rgba(139,92,246,.4),
      0 30px 80px rgba(139,92,246,.25),
      0 60px 120px rgba(0,0,0,.7),
      inset 0 0 0 2px rgba(255,255,255,.04);
    animation:phoneFloat 6s ease-in-out infinite;
  }
  @keyframes phoneFloat{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-10px) rotate(.4deg)}}
  .phone::before{
    /* notch */
    content:"";position:absolute;top:14px;left:50%;transform:translateX(-50%);
    width:110px;height:24px;background:#000;border-radius:14px;z-index:3;
    box-shadow:inset 0 -1px 0 rgba(255,255,255,.05);
  }
  .phone::after{
    /* side button glow */
    content:"";position:absolute;right:-2px;top:30%;width:3px;height:60px;
    background:linear-gradient(180deg, transparent, var(--violet), transparent);
    border-radius:2px;opacity:.6;
  }
  .phone-screen{
    position:relative;width:100%;height:100%;border-radius:30px;overflow:hidden;
    background:#000;
  }
  .phone-screen video{
    width:100%;height:100%;object-fit:cover;display:block;
  }

  /* play button overlay */
  .play-overlay{
    position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
    cursor:pointer;background:radial-gradient(circle at center, rgba(0,0,0,.2), rgba(0,0,0,.6));
    transition:opacity .3s;z-index:2;
  }
  .play-overlay.hidden{opacity:0;pointer-events:none}
  .play-btn{
    width:80px;height:80px;border-radius:50%;background:rgba(139,92,246,.95);
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 0 0 0 rgba(139,92,246,.6);
    animation:playPulse 2s ease infinite;
  }
  @keyframes playPulse{
    0%{box-shadow:0 0 0 0 rgba(139,92,246,.7)}
    100%{box-shadow:0 0 0 24px rgba(139,92,246,0)}
  }
  .play-btn svg{width:30px;height:30px;fill:#0a0a0a;margin-left:4px}
  .play-label{
    position:absolute;bottom:32px;left:0;right:0;text-align:center;
    font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.3em;
    text-transform:uppercase;color:#fff;
  }
  .play-label .live-tag{
    color:var(--violet-bright);
  }
  .play-label .live-tag::before{
    content:"";display:inline-block;width:6px;height:6px;background:var(--violet);
    border-radius:50%;margin-right:6px;vertical-align:middle;animation:pulse 1.8s ease infinite;
  }

  /* control bar shown after play */
  .video-controls{
    position:absolute;left:14px;right:14px;bottom:14px;z-index:2;
    display:flex;align-items:center;gap:10px;opacity:0;transition:opacity .3s;
    pointer-events:none;
  }
  .phone.playing .video-controls{opacity:1;pointer-events:auto}
  .video-controls button{
    background:rgba(0,0,0,.6);backdrop-filter:blur(6px);width:32px;height:32px;
    border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;
  }
  .video-controls button svg{width:14px;height:14px;fill:currentColor}
  .video-controls .progress{
    flex:1;height:3px;background:rgba(255,255,255,.2);border-radius:2px;overflow:hidden;
  }
  .video-controls .progress-fill{
    height:100%;width:0%;background:var(--violet);transition:width .1s linear;
  }

  /* decorative tape */
  .phone-tape{
    position:absolute;top:-12px;left:50%;transform:translateX(-50%) rotate(-3deg);
    background:var(--gold);color:#0a0a0a;font-family:'JetBrains Mono',monospace;
    font-size:9px;letter-spacing:.25em;font-weight:700;padding:4px 16px;text-transform:uppercase;
    z-index:4;
  }

  /* ==========  PILIERS  ========== */
  .piliers{background:linear-gradient(180deg, var(--bg) 0%, #0c0a0f 100%)}
  .pilier-grid{
    margin-top:72px;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1px;
    background:var(--line);border:1px solid var(--line);
  }
  .pilier{
    background:var(--bg);padding:48px 36px;position:relative;
    transition:background .3s;overflow:hidden;
  }
  .pilier:hover{background:var(--bg-2)}
  .pilier .num{
    font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.3em;color:var(--violet);
  }
  .pilier .icon{
    margin:32px 0 28px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;
    color:var(--gold);
  }
  .pilier .icon svg{width:100%;height:100%;fill:currentColor}
  .pilier h3{
    font-family:'Bebas Neue',sans-serif;font-size:32px;letter-spacing:.02em;margin-bottom:12px;
  }
  .pilier p{color:var(--ink-dim);font-size:14.5px;line-height:1.6}
  .pilier::after{
    content:"";position:absolute;left:0;top:0;height:2px;width:0;background:var(--violet);
    transition:width .4s ease;
  }
  .pilier:hover::after{width:100%}

  /* ==========  METIERS  ========== */
  .metiers{background:#0a0810;position:relative;overflow:hidden}
  .metiers::before{
    content:"VERDICT";position:absolute;left:-2vw;bottom:-4vw;
    font-family:'Bebas Neue',sans-serif;font-size:28vw;line-height:.85;
    color:transparent;-webkit-text-stroke:1px rgba(139,92,246,.07);pointer-events:none;letter-spacing:-.02em;
  }
  .metier-row{
    display:flex;align-items:center;justify-content:space-between;gap:32px;
    padding:32px 0;border-bottom:1px solid var(--line);
    transition:padding .3s;cursor:pointer;position:relative;
  }
  .metier-row:hover{padding-left:24px}
  .metier-row:first-of-type{border-top:1px solid var(--line)}
  .metier-row .left{display:flex;align-items:center;gap:32px;flex:1}
  .metier-row .id{
    font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--ink-dim);min-width:48px;
  }
  .metier-row .name{
    font-family:'Bebas Neue',sans-serif;font-size:clamp(28px,4vw,56px);letter-spacing:.02em;line-height:1;
    transition:color .25s;
  }
  .metier-row:hover .name{color:var(--violet-bright)}
  .metier-row .tag{
    font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.25em;text-transform:uppercase;
    padding:6px 12px;border:1px solid var(--line);color:var(--ink-dim);border-radius:2px;
  }
  .metier-row .tag.legal{color:var(--gold);border-color:rgba(212,175,55,.3)}
  .metier-row .tag.illegal{color:#ef4444;border-color:rgba(239,68,68,.3)}
  .metier-row .arrow{
    width:48px;height:48px;display:flex;align-items:center;justify-content:center;
    border:1px solid var(--line);border-radius:50%;
    transition:all .3s;
  }
  .metier-row:hover .arrow{border-color:var(--violet);background:var(--violet);color:#0a0a0a;transform:rotate(-45deg)}
  .metier-row .arrow svg{width:18px;height:18px;fill:currentColor}

  /* ==========  TRIBUNAL FEATURE  ========== */
  .tribunal{
    background:linear-gradient(160deg, #100d14 0%, #08070a 100%);
    position:relative;
  }
  .tribunal-grid{
    margin-top:64px;display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:center;
  }
  @media(max-width:900px){.tribunal-grid{grid-template-columns:1fr}}
  .tribunal-visual{
    position:relative;aspect-ratio:4/5;background:#000;overflow:hidden;
    border:1px solid var(--line);
  }
  .tribunal-visual::before{
    /* abstract courtroom — built with css */
    content:"";position:absolute;inset:0;
    background:
      radial-gradient(ellipse 60% 30% at 50% 70%, rgba(212,175,55,.25), transparent),
      linear-gradient(180deg, rgba(0,0,0,0) 30%, rgba(0,0,0,.8) 100%),
      repeating-linear-gradient(90deg, #2b1d10 0px, #3d2818 4px, #2b1d10 8px, #1f1409 12px),
      #1a1209;
  }
  /* gavel */
  .gavel{
    position:absolute;top:50%;left:50%;transform:translate(-50%,-60%);
    width:60%;color:var(--gold);
  }
  .gavel svg{width:100%;height:auto;filter:drop-shadow(0 12px 32px rgba(212,175,55,.4))}
  .tribunal-visual .scanline{
    position:absolute;left:0;right:0;height:2px;background:rgba(139,92,246,.5);
    box-shadow:0 0 12px var(--violet);animation:scan 4s ease-in-out infinite;
  }
  @keyframes scan{0%{top:0}50%{top:100%}100%{top:0}}
  .tribunal-visual .corner{position:absolute;width:20px;height:20px;border:1px solid var(--violet)}
  .tribunal-visual .corner.tl{top:12px;left:12px;border-right:none;border-bottom:none}
  .tribunal-visual .corner.tr{top:12px;right:12px;border-left:none;border-bottom:none}
  .tribunal-visual .corner.bl{bottom:12px;left:12px;border-right:none;border-top:none}
  .tribunal-visual .corner.br{bottom:12px;right:12px;border-left:none;border-top:none}
  .tribunal-visual .badge{
    position:absolute;top:24px;left:24px;font-family:'JetBrains Mono',monospace;
    font-size:10px;letter-spacing:.25em;color:var(--violet);
  }
  .tribunal-visual .badge::before{content:"● ";color:#ef4444;animation:blink 1.4s ease infinite}
  @keyframes blink{50%{opacity:.3}}
  .tribunal-visual .case{
    position:absolute;bottom:24px;left:24px;right:24px;
    font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink);
    border-top:1px solid rgba(212,175,55,.3);padding-top:14px;
    display:flex;justify-content:space-between;
  }
  .tribunal-visual .case span:last-child{color:var(--gold)}

  .tribunal-text h2{margin-bottom:24px}
  .tribunal-points{margin-top:36px;display:flex;flex-direction:column;gap:18px}
  .point{display:flex;gap:18px;padding-bottom:18px;border-bottom:1px dashed var(--line)}
  .point .pn{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--violet);min-width:32px;padding-top:4px}
  .point h4{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:.04em;margin-bottom:6px}
  .point p{color:var(--ink-dim);font-size:14.5px;line-height:1.55}

  /* ==========  DISCORD CTA  ========== */
  .discord{
    padding:140px 32px;position:relative;overflow:hidden;
    background:
      radial-gradient(ellipse 60% 80% at 50% 50%, rgba(139,92,246,.15), transparent 70%),
      var(--bg);
    text-align:center;
  }
  .discord-inner{max-width:900px;margin:0 auto;position:relative}
  .discord-logo{
    width:96px;height:96px;background:#5865F2;border-radius:24px;margin:0 auto 32px;
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 20px 60px rgba(88,101,242,.4);
    animation:float 4s ease-in-out infinite;
  }
  @keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
  .discord-logo svg{width:56px;height:56px;fill:#fff}
  .discord h2{
    font-family:'Bebas Neue',sans-serif;font-size:clamp(56px,9vw,128px);line-height:.9;letter-spacing:.005em;
    margin-bottom:24px;
  }
  .discord h2 .stamp{
    display:inline-block;color:var(--violet);position:relative;
  }
  .discord h2 .stamp::before{
    content:"";position:absolute;inset:-8px -16px;border:2px solid var(--violet);
    transform:rotate(-2deg);pointer-events:none;
  }
  .discord p.lead{color:var(--ink-dim);font-size:18px;max-width:560px;margin:0 auto 48px;line-height:1.6}
  .discord-btn{
    display:inline-flex;align-items:center;gap:14px;background:#5865F2;color:#fff;
    padding:22px 40px;font-weight:800;font-size:14px;letter-spacing:.12em;text-transform:uppercase;
    transition:all .2s;border:2px solid transparent;
  }
  .discord-btn:hover{background:transparent;border-color:#5865F2;color:#5865F2;transform:translateY(-2px)}
  .discord-btn svg{width:22px;height:22px;fill:currentColor}

  .discord-members{
    margin-top:64px;display:inline-flex;align-items:center;gap:16px;
    padding:14px 24px;border:1px solid var(--line);border-radius:100px;
    font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--ink-dim);
  }
  .avatars{display:flex}
  .avatars span{
    width:28px;height:28px;border-radius:50%;border:2px solid var(--bg);
    margin-left:-10px;display:flex;align-items:center;justify-content:center;
    font-family:'Bebas Neue',sans-serif;font-size:12px;color:#0a0a0a;
  }
  .avatars span:nth-child(1){background:var(--violet);margin-left:0}
  .avatars span:nth-child(2){background:var(--gold)}
  .avatars span:nth-child(3){background:#22c55e}
  .avatars span:nth-child(4){background:#ef4444}
  .discord-members b{color:var(--ink)}

  /* ==========  FOOTER  ========== */
  footer{
    border-top:1px solid var(--line);padding:64px 32px 32px;background:#06050a;
  }
  .footer-inner{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px}
  @media(max-width:800px){.footer-inner{grid-template-columns:1fr 1fr}}
  .footer-brand h4{font-family:'Bebas Neue',sans-serif;font-size:32px;letter-spacing:.04em;margin-bottom:12px}
  .footer-brand p{color:var(--ink-dim);font-size:13px;max-width:300px;line-height:1.6}
  .footer-col h5{
    font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.25em;text-transform:uppercase;
    color:var(--violet);margin-bottom:18px;
  }
  .footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
  .footer-col a{font-size:13.5px;color:var(--ink-dim);transition:color .2s}
  .footer-col a:hover{color:var(--ink)}
  .legal{
    max-width:1400px;margin:48px auto 0;padding-top:24px;border-top:1px solid var(--line);
    display:flex;justify-content:space-between;font-family:'JetBrains Mono',monospace;font-size:10px;
    letter-spacing:.2em;text-transform:uppercase;color:var(--ink-dim);flex-wrap:wrap;gap:12px;
  }

  /* utilities for reveal on scroll */
  .reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease, transform .8s ease}
  .reveal.in{opacity:1;transform:translateY(0)}
