/**
 * H4CK3R — assets/css/fixes.css
 * Layout fixes: nav, logo, post listing grid, sidebar, pagination, cards
 */

/* ══════════════════════════════════════════════════════════════
 * 1. NAV — Force correct height and clip oversized content
 * ══════════════════════════════════════════════════════════════*/
.cs-nav {
  overflow: visible !important; /* allow dropdown to show */
  height: var(--nav-height) !important;
}

.cs-nav .cs-container {
  height: 100%;
}

.cs-nav__inner {
  height: var(--nav-height) !important;
  overflow: visible !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
}

/* ══════════════════════════════════════════════════════════════
 * 2. LOGO — Hard cap the size no matter what WordPress outputs
 * ══════════════════════════════════════════════════════════════*/
.cs-nav__logo {
  flex-shrink: 0 !important;
  height: var(--nav-height) !important;
  max-height: calc(var(--nav-height) - 8px) !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: center !important;
  max-width: 220px !important;
}

/* Target every possible WordPress logo wrapper */
.cs-nav__logo a,
.cs-nav__logo .custom-logo-link {
  display: flex !important;
  align-items: center !important;
  height: 44px !important;
  max-height: 44px !important;
  overflow: hidden !important;
}

.cs-nav__logo img,
.cs-nav__logo .custom-logo,
.cs-nav__logo .custom-logo-link img,
.cs-nav__logo figure img,
.cs-nav__logo .wp-post-image {
  height: 44px !important;
  width: auto !important;
  max-height: 44px !important;
  max-width: 180px !important;
  min-height: unset !important;
  min-width: unset !important;
  object-fit: contain !important;
  display: block !important;
}

/* If WordPress wraps in a figure */
.cs-nav__logo figure {
  margin: 0 !important;
  padding: 0 !important;
  height: 44px !important;
  max-height: 44px !important;
  overflow: hidden !important;
}

/* ══════════════════════════════════════════════════════════════
 * 3. NAV MENU — Proper horizontal layout
 * ══════════════════════════════════════════════════════════════*/
.cs-nav__menu-wrap {
  display: flex !important;
  align-items: center !important;
  flex: 1 1 auto !important;
  justify-content: center !important;
  height: 100% !important;
  overflow: visible !important;
}

/* WordPress wraps menu in a div — strip it */
.cs-nav__menu-wrap > div,
.cs-nav__menu-wrap > nav {
  display: flex !important;
  align-items: center !important;
  height: 100% !important;
}

/* The actual <ul> menu */
.cs-nav__menu {
  display: flex !important;
  align-items: center !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  gap: 4px !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  height: 100% !important;
}

.cs-nav__menu > li {
  position: relative !important;
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
}

.cs-nav__menu > li > a {
  display: flex !important;
  align-items: center !important;
  padding: 8px 12px !important;
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  color: var(--color-text-secondary) !important;
  white-space: nowrap !important;
  border-radius: 6px !important;
  transition: color 0.15s ease, background 0.15s ease !important;
  text-decoration: none !important;
}

.cs-nav__menu > li > a:hover,
.cs-nav__menu > li.current-menu-item > a,
.cs-nav__menu > li.current-page-ancestor > a {
  color: var(--color-text-primary) !important;
  background: var(--color-surface-2) !important;
}

/* ══════════════════════════════════════════════════════════════
 * 4. DROPDOWN — Only show on hover, hide by default
 * ══════════════════════════════════════════════════════════════*/

/* Default hidden state for all sub-menus */
.cs-nav__menu > li > .sub-menu,
.cs-nav__menu > li > ul {
  position: absolute !important;
  top: calc(100% + 4px) !important;
  left: 50% !important;
  transform: translateX(-50%) translateY(-8px) !important;
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 10px !important;
  box-shadow: 0 10px 40px rgba(0,0,0,0.3) !important;
  padding: 8px !important;
  min-width: 200px !important;
  opacity: 0 !important;
  pointer-events: none !important;
  visibility: hidden !important;
  transition: opacity 0.15s ease, transform 0.15s ease, visibility 0.15s ease !important;
  list-style: none !important;
  z-index: 200 !important;
}

/* Show on hover */
.cs-nav__menu > li:hover > .sub-menu,
.cs-nav__menu > li:hover > ul,
.cs-nav__menu > li:focus-within > .sub-menu,
.cs-nav__menu > li:focus-within > ul {
  opacity: 1 !important;
  pointer-events: all !important;
  visibility: visible !important;
  transform: translateX(-50%) translateY(0) !important;
}

/* Sub-menu link styles */
.cs-nav__menu .sub-menu li,
.cs-nav__menu ul li {
  list-style: none !important;
  margin: 0 !important;
}

.cs-nav__menu .sub-menu li a,
.cs-nav__menu ul li a {
  display: block !important;
  padding: 8px 12px !important;
  font-size: 0.875rem !important;
  color: var(--color-text-secondary) !important;
  border-radius: 6px !important;
  text-decoration: none !important;
  transition: all 0.15s ease !important;
  white-space: nowrap !important;
}

.cs-nav__menu .sub-menu li a:hover,
.cs-nav__menu ul li a:hover {
  color: var(--color-accent) !important;
  background: var(--color-surface-2) !important;
  padding-left: 16px !important;
}

/* ══════════════════════════════════════════════════════════════
 * 5. NAV ACTIONS — Right side (search, toggle, hamburger)
 * ══════════════════════════════════════════════════════════════*/
.cs-nav__actions {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  flex-shrink: 0 !important;
  height: 100% !important;
}

/* ══════════════════════════════════════════════════════════════
 * 6. BODY OFFSET — Account for fixed nav + WordPress admin bar
 * ══════════════════════════════════════════════════════════════*/
html,
body {
  max-width: 100% !important;
  overflow-x: clip !important;
}

body {
  padding-top: var(--nav-height) !important;
}

/* When WordPress admin bar is visible (logged in users) */
.admin-bar .cs-nav {
  top: 32px !important; /* WP admin bar = 32px */
}

.admin-bar body,
.admin-bar .cs-nav ~ * {
  /* nothing — body padding already handles it */
}

/* WP admin bar on mobile is 46px */
@media screen and (max-width: 782px) {
  .admin-bar .cs-nav {
    top: 46px !important;
  }
}

@media screen and (max-width: 600px) {
  .admin-bar .cs-nav {
    top: 0 !important;
  }
}

/* ── Fixed News Ticker Offsets & Sibling Pushes ─────────────── */
.cs-ticker {
  position: fixed !important;
  top: var(--nav-height) !important;
  left: 0 !important;
  right: 0 !important;
  z-index: 290 !important;
  margin: 0 !important;
}

.admin-bar .cs-ticker {
  top: calc(var(--nav-height) + 32px) !important;
}

@media screen and (max-width: 782px) {
  .admin-bar .cs-ticker {
    top: calc(var(--nav-height) + 46px) !important;
  }
}

@media screen and (max-width: 600px) {
  .admin-bar .cs-ticker {
    top: var(--nav-height) !important;
  }
}

/* Push content down when news ticker is present in flow */
body:has(.cs-ticker) #cs-main {
  padding-top: 44px !important;
}

body:has(.cs-ticker) #cs-main > .cs-container:first-child {
  margin-top: 2rem !important;
}

body:has(.cs-ticker) #cs-main > .cs-hero:first-child {
  margin-top: 0 !important;
}

body:has(.cs-ticker) .cs-forum-header {
  top: calc(var(--nav-height) + 44px) !important;
}

body:has(.cs-ticker).admin-bar .cs-forum-header {
  top: calc(var(--nav-height) + 44px + 32px) !important;
}

@media screen and (max-width: 782px) {
  body:has(.cs-ticker).admin-bar .cs-forum-header {
    top: calc(var(--nav-height) + 44px + 46px) !important;
  }
}

@media screen and (max-width: 600px) {
  body:has(.cs-ticker).admin-bar .cs-forum-header {
    top: calc(var(--nav-height) + 44px) !important;
  }
}

body:has(.cs-ticker) .cs-forum-header + .cs-forum-layout,
body:has(.cs-ticker) .cs-forum-header + .cs-forum-search-layout {
  margin-top: var(--forum-header-height) !important;
}

/* Adjust sticky sidebars when news ticker is present */
body:has(.cs-ticker) .cs-sidebar,
body:has(.cs-ticker) #cs-roadmap-sidebar {
  top: calc(var(--nav-height) + 44px + 1.5rem) !important;
  max-height: calc(100vh - var(--nav-height) - 44px - 3rem) !important;
}

body:has(.cs-ticker) .cs-forum-sidebar {
  top: calc(var(--nav-height) + 44px + 80px) !important;
}

/* ── below_header Ad Slot Styling ───────────────────────────── */
.cs-ad-wrap--below-header {
  max-width: calc(var(--container-width) - 2 * var(--space-6)) !important;
  width: calc(100% - 2 * var(--space-6)) !important;
  margin: 1.5rem auto !important;
}

/* Push the ad down so it starts below the fixed navigation and ticker */
#cs-main > .cs-ad-wrap--below-header:first-child {
  margin-top: 1.5rem !important;
}

body:has(.cs-ticker) #cs-main > .cs-ad-wrap--below-header:first-child {
  margin-top: 1.5rem !important;
}

body:has(.cs-forum-header) #cs-main > .cs-ad-wrap--below-header:first-child {
  margin-top: calc(var(--forum-header-height) + 1.5rem) !important;
}

body:has(.cs-ticker):has(.cs-forum-header) #cs-main > .cs-ad-wrap--below-header:first-child {
  margin-top: calc(var(--forum-header-height) + 1.5rem) !important;
}

/* Sibling overrides when the below_header ad is active */
#cs-main > .cs-ad-wrap--below-header + .cs-container {
  margin-top: 1.5rem !important;
}

#cs-main > .cs-ad-wrap--below-header + .cs-hero {
  margin-top: 0 !important;
}

#cs-main > .cs-ad-wrap--below-header + .cs-forum-wrap .cs-forum-layout {
  padding-top: 1.5rem !important;
}

/* ── Contest, Profile & Container Layout Offsets (Ad/Ticker States) ── */

/* 1. Standard Page Containers */
#cs-main > .cs-container:first-child {
  margin-top: 2rem !important;
}

/* 2. Forum wrap without forum header (e.g. contests single & list) */
#cs-main > .cs-forum-wrap:first-child:not(:has(.cs-forum-header)) {
  margin-top: 2rem !important;
}
body:has(.cs-ticker) #cs-main > .cs-forum-wrap:first-child:not(:has(.cs-forum-header)) {
  margin-top: 2rem !important;
}
#cs-main > .cs-ad-wrap--below-header + .cs-forum-wrap .cs-contest-wrap {
  padding-top: 1.5rem !important;
}

/* 3. Contest Archive wrap */
#cs-main > .cs-contest-archive-wrap:first-child {
  margin-top: 2rem !important;
}
body:has(.cs-ticker) #cs-main > .cs-contest-archive-wrap:first-child {
  margin-top: 2rem !important;
}
#cs-main > .cs-ad-wrap--below-header + .cs-contest-archive-wrap {
  margin-top: 1.5rem !important;
}

/* 4. Author Profile Page */
body:has(.cs-ticker) .cs-profile-page {
  padding-top: calc(var(--nav-height) + 2rem) !important;
}
#cs-main > .cs-ad-wrap--below-header + .cs-profile-page {
  padding-top: 2rem !important;
}

:root {
  --forum-header-height: 56px;
}

/* Push content down when forum header is present in flow */
.cs-forum-header + .cs-forum-layout,
.cs-forum-header + .cs-forum-search-layout {
  margin-top: var(--forum-header-height) !important;
}

/* ══════════════════════════════════════════════════════════════
 * 7. MOBILE — Hide desktop menu, show hamburger
 * ══════════════════════════════════════════════════════════════*/
@media (max-width: 768px) {
  .cs-nav__menu-wrap {
    display: none !important;
  }

  .cs-nav__hamburger {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    gap: 5px !important;
    width: 36px !important;
    height: 36px !important;
    background: none !important;
    border: none !important;
    cursor: pointer !important;
    padding: 6px !important;
  }

  .cs-nav__hamburger span {
    display: block !important;
    width: 100% !important;
    height: 2px !important;
    background: var(--color-text-primary) !important;
    border-radius: 2px !important;
  }

  /* Mobile menu drawer */
  .cs-nav__mobile-menu {
    display: block !important;
    position: fixed !important;
    top: var(--nav-height) !important; /* default without admin bar */
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: var(--color-surface) !important;
    z-index: 300 !important;
    overflow-y: auto !important;
    padding: 24px !important;
    transform: translateX(-100%) !important;
    transition: transform 0.4s ease !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }

  .admin-bar .cs-nav__mobile-menu {
    top: calc(var(--nav-height) + 46px) !important; /* admin bar is always 46px below 768px */
  }

  .cs-nav__mobile-menu.open {
    transform: translateX(0) !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }

  .cs-nav__mobile-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  .cs-nav__mobile-list li a {
    display: block !important;
    padding: 14px 8px !important;
    font-size: 1.125rem !important;
    font-weight: 600 !important;
    color: var(--color-text-primary) !important;
    border-bottom: 1px solid var(--color-border) !important;
    text-decoration: none !important;
  }

  .cs-nav__mobile-list li a:hover {
    color: var(--color-accent) !important;
  }

  .cs-nav__mobile-list .sub-menu {
    list-style: none !important;
    padding-left: 16px !important;
    margin: 0 !important;
  }

  .cs-nav__mobile-list .sub-menu li a {
    font-size: 1rem !important;
    padding: 10px 8px !important;
    color: var(--color-text-secondary) !important;
  }

  /* Theme toggle mobile alignment and size fixes */
  .cs-theme-toggle {
    width: 36px !important;
    height: 36px !important;
  }

  html.has-mobile-menu-open,
  html.has-mobile-menu-open body {
    overflow: hidden !important;
    height: 100% !important;
  }
}

@media (max-width: 768px) {
  .cs-nav__logo .cs-nav__logo-mark {
    display: none !important;
  }
  .cs-nav__logo .cs-nav__logo-text {
    display: block !important;
    margin-left: 0 !important;
    font-size: 1.15rem !important;
    font-weight: 800 !important;
    letter-spacing: -0.02em !important;
  }
  .cs-nav__logo img,
  .cs-nav__logo .custom-logo,
  .cs-nav__logo .custom-logo-link img {
    height: 32px !important;
    max-height: 32px !important;
    max-width: 140px !important;
  }
}

/* ══════════════════════════════════════════════════════════════
 * 8. PROFILE AVATAR DROPDOWN
 * ══════════════════════════════════════════════════════════════*/

/* Wrapper — positions the dropdown relative to avatar */
.cs-nav__profile {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
}

/* Avatar button */
.cs-nav__avatar-btn {
  position: relative !important;
  background: none !important;
  border: none !important;
  cursor: pointer !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  border-radius: 50% !important;
  outline: none !important;
  transition: transform 0.15s ease !important;
}

.cs-nav__avatar-btn:hover { transform: scale(1.06) !important; }
.cs-nav__avatar-btn:focus-visible {
  box-shadow: 0 0 0 3px var(--color-accent) !important;
  border-radius: 50% !important;
}

/* Avatar image */
.cs-nav__avatar {
  width: 36px !important;
  height: 36px !important;
  border-radius: 50% !important;
  border: 2px solid var(--color-accent) !important;
  object-fit: cover !important;
  display: block !important;
}

/* Notification dot on avatar */
.cs-nav__notif-dot {
  position: absolute !important;
  top: -3px !important;
  right: -3px !important;
  background: #ff4757 !important;
  color: #fff !important;
  font-size: 9px !important;
  font-weight: 800 !important;
  width: 18px !important;
  height: 18px !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: 2px solid var(--color-surface) !important;
  line-height: 1 !important;
}

/* Dropdown Panel */
.cs-nav__profile-dropdown {
  position: absolute !important;
  top: calc(100% + 10px) !important;
  right: 0 !important;
  width: 240px !important;
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 14px !important;
  box-shadow: 0 16px 48px rgba(0,0,0,.45) !important;
  padding: 8px !important;
  z-index: 500 !important;
  opacity: 0 !important;
  transform: translateY(-8px) !important;
  transition: opacity .2s ease, transform .2s ease !important;
  pointer-events: none !important;
}

.cs-nav__profile-dropdown:not([hidden]) {
  opacity: 1 !important;
  transform: translateY(0) !important;
  pointer-events: all !important;
}

/* Profile head (avatar + name + stats) */
.cs-profile-drop__head {
  display: flex !important;
  align-items: center !important;
  gap: .75rem !important;
  padding: .625rem .5rem .75rem !important;
}

.cs-profile-drop__avatar {
  width: 44px !important;
  height: 44px !important;
  border-radius: 50% !important;
  border: 2px solid var(--color-accent) !important;
  object-fit: cover !important;
  flex-shrink: 0 !important;
}

.cs-profile-drop__name {
  font-weight: 700 !important;
  color: var(--color-text-primary) !important;
  font-size: .9375rem !important;
  line-height: 1.2 !important;
  max-width: 140px !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.cs-profile-drop__stats {
  display: flex !important;
  gap: .625rem !important;
  margin-top: .2rem !important;
  font-size: .75rem !important;
  color: var(--color-text-muted) !important;
}

/* Divider */
.cs-profile-drop__divider {
  height: 1px !important;
  background: var(--color-border) !important;
  margin: 4px 0 !important;
}

/* Menu items */
.cs-profile-drop__item {
  display: flex !important;
  align-items: center !important;
  gap: .625rem !important;
  padding: .625rem .75rem !important;
  border-radius: 8px !important;
  color: var(--color-text-secondary) !important;
  text-decoration: none !important;
  font-size: .875rem !important;
  transition: background .12s ease, color .12s ease !important;
  cursor: pointer !important;
}

.cs-profile-drop__item:hover {
  background: var(--color-surface-2) !important;
  color: var(--color-text-primary) !important;
}

.cs-profile-drop__icon {
  font-size: 1rem !important;
  flex-shrink: 0 !important;
  width: 20px !important;
  text-align: center !important;
}

/* Notification item */
.cs-profile-drop__item--notif {
  justify-content: flex-start !important;
}

.cs-profile-drop__badge {
  margin-left: auto !important;
  background: #ff4757 !important;
  color: #fff !important;
  font-size: .7rem !important;
  font-weight: 800 !important;
  padding: 1px 6px !important;
  border-radius: 100px !important;
}

/* Danger (logout) */
.cs-profile-drop__item--danger { color: #ff4757 !important; }
.cs-profile-drop__item--danger:hover { background: rgba(255,71,87,.08) !important; color: #ff4757 !important; }

/* ══════════════════════════════════════════════════════════════
 * 9. AUTH BUTTONS (Guest: Login / Register)
 * ══════════════════════════════════════════════════════════════*/
.cs-nav__auth-btn {
  display: inline-flex !important;
  align-items: center !important;
  padding: .45rem .875rem !important;
  border-radius: 7px !important;
  font-size: .875rem !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  transition: all .15s ease !important;
  white-space: nowrap !important;
}

.cs-nav__auth-btn--login {
  color: var(--color-text-secondary) !important;
  border: 1px solid var(--color-border) !important;
}
.cs-nav__auth-btn--login:hover {
  border-color: var(--color-accent) !important;
  color: var(--color-accent) !important;
}

.cs-nav__auth-btn--register {
  background: linear-gradient(135deg, var(--color-accent), #00cc7a) !important;
  color: #0a0e1a !important;
}
.cs-nav__auth-btn--register:hover { filter: brightness(1.1) !important; }

/* Hide auth text buttons on mobile (they appear in drawer) */
@media (max-width: 768px) {
  .cs-nav__auth-btn { display: none !important; }
}

/* ══════════════════════════════════════════════════════════════
 * 10. POST LISTING PAGE — Layout, Grid, Cards, Sidebar
 * ══════════════════════════════════════════════════════════════*/

/* ── Two-column layout (main + sidebar) ──────────────────────*/
.cs-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) var(--sidebar-width) !important; /* minmax(0) prevents blowout */
  gap: 2rem !important;
  align-items: start !important;
  width: 100% !important;
}

.cs-main {
  min-width: 0 !important;
  width: 100% !important;
}

.cs-sidebar {
  min-width: 0 !important;
  width: var(--sidebar-width) !important;
  position: sticky !important;
  top: calc(var(--nav-height) + 1.5rem) !important;
  max-height: calc(100vh - var(--nav-height) - 3rem) !important;
  overflow-y: auto !important;
  scrollbar-width: none !important;
  -ms-overflow-style: none !important;
}

.cs-sidebar::-webkit-scrollbar {
  display: none !important;
}

/* ── Archive header ──────────────────────────────────────────*/
.cs-archive-header {
  margin-bottom: 2rem !important;
  padding-bottom: 1.5rem !important;
  border-bottom: 1px solid var(--color-border) !important;
}

.cs-archive-title {
  font-size: clamp(1.5rem, 3vw, 2.25rem) !important;
  font-weight: 900 !important;
  color: var(--color-text-primary) !important;
  margin: 0 !important;
  line-height: 1.2 !important;
}

/* ── Post Card Grid ──────────────────────────────────────────*/
.cs-grid {
  display: grid !important;
  gap: 1.25rem !important;
  width: 100% !important;
}

/* 3-column grid by default; collapses to 1 column below 640px. */
.cs-grid--3 {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

.cs-layout .cs-grid--3,
.cs-layout .cs-grid--2 {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

.cs-grid--2 {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

.cs-grid--4 {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

/* ── Post Card ───────────────────────────────────────────────*/
.cs-card {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease !important;
  height: 100% !important;
  min-width: 0 !important; /* ← prevents blowout inside grid */
  word-break: normal !important;
  overflow-wrap: break-word !important;
}

.cs-card:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 12px 36px rgba(0,0,0,.3) !important;
  border-color: rgba(0,255,157,.2) !important;
}

/* Thumbnail — MUST override global img { height: auto } reset */
.cs-card__thumbnail {
  position: relative !important;
  overflow: hidden !important;
  width: 100% !important;
  aspect-ratio: 16 / 9 !important;
  background: linear-gradient(135deg, #0d1b2e 0%, #162740 100%) !important;
  flex-shrink: 0 !important;
  display: block !important;
}

/* Override critical.css global reset: img { max-width:100%; height:auto } */
.cs-card__thumbnail img,
.cs-card__img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;       /* ← THE KEY FIX: override height:auto */
  max-width: none !important;    /* ← override max-width:100% */
  object-fit: cover !important;
  display: block !important;
  transition: transform .4s ease !important;
}

.cs-card:hover .cs-card__thumbnail img,
.cs-card:hover .cs-card__img {
  transform: scale(1.05) !important;
}

/* Category badge on thumbnail */
.cs-card__badge {
  position: absolute !important;
  top: .625rem !important;
  left: .625rem !important;
  z-index: 2 !important;
}

/* Card body */
.cs-card__body {
  padding: 1rem !important;
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  min-width: 0 !important;
}

/* Title — clamp to 2 lines, no word-by-word break */
.cs-card__title {
  font-size: .9375rem !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
  color: var(--color-text-primary) !important;
  margin: 0 0 .5rem !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  word-break: normal !important;
  overflow-wrap: anywhere !important;
}

.cs-card__title a {
  color: inherit !important;
  text-decoration: none !important;
  transition: color .15s ease !important;
}

.cs-card:hover .cs-card__title a {
  color: var(--color-accent) !important;
}

/* Excerpt — clamp to 3 lines */
.cs-card__excerpt {
  font-size: .8125rem !important;
  color: var(--color-text-secondary) !important;
  line-height: 1.55 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 3 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  flex: 1 !important;
  margin-bottom: .875rem !important;
  word-break: normal !important;
  overflow-wrap: anywhere !important;
}

/* Footer: meta + read more */
.cs-card__footer {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding-top: .75rem !important;
  border-top: 1px solid var(--color-border) !important;
  margin-top: auto !important;
  gap: .375rem !important;
  flex-wrap: wrap !important;
}

/* Meta (author · date) */
.cs-meta {
  display: flex !important;
  align-items: center !important;
  gap: .25rem !important;
  font-size: .75rem !important;
  color: var(--color-text-muted) !important;
  min-width: 0 !important;
  flex-wrap: wrap !important;
}

.cs-meta span:first-child {
  max-width: 120px !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.cs-meta__sep { opacity: .4 !important; }

.cs-meta time { white-space: nowrap !important; font-size: .75rem !important; }

/* Read more */
.cs-card__read-more {
  font-size: .8125rem !important;
  font-weight: 700 !important;
  color: var(--color-accent) !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: .2rem !important;
  transition: gap .15s ease !important;
  flex-shrink: 0 !important;
}

.cs-card:hover .cs-card__read-more { gap: .4rem !important; }

/* ── Category badges ─────────────────────────────────────────*/
.cs-badge {
  display: inline-flex !important;
  align-items: center !important;
  padding: .2rem .55rem !important;
  border-radius: 100px !important;
  font-size: .6875rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .03em !important;
  text-decoration: none !important;
  white-space: nowrap !important;
}

.cs-badge--accent  { background: rgba(0,255,157,.12);  color: #00cc7a; }
.cs-badge--blue    { background: rgba(26,115,232,.12); color: #4d9fff; }
.cs-badge--red     { background: rgba(255,71,87,.12);  color: #ff6b7a; }
.cs-badge--orange  { background: rgba(255,163,71,.12); color: #ffb347; }
.cs-badge--purple  { background: rgba(167,119,255,.12);color: #b388ff; }
.cs-badge--yellow  { background: rgba(255,211,42,.12); color: #d4a000; }
.cs-badge--cyan    { background: rgba(0,229,255,.12);  color: #00b8cc; }
.cs-badge--green   { background: rgba(0,200,83,.12);   color: #00c853; }
.cs-badge--default { background: rgba(128,128,128,.1); color: var(--color-text-muted); }

/* Light mode badge tones */
[data-theme="light"] .cs-badge--accent { color: #007a4a !important; }
[data-theme="light"] .cs-badge--yellow { color: #8a6a00 !important; }

/* ── Pagination ──────────────────────────────────────────────*/
.cs-pagination {
  margin-top: 2.5rem !important;
}

.cs-pagination .nav-links {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: .375rem !important;
  flex-wrap: wrap !important;
}

.cs-pagination .page-numbers {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 40px !important;
  height: 40px !important;
  padding: 0 .75rem !important;
  border-radius: 8px !important;
  font-size: .875rem !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  color: var(--color-text-secondary) !important;
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  transition: all .15s ease !important;
}

.cs-pagination .page-numbers:hover,
.cs-pagination .page-numbers.current {
  background: var(--color-accent) !important;
  color: #0a0e1a !important;
  border-color: var(--color-accent) !important;
}

.cs-pagination .page-numbers.dots {
  background: none !important;
  border-color: transparent !important;
}

/* ── Sidebar widgets ─────────────────────────────────────────*/
.cs-sidebar .widget {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 12px !important;
  padding: 1.25rem !important;
  margin-bottom: 1.25rem !important;
  word-break: break-word !important;
}

.cs-sidebar .widget-title,
.cs-sidebar .widgettitle {
  font-size: .9375rem !important;
  font-weight: 700 !important;
  color: var(--color-text-primary) !important;
  margin: 0 0 1rem !important;
  padding-bottom: .75rem !important;
  border-bottom: 1px solid var(--color-border) !important;
}

/* ── H4CK3R Logo wordmark ────────────────────────────────────*/
.cs-nav__logo-mark {
  background: linear-gradient(135deg, #00ff9d, #1a73e8) !important;
  color: #0a0e1a !important;
  font-weight: 900 !important;
  font-size: .8125rem !important;
  letter-spacing: -.02em !important;
  width: 36px !important;
  height: 36px !important;
  border-radius: 7px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
}

.cs-nav__logo-text {
  font-weight: 900 !important;
  font-size: 1.125rem !important;
  letter-spacing: -.02em !important;
  color: var(--color-text-primary) !important;
  margin-left: .5rem !important;
}

.cs-nav__logo-text span {
  color: var(--color-accent) !important;
}

/* ── Responsive breakpoints ──────────────────────────────────*/



/* 1024px: stack sidebar below main content */
@media (max-width: 1024px) {
  .cs-layout {
    grid-template-columns: 1fr !important;
  }
  .cs-sidebar {
    position: static !important;
    width: 100% !important;
    max-height: none !important;
  }
  .cs-layout .cs-grid--3,
  .cs-layout .cs-grid--2 {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

/* 640px: 1-col card grid */
@media (max-width: 640px) {
  .cs-grid--3,
  .cs-grid--2,
  .cs-grid--4 {
    grid-template-columns: 1fr !important;
  }
  .cs-card__body {
    padding: .875rem !important;
  }
}



/* Guest avatar placeholder icon styling */
span.cs-nav__avatar--guest {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 36px !important;
  height: 36px !important;
  border-radius: 50% !important;
  border: 2px solid var(--color-border) !important;
  background: var(--color-surface-2) !important;
  color: var(--color-text-secondary) !important;
  font-size: 1.125rem !important;
  line-height: 1 !important;
  transition: border-color 0.15s ease, color 0.15s ease !important;
}

.cs-nav__avatar-btn:hover span.cs-nav__avatar--guest {
  border-color: var(--color-accent) !important;
  color: var(--color-text-primary) !important;
}

/* Table of Contents button reset to resolve visibility and layout issues */
.cs-toc__title {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  font-family: inherit !important;
  font-size: var(--text-base) !important;
  font-weight: var(--font-weight-bold) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  color: var(--color-text-primary) !important;
  text-align: left !important;
  width: 100% !important;
  outline: none !important;
  display: flex !important;
  align-items: center !important;
  gap: var(--space-2) !important;
  cursor: pointer !important;
  margin-bottom: var(--space-4) !important;
}

.cs-toc__title:focus-visible {
  outline: 2px solid var(--color-accent) !important;
  outline-offset: 2px !important;
  color: var(--color-accent) !important;
}

/* ══════════════════════════════════════════════════════════════
 * 11. COMMENTS & LEAVE A REPLY FORM STYLING
 * ══════════════════════════════════════════════════════════════*/

/* Container & Titles */
.cs-comments {
  margin-top: 3rem !important;
  padding-top: 2rem !important;
  border-top: 1px solid var(--color-border) !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

.cs-comments-title,
.comment-reply-title {
  font-size: var(--text-xl) !important;
  font-weight: var(--font-weight-bold) !important;
  color: var(--color-text-primary) !important;
  margin-bottom: 1.5rem !important;
  letter-spacing: -0.02em !important;
}

/* Comment list styling */
.comment-list {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 2.5rem 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 1rem !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

.comment-list .children {
  list-style: none !important;
  padding-left: 2rem !important;
  margin: 0.75rem 0 0 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 1rem !important;
  border-left: none !important; /* Thread lines drawn by cs-comment__thread-line */
  width: 100% !important;
  box-sizing: border-box !important;
}

@media (max-width: 768px) {
  .comment-list .children {
    padding-left: 1.25rem !important;
  }
}

/* Individual comment structure */
.cs-comment {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
  list-style: none !important;
}

.cs-comment__body {
  background: transparent !important;
  border: none !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0.75rem 0 1rem 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 0.5rem !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

[data-theme="light"] .cs-comment__body {
  border-bottom: 1px solid rgba(0, 0, 0, 0.06) !important;
}

.comment-list .cs-comment:last-child > .cs-comment__body {
  border-bottom: none !important;
}

.cs-comment__header {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 0.5rem !important;
  flex-wrap: wrap !important;
}

.cs-comment__avatar {
  flex-shrink: 0 !important;
}

.cs-comment__avatar-img {
  border-radius: 50% !important;
  background: var(--color-surface-2) !important;
  display: block !important;
  width: 28px !important;
  height: 28px !important;
  border: 1px solid var(--color-border) !important;
}

.cs-comment__meta {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 0.375rem !important;
  flex-grow: 1 !important;
}

.cs-comment__author {
  font-size: var(--text-sm) !important;
  font-weight: var(--font-weight-bold) !important;
  color: var(--color-text-primary) !important;
}

.cs-comment__time {
  font-size: var(--text-xs) !important;
  color: var(--color-text-muted) !important;
}

.cs-comment__separator {
  color: var(--color-text-muted) !important;
  font-size: var(--text-xs) !important;
  opacity: 0.7 !important;
}

/* Action row sits under the content */
.cs-comment__actions {
  display: flex !important;
  align-items: center !important;
  gap: 0.5rem !important;
  margin-left: 36px !important;
  margin-top: 0.25rem !important;
}

.cs-comment__reply a {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  background: none !important;
  border: none !important;
  padding: 4px 8px !important;
  font-size: var(--text-xs) !important;
  font-weight: 600 !important;
  color: var(--color-text-muted) !important;
  border-radius: 4px !important;
  text-decoration: none !important;
  transition: all 0.2s ease !important;
}

.cs-comment__reply a:hover {
  background: rgba(255, 255, 255, 0.08) !important;
  color: var(--color-text-primary) !important;
}

[data-theme="light"] .cs-comment__reply a:hover {
  background: rgba(0, 0, 0, 0.05) !important;
}

.cs-comment__content {
  font-size: var(--text-sm) !important;
  line-height: var(--line-height-relaxed) !important;
  color: var(--color-text-secondary) !important;
  word-break: break-word !important;
  overflow-wrap: break-word !important;
  margin-left: 36px !important;
}

.cs-comment__content p {
  margin-bottom: 0.5rem !important;
}

.cs-comment__content p:last-child {
  margin-bottom: 0 !important;
}

.cs-comment__pending {
  font-size: var(--text-xs) !important;
  font-style: italic !important;
  color: var(--color-accent) !important;
  margin-top: 0.5rem !important;
  margin-left: 36px !important;
}

/* Thread line for comments */
.cs-comment__thread-line {
  position: absolute !important;
  left: 13px !important;
  top: 36px !important;
  bottom: 0 !important;
  width: 2px !important;
  background: var(--color-border) !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  outline: none !important;
  box-shadow: none !important;
  border-radius: 2px !important;
  cursor: pointer !important;
  z-index: 10 !important;
  transition: background-color 0.2s ease, width 0.2s ease !important;
}

.cs-comment__thread-line:hover {
  background: var(--color-accent) !important;
  width: 3px !important;
}

/* Curved connector for child comments */
.comment-list .children .cs-comment::before {
  content: "" !important;
  position: absolute !important;
  left: -19px !important;
  top: -8px !important;
  width: 19px !important;
  height: 30px !important;
  border-left: 2px solid var(--color-border) !important;
  border-bottom: 2px solid var(--color-border) !important;
  border-bottom-left-radius: 8px !important;
  pointer-events: none !important;
  z-index: 5 !important;
  transition: border-color 0.2s ease !important;
}

/* Hover highlights for parent and nested child thread lines */
.cs-comment:hover > .cs-comment__thread-line {
  background: var(--color-accent) !important;
}

.cs-comment:hover > .children .cs-comment::before {
  border-color: var(--color-accent) !important;
}

.cs-comment:hover > .children .cs-comment__thread-line {
  background: var(--color-accent) !important;
}

@media (max-width: 768px) {
  .comment-list .children .cs-comment::before {
    left: -7px !important;
    width: 7px !important;
    height: 30px !important;
    border-bottom-left-radius: 4px !important;
  }
}

/* Collapsed Comments Styles */
.cs-comment__collapsed-placeholder {
  display: none !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 6px 12px !important;
  background: var(--color-surface-2) !important;
  border-radius: 8px !important;
  border: 1px dashed var(--color-border) !important;
  cursor: pointer !important;
  margin-bottom: 0.5rem !important;
  font-size: var(--text-xs) !important;
  color: var(--color-text-muted) !important;
  width: max-content !important;
}

.cs-comment__collapsed-placeholder:hover {
  background: var(--color-border) !important;
  color: var(--color-text-primary) !important;
}

.cs-comment__expand-btn {
  background: none !important;
  border: none !important;
  color: var(--color-accent) !important;
  font-weight: bold !important;
  cursor: pointer !important;
  padding: 0 4px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.cs-comment__collapse-btn {
  background: none !important;
  border: none !important;
  color: var(--color-text-muted) !important;
  font-weight: bold !important;
  cursor: pointer !important;
  padding: 0 4px !important;
  margin-left: 6px !important;
  opacity: 0.6 !important;
  transition: opacity 0.2s, color 0.2s !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.cs-comment__collapse-btn:hover {
  opacity: 1 !important;
  color: var(--color-accent) !important;
}

.cs-comment__meta .cs-badge {
  padding: 0 4px !important;
  font-size: 10px !important;
  line-height: 1.4 !important;
  vertical-align: middle !important;
  border-radius: 4px !important;
}

/* Toggle displays when collapsed */
.cs-comment.collapsed > .cs-comment__body,
.cs-comment.collapsed > .cs-comment__thread-line,
.cs-comment.collapsed > .children {
  display: none !important;
}

.cs-comment.collapsed > .cs-comment__collapsed-placeholder {
  display: flex !important;
}

/* Comment Form Layout and Aesthetics */
.comment-respond,
#respond {
  margin-top: 3rem !important;
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--border-radius-lg) !important;
  padding: 2rem !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

@media (max-width: 768px) {
  .comment-respond,
  #respond {
    padding: 1.25rem !important;
  }
}

.comment-form,
#commentform {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 1.25rem !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

@media (min-width: 769px) {
  .comment-form,
  #commentform {
    grid-template-columns: repeat(3, 1fr) !important;
  }
  .comment-form-comment,
  .logged-in-as,
  .comment-notes,
  .form-submit,
  .comment-form-cookies-consent {
    grid-column: 1 / -1 !important;
  }
}

.comment-form-comment,
.comment-form-author,
.comment-form-email,
.comment-form-url {
  display: flex !important;
  flex-direction: column !important;
  gap: 0.5rem !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

.comment-form-comment label,
.comment-form-author label,
.comment-form-email label,
.comment-form-url label {
  font-size: var(--text-sm) !important;
  font-weight: 600 !important;
  color: var(--color-text-secondary) !important;
}

.comment-form input[type="text"],
#commentform input[type="text"],
.comment-form input[type="email"],
#commentform input[type="email"],
.comment-form input[type="url"],
#commentform input[type="url"],
.comment-form textarea,
#commentform textarea {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  background: var(--color-surface-2) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--border-radius-sm) !important;
  padding: 12px 16px !important;
  font-family: var(--font-primary) !important;
  font-size: 0.9375rem !important;
  color: var(--color-text-primary) !important;
  transition: border-color var(--transition-fast) !important;
  outline: none !important;
}

.comment-form input[type="text"]:focus,
#commentform input[type="text"]:focus,
.comment-form input[type="email"]:focus,
#commentform input[type="email"]:focus,
.comment-form input[type="url"]:focus,
#commentform input[type="url"]:focus,
.comment-form textarea:focus,
#commentform textarea:focus {
  border-color: var(--color-accent) !important;
}

/* Cookies Consent Checkbox */
.comment-form-cookies-consent {
  display: flex !important;
  flex-direction: row !important;
  align-items: flex-start !important;
  gap: 0.625rem !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

.comment-form-cookies-consent input[type="checkbox"] {
  margin-top: 4px !important;
  flex-shrink: 0 !important;
}

.comment-form-cookies-consent label {
  font-size: var(--text-xs) !important;
  color: var(--color-text-secondary) !important;
  line-height: 1.5 !important;
  font-weight: normal !important;
  cursor: pointer !important;
}

.logged-in-as,
.comment-notes {
  font-size: var(--text-sm) !important;
  color: var(--color-text-secondary) !important;
  line-height: 1.6 !important;
}

.logged-in-as a {
  color: var(--color-accent) !important;
  text-decoration: none !important;
  font-weight: 600 !important;
}

.logged-in-as a:hover {
  text-decoration: underline !important;
}

/* Submit Button */
.form-submit {
  margin-top: 0.5rem !important;
}

.comment-form #submit,
#commentform #submit,
.comment-form input[type="submit"],
#commentform input[type="submit"] {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 12px 28px !important;
  font-family: var(--font-primary) !important;
  font-size: 0.875rem !important;
  font-weight: 600 !important;
  border-radius: var(--border-radius-sm) !important;
  border: none !important;
  cursor: pointer !important;
  transition: all var(--transition-base) !important;
  text-decoration: none !important;
  background: var(--color-accent) !important;
  color: #0a0e1a !important;
  width: auto !important;
}

.comment-form #submit:hover,
#commentform #submit:hover,
.comment-form input[type="submit"]:hover,
#commentform input[type="submit"]:hover {
  background: var(--color-accent-dark) !important;
  box-shadow: var(--shadow-accent) !important;
  transform: translateY(-1px) !important;
}

/* ══════════════════════════════════════════════════════════════
 * 12. LIGHT THEME FOOTER CONTRAST FIX
 * ══════════════════════════════════════════════════════════════*/
html.light .cs-footer,
[data-theme="light"] .cs-footer {
  --color-bg: #0a0e1a;
  --color-surface: #111827;
  --color-surface-2: #1a2235;
  --color-surface-3: #243048;
  --color-border: #1e2d47;
  --color-border-light: #2a3a56;
  --color-text-primary: #e8eaf2;
  --color-text-secondary: #9aa5b8;
  --color-text-muted: #5a6a84;
  --color-text-inverse: #e8eaf2;
  --color-accent: #00ff9d;
  --color-accent-dark: #00cc7a;
  --color-accent-glow: rgba(0, 255, 157, 0.12);
  --color-accent-glow2: rgba(0, 255, 157, 0.25);
  --color-card-bg: #111827;
  --color-card-hover: #162030;
  --color-code-bg: #0d1117;
  --color-nav-bg: #0d1220;
  --color-footer-bg: #060910;
}

/* Ensure custom uploaded logos in the footer scale correctly and do not overflow */
.cs-footer__logo .custom-logo-link {
  display: flex !important;
  align-items: center !important;
  max-height: 48px !important;
  text-decoration: none !important;
}

.cs-footer__logo .custom-logo-link img,
.cs-footer__logo img {
  height: 48px !important;
  width: auto !important;
  max-height: 48px !important;
  max-width: 180px !important;
  object-fit: contain !important;
  display: block !important;
}

/* ──────────────────────────────────────────────────────────────
 * 19. SINGLE ICON THEME SWITCHER
 * ──────────────────────────────────────────────────────────────*/
.cs-theme-toggle {
  width: 40px !important;
  height: 40px !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: var(--color-surface-2) !important;
  border: 1px solid var(--color-border) !important;
  padding: 0 !important;
  transition: all 0.25s ease !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
}

.cs-theme-toggle:hover {
  background: var(--color-surface-3) !important;
  border-color: var(--color-accent) !important;
  box-shadow: 0 0 12px var(--color-accent-glow) !important;
}

.cs-theme-toggle__track,
.cs-theme-toggle__thumb {
  display: none !important;
}

.cs-theme-toggle__icon {
  position: static !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: var(--color-text-secondary) !important;
  transition: color 0.25s ease, transform 0.25s ease !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1 !important;
  opacity: 1 !important;
}

.cs-theme-toggle:hover .cs-theme-toggle__icon {
  color: var(--color-accent) !important;
  transform: rotate(15deg) !important;
}

/* In dark mode: show sun, hide moon */
html[data-theme="dark"] .cs-theme-toggle__icon-dark,
html.dark .cs-theme-toggle__icon-dark {
  display: none !important;
}
html[data-theme="dark"] .cs-theme-toggle__icon-light,
html.dark .cs-theme-toggle__icon-light {
  display: flex !important;
}

/* In light mode: show moon, hide sun */
html[data-theme="light"] .cs-theme-toggle__icon-dark,
html.light .cs-theme-toggle__icon-dark {
  display: flex !important;
}
html[data-theme="light"] .cs-theme-toggle__icon-light,
html.light .cs-theme-toggle__icon-light {
  display: none !important;
}

.cs-theme-toggle svg {
  width: 18px !important;
  height: 18px !important;
  stroke-width: 2.2px !important;
  display: block !important;
}

/* --- Mobile sizing overrides for a completely uniform navigation bar --- */
@media (max-width: 480px) {
  .cs-theme-toggle {
    width: 32px !important;
    height: 32px !important;
  }
  .cs-nav__search-btn {
    width: 32px !important;
    height: 32px !important;
  }
  .cs-nav__avatar {
    width: 32px !important;
    height: 32px !important;
  }
  .cs-nav__avatar--guest {
    width: 32px !important;
    height: 32px !important;
  }
  .cs-nav__hamburger {
    width: 32px !important;
    height: 32px !important;
  }
}


/* --------------------------------------------------------------
 * AD ENHANCEMENTS - Sticky sidebar, native related posts, contest
 * --------------------------------------------------------------*/

/* Sticky sidebar ad slot */
.cs-ad-wrap--sidebar-sticky {
  z-index: 10 !important;
}

/* Contest result ad - shown after score reveal */
.cs-ad-wrap--contest-result-top {
  margin: 1.5rem 0 !important;
  border-radius: 10px !important;
  overflow: hidden !important;
}

/* Native Related Articles ad section */
.cs-related-native {
  margin: 2.5rem 0 !important;
  padding: 1.5rem !important;
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 14px !important;
}
.cs-related-native__heading {
  font-size: 0.75rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: var(--color-text-muted) !important;
  margin: 0 0 1rem !important;
}
.cs-related-native__grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 1rem !important;
}
@media (max-width: 768px) {
  .cs-related-native__grid { grid-template-columns: 1fr !important; }
}
.cs-related-native__item {
  display: flex !important;
  flex-direction: column !important;
  text-decoration: none !important;
  border-radius: 10px !important;
  overflow: hidden !important;
  background: var(--color-surface-2) !important;
  border: 1px solid var(--color-border) !important;
  transition: border-color 0.2s ease, transform 0.2s ease !important;
}
.cs-related-native__item:hover {
  border-color: rgba(0,255,157,0.25) !important;
  transform: translateY(-2px) !important;
}
.cs-related-native__thumb {
  width: 100% !important;
  aspect-ratio: 16/9 !important;
  object-fit: cover !important;
  display: block !important;
}
.cs-related-native__body { padding: 0.75rem !important; flex: 1 !important; }
.cs-related-native__title {
  font-size: 0.875rem !important;
  font-weight: 600 !important;
  color: var(--color-text-primary) !important;
  line-height: 1.4 !important;
  margin: 0 0 0.25rem !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}
.cs-related-native__meta { font-size: 0.75rem !important; color: var(--color-text-muted) !important; }
.cs-related-native__ad {
  margin-top: 1rem !important;
  border-top: 1px solid var(--color-border) !important;
  padding-top: 1rem !important;
}
.cs-ad-wrap--forum-reply-between { margin: 1.5rem 0 !important; }

/* ──────────────────────────────────────────────────────────────
 * ADVANCED SEO & ADSENSE REVENUE PERFORMANCE STYLING
 * ──────────────────────────────────────────────────────────────*/

/* CSS Containment for Core Web Vitals (INP/FCP) */
.cs-comments-area,
.cs-forum-topic-list,
.cs-forum-widget,
.widget {
  content-visibility: auto !important;
  contain-intrinsic-size: 500px !important;
}

/* Glassmorphic Premium Ad Placeholders */
.cs-ad-wrap:not(.cs-ad-wrap--mobile-sticky-bottom) {
  background: rgba(30, 45, 71, 0.25) !important;
  border: 1px dashed rgba(0, 255, 157, 0.15) !important;
  border-radius: 8px !important;
  position: relative !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  transition: all 0.3s ease !important;
}

.cs-ad-wrap:not(.cs-ad-wrap--mobile-sticky-bottom)::after {
  content: 'ADVERTISEMENT' !important;
  position: absolute !important;
  font-family: 'JetBrains Mono', 'Fira Code', monospace !important;
  font-size: 0.65rem !important;
  color: rgba(154, 165, 184, 0.12) !important;
  letter-spacing: 0.15em !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  pointer-events: none !important;
}

/* Ensure inner activated ad units sit on top */
.cs-ad-wrap:not(.cs-ad-wrap--mobile-sticky-bottom) .cs-ad,
.cs-ad-wrap:not(.cs-ad-wrap--mobile-sticky-bottom) ins.adsbygoogle {
  position: relative !important;
  z-index: 2 !important;
  width: 100% !important;
}

.cs-ad-wrap:not(.cs-ad-wrap--mobile-sticky-bottom):has(iframe),
.cs-ad-wrap:not(.cs-ad-wrap--mobile-sticky-bottom):has(ins.adsbygoogle[data-ad-status="filled"]),
.cs-ad-wrap:not(.cs-ad-wrap--mobile-sticky-bottom):has(.cs-ad[data-ad-status="filled"]),
.cs-ad:has(iframe),
.cs-ad:has(ins.adsbygoogle[data-ad-status="filled"]),
.cs-ad[data-ad-status="filled"] {
  background: transparent !important;
  border-color: transparent !important;
  border-style: none !important;
  box-shadow: none !important;
}

.cs-ad-wrap:not(.cs-ad-wrap--mobile-sticky-bottom):has(iframe)::before,
.cs-ad-wrap:not(.cs-ad-wrap--mobile-sticky-bottom):has(iframe)::after,
.cs-ad-wrap:not(.cs-ad-wrap--mobile-sticky-bottom):has(ins.adsbygoogle[data-ad-status="filled"])::before,
.cs-ad-wrap:not(.cs-ad-wrap--mobile-sticky-bottom):has(ins.adsbygoogle[data-ad-status="filled"])::after,
.cs-ad-wrap:not(.cs-ad-wrap--mobile-sticky-bottom):has(.cs-ad[data-ad-status="filled"])::before,
.cs-ad-wrap:not(.cs-ad-wrap--mobile-sticky-bottom):has(.cs-ad[data-ad-status="filled"])::after,
.cs-ad:has(iframe)::before,
.cs-ad:has(iframe)::after,
.cs-ad:has(ins.adsbygoogle[data-ad-status="filled"])::before,
.cs-ad:has(ins.adsbygoogle[data-ad-status="filled"])::after,
.cs-ad[data-ad-status="filled"]::before,
.cs-ad[data-ad-status="filled"]::after {
  display: none !important;
  content: none !important;
}

/* Collapse ad slots completely if no ad was returned (unfilled) */
.cs-ad-wrap:not(.cs-ad-wrap--mobile-sticky-bottom):has(ins.adsbygoogle[data-ad-status="unfilled"]),
.cs-ad:has(ins.adsbygoogle[data-ad-status="unfilled"]) {
  display: none !important;
}

/* Styling for preformatted blocks in contest questions */
.cs-quiz-q-text pre {
  background: #0d1117 !important;
  padding: 12px 16px !important;
  border-radius: 6px !important;
  font-family: 'JetBrains Mono', 'Fira Code', monospace !important;
  color: #c9d1d9 !important;
  border: 1px solid #30363d !important;
  overflow-x: auto !important;
  white-space: pre !important;
  margin: 1rem 0 !important;
  line-height: 1.5 !important;
  display: block !important;
}
.cs-quiz-q-text code {
  font-family: 'JetBrains Mono', 'Fira Code', monospace !important;
}

/* Sidebar Contest Leaderboard styling overrides */
.cs-sidebar .cs-contest-leaderboard {
  padding: 1.25rem !important;
  border-radius: 12px !important;
}
.cs-sidebar .cs-contest-lb-row {
  grid-template-columns: 28px 1fr 50px 44px !important;
  gap: 0.5rem !important;
  padding: 6px 8px !important;
  font-size: 0.8125rem !important;
}
.cs-sidebar .cs-contest-lb-row--head {
  padding-bottom: 0.375rem !important;
}
.cs-sidebar .cs-contest-lb-row > span:nth-child(5) {
  display: none !important;
}

/* Fix mobile sticky bottom ad positioning conflict */
.cs-ad--mobile-sticky {
  position: static !important;
  display: flex !important;
  width: 100% !important;
  max-width: 320px !important;
  margin: 0 auto !important;
  min-height: 50px !important;
  border: none !important;
  box-shadow: none !important;
}

/* Collapse ad slots completely if ads are blocked by ad-blocker */
body.cs-ads-blocked .cs-ad-wrap,
body.cs-ads-blocked .cs-ad {
  display: none !important;
}


