/* ── VARIABLES ── */
:root {
  --orange:  #FF5500;
  --red:     #CC2200;
  --black:   #080808;
  --surface: #111111;
  --border:  #1F1F1F;
  --muted:   #555555;
  --text:    #EBEBEB;
  --green:   #3DDB85;
}

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:'Inter', sans-serif; background:var(--black); color:var(--text); line-height:1.6; }
a { color:inherit; text-decoration:none; }
img { display:block; max-width:100%; }
::-webkit-scrollbar { width:4px; }
::-webkit-scrollbar-track { background:var(--black); }
::-webkit-scrollbar-thumb { background:var(--orange); }

/* ── TYPOGRAPHY HELPERS ── */
.text-orange { color:var(--orange); }
.text-muted  { color:var(--muted); }
.text-center { text-align:center; }
.mono        { font-family:monospace; font-size:12px; }

/* ── ANIMATIONS ── */
@keyframes fadeUp {
  from { opacity:0; transform:translateY(30px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes fadeIn {
  from { opacity:0; } to { opacity:1; }
}
@keyframes pulseGlow {
  0%,100% { filter:drop-shadow(0 0 20px rgba(255,85,0,.3)); }
  50%      { filter:drop-shadow(0 0 44px rgba(255,85,0,.7)); }
}
@keyframes scanLine {
  0%   { top:-60px; opacity:.1; }
  100% { top:100%; opacity:0; }
}

.reveal {
  opacity:0; transform:translateY(28px);
  transition:opacity .55s ease, transform .55s ease;
}
.reveal.visible { opacity:1; transform:none; }
.reveal.d1 { transition-delay:.08s; }
.reveal.d2 { transition-delay:.16s; }
.reveal.d3 { transition-delay:.24s; }
.reveal.d4 { transition-delay:.32s; }

/* ── BUTTONS ── */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:12px 24px; border-radius:999px;
  font-size:13px; font-weight:600; letter-spacing:1px;
  text-transform:uppercase; cursor:pointer;
  border:1px solid transparent; transition:all .2s ease;
  white-space:nowrap;
}
.btn svg { width:14px; height:14px; fill:currentColor; flex-shrink:0; }
.btn-orange {
  background:linear-gradient(135deg, #FF6B00 0%, #FF3300 100%);
  color:#fff; border-color:transparent;
  box-shadow:0 2px 12px rgba(255,85,0,.25);
}
.btn-orange:hover { opacity:.9; box-shadow:0 4px 20px rgba(255,85,0,.4); transform:translateY(-1px); }
.btn-outline { background:transparent; color:var(--text); border-color:rgba(255,255,255,.2); }
.btn-outline:hover { border-color:var(--orange); color:var(--orange); background:rgba(255,85,0,.06); }
.btn-ghost   { background:transparent; color:var(--muted); border-color:transparent; }
.btn-ghost:hover { color:var(--text); }
.btn-red     { background:linear-gradient(135deg,#C02020,#8B1A1A); color:#fff; border-color:transparent; }
.btn-red:hover { opacity:.85; }
.btn-sm  { padding:7px 16px; font-size:11px; }
.btn-lg  { padding:15px 32px; font-size:14px; }
.btn-block { width:100%; justify-content:center; }

/* ── FLASH MESSAGES ── */
.flash {
  position:fixed; top:68px; left:50%; transform:translateX(-50%);
  padding:12px 24px; border-radius:3px; font-size:13px; font-weight:600;
  z-index:200; animation:fadeIn .3s ease;
  max-width:480px; text-align:center;
}
.flash-success { background:#1A3A2A; border:1px solid var(--green); color:var(--green); }
.flash-error   { background:#3A1A1A; border:1px solid var(--orange); color:var(--orange); }
.flash-info    { background:#1A1A3A; border:1px solid #5555FF; color:#8888FF; }

/* ── NAV ── */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  height:60px; display:flex; align-items:center; justify-content:space-between;
  padding:0 48px;
  background:rgba(8,8,8,.96);
  border-bottom:1px solid var(--border);
  backdrop-filter:blur(10px);
  animation:fadeIn .4s ease both;
}
.nav-logo { display:flex; align-items:center; gap:10px; }
.nav-logo-img { height:32px; }
.nav-logo span { font-family:'Anton'; font-size:16px; letter-spacing:3px; }

.nav-links { display:flex; gap:28px; }
.nav-links a {
  font-size:12px; font-weight:500; letter-spacing:1px;
  text-transform:uppercase; color:var(--muted);
  position:relative; transition:color .15s;
}
.nav-links a::after {
  content:''; position:absolute; bottom:-4px; left:0; right:100%;
  height:1px; background:var(--orange); transition:right .2s ease;
}
.nav-links a:hover { color:var(--text); }
.nav-links a:hover::after { right:0; }
.admin-link { color:var(--orange) !important; }

.nav-actions { display:flex; align-items:center; gap:10px; }
.nav-avatar { width:28px; height:28px; border-radius:50%; border:1px solid var(--border); }
.nav-username { font-size:12px; font-weight:500; color:var(--muted); }

/* Botón Steam en nav — estilo Ibiza RP */
.btn-steam-nav {
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 18px; border-radius:999px;
  font-size:12px; font-weight:600; letter-spacing:.5px;
  text-transform:uppercase; cursor:pointer;
  background:rgba(255,255,255,.06); color:var(--text);
  border:1px solid rgba(255,255,255,.12);
  transition:all .2s ease;
}
.btn-steam-nav svg { width:14px; height:14px; flex-shrink:0; }
.btn-steam-nav:hover { background:var(--orange); border-color:var(--orange); }

/* Botón Discord hero */
.btn-discord-hero {
  background:rgba(88,101,242,.15); color:#8b9cf4;
  border:1px solid rgba(88,101,242,.3);
}
.btn-discord-hero:hover { background:rgba(88,101,242,.3); color:#fff; }

/* ── HERO ── */
.hero {
  min-height:100vh; display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  text-align:center; padding:120px 24px 80px;
  position:relative; overflow:hidden;
}
.hero::after {
  content:''; pointer-events:none;
  position:absolute; left:0; right:0; height:3px;
  background:linear-gradient(transparent, rgba(255,85,0,.1), transparent);
  animation:scanLine 6s linear infinite;
}
.hero > * { position:relative; z-index:1; }
.hero-logo {
  width:160px; margin:0 auto 24px;
  animation:fadeIn .9s ease both, pulseGlow 4s ease-in-out 1s infinite;
}
/* HERO CAROUSEL */
.hero-carousel {
  position:relative; height:clamp(110px,20vw,230px); overflow:hidden;
  margin:0 auto 40px; max-width:1000px; width:100%;
  animation:fadeUp .7s .2s ease both;
}
.hero-slide {
  position:absolute; left:0; right:0; text-align:center;
  font-family:'Anton', sans-serif;
  font-size:clamp(52px,9.5vw,115px);
  line-height:.92; color:var(--text);
  letter-spacing:3px; text-transform:uppercase;
  opacity:0; transform:translateY(20px);
  transition:opacity .7s ease, transform .7s ease;
  display:flex; align-items:center; justify-content:center;
  top:0; bottom:0;
}
.hero-slide.active { opacity:1; transform:translateY(0); }
.hero-slide-block { flex-direction:column; line-height:.88; }
.slide-orange { color:var(--orange); font-family:inherit; }

.hero-btns { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; animation:fadeUp .7s .5s ease both; }

/* ── STATS BAR ── */
.stats-bar {
  display:grid; grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.stat {
  padding:36px 0; text-align:center;
  border-right:1px solid var(--border);
}
.stat:last-child { border-right:none; }
.stat-n { font-family:'Anton'; font-size:44px; color:var(--orange); }
.stat-n.live { color:var(--green); }
.stat-l { font-size:11px; font-weight:600; letter-spacing:3px; color:var(--muted); text-transform:uppercase; margin-top:4px; }

/* ── SECTIONS ── */
.section { padding:96px 0; }
.section.bg-surface { background:var(--surface); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.section-pad { padding:64px 0; }
.container { max-width:1100px; margin:0 auto; padding:0 48px; }
.section-label { font-size:11px; font-weight:600; letter-spacing:4px; color:var(--orange); text-transform:uppercase; margin-bottom:12px; }
.section-title { font-family:'Anton'; font-size:clamp(36px,5vw,60px); letter-spacing:2px; text-transform:uppercase; margin-bottom:12px; }
.section-lead { color:var(--muted); font-size:15px; max-width:480px; margin-bottom:48px; }

/* ── RULES ── */
.rules-list { display:flex; flex-direction:column; }
.rule {
  display:flex; align-items:baseline; gap:28px;
  padding:22px 0; border-bottom:1px solid var(--border);
}
.rule:first-child { border-top:1px solid var(--border); }
.rule-n  { font-family:'Anton'; font-size:12px; color:var(--orange); letter-spacing:2px; min-width:26px; }
.rule-t  { font-weight:600; font-size:15px; min-width:200px; }
.rule-d  { font-size:14px; color:var(--muted); line-height:1.6; }

/* ── PROMO SECTIONS ── */
.promo-section {
  display:grid; grid-template-columns:1fr 1fr;
  min-height:460px; overflow:hidden;
  border-top:1px solid var(--border);
}
.promo-section.promo-dark { background:#0a0a0a; }
.promo-content {
  display:flex; flex-direction:column; justify-content:center;
  align-items:flex-start;
  padding:72px 64px;
}
.promo-label {
  font-size:10px; font-weight:700; letter-spacing:4px;
  color:var(--orange); text-transform:uppercase; margin-bottom:16px;
}
.promo-title {
  font-family:'Anton'; font-size:clamp(32px,4vw,52px);
  letter-spacing:2px; text-transform:uppercase;
  line-height:1.05; margin-bottom:20px;
}
.promo-title strong { color:var(--orange); font-family:inherit; }
.promo-sub {
  font-size:15px; color:var(--muted); margin-bottom:32px;
  max-width:380px; line-height:1.8;
}
.promo-art {
  position:relative; overflow:hidden;
  background:#111 center/cover no-repeat;
  display:flex; align-items:center; justify-content:center;
}
/* fade from content into art */
.promo-art::before {
  content:''; position:absolute; top:0; bottom:0; left:0; width:220px;
  background:linear-gradient(to right, #080808 0%, rgba(8,8,8,.6) 60%, transparent 100%);
  z-index:2;
}
.promo-art-left::before {
  left:auto; right:0; width:220px;
  background:linear-gradient(to left, #080808 0%, rgba(8,8,8,.6) 60%, transparent 100%);
}
/* Botón dentro de promo no ocupa todo el ancho */
.promo-content .btn { align-self:flex-start; }
.promo-art-placeholder {
  font-size:48px; opacity:.08; position:relative; z-index:1;
  user-select:none;
}

/* ── STAFF (Ibiza RP style) ── */
.staff-section {
  border-top:1px solid var(--border);
  background:var(--black);
  padding:80px 0;
}
.staff-wrap {
  max-width:1200px; margin:0 auto; padding:0 48px;
  display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start;
}
.staff-heading {
  font-family:'Inter', sans-serif; font-size:clamp(36px,4vw,56px);
  font-weight:800; line-height:1.05; margin:12px 0 20px;
}
.staff-em {
  font-style:italic; color:var(--orange);
}
.staff-desc { font-size:14px; color:var(--muted); line-height:1.7; max-width:320px; }

/* Staff list cards */
.staff-list { display:flex; flex-direction:column; gap:10px; }
.staff-row {
  display:flex; align-items:center; gap:16px;
  background:#111; border:1px solid var(--border);
  border-radius:6px; padding:12px 16px;
  transition:border-color .2s, background .2s;
}
.staff-row:hover { background:#161616; border-color:rgba(255,85,0,.2); }
.staff-row-thumb {
  width:52px; height:52px; border-radius:6px; flex-shrink:0;
  overflow:hidden; background:linear-gradient(135deg,#1c1c1c,#111);
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--border);
  position:relative;
}
/* La imagen flota encima de las iniciales */
.staff-row-thumb img {
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover;
  border-radius:5px;
}
.staff-row-empty { background:var(--border); }
.staff-row-empty span { font-size:22px; color:var(--muted); }
.staff-row-initials {
  font-family:'Anton'; font-size:18px; color:var(--orange); letter-spacing:1px;
}
.staff-row-info { flex:1; }
.staff-row-role {
  font-size:9px; font-weight:700; letter-spacing:3px;
  text-transform:uppercase; color:var(--muted); margin-bottom:3px;
}
.staff-row-name { font-size:16px; font-weight:700; }
.staff-row-name.muted { color:var(--muted); font-style:italic; font-weight:400; }
.btn-discord {
  background:linear-gradient(135deg,#5865F2,#404EED);
  color:#fff; border:none;
}
.btn-discord:hover { opacity:.85; }
.btn-instagram {
  background:linear-gradient(135deg,#f09433 0%,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888 100%);
  color:#fff; border:none; display:inline-flex; align-items:center; gap:5px;
}
.btn-instagram:hover { opacity:.85; }

/* ── BANS SECTION ── */
.bans-section {
  border-top:1px solid var(--border);
  background:var(--black);
  padding:96px 0;
  text-align:center;
}
.bans-inner { max-width:640px; margin:0 auto; padding:0 24px; }
.bans-title {
  font-family:'Inter'; font-size:clamp(32px,5vw,52px);
  font-weight:800; margin:12px 0 16px; line-height:1.1;
}
.bans-em { font-style:italic; color:var(--orange); }
.bans-desc { font-size:15px; color:var(--muted); line-height:1.7; margin-bottom:32px; }
.bans-card {
  background:#111; border:1px solid var(--border);
  border-radius:14px; padding:8px; text-align:left;
}
.bans-card-item {
  display:flex; align-items:flex-start; gap:14px;
  padding:16px 16px; border-bottom:1px solid var(--border);
}
.bans-card-item:last-of-type { border-bottom:none; }
.bans-icon { font-size:20px; color:var(--orange); flex-shrink:0; margin-top:2px; }
.bans-card-title { font-weight:700; font-size:15px; margin-bottom:3px; }
.bans-card-sub { font-size:12px; color:var(--muted); }
.bans-card > div:last-child { padding:14px 16px; }
.bans-card > div:last-child p, .bans-card > div:last-child { font-size:14px; color:var(--muted); line-height:1.6; }

/* ── CTA BAND ── */
.cta-band { padding:80px 48px; background:var(--surface); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.cta-title { font-family:'Anton'; font-size:clamp(36px,5vw,56px); letter-spacing:2px; text-transform:uppercase; margin-bottom:12px; }
.cta-sub  { color:var(--muted); font-size:15px; margin-bottom:36px; }
.cta-btns { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

/* ── FOOTER ── */
.footer { padding:48px; text-align:center; border-top:1px solid var(--border); }
.footer-logo { height:36px; margin:0 auto 20px; opacity:.4; }
.footer-links { display:flex; gap:24px; justify-content:center; margin-bottom:20px; flex-wrap:wrap; }
.footer-links a { font-size:12px; color:var(--muted); letter-spacing:1px; text-transform:uppercase; transition:color .15s; }
.footer-links a:hover { color:var(--orange); }
.footer-legal { font-size:12px; color:#333; }

/* ── LOGIN PAGE ── */
.login-page { min-height:100vh; display:flex; align-items:center; justify-content:center; padding:80px 24px; }
.login-box { background:var(--surface); border:1px solid var(--border); border-radius:4px; padding:48px 40px; text-align:center; max-width:420px; width:100%; }
.login-logo { width:80px; margin:0 auto 20px; }
.login-title { font-family:'Anton'; font-size:40px; letter-spacing:3px; margin-bottom:12px; }
.login-title span { color:var(--orange); }
.login-sub { color:var(--muted); font-size:14px; margin-bottom:28px; }
.login-note { font-size:12px; color:var(--muted); margin-top:14px; }

/* ── PAGE HEADER ── */
.page-header { padding:100px 0 40px; border-bottom:1px solid var(--border); }
.page-header-inner { display:flex; align-items:center; justify-content:space-between; }
.page-title { font-family:'Anton'; font-size:clamp(40px,6vw,72px); letter-spacing:3px; text-transform:uppercase; }
.page-sub { color:var(--muted); font-size:14px; margin-top:6px; }
.dashboard-avatar { width:80px; height:80px; border-radius:50%; border:2px solid var(--border); }

/* ── DASHBOARD CARDS ── */
.dashboard-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--border); margin:48px auto; }
.dash-card { background:var(--surface); padding:32px 28px; }
.dash-card-wide { grid-column:1/-1; }
.dash-card-label { font-size:11px; font-weight:600; letter-spacing:3px; color:var(--orange); text-transform:uppercase; margin-bottom:6px; }
.dash-card-title { font-family:'Anton'; font-size:26px; letter-spacing:1px; margin-bottom:20px; }
.dash-rows { display:flex; flex-direction:column; }
.dash-row { display:flex; justify-content:space-between; align-items:center; padding:10px 0; border-bottom:1px solid var(--border); font-size:14px; }
.dash-row:last-child { border-bottom:none; }
.dash-row span:first-child { color:var(--muted); }

/* ── BADGES ── */
.badge { display:inline-block; padding:3px 10px; border-radius:2px; font-size:11px; font-weight:600; letter-spacing:1px; text-transform:uppercase; }
.badge-green { background:#0D2A1A; color:var(--green); border:1px solid var(--green); }
.badge-red   { background:#2A0D0D; color:#FF4444; border:1px solid #FF4444; }
.badge-yellow { background:#2A2200; color:#FFB800; border:1px solid #FFB800; }
.badge-muted { background:var(--border); color:var(--muted); }

/* ── STORE ── */
.cards-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--border); }
.store-card { background:var(--surface); padding:36px 28px; display:flex; flex-direction:column; position:relative; transition:background .2s; }
.store-card:hover { background:#161616; }
.store-card-featured { border-top:2px solid var(--orange); }
.store-card-badge { position:absolute; top:-1px; right:20px; background:var(--orange); color:#fff; font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; padding:3px 10px; }
.store-card-tag  { font-size:11px; font-weight:600; letter-spacing:3px; color:var(--muted); text-transform:uppercase; margin-bottom:6px; }
.store-card-name { font-family:'Anton'; font-size:28px; color:var(--orange); margin-bottom:24px; }
.store-card-price { font-family:'Anton'; font-size:40px; }
.store-card-period { font-size:12px; color:var(--muted); margin-bottom:24px; letter-spacing:1px; }
.store-card-divider { height:1px; background:var(--border); margin-bottom:20px; }
.store-card-perks { list-style:none; display:flex; flex-direction:column; gap:9px; flex:1; margin-bottom:24px; }
.store-card-perks li { font-size:13px; color:#999; display:flex; align-items:center; gap:8px; }
.store-card-perks li::before { content:'—'; color:var(--orange); font-weight:700; }
.store-info { display:flex; flex-wrap:wrap; gap:16px 32px; margin-top:40px; justify-content:center; }
.store-info-item { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--muted); }

/* ── RESULT PAGE ── */
.result-icon { font-size:48px; margin-bottom:16px; }
.result-success { color:var(--green); }
.result-error   { color:#FF4444; }
.result-pending { color:#FFB800; }
.result-title   { font-family:'Anton'; font-size:32px; letter-spacing:2px; text-transform:uppercase; margin-bottom:12px; }
.result-sub     { color:var(--muted); font-size:15px; margin-bottom:4px; }
.result-id      { font-size:12px; color:var(--muted); margin-top:8px; }
.result-id code { background:var(--border); padding:2px 8px; border-radius:2px; font-family:monospace; }
.error-code     { font-family:'Anton'; font-size:96px; color:var(--orange); line-height:1; margin-bottom:8px; }

/* ── ADMIN ── */
.admin-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--border); margin-bottom:32px; }
.admin-stat-card { background:var(--surface); padding:32px 24px; text-align:center; }
.admin-stat-n { font-family:'Anton'; font-size:48px; color:var(--orange); }
.admin-stat-l { font-size:11px; font-weight:600; letter-spacing:3px; color:var(--muted); text-transform:uppercase; margin-top:4px; }
.admin-nav-cards { display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--border); margin-bottom:32px; }
.admin-nav-card { background:var(--surface); padding:28px 24px; transition:background .2s; cursor:pointer; }
.admin-nav-card:hover { background:#161616; }
.admin-nav-icon  { font-size:28px; margin-bottom:10px; }
.admin-nav-title { font-family:'Anton'; font-size:22px; letter-spacing:1px; margin-bottom:4px; }
.admin-nav-sub   { font-size:13px; color:var(--muted); }
.admin-search { display:flex; gap:10px; margin-bottom:24px; align-items:center; flex-wrap:wrap; }
.admin-table-wrap { overflow-x:auto; border:1px solid var(--border); border-radius:3px; }
.admin-table { width:100%; border-collapse:collapse; font-size:13px; }
.admin-table thead { background:var(--surface); border-bottom:1px solid var(--border); }
.admin-table th { padding:12px 16px; text-align:left; font-size:11px; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--muted); white-space:nowrap; }
.admin-table td { padding:12px 16px; border-bottom:1px solid var(--border); vertical-align:middle; }
.admin-table tr:last-child td { border-bottom:none; }
.admin-table tr:hover td { background:rgba(255,255,255,.02); }
.admin-table tr.row-banned td { opacity:.5; }
.input {
  background:var(--surface); border:1px solid var(--border); border-radius:3px;
  color:var(--text); padding:10px 14px; font-size:13px; font-family:inherit;
  flex:1; outline:none; transition:border-color .15s;
}
.input:focus { border-color:var(--orange); }

/* ── RULES GITBOOK LAYOUT ── */
.rules-page {
  display:grid;
  grid-template-columns:420px 1fr;
  min-height:100vh;
  margin-top:60px;
  max-width:1500px;
  margin-left:auto;
  margin-right:3%;
}

/* NAV SIDEBAR */
.rules-nav {
  position:sticky; top:60px; align-self:start;
  height:calc(100vh - 60px);
  display:flex; flex-direction:column;
  background: linear-gradient(160deg, #1a1a1a 0%, #131313 50%, #0d0d0d 100%);
  scrollbar-width:none;
  margin-left:24px;
  border:1px solid rgba(255,85,0,.18);
  border-radius:8px 0 0 8px;
  box-shadow:0 0 40px rgba(255,85,0,.06), inset 1px 0 0 rgba(255,85,0,.08);
  overflow:hidden;
}
.rules-nav-header {
  padding:28px 24px 18px;
  border-bottom:1px solid rgba(255,255,255,.06);
  background:linear-gradient(180deg, rgba(255,85,0,.06) 0%, transparent 100%);
  flex-shrink:0;
}
.rules-nav-label { font-size:10px; font-weight:700; letter-spacing:4px; text-transform:uppercase; color:var(--orange); margin-bottom:6px; }
.rules-nav-title { font-family:'Anton'; font-size:22px; letter-spacing:2px; }

/* scrollable list with bottom fade */
.rules-nav-list-wrap {
  flex:1;
  position:relative;
  overflow:hidden;
}
.rules-nav-list-wrap::after {
  content:'';
  position:absolute;
  bottom:0; left:0; right:0; height:80px;
  background:linear-gradient(to bottom, transparent, #0d0d0d);
  pointer-events:none;
  z-index:2;
}
.rules-nav-list {
  height:100%; overflow-y:auto;
  padding:12px 0 80px;
  scrollbar-width:none;
}
.rules-nav-list::-webkit-scrollbar { display:none; }

.rules-nav-item {
  display:flex; align-items:center; gap:12px;
  padding:10px 24px; font-size:13.5px; color:var(--muted);
  transition:all .15s; border-left:3px solid transparent;
}
.rules-nav-item span { font-size:11px; font-weight:700; color:#333; min-width:22px; }
.rules-nav-item:hover { color:var(--text); background:rgba(255,255,255,.04); }
.rules-nav-item.active { color:var(--orange); border-left-color:var(--orange); background:rgba(255,85,0,.08); }
.rules-nav-item.active span { color:var(--orange); }

.rules-nav-footer { padding:18px 24px; border-top:1px solid rgba(255,255,255,.06); flex-shrink:0; }

/* RULES CONTENT */
.rules-content {
  max-width:800px;
  padding:48px 56px 96px;
  line-height:1.7;
  margin:0; /* izquierda, no centrado */
}

.rules-section {
  margin-bottom:0;
  padding:48px 0;
  border-bottom:1px solid var(--border);
  scroll-margin-top:80px;
}
.rules-section:last-child { border-bottom:none; }

.rules-h2 {
  font-family:'Anton'; font-size:clamp(24px,3vw,32px);
  letter-spacing:1px; margin-bottom:20px; line-height:1.1;
  color:#FFD700;
}
.rules-h2 span { color:var(--muted); font-size:.7em; margin-right:8px; }
.rules-h3 { font-size:16px; font-weight:700; color:#FFD700; margin:24px 0 12px; }

.rules-content p { font-size:15px; margin-bottom:14px; color:#ccc; }
.rules-content ul { padding-left:20px; margin-bottom:14px; }
.rules-content li { font-size:15px; margin-bottom:8px; color:#bbb; }
.rules-content strong { color:var(--text); }
.rules-content code { background:#1A1A1A; border:1px solid var(--border); color:var(--orange); padding:2px 8px; border-radius:3px; font-size:13px; }

/* COLOR HELPERS */
.txt-red    { color:#FF4444; }
.txt-green  { color:#3DDB85; }
.txt-yellow { color:#FFD700; }
.txt-orange { color:var(--orange); }

/* HINT BOXES */
.hint {
  border-radius:4px; padding:16px 20px;
  margin:20px 0; font-size:14px;
  border-left:3px solid;
}
.hint-title { font-weight:700; font-size:12px; letter-spacing:2px; text-transform:uppercase; margin-bottom:8px; }
.hint ul { margin-bottom:0; padding-left:16px; }
.hint li { margin-bottom:4px; }

.hint-info    { background:rgba(59,130,246,.1); border-color:#3B82F6; color:#93C5FD; }
.hint-info .hint-title { color:#3B82F6; }
.hint-warning { background:rgba(245,158,11,.1); border-color:#F59E0B; color:#FCD34D; }
.hint-warning .hint-title { color:#F59E0B; }
.hint-danger  { background:rgba(239,68,68,.1);  border-color:#EF4444; color:#FCA5A5; }
.hint-danger .hint-title { color:#EF4444; }
.hint-success { background:rgba(34,197,94,.1);  border-color:#22C55E; color:#86EFAC; }
.hint-success .hint-title { color:#22C55E; }

/* BLOCKQUOTE */
.rules-content blockquote {
  border-left:3px solid var(--border);
  padding:12px 20px; margin:16px 0;
  background:rgba(255,255,255,.02);
  border-radius:0 4px 4px 0;
}
.rules-content blockquote ul { margin-bottom:0; }

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

/* COLLAPSIBLE */
.rules-details {
  border:1px solid var(--border); border-radius:4px;
  margin:14px 0; overflow:hidden;
}
.rules-details summary {
  padding:14px 18px; cursor:pointer;
  font-size:14px; font-weight:600;
  list-style:none; display:flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.02);
  transition:background .15s;
}
.rules-details summary:hover { background:rgba(255,255,255,.04); }
.rules-details summary::before { content:'▶'; font-size:10px; color:var(--muted); transition:transform .2s; }
.rules-details[open] summary::before { transform:rotate(90deg); }
.details-content {
  padding:16px 18px;
  border-top:1px solid var(--border);
  font-size:14px; color:#bbb;
}
.details-content ul { margin-bottom:0; }

/* COMMAND TABS */
.cmd-tabs { margin-top:20px; }
.cmd-tab-btns {
  display:flex; gap:0; flex-wrap:wrap;
  border-bottom:1px solid var(--border);
}
.cmd-tab-btn {
  padding:10px 18px; font-size:13px; font-weight:700;
  letter-spacing:1px; color:var(--muted);
  background:transparent; border:none; cursor:pointer;
  border-bottom:2px solid transparent; margin-bottom:-1px;
  transition:all .15s; font-family:'Inter', sans-serif;
}
.cmd-tab-btn:hover { color:var(--text); }
.cmd-tab-btn.active { color:var(--orange); border-bottom-color:var(--orange); }
.cmd-tab-content {
  display:none; padding:20px;
  background:rgba(255,255,255,.02);
  border:1px solid var(--border); border-top:none;
  border-radius:0 0 4px 4px;
  font-size:14px; color:#bbb; line-height:1.7;
}
.cmd-tab-content.active { display:block; }

/* ── STORE HERO ── */
.store-hero {
  margin-top:60px;
  background: radial-gradient(ellipse 80% 60% at 50% 0%, rgba(255,85,0,.12) 0%, transparent 70%), var(--black);
  border-bottom:1px solid var(--border);
  padding:64px 48px 48px;
}
.store-hero-inner { max-width:1200px; margin:0 auto; display:flex; align-items:flex-end; justify-content:space-between; gap:32px; flex-wrap:wrap; }
.store-hero-label { font-size:11px; font-weight:700; letter-spacing:4px; text-transform:uppercase; color:var(--orange); margin-bottom:12px; }
.store-hero-title { font-family:'Anton'; font-size:clamp(32px,5vw,56px); line-height:1; letter-spacing:2px; margin-bottom:14px; }
.store-hero-title span { color:var(--orange); }
.store-hero-sub { font-size:15px; color:var(--muted); max-width:500px; line-height:1.6; }
.store-hero-stats { display:flex; gap:40px; flex-shrink:0; }
.store-hero-stat { text-align:center; }
.store-hero-stat strong { display:block; font-family:'Anton'; font-size:40px; color:var(--orange); line-height:1; }
.store-hero-stat span { font-size:11px; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--muted); }

/* ── CATEGORY TABS ── */
.store-tabs-bar {
  position:sticky; top:60px; z-index:50;
  background:rgba(8,8,8,.97); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
}
.store-tabs-inner {
  max-width:1200px; margin:0 auto; padding:0 48px;
  display:flex; gap:0; overflow-x:auto;
  scrollbar-width:none;
}
.store-tabs-inner::-webkit-scrollbar { display:none; }
.store-tab {
  display:flex; align-items:center; gap:6px;
  padding:16px 20px; font-size:13px; font-weight:600;
  letter-spacing:.5px; color:var(--muted); white-space:nowrap;
  border-bottom:2px solid transparent;
  transition:all .15s; cursor:pointer;
}
.store-tab:hover { color:var(--text); }
.store-tab.active { color:var(--orange); border-bottom-color:var(--orange); }

/* ── TOOLBAR ── */
.store-toolbar {
  background:var(--surface);
  border-bottom:1px solid var(--border);
  padding:12px 0;
}
.store-toolbar-inner {
  max-width:1200px; margin:0 auto; padding:0 48px;
  display:flex; align-items:center; gap:16px; flex-wrap:wrap;
}
.store-search-form { display:flex; gap:8px; align-items:center; flex:1; min-width:200px; }
.store-search-input {
  flex:1; background:var(--black); border:1px solid var(--border);
  border-radius:3px; color:var(--text); padding:8px 14px;
  font-size:13px; font-family:inherit; outline:none;
  transition:border-color .15s;
}
.store-search-input:focus { border-color:var(--orange); }
.store-sort { display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.store-sort-label { font-size:11px; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--muted); }
.sort-pill {
  padding:5px 12px; border-radius:20px;
  font-size:11px; font-weight:600; color:var(--muted);
  border:1px solid var(--border); transition:all .15s;
}
.sort-pill:hover { border-color:var(--orange); color:var(--orange); }
.sort-pill.active { background:var(--orange); border-color:var(--orange); color:#fff; }
.store-count-badge {
  background:var(--border); color:var(--muted);
  padding:4px 12px; border-radius:20px;
  font-size:11px; font-weight:600; white-space:nowrap;
}

/* ── SHOP GRID ── */
.store-page-body { max-width:1200px; margin:0 auto; padding:40px 48px 64px; }
.shop-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}
.shop-card {
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:6px;
  overflow:hidden;
  display:flex; flex-direction:column;
  text-decoration:none; color:var(--text);
  transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease;
  cursor:pointer;
}
.shop-card:hover {
  transform:translateY(-4px);
  border-color:rgba(255,85,0,.4);
  box-shadow:0 8px 32px rgba(255,85,0,.12);
}
.shop-card-featured { border-color:var(--orange); }

/* IMAGE */
.shop-card-img {
  position:relative; height:180px;
  background-color:#161616;
  background-size:cover; background-position:center;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
}
.shop-card-img::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(to bottom, transparent 40%, rgba(8,8,8,.9) 100%);
}
.shop-card-img-fallback {
  display:flex; flex-direction:column; align-items:center; gap:10px;
  z-index:1; text-align:center; padding:16px;
}
.shop-card-icon {
  width:52px; height:52px; color:var(--orange); opacity:.7;
  stroke:var(--orange);
}
.shop-card-img-fallback span { font-size:40px; line-height:1; }
.shop-card-img-fallback p { font-family:'Anton'; font-size:14px; letter-spacing:1px; color:rgba(255,255,255,.5); }
.shop-card-badge {
  position:absolute; top:10px; left:10px; z-index:2;
  background:var(--orange); color:#fff;
  font-size:10px; font-weight:700; letter-spacing:1px;
  text-transform:uppercase; padding:3px 10px; border-radius:2px;
}
.shop-card-featured-tag {
  position:absolute; top:10px; right:10px; z-index:2;
  background:rgba(0,0,0,.7); border:1px solid var(--orange); color:var(--orange);
  font-size:10px; font-weight:700; letter-spacing:1px;
  padding:3px 10px; border-radius:2px;
}

/* CARD INFO */
.shop-card-info { padding:16px; display:flex; flex-direction:column; flex:1; }
.shop-card-cat { font-size:10px; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--muted); margin-bottom:4px; }
.shop-card-name { font-family:'Anton'; font-size:18px; letter-spacing:.5px; color:var(--text); margin-bottom:6px; line-height:1.1; }
.shop-card-desc { font-size:12px; color:var(--muted); line-height:1.5; flex:1; margin-bottom:14px;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.shop-card-footer { display:flex; align-items:center; justify-content:space-between; }
.shop-card-price { font-family:'Anton'; font-size:22px; color:var(--orange); }
.shop-card-price span { font-family:'Inter'; font-size:11px; color:var(--muted); font-weight:400; }
.shop-card-btn {
  font-size:11px; font-weight:700; letter-spacing:1px;
  color:var(--orange); background:rgba(255,85,0,.1);
  border:1px solid rgba(255,85,0,.3);
  padding:5px 12px; border-radius:3px;
  transition:all .15s;
}
.shop-card:hover .shop-card-btn { background:var(--orange); color:#fff; border-color:var(--orange); }

.store-empty { text-align:center; padding:80px 24px; color:var(--muted); }
.store-empty-icon { font-size:48px; margin-bottom:16px; }
.store-empty h3 { font-family:'Anton'; font-size:28px; letter-spacing:1px; margin-bottom:8px; color:var(--text); }

/* TRUST STRIP */
.store-trust-strip {
  display:flex; justify-content:center; flex-wrap:wrap; gap:32px;
  padding:24px 48px; background:var(--surface);
  border-top:1px solid var(--border);
}
.store-trust-item { font-size:13px; color:var(--muted); display:flex; align-items:center; gap:6px; }
.store-trust-item span { color:var(--orange); font-weight:700; }

/* ── ITEM DETALLE ── */
.item-layout { display:grid; grid-template-columns:1fr 340px; gap:48px; align-items:start; }
.item-main {}
.item-cat-tag { font-size:11px; font-weight:600; letter-spacing:4px; color:var(--orange); text-transform:uppercase; margin-bottom:10px; }
.item-title { font-family:'Anton'; font-size:clamp(40px,6vw,64px); letter-spacing:2px; text-transform:uppercase; margin-bottom:16px; line-height:.95; }
.item-desc { font-size:16px; color:var(--muted); line-height:1.7; margin-bottom:32px; }
.item-perks-box { background:var(--surface); border:1px solid var(--border); border-radius:3px; padding:24px; }
.item-perks-title { font-size:11px; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--muted); margin-bottom:16px; }
.item-perks { list-style:none; display:flex; flex-direction:column; gap:10px; }
.item-perks li { display:flex; align-items:center; gap:10px; font-size:14px; }
.perk-check { color:var(--orange); font-weight:700; flex-shrink:0; }
.item-buy-box { background:var(--surface); border:1px solid var(--border); border-radius:3px; padding:28px; position:sticky; top:80px; }
.item-price { font-family:'Anton'; font-size:52px; color:var(--orange); line-height:1; }
.item-price-label { font-size:12px; color:var(--muted); letter-spacing:1px; margin-top:4px; margin-bottom:20px; }
.item-divider { height:1px; background:var(--border); margin:20px 0; }
.item-note { font-size:12px; color:var(--muted); margin-top:12px; line-height:1.5; }
.item-trust { list-style:none; display:flex; flex-direction:column; gap:8px; }
.item-trust li { font-size:13px; color:var(--muted); }

/* ── RULES MAIN ── */
.rules-main { padding:32px 40px; }
.rules-section-header { display:flex; align-items:flex-start; gap:20px; margin-bottom:36px; padding-bottom:28px; border-bottom:1px solid var(--border); }
.rules-section-icon { font-size:40px; flex-shrink:0; line-height:1; margin-top:4px; }
.rules-section-title { font-family:'Anton'; font-size:clamp(32px,4vw,48px); letter-spacing:2px; text-transform:uppercase; margin-bottom:8px; }
.rules-section-intro { font-size:14px; color:var(--muted); line-height:1.6; }
.rules-cards { display:flex; flex-direction:column; gap:1px; background:var(--border); margin-bottom:32px; }
.rule-card { background:var(--surface); padding:24px 28px; display:flex; gap:24px; align-items:flex-start; transition:background .2s; }
.rule-card:hover { background:#161616; }
.rule-card-n { font-family:'Anton'; font-size:14px; color:var(--orange); letter-spacing:2px; min-width:36px; padding-top:2px; }
.rule-card-title { font-weight:600; font-size:15px; margin-bottom:6px; }
.rule-card-desc { font-size:14px; color:var(--muted); line-height:1.6; }
.rules-pagination { display:flex; align-items:center; justify-content:space-between; padding-top:12px; }
.rules-page-info { font-size:13px; color:var(--muted); }

/* ── RESPONSIVE ── */
@media (max-width:768px) {
  .nav { padding:0 20px; }
  .nav-links { display:none; }
  .hero-title { font-size:clamp(40px,13vw,72px); }
  .hero-carousel { max-width:100%; }
  .stats-bar { grid-template-columns:repeat(2,1fr); }
  .stat { border-right:1px solid var(--border); }
  .promo-section { grid-template-columns:1fr; min-height:auto; }
  .promo-art { min-height:220px; }
  .promo-art::before, .promo-art-left::before { display:none; }
  .promo-content { padding:48px 24px; }
  .staff-ibiza-grid { grid-template-columns:repeat(2,1fr); }
  .staff-ibiza-card { border-right:none; border-bottom:1px solid var(--border); }
  .cards-grid { grid-template-columns:1fr; }
  .dashboard-grid { grid-template-columns:1fr; }
  .admin-stats { grid-template-columns:1fr; }
  .admin-nav-cards { grid-template-columns:1fr; }
  .container { padding:0 20px; }
  .cta-band { padding:48px 20px; }
  .rules-list .rule { flex-direction:column; gap:6px; }
  .rules-page { grid-template-columns:1fr; }
  .rules-nav { position:static; height:auto; }
  .rules-content { padding:32px 20px 64px; }
  .item-layout { grid-template-columns:1fr; }
  .item-buy-box { position:static; }
  .store-hero { padding:40px 20px 32px; }
  .store-hero-inner { flex-direction:column; align-items:flex-start; gap:24px; }
  .store-hero-stats { gap:24px; }
  .store-tabs-inner { padding:0 20px; }
  .store-toolbar-inner { padding:0 20px; }
  .store-page-body { padding:24px 20px 48px; }
  .shop-grid { grid-template-columns:repeat(2,1fr); gap:12px; }
  .store-trust-strip { padding:20px; gap:16px; flex-direction:column; align-items:center; }
  .rule-t { min-width:auto; }
}
