
/* ─── RESET ─── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:auto}
body{
  background:#030208;
  color:#e8ddd0;
  font-family:'DM Mono',monospace;
  overflow-x:hidden;
  cursor:none;
  user-select:none;
}

/* ─── CSS VARS ─── */
:root{
  --red:#b01020;
  --red2:#e0182c;
  --red3:#ff2040;
  --gold:#c8882a;
  --gold2:#f0b84a;
  --cream:#e8ddd0;
  --dim:rgba(232,221,208,0.35);
  --bg:#030208;
  --bg2:#07050f;
  --ff-display:'Unbounded',sans-serif;
  --ff-title:'Cinzel Decorative',serif;
  --ff-mono:'DM Mono',monospace;
  --ff-block:'Bebas Neue',sans-serif;
}

/* ─── CURSOR ─── */
#cur{
  position:fixed;width:6px;height:6px;
  background:var(--red3);border-radius:50%;
  pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .15s,height .15s;
  mix-blend-mode:screen;
}
#cur-trail{
  position:fixed;width:28px;height:28px;
  border:1px solid rgba(224,24,44,0.5);border-radius:50%;
  pointer-events:none;z-index:9998;
  transform:translate(-50%,-50%);
  transition:width .3s,height .3s,border-color .3s;
}
body:has(a:hover) #cur{width:16px;height:16px}
body:has(a:hover) #cur-trail{width:50px;height:50px;border-color:rgba(224,24,44,0.8)}

/* ─── CANVAS BG ─── */
#canvas-bg{
  position:fixed;inset:0;
  z-index:0;pointer-events:none;
  opacity:.7;
}

/* ─── NOISE ─── */
.noise{
  position:fixed;inset:0;z-index:1000;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  opacity:.025;
}

/* ─── PROGRESS BAR ─── */
#progress{
  position:fixed;top:0;left:0;height:1px;
  background:linear-gradient(90deg,var(--red),var(--red3),var(--gold));
  z-index:900;width:0%;transition:width .1s linear;
}

/* ─── NAV ─── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 48px;height:68px;
  background:linear-gradient(to bottom,rgba(3,2,8,.95),transparent);
}
.nav-logo{
  font-family:var(--ff-block);font-size:26px;
  letter-spacing:.15em;color:var(--cream);
  text-decoration:none;
}
.nav-logo b{color:var(--red3)}
.nav-links{display:flex;gap:36px;list-style:none}
.nav-links a{
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.3em;text-transform:uppercase;
  color:var(--dim);text-decoration:none;
  transition:color .2s;
}
.nav-links a:hover{color:var(--cream)}
.nav-btn{
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--bg);background:var(--red2);
  border:none;padding:10px 22px;
  text-decoration:none;
  transition:background .2s,box-shadow .2s;
}
.nav-btn:hover{background:var(--red3);box-shadow:0 0 30px rgba(224,24,44,.5)}

/* ─── SECTIONS BASE ─── */
section{position:relative;z-index:2}

/* ══════════════════════════════════════════════
   HERO — cinematic opener
══════════════════════════════════════════════ */
.hero{
  height:100vh;display:flex;align-items:center;justify-content:center;
  overflow:hidden;position:relative;
  padding:0 20px;
}
.hero-bg-text{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-block);font-size:clamp(160px,30vw,380px);
  color:transparent;-webkit-text-stroke:1px rgba(176,16,32,.06);
  pointer-events:none;letter-spacing:-.02em;white-space:nowrap;
  animation:bgRotate 60s linear infinite;
  transform-origin:center;
}
@keyframes bgRotate{to{letter-spacing:.1em}}

.hero-center{
  position:relative;z-index:3;text-align:center;
  display:flex;flex-direction:column;align-items:center;
  width:100%;max-width:800px;
}

.hero-eyebrow{
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.5em;color:var(--red2);text-transform:uppercase;
  margin-bottom:32px;opacity:0;
  animation:fadeUp .8s .3s cubic-bezier(.22,1,.36,1) forwards;
  display:flex;align-items:center;gap:16px;
}
.hero-eyebrow::before,.hero-eyebrow::after{
  content:'';width:32px;height:1px;background:var(--red2);
}

/* Big title with reveal mask */
.hero-title-wrap{overflow:hidden;margin-bottom:8px}
.hero-title{
  font-family:var(--ff-title);
  font-size:clamp(64px,12vw,160px);
  font-weight:900;
  letter-spacing:.06em;
  color:var(--cream);
  line-height:.9;
  display:block;
  transform:translateY(110%);
  animation:revealUp 1s .6s cubic-bezier(.22,1,.36,1) forwards;
  text-shadow:0 0 80px rgba(224,24,44,.2);
}
@keyframes revealUp{to{transform:translateY(0)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

.hero-sub-wrap{overflow:hidden}
.hero-sub{
  font-family:var(--ff-block);font-size:clamp(40px,7vw,90px);
  letter-spacing:.25em;color:transparent;
  -webkit-text-stroke:1px rgba(232,221,208,.25);
  transform:translateY(110%);
  animation:revealUp 1s .85s cubic-bezier(.22,1,.36,1) forwards;
  display:block;
}

.hero-tagline{
  font-family:var(--ff-mono);font-size:13px;font-weight:300;
  color:var(--dim);letter-spacing:.15em;
  max-width:460px;line-height:1.9;
  margin-top:36px;
  opacity:0;animation:fadeUp .8s 1.2s cubic-bezier(.22,1,.36,1) forwards;
}
.hero-tagline strong{color:var(--red3);font-weight:500}

.hero-actions{
  display:flex;gap:20px;margin-top:48px;align-items:center;
  opacity:0;animation:fadeUp .8s 1.5s cubic-bezier(.22,1,.36,1) forwards;
}
.btn-main{
  font-family:var(--ff-mono);font-size:11px;letter-spacing:.25em;
  text-transform:uppercase;color:var(--bg);
  background:var(--red2);padding:16px 40px;
  text-decoration:none;position:relative;overflow:hidden;
  transition:background .2s,box-shadow .3s;
}
.btn-main::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(105deg,transparent 35%,rgba(255,255,255,.15) 50%,transparent 65%);
  transform:translateX(-150%);transition:transform .5s;
}
.btn-main:hover{background:var(--red3);box-shadow:0 0 60px rgba(224,24,44,.4)}
.btn-main:hover::before{transform:translateX(150%)}
.btn-ghost{
  font-family:var(--ff-mono);font-size:11px;letter-spacing:.25em;
  text-transform:uppercase;color:var(--dim);
  text-decoration:none;padding:15px 32px;
  border:1px solid rgba(232,221,208,.15);
  transition:border-color .2s,color .2s;
}
.btn-ghost:hover{border-color:var(--red2);color:var(--cream)}

/* Scroll mouse */
.scroll-indicator{
  position:absolute;bottom:40px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:12px;
  opacity:0;animation:fadeUp .8s 2s cubic-bezier(.22,1,.36,1) forwards;
  color:var(--dim);
}
.scroll-mouse{
  width:22px;height:36px;border:1px solid rgba(232,221,208,.25);
  border-radius:11px;position:relative;
}
.scroll-mouse::before{
  content:'';position:absolute;top:6px;left:50%;transform:translateX(-50%);
  width:3px;height:7px;background:var(--red2);border-radius:2px;
  animation:scrollDot 2s ease-in-out infinite;
}
@keyframes scrollDot{0%,100%{top:6px;opacity:1}60%{top:18px;opacity:0}}
.scroll-txt{font-size:9px;letter-spacing:.4em;text-transform:uppercase}

/* ══════════════════════════════════════════════
   CHAPTER SYSTEM — scroll storytelling
══════════════════════════════════════════════ */
.chapter{
  min-height:100vh;
  display:flex;align-items:center;
  padding:120px 0;
  position:relative;
  overflow:hidden;
}

/* horizontal rule decoration */
.chapter::before{
  content:attr(data-num);
  position:absolute;top:60px;left:48px;
  font-family:var(--ff-block);font-size:180px;
  color:transparent;-webkit-text-stroke:1px rgba(176,16,32,.06);
  pointer-events:none;line-height:1;
}

.ch-inner{
  max-width:1200px;margin:0 auto;padding:0 60px;
  width:100%;
}

/* ── CHAPTER: 3 VIES ── */
.three-lives-layout{
  display:grid;grid-template-columns:1fr 1fr;
  gap:120px;align-items:center;
}

.lives-visual{
  display:flex;flex-direction:column;gap:0;
  position:sticky;top:calc(50vh - 140px);
  align-self:start;
}

/* Three life bars — cinematic style */
.life-row{
  display:flex;align-items:center;gap:32px;
  padding:28px 0;border-bottom:1px solid rgba(176,16,32,.12);
  opacity:.25;transform:translateX(-30px);
  transition:opacity .6s,transform .6s;
}
.life-row.active{opacity:1;transform:none}
.life-row.dead{opacity:.12}

.life-num{
  font-family:var(--ff-block);font-size:72px;
  line-height:1;min-width:80px;
  color:var(--cream);
}
.life-row.dead .life-num{color:var(--red);text-decoration:line-through}

.life-bar-wrap{flex:1}
.life-bar-label{
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.3em;text-transform:uppercase;
  color:var(--dim);margin-bottom:8px;
}
.life-bar{
  height:2px;background:rgba(232,221,208,.08);
  position:relative;overflow:hidden;
}
.life-bar-fill{
  position:absolute;inset:0;
  background:linear-gradient(90deg,var(--red),var(--red3));
  transform:scaleX(1);transform-origin:left;
  transition:transform 1s cubic-bezier(.22,1,.36,1);
}
.life-row.dead .life-bar-fill{
  transform:scaleX(0);
  background:rgba(176,16,32,.3);
}

.life-status{
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.2em;text-transform:uppercase;
  white-space:nowrap;
}
.life-row:not(.dead) .life-status{color:var(--red2)}
.life-row.dead .life-status{color:rgba(176,16,32,.4)}

/* text side */
.lives-text{}
.ch-label{
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.5em;text-transform:uppercase;
  color:var(--red2);margin-bottom:24px;
  display:flex;align-items:center;gap:12px;
}
.ch-label::before{content:'';width:24px;height:1px;background:var(--red2)}

.ch-title{
  font-family:var(--ff-display);font-weight:900;
  font-size:clamp(42px,5.5vw,72px);
  line-height:.95;color:var(--cream);
  letter-spacing:-.02em;margin-bottom:28px;
}
.ch-title em{color:var(--red3);font-style:normal}

.ch-body{
  font-size:14px;font-weight:300;
  color:var(--dim);line-height:1.9;
  letter-spacing:.02em;max-width:440px;
}
.ch-body + .ch-body{margin-top:16px}

/* Reveal on scroll */
.s-reveal{
  opacity:0;transform:translateY(40px);
  transition:opacity .9s cubic-bezier(.22,1,.36,1),transform .9s cubic-bezier(.22,1,.36,1);
}
.s-reveal.in{opacity:1;transform:none}
.s-reveal-left{
  opacity:0;transform:translateX(-40px);
  transition:opacity .9s cubic-bezier(.22,1,.36,1),transform .9s cubic-bezier(.22,1,.36,1);
}
.s-reveal-left.in{opacity:1;transform:none}
.delay-1{transition-delay:.1s}
.delay-2{transition-delay:.2s}
.delay-3{transition-delay:.3s}
.delay-4{transition-delay:.4s}
.delay-5{transition-delay:.5s}

/* ── CHAPTER: TERRITORY ── */
.territory-section{background:var(--bg2)}
.territory-layout{
  display:grid;grid-template-columns:1.2fr 1fr;
  gap:100px;align-items:center;
}

/* ASCII-style map */
.map-container{
  position:relative;
  aspect-ratio:1;max-width:520px;
}
.map-grid{
  width:100%;height:100%;
  display:grid;grid-template-columns:repeat(12,1fr);grid-template-rows:repeat(12,1fr);
  gap:3px;
  padding:24px;
  background:rgba(255,255,255,.01);
  border:1px solid rgba(176,16,32,.12);
}
.map-cell{
  background:rgba(232,221,208,.02);
  border:1px solid rgba(176,16,32,.05);
  border-radius:1px;
  position:relative;
  transition:background .4s,border-color .4s;
  cursor:none;
}
.map-cell.faction-1{background:rgba(176,16,32,.18);border-color:rgba(176,16,32,.4)}
.map-cell.faction-2{background:rgba(68,136,255,.14);border-color:rgba(68,136,255,.35)}
.map-cell.faction-3{background:rgba(68,255,136,.1);border-color:rgba(68,255,136,.3)}
.map-cell.faction-4{background:rgba(255,187,51,.1);border-color:rgba(255,187,51,.3)}
.map-cell.contested{
  background:rgba(224,24,44,.08);
  border-color:rgba(224,24,44,.6);
  animation:contestPulse 1.5s ease-in-out infinite;
}
@keyframes contestPulse{
  0%,100%{background:rgba(224,24,44,.08);border-color:rgba(224,24,44,.4)}
  50%{background:rgba(224,24,44,.2);border-color:rgba(224,24,44,.8)}
}
.map-cell:hover{background:rgba(224,24,44,.2)!important;border-color:rgba(224,24,44,.8)!important}

.map-legend{
  display:flex;flex-wrap:wrap;gap:12px;margin-top:16px;
}
.map-leg-item{
  display:flex;align-items:center;gap:8px;
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.15em;color:var(--dim);
}
.map-leg-dot{width:8px;height:8px;border-radius:50%}

.map-tooltip{
  position:absolute;pointer-events:none;z-index:10;
  background:rgba(3,2,8,.95);border:1px solid rgba(176,16,32,.4);
  padding:12px 18px;
  font-family:var(--ff-mono);font-size:11px;
  color:var(--cream);letter-spacing:.1em;
  opacity:0;transition:opacity .2s;
  white-space:nowrap;
  top:-60px;left:50%;transform:translateX(-50%);
}
.map-container:hover .map-tooltip{opacity:1}

/* ── CHAPTER: FEATURES (horizontal scroll) ── */
.features-outer{
  overflow:hidden;padding:160px 0;
  background:var(--bg);
}
.features-header-row{
  max-width:1200px;margin:0 auto;padding:0 60px;
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-bottom:80px;
}
.features-scroll-wrap{
  position:relative;cursor:none;
  padding-left:60px;
}
.features-track{
  display:flex;gap:24px;
  overflow-x:auto;scrollbar-width:none;
  padding-bottom:40px;
  scroll-behavior:smooth;
}
.features-track::-webkit-scrollbar{display:none}

.feat-card{
  flex-shrink:0;width:320px;
  background:rgba(255,255,255,.015);
  border:1px solid rgba(176,16,32,.1);
  padding:48px 36px;
  position:relative;overflow:hidden;
  transition:border-color .3s,transform .4s;
  cursor:none;
}
.feat-card::after{
  content:'';position:absolute;
  bottom:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--red),transparent);
  transform:scaleX(0);transform-origin:center;
  transition:transform .4s;
}
.feat-card:hover{border-color:rgba(176,16,32,.4);transform:translateY(-8px)}
.feat-card:hover::after{transform:scaleX(1)}

.feat-num{
  font-family:var(--ff-block);font-size:80px;
  color:rgba(176,16,32,.1);line-height:1;
  margin-bottom:24px;
  transition:color .3s;
}
.feat-card:hover .feat-num{color:rgba(176,16,32,.25)}

.feat-title{
  font-family:var(--ff-display);font-weight:700;
  font-size:20px;color:var(--cream);
  letter-spacing:-.01em;margin-bottom:16px;
}
.feat-desc{
  font-size:13px;font-weight:300;
  color:var(--dim);line-height:1.8;
}
.feat-tag{
  display:inline-block;margin-top:24px;
  font-family:var(--ff-mono);font-size:9px;
  letter-spacing:.25em;text-transform:uppercase;
  color:var(--red2);
  border:1px solid rgba(176,16,32,.3);
  padding:5px 14px;
}

/* drag hint */
.drag-hint{
  display:flex;align-items:center;gap:12px;
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.3em;text-transform:uppercase;
  color:var(--dim);
}
.drag-hint-arrow{
  width:48px;height:1px;background:var(--dim);
  position:relative;
}
.drag-hint-arrow::after{
  content:'';position:absolute;right:-1px;top:-3px;
  width:7px;height:7px;border-right:1px solid var(--dim);border-top:1px solid var(--dim);
  transform:rotate(45deg);
}

/* ── ITEMS — reveal on hover ── */
.items-outer{
  background:var(--bg2);padding:160px 0;overflow:hidden;
}
.items-inner{max-width:1200px;margin:0 auto;padding:0 60px}

.items-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
  margin-top:80px;
}

.item-tile{
  aspect-ratio:.75;
  background:rgba(255,255,255,.015);
  border:1px solid rgba(176,16,32,.08);
  position:relative;overflow:hidden;
  cursor:none;
  transition:border-color .3s;
}
.item-tile:hover{border-color:rgba(176,16,32,.5)}

.item-bg{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-size:64px;
  filter:grayscale(1);opacity:.15;
  transition:opacity .4s,filter .4s,transform .4s;
}
.item-tile:hover .item-bg{opacity:.4;filter:grayscale(0);transform:scale(1.1)}

.item-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(3,2,8,.95) 0%,transparent 60%);
}
.item-content{
  position:absolute;bottom:0;left:0;right:0;padding:24px;
  transform:translateY(8px);transition:transform .3s;
}
.item-tile:hover .item-content{transform:none}

.item-rarity-badge{
  display:inline-block;
  font-family:var(--ff-mono);font-size:8px;
  letter-spacing:.3em;text-transform:uppercase;
  padding:3px 10px;margin-bottom:8px;
}
.r-legendary{color:#f0b84a;border:1px solid rgba(240,184,74,.35)}
.r-epic{color:#c878ff;border:1px solid rgba(200,120,255,.35)}
.r-rare{color:#5090ff;border:1px solid rgba(80,144,255,.35)}
.r-uncommon{color:#50e880;border:1px solid rgba(80,232,128,.35)}

.item-name{
  font-family:var(--ff-display);font-weight:700;
  font-size:16px;color:var(--cream);letter-spacing:-.01em;
}
.item-desc{
  font-family:var(--ff-mono);font-size:10px;
  color:var(--dim);line-height:1.6;margin-top:6px;
  max-height:0;overflow:hidden;
  transition:max-height .4s;
}
.item-tile:hover .item-desc{max-height:80px}

/* tall item spans 2 rows */
.item-tile.tall{grid-row:span 2;aspect-ratio:unset}

/* ── FACTIONS BOARD ── */
.factions-outer{
  background:var(--bg);padding:160px 0;
}
.factions-inner{max-width:1200px;margin:0 auto;padding:0 60px}

.factions-layout{
  display:grid;grid-template-columns:1fr 1.6fr;
  gap:100px;align-items:start;
  margin-top:80px;
}

.faction-cards{display:flex;flex-direction:column;gap:12px}

.faction-card{
  padding:28px 32px;
  background:rgba(255,255,255,.015);
  border:1px solid rgba(176,16,32,.1);
  position:relative;overflow:hidden;cursor:none;
  transition:all .3s;
}
.faction-card::before{
  content:'';position:absolute;
  left:0;top:0;bottom:0;width:3px;
  transform:scaleY(0);transform-origin:top;
  transition:transform .3s;
}
.faction-card:hover{border-color:rgba(176,16,32,.4);padding-left:44px}
.faction-card:hover::before{transform:scaleY(1)}

.faction-card[data-color="red"]::before{background:#ff4444}
.faction-card[data-color="blue"]::before{background:#4488ff}
.faction-card[data-color="green"]::before{background:#44ee88}
.faction-card[data-color="gold"]::before{background:#ffbb33}

.fc-top{display:flex;justify-content:space-between;align-items:center}
.fc-name{
  font-family:var(--ff-display);font-weight:700;
  font-size:18px;color:var(--cream);letter-spacing:-.01em;
}
.fc-pts{
  font-family:var(--ff-block);font-size:32px;
  color:var(--dim);
}
.fc-meta{
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.15em;color:var(--dim);
  margin-top:6px;
}
.fc-bar{
  height:1px;background:rgba(232,221,208,.06);
  margin-top:14px;
  position:relative;overflow:hidden;
}
.fc-bar-fill{
  position:absolute;left:0;top:0;bottom:0;
  background:linear-gradient(90deg,rgba(176,16,32,.4),rgba(224,24,44,.8));
  transition:width 1.4s cubic-bezier(.22,1,.36,1) .2s;
  width:0%;
}
.faction-card.in .fc-bar-fill{width:var(--pct,50%)}

/* Leaderboard visual */
.leaderboard{
  background:rgba(255,255,255,.01);
  border:1px solid rgba(176,16,32,.12);
  padding:0;
  position:relative;
}
.lb-header{
  padding:20px 32px;
  border-bottom:1px solid rgba(176,16,32,.1);
  display:flex;justify-content:space-between;align-items:center;
}
.lb-title{
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.35em;text-transform:uppercase;
  color:var(--red2);
}
.lb-live{
  display:flex;align-items:center;gap:8px;
  font-family:var(--ff-mono);font-size:9px;
  letter-spacing:.2em;color:rgba(34,255,102,.7);
}
.lb-dot{
  width:6px;height:6px;background:#22ff66;border-radius:50%;
  box-shadow:0 0 8px #22ff66;
  animation:lbPulse 1.5s ease-in-out infinite;
}
@keyframes lbPulse{50%{box-shadow:0 0 16px #22ff66}}

.lb-row{
  display:grid;grid-template-columns:52px 1fr auto 100px;
  align-items:center;gap:20px;
  padding:22px 32px;
  border-bottom:1px solid rgba(176,16,32,.07);
  transition:background .2s;
  position:relative;overflow:hidden;
}
.lb-row::before{
  content:'';position:absolute;left:0;top:0;bottom:0;
  width:0%;
  transition:width .6s;
  opacity:.04;
}
.lb-row:hover::before{width:100%}
.lb-row:last-child{border-bottom:none}
.lb-row:hover{background:rgba(176,16,32,.04)}

.lb-rank{
  font-family:var(--ff-block);font-size:28px;line-height:1;
  text-align:center;
}
.lb-row:nth-child(1) .lb-rank{color:var(--gold2)}
.lb-row:nth-child(2) .lb-rank{color:#c0c0c0}
.lb-row:nth-child(3) .lb-rank{color:#cd7f32}
.lb-row:nth-child(n+4) .lb-rank{color:rgba(232,221,208,.2)}

.lb-info .lb-fname{font-weight:500;font-size:15px;color:var(--cream)}
.lb-info .lb-fmeta{
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.1em;color:var(--dim);margin-top:3px;
}

.lb-pts-val{
  font-family:var(--ff-block);font-size:36px;
  color:var(--red2);text-align:right;
}
.lb-row:hover .lb-pts-val{color:var(--red3)}

.lb-bar-col{display:flex;align-items:center}
.lb-mini-bar{
  width:100%;height:2px;background:rgba(232,221,208,.05);
  position:relative;overflow:hidden;
}
.lb-mini-fill{
  position:absolute;left:0;top:0;bottom:0;
  background:linear-gradient(90deg,var(--red),var(--red3));
  transition:width 1.6s cubic-bezier(.22,1,.36,1);width:0%;
}
.leaderboard.in .lb-mini-fill{width:var(--w,0%)}

/* ── CTA FINALE ── */
.cta-section{
  background:var(--bg2);
  min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
  text-align:center;
}

.cta-bg-title{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-block);font-size:clamp(200px,35vw,500px);
  color:transparent;-webkit-text-stroke:1px rgba(176,16,32,.04);
  pointer-events:none;letter-spacing:-.02em;
  white-space:nowrap;
}

.cta-inner{position:relative;z-index:2}
.cta-kicker{
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.5em;text-transform:uppercase;
  color:var(--red2);margin-bottom:32px;
  opacity:0;
}
.cta-inner.in .cta-kicker{animation:fadeUp .8s .1s cubic-bezier(.22,1,.36,1) forwards}

.cta-title{
  font-family:var(--ff-title);font-weight:900;
  font-size:clamp(56px,9vw,130px);
  line-height:.9;color:var(--cream);
  letter-spacing:.04em;
  opacity:0;
}
.cta-inner.in .cta-title{animation:fadeUp .9s .3s cubic-bezier(.22,1,.36,1) forwards}

.cta-title span{color:var(--red3)}

.cta-desc{
  font-family:var(--ff-mono);font-size:13px;font-weight:300;
  color:var(--dim);max-width:480px;
  line-height:1.9;margin:36px auto 0;
  letter-spacing:.03em;
  opacity:0;
}
.cta-inner.in .cta-desc{animation:fadeUp .8s .5s cubic-bezier(.22,1,.36,1) forwards}

/* IP box */
.ip-box{
  display:inline-flex;align-items:stretch;
  margin-top:48px;
  border:1px solid rgba(176,16,32,.35);
  overflow:hidden;
  opacity:0;
}
.cta-inner.in .ip-box{animation:fadeUp .8s .7s cubic-bezier(.22,1,.36,1) forwards}

.ip-label{
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.25em;text-transform:uppercase;
  background:var(--red);color:var(--bg);
  padding:0 20px;display:flex;align-items:center;
}
.ip-val{
  font-family:var(--ff-mono);font-size:18px;
  letter-spacing:.12em;color:var(--gold2);
  padding:18px 36px;
  background:rgba(255,255,255,.02);
}
.ip-copy{
  font-family:var(--ff-mono);font-size:9px;
  letter-spacing:.25em;text-transform:uppercase;
  color:var(--dim);padding:0 20px;
  border-left:1px solid rgba(176,16,32,.2);
  cursor:none;transition:background .2s,color .2s;
  display:flex;align-items:center;
}
.ip-copy:hover{background:rgba(176,16,32,.15);color:var(--cream)}

.cta-buttons{
  display:flex;gap:16px;justify-content:center;
  margin-top:32px;flex-wrap:wrap;
  opacity:0;
}
.cta-inner.in .cta-buttons{animation:fadeUp .8s .9s cubic-bezier(.22,1,.36,1) forwards}

/* ── STATS TICKER ── */
.stats-ticker{
  background:var(--bg);
  border-top:1px solid rgba(176,16,32,.15);
  border-bottom:1px solid rgba(176,16,32,.15);
  padding:0;overflow:hidden;
  position:relative;z-index:3;
}
.ticker-inner{
  display:flex;
  animation:tickerMove 20s linear infinite;
  width:max-content;
}
@keyframes tickerMove{to{transform:translateX(-50%)}}
.ticker-item{
  display:flex;align-items:center;gap:48px;
  padding:20px 60px;
  border-right:1px solid rgba(176,16,32,.1);
  white-space:nowrap;
}
.ticker-val{
  font-family:var(--ff-block);font-size:36px;
  color:var(--cream);letter-spacing:.02em;
}
.ticker-val span{color:var(--red3)}
.ticker-lbl{
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.3em;text-transform:uppercase;
  color:var(--dim);
}

/* ── FOOTER ── */
footer{
  background:var(--bg);
  border-top:1px solid rgba(176,16,32,.1);
  padding:48px 0;
}
.footer-inner{
  max-width:1200px;margin:0 auto;padding:0 60px;
  display:flex;align-items:center;justify-content:space-between;
}
.footer-logo{
  font-family:var(--ff-title);font-size:20px;
  letter-spacing:.08em;color:var(--cream);
}
.footer-logo span{color:var(--red3)}
.footer-links{display:flex;gap:32px;list-style:none}
.footer-links a{
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--dim);text-decoration:none;transition:color .2s;
}
.footer-links a:hover{color:var(--red2)}
.footer-copy{
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.08em;color:rgba(232,221,208,.15);
}

/* ── GLITCH LINE ── */
.glitch-line{
  position:absolute;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--red3),transparent);
  opacity:0;
  animation:glitchFlash 8s infinite;
}
@keyframes glitchFlash{
  0%,98%,100%{opacity:0;transform:translateY(0)}
  98.5%{opacity:.6;transform:translateY(3px)}
  99%{opacity:0}
  99.5%{opacity:.4;transform:translateY(-2px)}
}

/* ── CHAPTER DIVIDER ── */
.divider{
  position:relative;z-index:3;
  padding:60px;
  display:flex;align-items:center;gap:40px;
  max-width:1200px;margin:0 auto;
}
.div-line{flex:1;height:1px;background:rgba(176,16,32,.15)}
.div-text{
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.4em;text-transform:uppercase;
  color:rgba(176,16,32,.4);white-space:nowrap;
}

/* ══════════════════════════════════════════════
   RESPONSIVE — MOBILE FIRST PATCHES
══════════════════════════════════════════════ */
@media(hover:none){
  /* No custom cursor on touch */
  #cur,#cur-trail{display:none}
  body{cursor:auto}
  /* Hide mouse scroll indicator */
  .scroll-indicator{display:none}
  /* Items: show content always on touch */
  .item-desc{max-height:60px!important}
  .item-bg{opacity:.3!important;filter:grayscale(0)!important}
}

@media(max-width:900px){
  /* ── NAV ── */
  nav{padding:0 20px;height:60px}
  .nav-links{display:none}
  .nav-btn{padding:8px 16px;font-size:9px}

  /* ── HERO ── */
  .hero-bg-text{font-size:clamp(80px,28vw,180px);letter-spacing:-.01em}
  .hero-center{padding:0 24px;padding-top:60px}
  .hero-title{font-size:clamp(48px,16vw,96px)}
  .hero-sub{font-size:clamp(28px,10vw,56px);left:0}
  .hero-eyebrow{font-size:8px;letter-spacing:.3em;gap:10px}
  .hero-eyebrow::before,.hero-eyebrow::after{width:20px}
  .hero-tagline{font-size:12px;margin-top:24px;padding:0 8px}
  .hero-actions{flex-direction:column;gap:12px;margin-top:32px;width:100%}
  .btn-main,.btn-ghost{width:100%;text-align:center;padding:14px 24px}
  .scroll-indicator{bottom:24px}

  /* ── TICKER ── */
  .ticker-item{padding:16px 32px;gap:24px}
  .ticker-val{font-size:26px}
  .ticker-lbl{font-size:8px;letter-spacing:.2em}

  /* ── CHAPTERS ── */
  .chapter{padding:80px 0;min-height:auto}
  /* Hide giant background chapter numbers — they cause overflow */
  .chapter::before{display:none}
  .ch-inner{padding:0 20px}

  /* ── 3 VIES SECTION ── */
  .three-lives-layout{
    grid-template-columns:1fr;gap:48px;
  }
  .lives-visual{
    position:static!important;transform:none!important;
    top:auto!important;align-self:auto;
    flex-direction:column;gap:0;
  }
  .life-row{
    opacity:1!important;transform:none!important;
    padding:16px 0;gap:16px;
    transition:opacity .4s,transform .4s;
  }
  .life-num{font-size:48px;min-width:56px}
  .life-bar-label{font-size:9px}
  .lives-text > div[style]{margin-top:32px!important}
  .lives-text > div[style] > div[style]{padding:16px!important;gap:12px!important}
  .lives-text > div[style] > div[style] span{font-size:36px!important}

  /* ── TERRITORY ── */
  .territory-section .chapter::before{display:none}
  .territory-layout{grid-template-columns:1fr;gap:48px}
  .map-container{max-width:100%}
  .map-grid{padding:16px;gap:2px}
  /* Stats grid inside territory */
  .territory-layout > div > div[style*="grid"]{
    grid-template-columns:1fr 1fr!important;
  }
  .territory-layout > div > div[style*="grid"] > div{
    padding:16px!important;
  }
  .territory-layout > div > div[style*="grid"] > div > div:first-child{
    font-size:38px!important;
  }

  /* ── FEATURES ── */
  .features-outer{padding:100px 0}
  .features-header-row{
    padding:0 20px;
    flex-direction:column;align-items:flex-start;gap:20px;
    margin-bottom:48px;
  }
  .features-scroll-wrap{padding-left:20px}
  .feat-card{width:260px;padding:32px 24px}
  .feat-num{font-size:56px}
  .feat-title{font-size:17px}
  .feat-desc{font-size:12px}

  /* ── ITEMS ── */
  .items-outer{padding:100px 0}
  .items-inner{padding:0 20px}
  .items-grid{
    grid-template-columns:repeat(2,1fr);
    gap:10px;
    margin-top:48px;
  }
  /* Remove tall on mobile — causes weird heights */
  .item-tile.tall{grid-row:span 1;aspect-ratio:.75}
  .item-bg{font-size:44px}
  .item-name{font-size:13px}
  .item-content{padding:16px}
  .item-rarity-badge{font-size:7px;letter-spacing:.2em;padding:2px 8px}
  /* Always show desc on mobile */
  .item-desc{max-height:none!important}
  .item-bg{opacity:.25!important;filter:grayscale(0)!important}

  /* ── FACTIONS ── */
  .factions-outer{padding:100px 0}
  .factions-inner{padding:0 20px}
  .factions-layout{
    grid-template-columns:1fr;gap:48px;margin-top:48px;
  }
  .leaderboard{overflow-x:auto}
  .lb-row{
    grid-template-columns:40px 1fr auto;
    gap:12px;padding:16px 20px;
  }
  /* Hide bar column on mobile */
  .lb-bar-col{display:none}
  .lb-header{padding:16px 20px}
  .lb-rank{font-size:22px}
  .lb-fname{font-size:13px}
  .lb-pts-val{font-size:28px}
  .faction-card{padding:20px 24px}
  .fc-pts{font-size:26px}

  /* ── CTA ── */
  .cta-section{padding:80px 20px;min-height:auto}
  .cta-bg-title{font-size:clamp(100px,40vw,200px)}
  .cta-title{font-size:clamp(40px,13vw,80px);line-height:.95}
  .cta-desc{font-size:12px;padding:0 8px}
  /* IP box: stack vertically */
  .ip-box{
    flex-direction:column;
    width:100%;max-width:320px;
    margin-top:32px;
  }
  .ip-label{padding:10px 20px;justify-content:center}
  .ip-val{
    font-size:14px;letter-spacing:.08em;
    padding:14px 20px;text-align:center;
  }
  .ip-copy{
    border-left:none;border-top:1px solid rgba(176,16,32,.2);
    padding:12px 20px;justify-content:center;
  }
  .cta-buttons{flex-direction:column;gap:12px;margin-top:24px;width:100%;max-width:320px;margin-left:auto;margin-right:auto}
  .cta-buttons a{text-align:center;width:100%}

  /* ── DIVIDERS ── */
  .divider{padding:40px 20px;gap:20px}
  .div-text{font-size:8px;letter-spacing:.25em}

  /* ── FOOTER ── */
  .footer-inner{
    flex-direction:column;gap:24px;text-align:center;
    padding:0 20px;
  }
  .footer-links{flex-wrap:wrap;justify-content:center;gap:20px}
  .footer-logo{font-size:18px}
}

@media(max-width:480px){
  .hero-title{font-size:clamp(40px,18vw,72px)}
  .hero-sub{font-size:clamp(22px,12vw,44px)}
  .items-grid{grid-template-columns:1fr 1fr;gap:8px}
  .feat-card{width:220px}
  .ch-title{font-size:clamp(32px,9vw,52px)!important}
  .ticker-val{font-size:22px}
}

/* ─── LARGE SCREENS (>1400px) ─── */
@media(min-width:1400px){
  /* Increase base text sizes */
  body{font-size:16px}
  
  /* Hero */
  .hero-title{font-size:clamp(72px,8vw,140px)}
  .hero-sub{font-size:clamp(40px,4vw,72px)}
  .hero-desc{font-size:15px;max-width:560px}
  
  /* Navigation */
  .nav-logo{font-size:22px}
  .nav-links a{font-size:13px;letter-spacing:.12em}
  .nav-btn{font-size:12px;padding:14px 32px}
  
  /* Chapter titles */
  .ch-title{font-size:clamp(52px,5vw,84px)}
  .ch-label{font-size:13px}
  
  /* Feature cards */
  .feat-title{font-size:18px}
  .feat-desc{font-size:14px}
  .feat-tag{font-size:10px}
  
  /* Item tiles */
  .item-name{font-size:18px}
  .item-desc{font-size:13px}
  .item-rarity-badge{font-size:9px}
  
  /* Ticker */
  .ticker-val{font-size:42px}
  .ticker-label{font-size:12px}
  
  /* CTA section */
  .cta-title{font-size:clamp(64px,7vw,120px)}
  .cta-desc{font-size:15px;max-width:540px}
  .ip-val{font-size:16px;letter-spacing:.15em}
  .ip-copy{padding:18px 28px}
  .cta-buttons a{font-size:13px;padding:18px 36px}
  
  /* Footer */
  .footer-logo{font-size:24px}
  .footer-links a{font-size:14px}
  .footer-copy{font-size:13px}
}

/* ─── EXTRA LARGE SCREENS (>1800px) ─── */
@media(min-width:1800px){
  /* Further increase sizes */
  body{font-size:18px}
  
  .hero-title{font-size:clamp(84px,7vw,160px)}
  .hero-sub{font-size:clamp(48px,3.5vw,84px)}
  
  .ch-title{font-size:clamp(64px,4.5vw,96px)}
  
  .nav-logo{font-size:26px}
  .nav-links a{font-size:14px;padding:10px 20px}
  .nav-btn{font-size:13px;padding:16px 36px}
  
  .feat-card{padding:36px}
  .feat-title{font-size:20px}
  .feat-desc{font-size:15px;line-height:1.8}
  
  .item-tile{padding:28px}
  .item-name{font-size:20px}
  .item-desc{font-size:14px}
  
  .cta-title{font-size:clamp(72px,6vw,140px)}
  .cta-desc{font-size:16px}
  .ip-box{height:64px}
  .ip-val{font-size:18px}
  .ip-copy{padding:20px 32px}
  
  /* Max-width containers for readability */
  .hero-inner{max-width:1600px}
  .ch-inner{max-width:1400px}
  .items-inner{max-width:1600px}
  .cta-inner{max-width:1200px}
}

/* ═══════════════════════════════════════════════════════════════
   SHOP DISABLED — Boutique temporairement fermée
   ═══════════════════════════════════════════════════════════════ */

/* Liens vers la boutique : grisés, non-cliquables */
.shop-disabled{
  opacity:.45;
  cursor:not-allowed !important;
  pointer-events:none;
  position:relative;
  text-decoration:line-through !important;
}
.shop-disabled::after{
  content:" 🚫";
  font-size:.85em;
  opacity:.7;
}

/* Bannière en haut de la page boutique */
.shop-closed-banner{
  position:fixed;
  top:0;left:0;right:0;
  z-index:9999;
  background:linear-gradient(90deg,#3a1818,#5a1f1f,#3a1818);
  border-bottom:2px solid var(--red2,#e0182c);
  color:#ffd9d9;
  font-family:var(--ff-mono,monospace);
  font-size:13px;
  letter-spacing:.04em;
  padding:14px 24px;
  text-align:center;
  box-shadow:0 4px 24px rgba(224,24,44,.3);
  animation:bannerSlideDown .6s ease-out;
}
.shop-closed-banner strong{
  color:#fff;
  letter-spacing:.06em;
  font-weight:700;
}
.shop-closed-banner .banner-icon{
  font-size:18px;
  margin-right:8px;
  vertical-align:-2px;
}
@keyframes bannerSlideDown{
  from{transform:translateY(-100%);opacity:0}
  to{transform:translateY(0);opacity:1}
}
body.has-shop-banner{padding-top:54px}

/* Note : les CTAs boutique sont actifs (ajout au panier), seul le checkout
   final dans cart.html est désactivé tant que SHOP_ENABLED=false côté backend. */
