:root {
  --void: #020408;
  --dark: #080d14;
  --surface: #0d1520;
  --card: #111c2e;
  --card2: #162035;
  --border: #1e2d45;
  --border2: #243550;
  --neon: #00d4ff;
  --neon2: #7c3aed;
  --neon3: #f59e0b;
  --neon4: #10b981;
  --neon5: #ef4444;
  --text: #e2eaf6;
  --text2: #8fa8c8;
  --text3: #4a6380;
  --glow: 0 0 20px rgba(0,212,255,0.4);
  --glow2: 0 0 20px rgba(124,58,237,0.4);
  --glow3: 0 0 20px rgba(245,158,11,0.4);
  --font-display: 'Orbitron', monospace;
  --font-ui: 'Rajdhani', sans-serif;
  --font-body: 'Exo 2', sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--void);color:var(--text);font-family:var(--font-body);min-height:100vh;overflow-x:hidden}

/* BACKGROUND STARS */
body::before{
  content:'';position:fixed;inset:0;
  background:radial-gradient(ellipse at 20% 50%,rgba(124,58,237,.06) 0%,transparent 50%),
             radial-gradient(ellipse at 80% 20%,rgba(0,212,255,.05) 0%,transparent 50%),
             radial-gradient(ellipse at 50% 80%,rgba(245,158,11,.04) 0%,transparent 50%);
  pointer-events:none;z-index:0
}
.stars{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.stars span{position:absolute;width:2px;height:2px;background:rgba(255,255,255,.6);border-radius:50%;animation:twinkle var(--d,3s) var(--delay,0s) infinite ease-in-out}
@keyframes twinkle{0%,100%{opacity:.2;transform:scale(1)}50%{opacity:1;transform:scale(1.5)}}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideInLeft{from{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}
@keyframes slideInRight{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}
@keyframes scaleIn{from{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}
@keyframes glowPulse{0%,100%{box-shadow:0 0 8px rgba(0,212,255,.2)}50%{box-shadow:0 0 28px rgba(0,212,255,.6),0 0 60px rgba(0,212,255,.2)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes borderSpin{0%{border-color:var(--neon) transparent transparent transparent}25%{border-color:transparent var(--neon2) transparent transparent}50%{border-color:transparent transparent var(--neon4) transparent}75%{border-color:transparent transparent transparent var(--neon3)}100%{border-color:var(--neon) transparent transparent transparent}}
@keyframes neonFlicker{0%,90%,100%{opacity:1}92%{opacity:.8}94%{opacity:1}96%{opacity:.7}98%{opacity:1}}
@keyframes countUp{from{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes scanline{0%{transform:translateY(-100%)}100%{transform:translateY(100vh)}}
@keyframes warpIn{from{clip-path:polygon(50% 50%,50% 50%,50% 50%,50% 50%);opacity:0}to{clip-path:polygon(0 0,100% 0,100% 100%,0 100%);opacity:1}}

/* Page transition */
.page.active{animation:fadeIn .35s ease-out}
.page-enter{animation:warpIn .4s cubic-bezier(0.22,1,0.36,1)}

/* Cards animate in staggered */
.card{animation:fadeUp .4s ease-out both}
.card:nth-child(1){animation-delay:.05s}
.card:nth-child(2){animation-delay:.1s}
.card:nth-child(3){animation-delay:.15s}
.card:nth-child(4){animation-delay:.2s}
.card:nth-child(5){animation-delay:.25s}
.card:nth-child(6){animation-delay:.3s}

/* Hero logo float */
.hero-logo{animation:floatY 4s ease-in-out infinite}

/* Neon elements pulse */
.status-ongoing{animation:glowPulse 2s ease-in-out infinite}

/* Bracket match hover lift */
.bracket-match{transition:transform .2s,border-color .2s,box-shadow .2s}
.bracket-match.clickable:hover{transform:translateY(-2px)}
.bracket-match.grand-final{animation:glowPulse 3s ease-in-out infinite}

/* Progress bar animated fill */
.progress-fill{transition:width 1s cubic-bezier(0.22,1,0.36,1);animation:shimmer 2.5s linear infinite;background:linear-gradient(90deg,var(--neon2),var(--neon),var(--neon2));background-size:200% 100%}

/* Buttons */
.btn{transition:transform .15s,box-shadow .15s,background .15s,border-color .15s}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0) scale(.97)}
.btn-primary:hover{box-shadow:0 8px 30px rgba(0,212,255,.4),0 0 0 1px rgba(0,212,255,.3)}
.btn-warning:hover{box-shadow:0 8px 20px rgba(245,158,11,.3)}

/* Nav active underline animated */
.nav-links a.active::after{animation:shimmer 3s linear infinite;background:linear-gradient(90deg,var(--neon2),var(--neon),var(--neon2));background-size:200% 100%}

/* Tournament card */
.tournament-card{transition:transform .25s cubic-bezier(0.34,1.56,0.64,1),border-color .25s,box-shadow .25s}
.tournament-card:hover{transform:translateY(-4px) scale(1.01);border-color:rgba(0,212,255,.4);box-shadow:0 12px 40px rgba(0,212,255,.1),0 4px 16px rgba(0,0,0,.4)}

/* News cards */
.news-card{transition:transform .25s cubic-bezier(0.34,1.56,0.64,1),border-color .25s,box-shadow .25s}
.news-card:hover{transform:translateY(-4px);border-color:rgba(124,58,237,.5);box-shadow:0 12px 40px rgba(124,58,237,.12)}

/* Tag hover */
.tag{transition:background .15s,border-color .15s,color .15s}
.tag:hover{background:rgba(0,212,255,.15);border-color:rgba(0,212,255,.4);color:var(--neon)}

/* Form inputs */
.form-input:focus{box-shadow:0 0 0 3px rgba(124,58,237,.2),0 0 20px rgba(124,58,237,.1)}

/* Modal */
@keyframes modalIn{from{transform:scale(.9) translateY(20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}
@keyframes overlayIn{from{opacity:0;backdrop-filter:blur(0)}to{opacity:1;backdrop-filter:blur(8px)}}
.modal-overlay.active{animation:overlayIn .25s ease-out}
.modal{animation:modalIn .3s cubic-bezier(0.34,1.56,0.64,1)}

/* Section titles animate */
.section-title{animation:fadeUp .5s ease-out .1s both}
.tabs{animation:fadeUp .4s ease-out .15s both}

/* Stat cards pulse on hover */
.detail-info-item{transition:transform .2s,border-color .2s,box-shadow .2s;cursor:default}
.detail-info-item:hover{transform:scale(1.03);border-color:rgba(0,212,255,.3);box-shadow:0 4px 20px rgba(0,212,255,.08)}

/* Bracket section title */
.bracket-section-title{animation:fadeUp .3s ease-out both}

/* Champion banner */
@keyframes championGlow{0%,100%{box-shadow:0 0 30px rgba(245,158,11,.2),inset 0 0 30px rgba(245,158,11,.05)}50%{box-shadow:0 0 60px rgba(245,158,11,.4),inset 0 0 60px rgba(245,158,11,.1)}}

/* Scanline overlay for cyberpunk feel on hero */
.hero::after{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,0,0,.03) 3px,rgba(0,0,0,.03) 4px);
  pointer-events:none;animation:scanline 8s linear infinite;opacity:.4
}

/* Team cards */
.team-card{transition:transform .2s,border-color .2s;animation:fadeUp .4s ease-out both}
.team-card:hover{transform:translateY(-2px)}

/* Status badges glow */
.status{transition:box-shadow .3s}
.status-ongoing{box-shadow:0 0 10px rgba(16,185,129,.4)}
.status-registration{box-shadow:0 0 10px rgba(16,185,129,.3)}


/* SCROLLBAR */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--dark)}
::-webkit-scrollbar-thumb{background:var(--neon2);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--neon)}

/* NAVBAR */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:64px;display:flex;align-items:center;
  background:rgba(8,13,20,.85);backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  padding:0 24px;gap:16px
}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.nav-logo img{height:38px;width:38px;object-fit:contain;filter:drop-shadow(0 0 8px rgba(124,58,237,.6))}
.nav-logo span{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--text);letter-spacing:2px}
.nav-logo span em{color:var(--neon);font-style:normal}
.nav-links{display:flex;align-items:center;gap:4px;margin-left:16px;flex:1}
.nav-links a{
  font-family:var(--font-ui);font-size:14px;font-weight:600;letter-spacing:1px;text-transform:uppercase;
  color:var(--text2);text-decoration:none;padding:6px 14px;border-radius:6px;
  transition:.2s;position:relative
}
.nav-links a:hover,.nav-links a.active{color:var(--neon);background:rgba(0,212,255,.08)}
.nav-links a.active::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--neon);box-shadow:var(--glow)}
.nav-right{display:flex;align-items:center;gap:10px;margin-left:auto}
.nav-user{display:flex;align-items:center;gap:10px}
.nav-avatar{
  width:34px;height:34px;border-radius:50%;border:2px solid var(--neon2);
  background:var(--card);display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:12px;color:var(--neon2);cursor:pointer;
  transition:.2s
}
.nav-avatar:hover{border-color:var(--neon);color:var(--neon)}
.nav-username{font-family:var(--font-ui);font-weight:600;font-size:14px;color:var(--text)}

/* BUTTONS */
.btn{
  font-family:var(--font-ui);font-size:14px;font-weight:700;letter-spacing:1px;text-transform:uppercase;
  padding:8px 20px;border-radius:6px;border:none;cursor:pointer;transition:.2s;text-decoration:none;display:inline-flex;align-items:center;gap:8px
}
.btn-primary{background:linear-gradient(135deg,var(--neon) 0%,var(--neon2) 100%);color:#fff;box-shadow:0 0 20px rgba(0,212,255,.25)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 30px rgba(0,212,255,.4)}
.btn-secondary{background:var(--card);border:1px solid var(--border2);color:var(--text)}
.btn-secondary:hover{border-color:var(--neon2);color:var(--neon)}
.btn-danger{background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.4);color:var(--neon5)}
.btn-danger:hover{background:rgba(239,68,68,.25)}
.btn-success{background:rgba(16,185,129,.15);border:1px solid rgba(16,185,129,.4);color:var(--neon4)}
.btn-sm{padding:5px 12px;font-size:12px}
.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text2)}
.btn-ghost:hover{border-color:var(--neon);color:var(--neon)}
.btn-warning{background:rgba(245,158,11,.15);border:1px solid rgba(245,158,11,.4);color:var(--neon3)}
.btn-warning:hover{background:rgba(245,158,11,.25)}

/* LAYOUT */
#app{position:relative;z-index:1;padding-top:64px;min-height:100vh}
.page{display:none;min-height:calc(100vh - 64px)}
.page.active{display:block}
.container{max-width:1200px;margin:0 auto;padding:0 20px}
.section{padding:60px 0}  /* keep for non-home pages */

/* GLITCH EFFECT */
.hero-title{position:relative}
.hero-title.glitch::before,.hero-title.glitch::after{
  content:attr(data-text);position:absolute;inset:0;
  font-family:var(--font-display);font-size:inherit;font-weight:inherit;
  clip-path:polygon(0 30%,100% 30%,100% 60%,0 60%)
}
.hero-title.glitch::before{color:var(--neon);left:2px;animation:glitch1 .2s steps(2,end)}
.hero-title.glitch::after{color:var(--neon5);left:-2px;animation:glitch2 .2s steps(2,end)}
@keyframes glitch1{0%{clip-path:polygon(0 0%,100% 0%,100% 30%,0 30%)}50%{clip-path:polygon(0 60%,100% 60%,100% 80%,0 80%)}100%{clip-path:polygon(0 20%,100% 20%,100% 50%,0 50%)}}
@keyframes glitch2{0%{clip-path:polygon(0 50%,100% 50%,100% 70%,0 70%)}50%{clip-path:polygon(0 10%,100% 10%,100% 40%,0 40%)}100%{clip-path:polygon(0 70%,100% 70%,100% 90%,0 90%)}}

/* HERO */
/* ============================================================
   HOME — COMPACT LAYOUT
   ============================================================ */

/* Keep legacy hero classes for glitch JS (they're referenced by script) */
.hero-title{position:relative}

/* HERO COMPACT BAR */
.home-hero-compact{
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;
  padding:18px 28px 16px;border-bottom:1px solid var(--border);position:relative;overflow:hidden;
  background:linear-gradient(135deg,rgba(124,58,237,.07) 0%,rgba(0,212,255,.04) 100%);
  max-width:1400px;margin:0 auto;width:100%
}
.home-hero-bg{
  position:absolute;inset:0;
  background:radial-gradient(ellipse at 20% 50%,rgba(124,58,237,.1) 0%,transparent 60%);
  pointer-events:none
}
.home-hero-left{
  display:flex;align-items:center;gap:18px;flex:1;min-width:0;position:relative;z-index:1
}
.home-hero-logo{
  width:72px;height:72px;object-fit:contain;flex-shrink:0;
  filter:drop-shadow(0 0 16px rgba(124,58,237,.8)) drop-shadow(0 0 32px rgba(0,212,255,.4));
  animation:logoFloat 4s ease-in-out infinite
}
@keyframes logoFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.home-hero-tag{
  font-family:var(--font-ui);font-size:10px;letter-spacing:3px;text-transform:uppercase;
  color:var(--neon);background:rgba(0,212,255,.08);border:1px solid rgba(0,212,255,.25);
  padding:3px 10px;border-radius:20px;display:inline-block;margin-bottom:6px
}
.home-hero-title{
  font-family:var(--font-display);font-size:clamp(20px,2.5vw,32px);font-weight:900;
  line-height:1;margin-bottom:4px;
  background:linear-gradient(180deg,#fff 0%,var(--neon) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text
}
.home-hero-sub{
  font-family:var(--font-display);font-size:11px;font-weight:400;
  color:var(--neon2);letter-spacing:4px;text-transform:uppercase;margin-bottom:8px
}
.home-hero-desc{
  font-size:12px;color:var(--text3);max-width:360px;line-height:1.5;margin-bottom:10px
}
.home-hero-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.btn-discord{background:rgba(88,101,242,.2);border:1px solid rgba(88,101,242,.5);color:#7289da}
.btn-discord:hover{background:rgba(88,101,242,.35);border-color:#7289da;color:#fff}

/* HERO STATS */
.home-hero-stats{
  display:flex;gap:0;flex-shrink:0;border:1px solid var(--border);border-radius:10px;overflow:hidden;
  position:relative;z-index:1
}
.home-hero-stat{
  text-align:center;padding:12px 20px;position:relative
}
.home-hero-stat+.home-hero-stat::before{
  content:'';position:absolute;left:0;top:20%;height:60%;width:1px;background:var(--border)
}
.home-stat-num{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--neon)}
.home-stat-label{font-family:var(--font-ui);font-size:9px;letter-spacing:2px;color:var(--text3);text-transform:uppercase;margin-top:2px}

/* HOME MAIN GRID */
.home-grid{
  display:grid;grid-template-columns:1fr 340px;gap:20px;
  padding-top:20px;padding-bottom:28px;align-items:start
}
.home-col-main{display:flex;flex-direction:column;gap:20px;min-width:0}
.home-col-side{min-width:0}
.home-block-sticky{position:sticky;top:76px}

/* HOME BLOCK */
.home-block{
  background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden
}
.home-block-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 16px;border-bottom:1px solid var(--border);
  background:linear-gradient(90deg,var(--card2),var(--card))
}
.home-block-title{
  font-family:var(--font-display);font-size:12px;font-weight:700;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--text)
}

/* NEWS LIST (compact) */
.home-news-list{display:flex;flex-direction:column}
.home-news-item{
  display:flex;gap:12px;align-items:flex-start;padding:12px 16px;
  border-bottom:1px solid var(--border);cursor:pointer;transition:.18s
}
.home-news-item:last-child{border-bottom:none}
.home-news-item:hover{background:rgba(255,255,255,.03)}
.home-news-item-badge{
  flex-shrink:0;margin-top:2px;
  font-family:var(--font-ui);font-size:9px;font-weight:700;letter-spacing:1.5px;
  text-transform:uppercase;padding:2px 7px;border-radius:4px
}
.home-news-item-body{flex:1;min-width:0}
.home-news-item-title{
  font-family:var(--font-ui);font-weight:700;font-size:13px;color:var(--text);
  margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis
}
.home-news-item-meta{font-size:11px;color:var(--text3)}
.home-news-pinned{color:var(--neon3);font-size:10px;margin-right:4px}

/* TOURNAMENT LIST (compact) */
.home-tournaments-list{display:flex;flex-direction:column;gap:0}
.home-t-item{display:flex;align-items:stretch;gap:0;cursor:pointer;border-bottom:1px solid var(--border);transition:background .15s;overflow:hidden;border-radius:0}
.home-t-item:first-child{border-radius:8px 8px 0 0}
.home-t-item:last-child{border-bottom:none;border-radius:0 0 8px 8px}
.home-t-item:hover{background:rgba(255,255,255,.03)}
.home-t-visual{width:64px;min-height:80px;flex-shrink:0;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.home-t-logo{width:44px;height:44px;object-fit:contain;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:rgba(0,0,0,.3);padding:4px}
.home-t-emoji{font-size:26px}
.home-t-info{flex:1;min-width:0;padding:12px 10px}
.home-t-game{font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--neon2);margin-bottom:3px}
.home-t-name{font-family:var(--font-ui);font-weight:700;font-size:13px;color:var(--text);margin-bottom:6px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.home-t-tags{display:flex;gap:4px;flex-wrap:wrap}
.home-t-tag{font-family:var(--font-ui);font-size:10px;color:var(--text3);background:var(--dark);border:1px solid var(--border);border-radius:4px;padding:1px 6px}
.home-t-tag-neon{color:var(--neon);border-color:rgba(0,212,255,.3);background:rgba(0,212,255,.08)}
.home-t-tag-purple{color:var(--neon2);border-color:rgba(124,58,237,.3);background:rgba(124,58,237,.08)}
.home-t-right{display:flex;flex-direction:column;align-items:flex-end;justify-content:center;gap:6px;padding:12px 14px 12px 0;flex-shrink:0;min-width:110px}
.home-t-status{font-family:var(--font-ui);font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase}
.home-t-progress{display:flex;flex-direction:column;align-items:flex-end;gap:2px;width:100%}
.home-t-progress-bar{width:90px;height:3px;background:var(--border);border-radius:2px;overflow:hidden}
.home-t-progress-fill{height:100%;background:linear-gradient(90deg,var(--neon2),var(--neon));border-radius:2px}
.home-t-progress-label{font-size:10px;color:var(--text3);font-family:var(--font-ui)}

/* LEADERBOARD (compact) */
.home-lb-item{
  display:flex;align-items:center;gap:10px;padding:10px 14px;
  border-bottom:1px solid var(--border);cursor:pointer;transition:.18s
}
.home-lb-item:last-child{border-bottom:none}
.home-lb-item:hover{background:rgba(255,255,255,.03)}
.home-lb-rank{font-size:17px;width:24px;text-align:center;flex-shrink:0}
.home-lb-avatar{
  width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:17px;flex-shrink:0;border:2px solid transparent
}
.home-lb-info{flex:1;min-width:0}
.home-lb-name{font-family:var(--font-ui);font-weight:700;font-size:13px;margin-bottom:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.home-lb-sub{font-size:10px;color:var(--text3);font-family:var(--font-ui)}
.home-lb-stats{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}
.home-lb-wins{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--neon4)}
.home-lb-wr{font-size:10px;color:var(--text3);font-family:var(--font-ui)}
.home-lb-bar-wrap{width:50px;height:3px;background:var(--border);border-radius:2px;overflow:hidden}
.home-lb-bar{height:100%;border-radius:2px}

/* Section (non-home) keep existing */
.section{padding:60px 0}  /* keep for non-home pages */

/* SECTION TITLE */
.section-title{
  font-family:var(--font-display);font-size:clamp(22px,4vw,32px);font-weight:700;
  color:var(--text);letter-spacing:2px;margin-bottom:8px
}
.section-title span{color:var(--neon)}
.section-sub{font-family:var(--font-ui);font-size:13px;letter-spacing:3px;text-transform:uppercase;color:var(--text3);margin-bottom:32px}
.section-header{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:32px}

/* CARDS */
.card{
  background:var(--card);border:1px solid var(--border);border-radius:12px;
  padding:24px;transition:.25s;position:relative;overflow:hidden
}
.card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--neon),transparent);opacity:0;transition:.25s
}
.card:hover{border-color:var(--border2);transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,0,0,.4)}
.card:hover::before{opacity:1}
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:20px}


/* Bouton suppression card (admin) */
.card-delete-btn{
  position:absolute;top:10px;right:10px;
  width:22px;height:22px;border-radius:50%;
  background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.3);
  color:var(--neon5);font-size:11px;font-weight:700;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  opacity:0;transition:.2s;z-index:5;line-height:1
}
.card:hover .card-delete-btn{opacity:1}
.card-delete-btn:hover{background:rgba(239,68,68,.35);border-color:var(--neon5);transform:scale(1.1)}

/* NEWS CARD */
.news-card{cursor:pointer}
.news-badge{
  display:inline-block;font-family:var(--font-ui);font-size:10px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;padding:3px 10px;border-radius:4px;margin-bottom:12px
}
.badge-news{background:rgba(0,212,255,.15);border:1px solid rgba(0,212,255,.3);color:var(--neon)}
.badge-announcement{background:rgba(245,158,11,.15);border:1px solid rgba(245,158,11,.3);color:var(--neon3)}
.badge-event{background:rgba(124,58,237,.15);border:1px solid rgba(124,58,237,.3);color:var(--neon2)}
.badge-update{background:rgba(16,185,129,.15);border:1px solid rgba(16,185,129,.3);color:var(--neon4)}
.news-title{font-family:var(--font-display);font-size:16px;font-weight:700;margin-bottom:8px;line-height:1.3}
.news-excerpt{font-size:13px;color:var(--text2);line-height:1.6;margin-bottom:16px}
.news-meta{display:flex;align-items:center;gap:12px;font-family:var(--font-ui);font-size:12px;color:var(--text3)}
.news-pinned{
  position:absolute;top:12px;right:12px;
  background:rgba(245,158,11,.2);border:1px solid rgba(245,158,11,.4);
  border-radius:4px;padding:2px 8px;font-size:10px;font-family:var(--font-ui);color:var(--neon3);font-weight:700
}

/* TOURNAMENT CARD */
.tournament-card{cursor:pointer;padding:0;overflow:hidden}
.tournament-banner{height:90px;position:relative;overflow:hidden;background:var(--card2);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:16px;flex-shrink:0}
.tournament-banner::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,0,0,.35) 0%,rgba(0,0,0,.05) 100%);pointer-events:none}
.tournament-banner-logo{width:50px;height:50px;border-radius:10px;object-fit:contain;background:rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.15);padding:5px;flex-shrink:0;position:relative;z-index:1;filter:drop-shadow(0 3px 8px rgba(0,0,0,.5))}
.tournament-banner-emoji{width:50px;height:50px;border-radius:10px;background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;position:relative;z-index:1}
.tournament-banner-game-name{font-family:var(--font-display);font-size:17px;font-weight:900;color:#fff;letter-spacing:.5px;line-height:1.2;text-shadow:0 2px 8px rgba(0,0,0,.7);position:relative;z-index:1;flex:1;min-width:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.tournament-banner-status{position:relative;z-index:1}
.tournament-body{padding:20px 20px 0}
.tournament-title{font-family:var(--font-display);font-size:16px;font-weight:700;margin-bottom:10px;line-height:1.3}
.tournament-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.tag{font-family:var(--font-ui);font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:2px 8px;border-radius:4px;background:var(--card2);border:1px solid var(--border2);color:var(--text2)}
.tag:hover{background:rgba(0,212,255,.15);border-color:rgba(0,212,255,.4);color:var(--neon)}
.tag-neon{background:rgba(0,212,255,.1);border-color:rgba(0,212,255,.3);color:var(--neon)}
.tag-purple{background:rgba(124,58,237,.1);border-color:rgba(124,58,237,.3);color:var(--neon2)}
.tag-gold{background:rgba(245,158,11,.1);border-color:rgba(245,158,11,.3);color:var(--neon3)}
.tag-green{background:rgba(16,185,129,.1);border-color:rgba(16,185,129,.3);color:var(--neon4)}
.tag-red{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.3);color:var(--neon5)}
.tournament-progress{margin:0 0 14px}
.progress-bar{height:4px;background:var(--border2);border-radius:2px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--neon2),var(--neon));border-radius:2px;transition:.5s}
.progress-label{font-family:var(--font-ui);font-size:11px;color:var(--text3);margin-top:5px}
.tournament-footer{display:flex;align-items:center;flex-wrap:wrap;gap:8px;padding:14px 20px;border-top:1px solid var(--border);background:rgba(0,0,0,.15)}

/* TOURNAMENT DETAIL */
.tournament-detail{padding:40px 0}
.detail-hero{
  background:var(--card);border:1px solid var(--border);border-radius:16px;
  padding:32px;margin-bottom:32px;position:relative;overflow:hidden;transition:background .3s
}
.detail-hero::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--neon2),var(--neon),var(--neon3))
}
.detail-info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;margin-top:24px}
.detail-info-item{
  background:var(--card2);border:1px solid var(--border);border-radius:8px;padding:14px 16px
}
.detail-info-label{font-family:var(--font-ui);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--text3);margin-bottom:4px}
.detail-info-value{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--neon)}

/* BRACKET */
.bracket-section{margin-bottom:48px}
.bracket-section-title{font-family:var(--font-display);font-size:13px;font-weight:700;letter-spacing:3px;text-transform:uppercase;margin-bottom:24px;padding:10px 18px;border-radius:8px;display:inline-flex;align-items:center;gap:10px}
.bracket-section-title.wb{background:rgba(0,212,255,.1);border:1px solid rgba(0,212,255,.3);color:var(--neon)}
.bracket-section-title.lb{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);color:var(--neon5)}
.bracket-section-title.gf{background:rgba(245,158,11,.15);border:1px solid rgba(245,158,11,.4);color:var(--neon3)}
.bracket-container{overflow-x:auto;padding:8px 0 24px}
.bracket{display:flex;gap:0;align-items:flex-start;min-width:max-content}
/* Each round is wrapped in a bracket-col that includes the matches + SVG connectors */
.bracket-col{display:flex;flex-direction:row;align-items:flex-start}
.bracket-round{display:flex;flex-direction:column;justify-content:space-around;min-width:215px;padding:0 4px}
.bracket-round-title{font-family:var(--font-ui);font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--text3);text-align:center;margin-bottom:8px;padding:5px 8px;background:var(--card2);border-radius:6px;border:1px solid var(--border)}
.bracket-match-wrap{display:flex;flex-direction:column;justify-content:center;flex:1;padding:6px 0}
.bracket-match{background:var(--card);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:.2s;position:relative;width:215px}
.bracket-match.clickable{cursor:pointer}
.bracket-match.clickable:hover{border-color:var(--neon3);box-shadow:0 0 16px rgba(245,158,11,.25);transform:translateY(-1px)}
.bracket-match.grand-final{border-color:rgba(245,158,11,.5);box-shadow:0 0 20px rgba(245,158,11,.15)}
.bracket-match.grand-final::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--neon2),var(--neon3),var(--neon))}
.bracket-match.cancelled{opacity:.4}
.bracket-match.pending-score{border-color:rgba(245,158,11,.6);animation:pendingPulse 2s ease-in-out infinite}
@keyframes pendingPulse{0%,100%{box-shadow:0 0 0 0 rgba(245,158,11,0)}50%{box-shadow:0 0 0 4px rgba(245,158,11,.15)}}
.bracket-team{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border);transition:.15s;gap:8px}
.bracket-team:last-of-type{border-bottom:none}
.bracket-team.winner{background:rgba(16,185,129,.1);border-left:3px solid var(--neon4)}
.bracket-team.loser{opacity:.35}
.bracket-team.tbd{opacity:.45}
.bracket-team-name{font-family:var(--font-ui);font-size:13px;font-weight:600;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bracket-score{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--neon);min-width:22px;text-align:right;flex-shrink:0}
.bracket-score.ws{color:var(--neon4)}
.bracket-status-bar{font-size:9px;text-align:center;padding:4px 6px;border-top:1px solid var(--border);letter-spacing:1.5px;font-family:var(--font-ui);font-weight:700}
.bye-label{padding:10px 14px;font-size:11px;color:var(--text3);font-family:var(--font-ui);text-align:center;font-style:italic}
.gf-reset-badge{font-family:var(--font-ui);font-size:9px;letter-spacing:2px;text-transform:uppercase;padding:2px 8px;background:rgba(245,158,11,.15);border:1px solid rgba(245,158,11,.4);color:var(--neon3);border-radius:4px;position:absolute;top:4px;right:6px}
/* SVG connector between rounds */
.bracket-connector{flex-shrink:0;align-self:stretch}

/* MEMBERS GRID */
.members-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.member-card{
  background:var(--card);border:1px solid var(--border);border-radius:14px;
  overflow:hidden;cursor:pointer;transition:transform .25s cubic-bezier(.34,1.56,.64,1),border-color .2s,box-shadow .2s
}
.member-card:hover{transform:translateY(-5px) scale(1.02);border-color:rgba(124,58,237,.5);box-shadow:0 16px 40px rgba(124,58,237,.15)}
.member-banner{height:56px;position:relative;flex-shrink:0}
.member-avatar-wrap{position:absolute;bottom:-20px;left:16px}
.member-avatar{
  width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:22px;border:3px solid var(--card);box-shadow:0 4px 12px rgba(0,0,0,.4)
}
.member-body{padding:28px 16px 14px}
.member-name{font-family:var(--font-display);font-size:15px;font-weight:700;margin-bottom:2px}
.member-epic{font-size:11px;color:var(--text3);font-family:var(--font-ui);margin-bottom:8px}
.member-bio{font-size:12px;color:var(--text2);margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}
.member-stats{display:flex;gap:12px}
.member-stat{text-align:center;flex:1}
.member-stat-val{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--neon)}
.member-stat-label{font-family:var(--font-ui);font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text3)}
.members-sort-btn.active{border-color:var(--neon2);color:var(--neon2);background:rgba(124,58,237,.1)}

/* PUBLIC PROFILE */
.profile-banner{height:200px;position:relative;overflow:visible}
.profile-banner::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(8,13,20,.7));pointer-events:none}
.profile-avatar-hero{
  width:96px;height:96px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:44px;border:4px solid var(--card);box-shadow:0 8px 30px rgba(0,0,0,.6);
  position:absolute;bottom:-48px;left:32px;z-index:10;background:var(--card)
}
.profile-header-info{padding:64px 32px 24px;background:var(--card);border-bottom:1px solid var(--border)}
.profile-username{font-family:var(--font-display);font-size:26px;font-weight:900;margin-bottom:4px}
.profile-badges{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0}
.profile-badge{font-family:var(--font-ui);font-size:10px;letter-spacing:2px;text-transform:uppercase;padding:3px 10px;border-radius:20px;font-weight:700}
.profile-body{background:var(--surface)}
.profile-stat-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border-top:1px solid var(--border)}
.profile-stat{background:var(--card);padding:18px;text-align:center}
.profile-stat-val{font-family:var(--font-display);font-size:22px;font-weight:900;color:var(--neon)}
.profile-stat-label{font-family:var(--font-ui);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--text3);margin-top:4px}
.profile-tab-body{padding:28px 32px;max-width:900px;margin:0 auto}
.match-row{display:flex;align-items:center;gap:16px;padding:12px 16px;background:var(--card);border:1px solid var(--border);border-radius:10px;margin-bottom:8px;font-size:13px}
.match-result-badge{font-family:var(--font-ui);font-size:10px;letter-spacing:2px;font-weight:700;padding:3px 8px;border-radius:6px;text-transform:uppercase;flex-shrink:0}
.match-result-badge.win{background:rgba(16,185,129,.15);border:1px solid rgba(16,185,129,.4);color:var(--neon4)}
.match-result-badge.loss{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);color:var(--neon5)}
.winrate-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin-top:6px}
.winrate-fill{height:100%;background:linear-gradient(90deg,var(--neon4),var(--neon));border-radius:3px;transition:width 1s cubic-bezier(.22,1,.36,1)}

/* MY PROFILE EDITOR */
.profile-editor{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:640px){.profile-editor{grid-template-columns:1fr}}
.color-picker-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.color-swatch{width:28px;height:28px;border-radius:50%;cursor:pointer;border:3px solid transparent;transition:.15s;flex-shrink:0}
.color-swatch.active,.color-swatch:hover{border-color:var(--text);transform:scale(1.15)}
.emoji-picker-row{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}
.emoji-btn{width:36px;height:36px;background:var(--card2);border:1px solid var(--border);border-radius:8px;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.15s}
.emoji-btn:hover,.emoji-btn.active{border-color:var(--neon2);background:rgba(124,58,237,.15)}

/* TEAMS LIST */
.teams-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.team-card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:18px}
.team-card.pending{border-color:rgba(245,158,11,.4)}
.team-card.approved{border-color:rgba(16,185,129,.4)}
.team-card.rejected{border-color:rgba(239,68,68,.3);opacity:.7}
.team-name{font-family:var(--font-display);font-size:14px;font-weight:700;margin-bottom:8px}
.team-member{display:flex;align-items:center;gap:8px;margin-top:8px;font-size:12px;color:var(--text2)}
.team-member-epic{font-family:var(--font-ui);font-size:11px;color:var(--text3)}

/* REGISTER FORM */
.register-form{max-width:400px;margin:0 auto}
.modal-overlay{
  display:none;position:fixed;inset:0;z-index:200;
  background:rgba(0,0,0,.7);backdrop-filter:blur(8px);
  align-items:center;justify-content:center;padding:20px
}
.modal-overlay.active{display:flex}
.modal{
  background:var(--card);border:1px solid var(--border2);border-radius:16px;
  padding:32px;width:100%;max-width:440px;position:relative;
  animation:modalIn .25s ease-out
}
@keyframes modalIn{from{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}
.modal-close{
  position:absolute;top:16px;right:16px;width:28px;height:28px;border-radius:6px;
  background:var(--card2);border:1px solid var(--border);color:var(--text2);
  cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:.2s
}
.modal-close:hover{border-color:var(--neon5);color:var(--neon5)}
.modal-title{font-family:var(--font-display);font-size:20px;font-weight:700;margin-bottom:6px}
.modal-sub{font-size:13px;color:var(--text2);margin-bottom:24px}

/* FORM */
.form-group{margin-bottom:18px}
.form-label{
  display:block;font-family:var(--font-ui);font-size:12px;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--text2);margin-bottom:8px;font-weight:600
}
.form-input{
  width:100%;background:var(--dark);border:1px solid var(--border2);border-radius:8px;
  padding:10px 14px;color:var(--text);font-family:var(--font-body);font-size:14px;
  transition:.2s;outline:none
}
.form-input:focus{border-color:var(--neon2);box-shadow:0 0 0 3px rgba(124,58,237,.15)}
.form-input::placeholder{color:var(--text3)}
.form-select{
  width:100%;background:var(--dark);border:1px solid var(--border2);border-radius:8px;
  padding:10px 14px;color:var(--text);font-family:var(--font-body);font-size:14px;
  transition:.2s;outline:none;cursor:pointer
}
.form-select:focus{border-color:var(--neon2)}
.form-hint{font-size:11px;color:var(--text3);margin-top:4px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-error{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:10px 14px;font-size:13px;color:var(--neon5);margin-bottom:16px}
.form-success{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.3);border-radius:8px;padding:10px 14px;font-size:13px;color:var(--neon4);margin-bottom:16px}

/* ALERT / TOAST */
#toast-container{position:fixed;bottom:24px;right:24px;z-index:500;display:flex;flex-direction:column;gap:10px}
.toast{
  background:var(--card);border:1px solid var(--border2);border-radius:10px;padding:14px 20px;
  font-family:var(--font-ui);font-size:14px;max-width:320px;
  animation:toastIn .3s ease-out;box-shadow:0 4px 20px rgba(0,0,0,.5)
}
@keyframes toastIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}
.toast-success{border-color:rgba(16,185,129,.5);color:var(--neon4)}
.toast-error{border-color:rgba(239,68,68,.5);color:var(--neon5)}
.toast-info{border-color:rgba(0,212,255,.5);color:var(--neon)}

/* TABS */
.tabs{display:flex;gap:4px;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:4px;margin-bottom:24px;overflow-x:auto}
.tab{
  font-family:var(--font-ui);font-size:13px;font-weight:600;letter-spacing:1px;text-transform:uppercase;
  padding:8px 18px;border-radius:7px;border:none;cursor:pointer;background:transparent;color:var(--text3);
  transition:.2s;white-space:nowrap
}
.tab:hover{color:var(--text)}
.tab.active{background:var(--card2);color:var(--neon);box-shadow:0 2px 10px rgba(0,212,255,.2)}
.tab-content{display:none}
.tab-content.active{display:block}

/* LOADING */
.loading{display:flex;align-items:center;justify-content:center;padding:40px}
.spinner{width:36px;height:36px;border:3px solid var(--border2);border-top-color:var(--neon);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.empty{text-align:center;padding:60px 20px;color:var(--text3);font-family:var(--font-ui);font-size:14px}
.empty-icon{font-size:48px;margin-bottom:12px;opacity:.5}

/* PROFILE */
.profile-header{
  background:var(--card);border:1px solid var(--border);border-radius:16px;
  padding:32px;margin-bottom:24px;display:flex;align-items:center;gap:24px;flex-wrap:wrap
}
.profile-avatar-big{
  width:80px;height:80px;border-radius:50%;border:3px solid var(--neon2);
  background:var(--card2);display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:28px;color:var(--neon2);flex-shrink:0;
  box-shadow:0 0 30px rgba(124,58,237,.4)
}
.profile-info h2{font-family:var(--font-display);font-size:24px;font-weight:700;margin-bottom:6px}
.profile-role{
  display:inline-block;font-family:var(--font-ui);font-size:10px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;padding:3px 10px;border-radius:4px;margin-bottom:8px
}
.role-user{background:rgba(0,212,255,.1);border:1px solid rgba(0,212,255,.3);color:var(--neon)}
.role-admin{background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.3);color:var(--neon3)}
.role-superadmin{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);color:var(--neon5)}
.profile-epic{font-family:var(--font-ui);font-size:13px;color:var(--text2)}
.profile-epic span{color:var(--neon);font-weight:600}

/* DIVIDER */
.divider{height:1px;background:var(--border);margin:32px 0}

/* STATUS BADGE */
.status{
  display:inline-block;font-family:var(--font-ui);font-size:10px;font-weight:700;
  letter-spacing:1.5px;text-transform:uppercase;padding:3px 10px;border-radius:20px
}
.status-upcoming{background:rgba(0,212,255,.1);border:1px solid rgba(0,212,255,.3);color:var(--neon)}
.status-registration{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.3);color:var(--neon4)}
.status-ongoing{background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.3);color:var(--neon3)}
.status-completed{background:rgba(100,100,120,.1);border:1px solid rgba(100,100,120,.3);color:var(--text3)}
.status-cancelled{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);color:var(--neon5)}
.status-pending{background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.3);color:var(--neon3)}
.status-approved{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.3);color:var(--neon4)}
.status-rejected{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);color:var(--neon5)}

/* PAGINATION */
.pagination{display:flex;gap:6px;justify-content:center;margin-top:32px}
.page-btn{
  font-family:var(--font-ui);font-size:12px;font-weight:700;padding:7px 14px;
  border-radius:6px;border:1px solid var(--border2);background:var(--card);color:var(--text2);
  cursor:pointer;transition:.2s
}
.page-btn.active,.page-btn:hover{border-color:var(--neon);color:var(--neon)}

/* NEWS DETAIL */
.news-content-full{
  background:var(--card);border:1px solid var(--border);border-radius:12px;padding:32px;
  line-height:1.8;font-size:15px;color:var(--text2)
}
.news-content-full h1,.news-content-full h2,.news-content-full h3{
  font-family:var(--font-display);color:var(--text);margin:20px 0 10px
}
.news-content-full p{margin-bottom:14px}
.news-content-full a{color:var(--neon)}

/* FOOTER */
footer{
  background:var(--dark);border-top:1px solid var(--border);
  padding:32px 20px;text-align:center;margin-top:80px
}
.footer-logo{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:12px}
.footer-logo img{height:30px;opacity:.7}
.footer-text{font-family:var(--font-ui);font-size:12px;color:var(--text3)}

/* RESPONSIVE */
@media(max-width:768px){
  .nav-links{display:none}
  .card-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .profile-header{flex-direction:column;align-items:flex-start}
  .detail-info-grid{grid-template-columns:repeat(2,1fr)}
}

/* HOME RESPONSIVE */
@media(max-width:1100px){.home-grid{grid-template-columns:1fr 300px}}
@media(max-width:900px){
  .home-grid{grid-template-columns:1fr}
  .home-block-sticky{position:static}
  .home-hero-compact{padding:14px 16px;gap:12px}
  .home-hero-logo{width:52px;height:52px}
}
@media(max-width:640px){
  .home-hero-stats{display:none}
  .home-hero-left{flex-wrap:wrap}
}
/* DEVBLOG */
/* DEVBLOG — cards style news */
.devblog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:20px}
.devblog-card{
  background:var(--card);border:1px solid var(--border);border-radius:12px;
  padding:24px;cursor:pointer;position:relative;overflow:hidden;transition:.25s
}
.devblog-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--neon2),transparent);opacity:0;transition:.25s
}
.devblog-card:hover{border-color:rgba(124,58,237,.5);transform:translateY(-4px);box-shadow:0 12px 40px rgba(124,58,237,.12)}
.devblog-card:hover::before{opacity:1}
.devblog-card-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.devblog-type-badge{font-family:var(--font-ui);font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:3px 10px;border-radius:4px;border:1px solid}
.devblog-version{font-family:var(--font-display);font-size:11px;font-weight:700;background:rgba(0,212,255,.1);border:1px solid rgba(0,212,255,.3);color:var(--neon);padding:3px 10px;border-radius:4px;letter-spacing:1px}
.devblog-card-title{font-family:var(--font-display);font-size:17px;font-weight:700;margin-bottom:10px;color:var(--text);line-height:1.3}
.devblog-card-excerpt{font-size:13px;color:var(--text2);line-height:1.6;margin-bottom:16px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.devblog-card-meta{display:flex;align-items:center;gap:12px;font-family:var(--font-ui);font-size:12px;color:var(--text3)}
.devblog-card-meta .read-more{margin-left:auto;color:var(--neon2);font-weight:600}
.devblog-card:hover .read-more{text-decoration:underline}
/* Vue lecture */
.devblog-detail-wrap{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:32px;max-width:760px}
.devblog-detail-wrap h1,.devblog-detail-wrap h2,.devblog-detail-wrap h3{font-family:var(--font-display);color:var(--text);margin:20px 0 10px}
.devblog-detail-wrap h2{font-size:18px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.devblog-detail-wrap h3{font-size:15px;color:var(--neon2)}
.devblog-detail-wrap p{margin-bottom:14px;font-size:14px;color:var(--text2);line-height:1.8}
.devblog-detail-wrap ul{padding-left:20px;margin-bottom:14px}
.devblog-detail-wrap li{font-size:14px;color:var(--text2);line-height:1.8;margin-bottom:4px}
.devblog-detail-wrap strong{color:var(--text)}
.devblog-detail-wrap em{color:var(--text3)}
.devblog-detail-wrap code{background:var(--dark);border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-size:12px;color:var(--neon)}
/* Type picker modal */
.devblog-type-opt{display:inline-flex;align-items:center;padding:6px 14px;border-radius:8px;border:1px solid var(--border2);cursor:pointer;font-family:var(--font-ui);font-size:12px;font-weight:600;color:var(--text2);transition:.2s;user-select:none}
.devblog-type-opt:hover{border-color:var(--neon2);color:var(--text)}
.devblog-type-opt.active{background:rgba(124,58,237,.15);border-color:var(--neon2);color:var(--neon2)}
@media(max-width:640px){.devblog-grid{grid-template-columns:1fr}}
