/* =====================================================
   MYTHICOLBIA GUIDE — MAIN STYLESHEET
   Dark Fantasy Minecraft Theme
   ===================================================== */

@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700;900&family=Nunito:wght@300;400;600;700;800&family=JetBrains+Mono:wght@400;600&display=swap');

/* ── 1. Custom Properties ─────────────────────────── */
:root {
  --bg-base:         #050810;
  --bg-surface:      #080d1c;
  --bg-card:         rgba(8, 18, 45, 0.72);
  --bg-sidebar:      rgba(4, 7, 18, 0.97);
  --bg-code:         rgba(0, 0, 0, 0.55);

  --cyan:            #00d8ff;
  --cyan-dim:        rgba(0, 216, 255, 0.12);
  --blue:            #3a8fff;
  --violet:          #7b2fff;
  --violet-dim:      rgba(123, 47, 255, 0.12);
  --magenta:         #e82dcd;
  --magenta-dim:     rgba(232, 45, 205, 0.12);
  --gold:            #ffca3a;
  --gold-dim:        rgba(255, 202, 58, 0.12);
  --green:           #00ff9f;
  --green-dim:       rgba(0, 255, 159, 0.12);
  --orange:          #ff8c00;
  --red:             #ff4466;

  --text-primary:    #ddeeff;
  --text-secondary:  #7a9ec0;
  --text-muted:      #3d5470;
  --text-code:       #00f0b5;

  --sidebar-width:   268px;
  --content-max:     820px;
  --section-pad:     4.5rem 2.5rem 5rem;

  --font-display:    'Cinzel', Georgia, serif;
  --font-body:       'Nunito', system-ui, sans-serif;
  --font-mono:       'JetBrains Mono', 'Courier New', monospace;

  --radius-sm:       6px;
  --radius-md:       12px;
  --radius-lg:       18px;
  --radius-xl:       24px;

  --transition:      0.28s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ── 2. Reset & Base ──────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  font-size: 16px;
}

body {
  background-color: var(--bg-base);
  color: var(--text-primary);
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.75;
  overflow-x: hidden;
  min-height: 100vh;
}

img {}
a { color: var(--cyan); text-decoration: none; transition: color var(--transition); }
a:hover { color: #fff; }
ul, ol { padding-left: 1.4em; }
li { margin-bottom: 0.35em; }

/* ── 3. Particle Canvas ───────────────────────────── */
#particles {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

/* ── 4. Layout ────────────────────────────────────── */
#content {
  margin-left: var(--sidebar-width);
  position: relative;
  z-index: 1;
}

/* ── 5. Mobile Top Bar ────────────────────────────── */
.mobile-topbar {
  display: none;
  position: fixed;
  top: 0; left: 0; right: 0;
  height: 58px;
  background: rgba(4, 7, 18, 0.96);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(0, 216, 255, 0.2);
  align-items: center;
  gap: 1rem;
  padding: 0 1.2rem;
  z-index: 200;
}
.mobile-topbar .mobile-logo {
  font-family: var(--font-display);
  font-size: 1rem;
  color: var(--cyan);
  letter-spacing: 0.08em;
  text-shadow: 0 0 18px rgba(0,216,255,0.6);
}
#hamburger {
  background: none;
  border: 1.5px solid rgba(0,216,255,0.4);
  color: var(--cyan);
  border-radius: var(--radius-sm);
  padding: 0.3rem 0.6rem;
  font-size: 1.1rem;
  cursor: pointer;
  transition: var(--transition);
}
#hamburger:hover {
  background: var(--cyan-dim);
  border-color: var(--cyan);
}

/* ── 6. Sidebar ───────────────────────────────────── */
#sidebar {
  position: fixed;
  top: 0; left: 0;
  width: var(--sidebar-width);
  height: 100vh;
  background: var(--bg-sidebar);
  border-right: 1px solid rgba(0, 216, 255, 0.14);
  display: flex;
  flex-direction: column;
  z-index: 100;
  overflow: hidden;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

.sidebar-header {
  padding: 1.6rem 1.4rem 1.2rem;
  border-bottom: 1px solid rgba(0,216,255,0.1);
  flex-shrink: 0;
}
.sidebar-logo {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 900;
  letter-spacing: 0.06em;
  background: linear-gradient(135deg, var(--cyan), var(--violet));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-shadow: none;
  display: block;
  margin-bottom: 0.25rem;
}
.sidebar-sub {
  font-size: 0.65rem;
  color: var(--text-muted);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.sidebar-ip {
  margin-top: 0.7rem;
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  color: var(--cyan);
  background: var(--cyan-dim);
  border: 1px solid rgba(0,216,255,0.25);
  border-radius: 4px;
  padding: 0.15rem 0.5rem;
}

.sidebar-nav {
  flex: 1;
  overflow-y: auto;
  padding: 0.8rem 0 1.5rem;
  list-style: none;
}
.sidebar-nav::-webkit-scrollbar { width: 4px; }
.sidebar-nav::-webkit-scrollbar-track { background: transparent; }
.sidebar-nav::-webkit-scrollbar-thumb { background: rgba(0,216,255,0.2); border-radius: 4px; }

.sidebar-nav .nav-group-label {
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: 0.9rem 1.4rem 0.3rem;
  display: block;
}

.sidebar-nav a {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.46rem 1.4rem 0.46rem 1.2rem;
  font-size: 0.82rem;
  color: var(--text-secondary);
  border-left: 2.5px solid transparent;
  transition: var(--transition);
  position: relative;
}
.sidebar-nav a .nav-icon {
  font-size: 0.85rem;
  opacity: 0.75;
  flex-shrink: 0;
  width: 18px;
  text-align: center;
}
.sidebar-nav a:hover,
.sidebar-nav a:focus,
.sidebar-nav a:focus-visible,
.sidebar-nav a.active,
.sidebar-nav a.current,
.sidebar-nav a.selected,
.sidebar-nav a[aria-current="true"],
.sidebar-nav a[aria-current="page"] {
  color: var(--text-secondary) !important;
  background: transparent !important;
  border-left-color: transparent !important;
  box-shadow: none !important;
  outline: none !important;
}

/* Evidenziazione automatica disattivata completamente: nessuno stato active/hover/focus sulla sidebar. */

/* Sidebar overlay (mobile) */
#sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  z-index: 99;
  opacity: 0;
  transition: opacity var(--transition);
}
#sidebar-overlay.visible {
  opacity: 1;
}

/* ── 7. Sections Base ─────────────────────────────── */
.section {
  padding: var(--section-pad);
  position: relative;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.section::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--section-gradient, linear-gradient(90deg, var(--cyan), var(--violet)));
  opacity: 0.6;
}

.section-inner {
  max-width: var(--content-max);
  margin: 0 auto;
  animation: fadeInUp 0.6s both;
}
.section.visible .section-inner {
  animation-name: fadeInUp;
}

.section-tag {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent, var(--cyan));
  display: inline-block;
  margin-bottom: 0.4rem;
  padding: 0.18rem 0.7rem;
  border: 1px solid currentColor;
  border-radius: 4px;
  opacity: 0.9;
}
.section-title {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  font-weight: 900;
  color: var(--text-primary);
  margin-bottom: 1.6rem;
  line-height: 1.15;
}
.section-title span {
  background: var(--section-gradient, linear-gradient(135deg, var(--cyan), var(--violet)));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.section-intro {
  font-size: 1.05rem;
  color: var(--text-secondary);
  margin-bottom: 2rem;
  max-width: 680px;
}

/* Section accent colors */
.section--cyan   { --accent: var(--cyan);    --section-gradient: linear-gradient(135deg, var(--cyan), var(--blue));    }
.section--violet { --accent: var(--violet);  --section-gradient: linear-gradient(135deg, var(--violet), var(--blue));  }
.section--gold   { --accent: var(--gold);    --section-gradient: linear-gradient(135deg, var(--gold), var(--orange));  }
.section--magenta{ --accent: var(--magenta); --section-gradient: linear-gradient(135deg, var(--magenta), var(--violet));}
.section--green  { --accent: var(--green);   --section-gradient: linear-gradient(135deg, var(--green), var(--cyan));   }
.section--blue   { --accent: var(--blue);    --section-gradient: linear-gradient(135deg, var(--blue), var(--violet));  }
.section--orange { --accent: var(--orange);  --section-gradient: linear-gradient(135deg, var(--orange), var(--red));   }

/* ── 8. Hero Section ──────────────────────────────── */
.hero {
  padding: 5.5rem 2.5rem 5rem;
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%, rgba(0,180,255,0.06) 0%, transparent 70%),
    radial-gradient(ellipse 60% 40% at 80% 80%, rgba(123,47,255,0.06) 0%, transparent 70%);
}
.hero::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--violet), var(--cyan), var(--magenta));
}
.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--cyan);
  background: var(--cyan-dim);
  border: 1px solid rgba(0,216,255,0.3);
  border-radius: 99px;
  padding: 0.3rem 1rem;
  margin-bottom: 1.5rem;
  letter-spacing: 0.05em;
}
.hero-badge::before {
  content: '⬡';
  font-size: 0.8rem;
}
.hero-title {
  font-family: var(--font-display);
  font-size: clamp(2.2rem, 6vw, 4rem);
  font-weight: 900;
  line-height: 1.1;
  background: linear-gradient(135deg, #fff 0%, var(--cyan) 45%, var(--violet) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 1rem;
  text-shadow: none;
}
.hero-subtitle {
  font-size: 1.1rem;
  color: var(--text-secondary);
  max-width: 620px;
  margin-bottom: 2rem;
  line-height: 1.7;
}
.hero-ip {
  display: inline-flex;
  align-items: center;
  gap: 0.8rem;
  background: rgba(0,0,0,0.4);
  border: 1.5px solid rgba(0,216,255,0.35);
  border-radius: var(--radius-md);
  padding: 0.7rem 1.4rem;
  font-family: var(--font-mono);
  font-size: 1rem;
  color: var(--cyan);
  margin-bottom: 3rem;
  box-shadow: 0 0 30px rgba(0,216,255,0.15);
  cursor: pointer;
  transition: var(--transition);
}
.hero-ip:hover {
  border-color: var(--cyan);
  box-shadow: 0 0 40px rgba(0,216,255,0.3);
  color: #fff;
}
.hero-ip .ip-label {
  font-size: 0.65rem;
  color: var(--text-muted);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.hero-body p {
  color: var(--text-secondary);
  margin-bottom: 1rem;
  font-size: 0.97rem;
}

.hero-features {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem;
  margin: 2.5rem 0;
}
.hero-feature {
  background: var(--bg-card);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: var(--radius-md);
  padding: 1.1rem 1.3rem;
  display: flex;
  align-items: flex-start;
  gap: 0.8rem;
  backdrop-filter: blur(8px);
  transition: var(--transition);
}
.hero-feature:hover {
  border-color: rgba(0,216,255,0.25);
  transform: translateY(-2px);
}
.hero-feature-icon { font-size: 1.4rem; flex-shrink: 0; }
.hero-feature-text strong { display: block; font-size: 0.85rem; color: var(--text-primary); margin-bottom: 0.15rem; }
.hero-feature-text span { font-size: 0.78rem; color: var(--text-muted); }

/* ── 9. Cards ─────────────────────────────────────── */
.card {
  background: var(--bg-card);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: var(--radius-lg);
  padding: 1.5rem 1.8rem;
  margin-bottom: 1.4rem;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  position: relative;
  overflow: hidden;
  transition: var(--transition);
}
.card:hover {
  border-color: rgba(var(--accent-rgb, 0,216,255), 0.25);
  transform: translateY(-2px);
  box-shadow: 0 8px 30px rgba(0,0,0,0.3);
}
.card::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(135deg, rgba(255,255,255,0.02) 0%, transparent 50%);
  pointer-events: none;
}
.card--cyan   { border-color: rgba(0,216,255,0.18);    box-shadow: 0 0 20px rgba(0,216,255,0.05);    }
.card--violet { border-color: rgba(123,47,255,0.18);   box-shadow: 0 0 20px rgba(123,47,255,0.05);   }
.card--gold   { border-color: rgba(255,202,58,0.18);   box-shadow: 0 0 20px rgba(255,202,58,0.05);   }
.card--magenta{ border-color: rgba(232,45,205,0.18);   box-shadow: 0 0 20px rgba(232,45,205,0.05);   }
.card--green  { border-color: rgba(0,255,159,0.18);    box-shadow: 0 0 20px rgba(0,255,159,0.05);    }

.card-title {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: 0.6rem;
}
.card-title .card-icon { font-size: 1.2rem; }

/* Feature list inside cards */
.feature-list {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.feature-list li {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  font-size: 0.9rem;
  color: var(--text-secondary);
}
.feature-list li::before {
  content: '▸';
  color: var(--accent, var(--cyan));
  font-size: 0.75rem;
  margin-top: 0.28rem;
  flex-shrink: 0;
}

/* ── 10. Command Badges ───────────────────────────── */
.cmd-group {
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
  margin: 1.4rem 0;
}
.cmd-row {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  flex-wrap: wrap;
}
.cmd {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 0.82rem;
  color: var(--text-code);
  background: var(--bg-code);
  border: 1px solid rgba(0,240,181,0.22);
  border-radius: var(--radius-sm);
  padding: 0.28rem 0.75rem;
  white-space: nowrap;
  box-shadow: 0 0 10px rgba(0,240,181,0.06);
  flex-shrink: 0;
}
.cmd-desc {
  font-size: 0.88rem;
  color: var(--text-secondary);
  padding-top: 0.22rem;
}

/* Sub-header for command groups */
.cmd-section-title {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--accent, var(--cyan));
  margin: 1.5rem 0 0.6rem;
  padding-bottom: 0.3rem;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}

/* ── 11. Tables ───────────────────────────────────── */
.reward-table-wrap {
  overflow-x: auto;
  margin: 1.4rem 0;
  border-radius: var(--radius-md);
  border: 1px solid rgba(255,255,255,0.07);
}
table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.88rem;
}
thead {
  background: var(--section-gradient, linear-gradient(135deg, var(--cyan-dim), var(--violet-dim)));
}
thead th {
  padding: 0.75rem 1rem;
  text-align: left;
  font-family: var(--font-display);
  font-size: 0.75rem;
  letter-spacing: 0.1em;
  color: var(--text-primary);
  font-weight: 600;
  white-space: nowrap;
}
tbody tr {
  border-top: 1px solid rgba(255,255,255,0.04);
  transition: background var(--transition);
}
tbody tr:hover { background: rgba(255,255,255,0.03); }
tbody td {
  padding: 0.65rem 1rem;
  color: var(--text-secondary);
}
tbody td:first-child { color: var(--text-primary); font-weight: 600; }

/* ── 12. Tip / Warning Cards ──────────────────────── */
.tip-card, .warn-card, .info-card {
  display: flex;
  gap: 1rem;
  padding: 1rem 1.3rem;
  border-radius: var(--radius-md);
  margin: 1.4rem 0;
  font-size: 0.9rem;
  line-height: 1.6;
}
.tip-card {
  background: rgba(0,255,159,0.07);
  border-left: 3px solid var(--green);
  color: var(--text-secondary);
}
.warn-card {
  background: rgba(255,202,58,0.07);
  border-left: 3px solid var(--gold);
  color: var(--text-secondary);
}
.info-card {
  background: rgba(0,216,255,0.07);
  border-left: 3px solid var(--cyan);
  color: var(--text-secondary);
}
.tip-card .card-ico, .warn-card .card-ico, .info-card .card-ico {
  font-size: 1.2rem;
  flex-shrink: 0;
  margin-top: 0.1rem;
}
.tip-card strong, .warn-card strong, .info-card strong {
  color: var(--text-primary);
}

/* ── 13. Info Grid ─────────────────────────────────── */
.info-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 1.1rem;
  margin: 1.5rem 0;
}
.info-tile {
  background: var(--bg-card);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: var(--radius-md);
  padding: 1.2rem;
  backdrop-filter: blur(8px);
  transition: var(--transition);
}
.info-tile:hover {
  border-color: rgba(0,216,255,0.2);
  transform: translateY(-2px);
}
.info-tile-icon { font-size: 1.6rem; margin-bottom: 0.6rem; }
.info-tile-label {
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 0.3rem;
}
.info-tile-value {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 0.4rem;
}
.info-tile-desc {
  font-size: 0.82rem;
  color: var(--text-secondary);
  line-height: 1.55;
}

/* ── 14. VIP Rank Cards ───────────────────────────── */
.vip-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 1.1rem;
  margin: 1.8rem 0;
}
.vip-card {
  background: var(--bg-card);
  border: 1.5px solid;
  border-radius: var(--radius-lg);
  padding: 1.5rem 1.2rem;
  text-align: center;
  backdrop-filter: blur(10px);
  transition: var(--transition);
  position: relative;
  overflow: hidden;
}
.vip-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at top, var(--vip-glow, rgba(0,216,255,0.08)), transparent 70%);
  pointer-events: none;
}
.vip-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px var(--vip-shadow, rgba(0,216,255,0.2));
}
.vip-card--1 { --vip-glow: rgba(0,216,255,0.1);    --vip-shadow: rgba(0,216,255,0.2);    border-color: rgba(0,216,255,0.35);    }
.vip-card--2 { --vip-glow: rgba(0,255,159,0.1);    --vip-shadow: rgba(0,255,159,0.2);    border-color: rgba(0,255,159,0.35);    }
.vip-card--3 { --vip-glow: rgba(123,47,255,0.1);   --vip-shadow: rgba(123,47,255,0.2);   border-color: rgba(123,47,255,0.35);   }
.vip-card--4 { --vip-glow: rgba(255,202,58,0.1);   --vip-shadow: rgba(255,202,58,0.3);   border-color: rgba(255,202,58,0.45);   }

.vip-badge {
  display: inline-block;
  font-family: var(--font-display);
  font-size: 0.65rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 0.2rem 0.7rem;
  border-radius: 99px;
  margin-bottom: 0.6rem;
}
.vip-card--1 .vip-badge { background: var(--cyan-dim);    color: var(--cyan);    border: 1px solid rgba(0,216,255,0.3);  }
.vip-card--2 .vip-badge { background: var(--green-dim);   color: var(--green);   border: 1px solid rgba(0,255,159,0.3);  }
.vip-card--3 .vip-badge { background: var(--violet-dim);  color: #a87fff;        border: 1px solid rgba(123,47,255,0.3); }
.vip-card--4 .vip-badge { background: var(--gold-dim);    color: var(--gold);    border: 1px solid rgba(255,202,58,0.4); }

.vip-rank-name {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 900;
  margin-bottom: 0.6rem;
}
.vip-card--1 .vip-rank-name { color: var(--cyan);    text-shadow: 0 0 20px rgba(0,216,255,0.5);  }
.vip-card--2 .vip-rank-name { color: var(--green);   text-shadow: 0 0 20px rgba(0,255,159,0.5);  }
.vip-card--3 .vip-rank-name { color: #a87fff;        text-shadow: 0 0 20px rgba(123,47,255,0.5); }
.vip-card--4 .vip-rank-name { color: var(--gold);    text-shadow: 0 0 20px rgba(255,202,58,0.5); }

.vip-card-desc {
  font-size: 0.8rem;
  color: var(--text-secondary);
  line-height: 1.55;
}

/* ── 15. Image & Media Blocks ─────────────────────── */
.media-block {
  margin: 2rem 0;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(0,0,0,0.3);
}
.image-placeholder {
  min-height: 160px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  font-size: 0.82rem;
  flex-direction: column;
  gap: 0.4rem;
  padding: 1.5rem;
  background: rgba(0,0,0,0.15);
}

/* ── 16. FAQ Section ──────────────────────────────── */
.faq-list {
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
  margin-top: 1.5rem;
}
.faq-item {
  background: var(--bg-card);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: var(--transition);
  backdrop-filter: blur(8px);
}
.faq-item:hover {
  border-color: rgba(0,216,255,0.2);
}
.faq-question {
  padding: 1.1rem 1.4rem;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text-primary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  user-select: none;
}
.faq-question::after {
  content: '▾';
  color: var(--cyan);
  font-size: 0.8rem;
  transition: transform var(--transition);
  flex-shrink: 0;
}
.faq-item.open .faq-question::after {
  transform: rotate(180deg);
}
.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.35s cubic-bezier(0.4,0,0.2,1);
}
.faq-item.open .faq-answer {
  max-height: 300px;
}
.faq-answer-inner {
  padding: 0 1.4rem 1.2rem;
  font-size: 0.9rem;
  color: var(--text-secondary);
  line-height: 1.7;
  border-top: 1px solid rgba(255,255,255,0.05);
  padding-top: 0.9rem;
}

/* ── 17. Quote Block ──────────────────────────────── */
.quote-block {
  margin: 2.5rem 0;
  padding: 1.5rem 2rem;
  border-left: 3px solid var(--violet);
  background: rgba(123,47,255,0.06);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
}
.quote-block p {
  font-family: var(--font-display);
  font-size: 1.05rem;
  color: var(--text-primary);
  line-height: 1.6;
  font-style: italic;
  opacity: 0.9;
}

/* ── 18. Back to Top ──────────────────────────────── */
#back-to-top {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  width: 46px;
  height: 46px;
  background: rgba(0,0,0,0.7);
  border: 1.5px solid rgba(0,216,255,0.4);
  color: var(--cyan);
  border-radius: var(--radius-md);
  font-size: 1.1rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 150;
  opacity: 0;
  transform: translateY(20px);
  transition: var(--transition);
  backdrop-filter: blur(10px);
}
#back-to-top.visible {
  opacity: 1;
  transform: translateY(0);
}
#back-to-top:hover {
  background: var(--cyan-dim);
  border-color: var(--cyan);
  box-shadow: 0 0 20px rgba(0,216,255,0.3);
}

/* ── 19. Section Prose Utilities ──────────────────── */
.prose p { color: var(--text-secondary); margin-bottom: 0.9rem; }
.prose strong { color: var(--text-primary); }
.prose h3 {
  font-family: var(--font-display);
  font-size: 1.05rem;
  color: var(--text-primary);
  margin: 1.8rem 0 0.7rem;
}
.highlight { color: var(--accent, var(--cyan)); font-weight: 700; }
.divider {
  height: 1px;
  background: rgba(255,255,255,0.05);
  margin: 2rem 0;
}

/* ── 20. Keyframes & Animations ──────────────────── */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0);    }
}
@keyframes glow {
  0%, 100% { box-shadow: 0 0 8px var(--cyan); }
  50%       { box-shadow: 0 0 25px var(--cyan); }
}
@keyframes float {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-6px); }
}
@keyframes pulse-border {
  0%, 100% { border-color: rgba(0,216,255,0.2); }
  50%       { border-color: rgba(0,216,255,0.5); }
}

/* ── 21. Responsive ───────────────────────────────── */
@media (max-width: 1024px) {
  :root { --sidebar-width: 240px; }
}

@media (max-width: 768px) {
  .mobile-topbar { display: flex; }

  #content { margin-left: 0; padding-top: 58px; }

  #sidebar {
    transform: translateX(-100%);
    transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
    top: 0;
    z-index: 150;
  }
  #sidebar.open {
    transform: translateX(0);
    box-shadow: 10px 0 40px rgba(0,0,0,0.6);
  }

  #sidebar-overlay { display: block; }

  .section { padding: 3rem 1.3rem 3.5rem; }
  .hero    { padding: 3rem 1.3rem 3.5rem; }

  .hero-features { grid-template-columns: 1fr 1fr; }
  .vip-grid      { grid-template-columns: 1fr 1fr; }
  .info-grid     { grid-template-columns: 1fr; }

  #back-to-top { bottom: 1.2rem; right: 1.2rem; width: 40px; height: 40px; font-size: 1rem; }
}

@media (max-width: 480px) {
  .hero-features { grid-template-columns: 1fr; }
  .vip-grid      { grid-template-columns: 1fr; }
  .cmd-row       { flex-direction: column; }
}


/* HARD OVERRIDE: disabilita qualsiasi evidenziazione della sidebar, anche se un vecchio JS aggiunge classi. */
#sidebar .sidebar-nav a,
#sidebar .sidebar-nav a:hover,
#sidebar .sidebar-nav a:focus,
#sidebar .sidebar-nav a:focus-visible,
#sidebar .sidebar-nav a.active,
#sidebar .sidebar-nav a.current,
#sidebar .sidebar-nav a.selected,
#sidebar .sidebar-nav a[aria-current="true"],
#sidebar .sidebar-nav a[aria-current="page"] {
  background: transparent !important;
  border-left-color: transparent !important;
  box-shadow: none !important;
  outline: none !important;
}

/* ── Category Dividers ────────────────────────────── */
.category-divider {
  position: relative;
  z-index: 1;
  margin-left: 0;
  padding: 6.2rem 2.5rem 3rem;
  overflow: hidden;
}
/* Full-width category separator, same logic as the large section line above "Modalità di gioco".
   It spans the entire content area from the left edge of the page content to the right edge,
   not just the centered card width. */
.category-divider::before {
  content: '';
  position: absolute;
  top: 3rem;
  left: 0;
  right: 0;
  height: 4px;
  border-radius: 999px;
  background: var(--divider-gradient, linear-gradient(90deg, var(--cyan), var(--violet)));
  box-shadow: 0 0 22px var(--divider-glow, rgba(0,216,255,0.32));
  opacity: 0.95;
}
.category-divider-line {
  display: none;
}
.category-divider-content {
  width: min(820px, 100%);
  margin: 0 auto;
  padding: 1.25rem 1.35rem;
  border: 1px solid var(--divider-border, rgba(0,216,255,0.28));
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, rgba(5, 10, 28, 0.82), rgba(12, 18, 45, 0.58));
  box-shadow: 0 18px 70px rgba(0,0,0,0.28), inset 0 0 40px var(--divider-soft, rgba(0,216,255,0.035));
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
.category-divider-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  margin-right: 0.65rem;
  border-radius: 12px;
  background: var(--divider-soft, rgba(0,216,255,0.12));
  box-shadow: 0 0 22px var(--divider-glow, rgba(0,216,255,0.28));
  vertical-align: middle;
}
.category-divider-kicker {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 0.67rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--divider-accent, var(--cyan));
}
.category-divider h2 {
  margin: 0.65rem 0 0.35rem;
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3.8rem);
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--divider-accent, var(--cyan));
  text-shadow: 0 0 28px var(--divider-glow, rgba(0,216,255,0.28));
}
.category-divider p {
  max-width: 720px;
  color: var(--text-secondary);
  font-size: 1.02rem;
}
.category-divider--mythic {
  --divider-gradient: linear-gradient(90deg, #7b2fff, #00d8ff, #e82dcd);
  --divider-accent: #b78cff;
  --divider-border: rgba(123,47,255,0.4);
  --divider-glow: rgba(123,47,255,0.35);
  --divider-soft: rgba(123,47,255,0.11);
}
.category-divider--vip {
  --divider-gradient: linear-gradient(90deg, #ffca3a, #ff8c00, #e82dcd);
  --divider-accent: #ffca3a;
  --divider-border: rgba(255,202,58,0.36);
  --divider-glow: rgba(255,202,58,0.34);
  --divider-soft: rgba(255,202,58,0.10);
}
.category-divider--progress {
  --divider-gradient: linear-gradient(90deg, #00ff9f, #ffca3a, #00d8ff);
  --divider-accent: #00ff9f;
  --divider-border: rgba(0,255,159,0.32);
  --divider-glow: rgba(0,255,159,0.30);
  --divider-soft: rgba(0,255,159,0.09);
}
.category-divider--features {
  --divider-gradient: linear-gradient(90deg, #00d8ff, #3a8fff, #7b2fff);
  --divider-accent: #00d8ff;
  --divider-border: rgba(0,216,255,0.32);
  --divider-glow: rgba(0,216,255,0.30);
  --divider-soft: rgba(0,216,255,0.09);
}
.category-divider--support {
  --divider-gradient: linear-gradient(90deg, #e82dcd, #7b2fff, #ffca3a);
  --divider-accent: #e82dcd;
  --divider-border: rgba(232,45,205,0.34);
  --divider-glow: rgba(232,45,205,0.32);
  --divider-soft: rgba(232,45,205,0.09);
}

@media (max-width: 768px) {
  .category-divider {
    margin-left: 0;
    padding: 5rem 1.25rem 2rem;
  }
  .category-divider::before {
    top: 2.65rem;
  }
  .category-divider-content {
    padding: 1rem;
  }
}
