/* theme.css — XPLog Classic Dark (Public)
   - Owns PUBLIC styling only (Option A split)
   - Uses Tailwind CDN in markup, so we provide bridge classes like bg-panel, border-border, text-main
*/

/* =========================
   Theme Variables
========================= */
:root{
  --bg-color:#0f1115;
  --panel-bg:#151a22;
  --panel-bg-2:#10151c;

  --text-main:#e7eaf0;
  --text-muted:#a8b0bf;
  --heading:#ffffff;

  --accent:#4ea1ff;
  --accent-2:#2f7fe0;
  --secondary:#38bdf8;

  --border-color:rgba(255,255,255,.10);
  --shadow:0 8px 24px rgba(0,0,0,.35);

  --font-heading:system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  --font-body:system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;

  --radius:14px;
  --radius-sm:10px;
  --header-height:80px;
}

/* =========================
   Base
========================= */
html,body{ height:100%; }
html{ overflow-y: scroll; }

body{
  margin:0;
  font-family:var(--font-body);
  background:var(--bg-color);
  color:var(--text-main);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

a{ color:var(--accent); text-decoration:none; }
a:hover{ text-decoration:underline; }

::selection{ background-color: var(--accent); color: var(--bg-color); }

h1,h2,h3,h4,h5,h6{
  font-family:var(--font-heading);
  color:var(--heading);
  margin:0 0 .6rem;
  line-height:1.2;
  letter-spacing:.2px;
}

/* =========================
   Tailwind-bridge classes
   (your header.php uses these)
========================= */
.theme-body{
  background:
    radial-gradient(1200px 600px at 20% -10%, rgba(78,161,255,0.10), transparent 60%),
    radial-gradient(900px 500px at 80% 0%, rgba(56,189,248,0.08), transparent 55%),
    var(--bg-color);
  color:var(--text-main);
}

.bg-panel{ background-color: var(--panel-bg) !important; }
.bg-bg{ background-color: var(--bg-color) !important; }
.text-main{ color: var(--text-main) !important; }
.text-muted{ color: var(--text-muted) !important; }
.text-accent{ color: var(--accent) !important; }
.bg-accent{ background-color: var(--accent) !important; }
.border-border{ border-color: var(--border-color) !important; }
.placeholder-muted::placeholder{ color: var(--text-muted) !important; opacity:.75; }

/* Tailwind escape helper used in markup: hover:text-accent */
.hover\:text-accent:hover{ color: var(--accent) !important; }

/* Ensure your public container class doesn’t fight Tailwind spacing */
.public-container{ width:100%; }

/* =========================
   Header + Nav
========================= */
header.relative.sticky{
  backdrop-filter: saturate(140%) blur(10px);
  -webkit-backdrop-filter: saturate(140%) blur(10px);
  background: rgba(21,26,34,.85);
  border-bottom: 1px solid var(--border-color);
}

header .max-w-7xl{ position: relative; }

#mobileMenuButton{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:44px;
  height:44px;
  border-radius:12px;
}

/* Dropdowns (desktop only) */
.dropdown{ position:relative; display:none; }
@media (min-width: 1024px){ .dropdown{ display:inline-block; } }

.dropdown-content{
  display:none;
  position:absolute;
  background-color: var(--panel-bg);
  min-width: 180px;
  box-shadow: 0 12px 30px rgba(0,0,0,0.45);
  z-index: 50;
  border-radius: 12px;
  border: 1px solid var(--border-color);
  overflow: hidden;
}

.dropdown:hover .dropdown-content{ display:block; }

.dropdown-content a{
  color: var(--text-main);
  padding: 12px 14px;
  display:block;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.dropdown-content a:last-child{ border-bottom:none; }
.dropdown-content a:hover{
  background: rgba(255,255,255,0.06);
  font-weight: 700;
  text-decoration:none;
}

.dropdown .drop-btn{
  background: transparent;
  color: var(--text-main);
  padding: .5rem .85rem;
  cursor: pointer;
  border: 1px solid transparent;
}

/* =========================
   Mobile Menu (authoritative)
========================= */
.mobile-menu{
  position:absolute;
  top:100%;
  left:0;
  right:0;
  width:100%;
  z-index:40;

  background: var(--panel-bg);
  border-bottom: 1px solid var(--border-color);
  box-shadow: 0 16px 40px rgba(0,0,0,0.35);

  display:none;
  opacity:0;
  transform: translateY(-8px);
  pointer-events:none;
  transition: opacity .2s ease, transform .2s ease;

  max-height: calc(100vh - 80px);
  overflow-y:auto;
  -webkit-overflow-scrolling: touch;
}

.mobile-menu.is-open{
  display:block !important;
  opacity:1;
  transform: translateY(0);
  pointer-events:auto;
}

.mobile-menu form{
  padding:14px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}

.mobile-menu input[type="search"]{
  width:100%;
  background: rgba(255,255,255,.03);
  color: var(--text-main);
  border: 1px solid var(--border-color);
  border-radius: 12px;
  padding: 12px 14px;
  outline:none;
}
.mobile-menu input[type="search"]:focus{
  border-color: rgba(78,161,255,.55);
  box-shadow:0 0 0 3px rgba(78,161,255,.18);
}

.mobile-menu a{
  display:block;
  padding: 14px 18px;
  color: var(--text-main);
  border-bottom: 1px solid rgba(255,255,255,.06);
  font-weight: 700;
  text-decoration:none;
}
.mobile-menu a:hover{
  background: rgba(255,255,255,0.06);
}

/* Desktop nav spacing safety */
@media (min-width: 1024px){
  header nav.hidden.lg\:flex{ gap: 1rem; }
  header nav form input[type="search"]{ width: 12rem; }
  header nav form input[type="search"]:focus{ width: 16rem; }
}

/* =========================
   Page layout grid (non-home)
========================= */
.page-wrapper-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  grid-template-areas: "main" "sidebar";
}
.page-main-content{ grid-area: main; }
.page-sidebar{ grid-area: sidebar; }
@media (min-width:1024px){
  .page-wrapper-grid{
    grid-template-areas:"main sidebar";
    grid-template-columns: 2fr 1fr;
  }
}

/* =========================
   Cards / Lists (public)
========================= */
.card, .panel, .box,
.game-card, .news-card, .event-card, .post-card{
  background: var(--panel-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow:hidden;
  color: var(--text-main);
}

.game-card, .news-card, .post-card{
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.game-card:hover, .news-card:hover, .post-card:hover{
  transform: translateY(-3px);
  box-shadow: 0 16px 40px rgba(0,0,0,.45);
  border-color: rgba(255,255,255,.16);
}

.info-tag, .event-badge, .chip, .badge, .tag{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  padding:.25rem .55rem;
  border-radius:999px;
  border:1px solid var(--border-color);
  background: rgba(255,255,255,.04);
  color: var(--text-muted);
  font-weight:700;
  font-size:.75rem;
}

/* Pagination */
.pagination-container{ display:flex; justify-content:center; margin:40px 0; width:100%; }
.pagination{ display:flex; flex-wrap:wrap; gap:6px; justify-content:center; align-items:center; }
.page-btn{
  background: rgba(255,255,255,.04);
  color: var(--text-main);
  border: 1px solid rgba(255,255,255,.08);
  padding: 8px 14px;
  border-radius: 12px;
  text-decoration:none;
  font-size: 14px;
  font-weight: 650;
  transition: background-color .15s ease, border-color .15s ease;
}
.page-btn:hover{
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.14);
  text-decoration:none;
}
.page-btn.active{
  background: var(--accent);
  color: #08111f;
  font-weight: 800;
  pointer-events:none;
  border-color: rgba(255,255,255,.10);
}
.dots{ color: var(--text-muted); font-size:15px; padding:6px 10px; letter-spacing:2px; }

/* Footer */
footer, .footer, .site-footer{
  border-top:1px solid var(--border-color);
  color:var(--text-muted);
  padding:1.25rem 0;
}

/* Kill-switch for leftover neon classes */
.pulse,.boot-animation,.glow,.neon,.flicker{
  animation:none !important;
  box-shadow:none !important;
  text-shadow:none !important;
  filter:none !important;
  transform:none !important;
}