/*
Theme Name: SoundB
Theme URI: https://soundb.net
Description: Dark 2000s audiobook library theme — standalone, no parent theme required.
Author: SoundB
Author URI: https://soundb.net
Version: 1.0.0
Text Domain: soundb
License: GPL v2 or later
*/

/* ===== DARK 2000s THEME ===== */
:root {
  --fluid-xs: clamp(0.625rem, 0.55rem + 0.35vw, 0.75rem);
  --fluid-sm: clamp(0.688rem, 0.6rem + 0.4vw, 0.813rem);
  --fluid-base: clamp(0.75rem, 0.68rem + 0.35vw, 0.875rem);
  --fluid-lg: clamp(0.875rem, 0.8rem + 0.38vw, 1.063rem);
  --fluid-xl: clamp(1rem, 0.88rem + 0.6vw, 1.25rem);
  --fluid-2xl: clamp(1.125rem, 0.95rem + 0.9vw, 1.5rem);
  --fluid-3xl: clamp(1.375rem, 1.1rem + 1.4vw, 1.875rem);
  --fluid-pad-xs: clamp(0.25rem, 0.18rem + 0.35vw, 0.375rem);
  --fluid-pad-sm: clamp(0.375rem, 0.28rem + 0.5vw, 0.625rem);
  --fluid-pad: clamp(0.5rem, 0.38rem + 0.6vw, 0.75rem);
  --fluid-pad-lg: clamp(0.75rem, 0.55rem + 1vw, 1.25rem);
  --fluid-gap: clamp(0.375rem, 0.25rem + 0.6vw, 0.625rem);
  --fluid-gap-lg: clamp(0.625rem, 0.45rem + 0.9vw, 1rem);
  --bg-body: #121218;
  --bg-panel: #1a1a24;
  --bg-panel-alt: #1e1e2a;
  --bg-header: #252535;
  --bg-header-accent: linear-gradient(180deg, #2a2a40, #1e1e30);
  --bg-input: #14141c;
  --bg-hover: #222230;
  --bg-alt-row: #16161e;
  --bg-nav: #0e0e14;
  --border-main: #2a2a3a;
  --border-light: #222230;
  --border-accent: #3a3a55;
  --text-main: #c8c8d0;
  --text-heading: #e0e0e8;
  --text-dim: #707088;
  --text-link: #6888c8;
  --text-link-hover: #88a8e8;
  --accent-blue: #4868a8;
  --accent-green: #48a848;
  --accent-gold: #c89030;
  --accent-red: #c84848;
  --star-color: #d4a020;
  --premium-bg: linear-gradient(135deg, #28201a, #1e1a14);
  --premium-border: #4a3820;
  --shadow-card: 0 2px 8px rgba(0,0,0,0.4), 0 1px 3px rgba(0,0,0,0.3);
  --shadow-panel: 0 2px 12px rgba(0,0,0,0.35);
  --shadow-elevated: 0 4px 20px rgba(0,0,0,0.5);
}

/* ===== LIGHT MODE ===== */
[data-theme="light"] {
  --bg-body: #f0f0f4;
  --bg-panel: #ffffff;
  --bg-panel-alt: #f5f5f8;
  --bg-header: #e8e8f0;
  --bg-header-accent: linear-gradient(180deg, #f0f0f6, #e8e8f0);
  --bg-input: #ffffff;
  --bg-hover: #e8e8f0;
  --bg-alt-row: #f8f8fc;
  --bg-nav: #ffffff;
  --border-main: #d8d8e0;
  --border-light: #e8e8f0;
  --border-accent: #c8c8d8;
  --text-main: #333340;
  --text-heading: #1a1a28;
  --text-dim: #888898;
  --text-link: #3858a0;
  --text-link-hover: #2848a0;
  --accent-blue: #3858a0;
  --accent-green: #2e8a2e;
  --accent-gold: #a87020;
  --accent-red: #c03838;
  --star-color: #c89020;
  --premium-bg: linear-gradient(135deg, #f8f0e8, #f0e8d8);
  --premium-border: #d0b888;
  --shadow-card: 0 1px 4px rgba(0,0,0,0.08), 0 1px 2px rgba(0,0,0,0.05);
  --shadow-panel: 0 1px 6px rgba(0,0,0,0.06);
  --shadow-elevated: 0 4px 16px rgba(0,0,0,0.1);
}
[data-theme="light"] body {
  background-image: none;
}
[data-theme="light"] .sb-nav {
  box-shadow: 0 1px 3px rgba(0,0,0,0.08);
}
[data-theme="light"] .book-card .book-cover::after {
  background: linear-gradient(transparent, rgba(255,255,255,0.2));
}
[data-theme="light"] .book-card-info {
  background: linear-gradient(180deg, #fff, #f8f8fc);
}

/* ===== RESET ===== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
img { max-width: 100%; height: auto; display: block; }

/* ===== BASE ===== */
html { height: 100%; }
body {
  background: var(--bg-body);
  background-image:
    repeating-radial-gradient(circle at 17% 32%, rgba(255,255,255,0.01) 0px, transparent 1px),
    repeating-radial-gradient(circle at 62% 78%, rgba(255,255,255,0.008) 0px, transparent 1px),
    repeating-radial-gradient(circle at 89% 14%, rgba(255,255,255,0.012) 0px, transparent 1px);
  background-size: 200px 200px, 150px 150px, 180px 180px;
  color: var(--text-main);
  font-family: Verdana, Tahoma, "Segoe UI", Geneva, Arial, sans-serif;
  font-size: var(--fluid-base);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  min-height: 100%;
  display: flex;
  flex-direction: column;
}
main.sb-wrapper { flex: 1; }
::selection { background: var(--accent-blue); color: #fff; }
::-moz-selection { background: var(--accent-blue); color: #fff; }
a { color: var(--text-link); text-decoration: none; }
a:hover { color: var(--text-link-hover); text-decoration: underline; }
h1,h2,h3,h4,h5,h6 { color: var(--text-heading); text-shadow: 0 1px 2px rgba(0,0,0,0.5); }

/* ===== PANEL ===== */
.sb-panel { background: var(--bg-panel); border: 1px solid var(--border-main); border-radius: clamp(3px, 0.4vw, 6px); overflow: hidden; box-shadow: var(--shadow-panel); }
.sb-panel-header { background: var(--bg-header-accent); border-bottom: 1px solid var(--border-main); padding: var(--fluid-pad-xs) var(--fluid-pad); display: flex; align-items: center; justify-content: space-between; gap: var(--fluid-gap); flex-wrap: wrap; position: relative; }
.sb-panel-header::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, rgba(255,255,255,0.06), transparent); }
.sb-panel-header h2, .sb-panel-header span { color: var(--text-heading); font-size: var(--fluid-sm); font-weight: bold; margin: 0; }
.sb-panel-header a { color: var(--text-link); font-size: var(--fluid-xs); font-weight: bold; }
.sb-panel-body { padding: var(--fluid-pad); }

/* ===== NAVBAR ===== */
.sb-nav { background: var(--bg-nav); border-bottom: 1px solid var(--border-main); position: relative; z-index: 100; }
.sb-nav-spacer { height: 0; }
.admin-bar .sb-nav { margin-top: 32px; }
@media (max-width: 782px) { .admin-bar .sb-nav { margin-top: 46px; } }
.sb-nav-inner { max-width: 1400px; width: 100%; margin: 0 auto; padding: 0 20px; display: flex; align-items: center; justify-content: space-between; height: clamp(44px, 6vw, 56px); gap: var(--fluid-gap); }

/* Logo with Lottie */
/* Logo: spinning vinyl disc = the "O" in SoundB */
.sb-logo {
  display: flex;
  align-items: center;
  text-decoration: none !important;
  flex-shrink: 0;
  gap: 0;
}
.sb-logo-text {
  font-family: 'Audiowide', sans-serif;
  font-weight: 400;
  font-size: clamp(20px, 3vw, 28px);
  color: var(--text-heading);
  line-height: 1;
  letter-spacing: 0.5px;
}
.sb-logo-lottie {
  display: inline-block;
  width: clamp(24px, 3vw, 32px);
  height: clamp(24px, 3vw, 32px);
  margin: 0 -1px;
  pointer-events: none;
}
.sb-logo:hover .sb-logo-text { color: var(--accent-gold); }
.sb-logo:hover .sb-logo-lottie { filter: drop-shadow(0 0 6px var(--accent-gold)); }
.sb-nav-link { color: var(--text-dim); font-size: var(--fluid-xs); font-weight: bold; padding: var(--fluid-pad-xs) var(--fluid-pad-sm); border-radius: 3px; transition: color 0.1s, background 0.1s; text-transform: uppercase; letter-spacing: 0.3px; text-decoration: none; }
.sb-nav-link:hover { color: var(--text-heading); background: var(--bg-hover); text-decoration: none; }
.sb-nav-dropdown { position: relative; }
.sb-nav-dropdown-menu { display: none; position: absolute; top: calc(100% + 6px); left: 0; z-index: 1000; min-width: 220px; max-height: 400px; overflow-y: auto; background: var(--bg-panel); border: 1px solid var(--border-accent); border-radius: 6px; box-shadow: var(--shadow-elevated); padding: 4px 0; }
/* Bridge the gap so hover doesn't break */
.sb-nav-dropdown::after { content: ''; position: absolute; top: 100%; left: 0; width: 100%; height: 8px; }
.sb-nav-dropdown:hover .sb-nav-dropdown-menu { display: block; }
.sb-nav-dropdown-item { display: block; padding: 6px 14px; color: var(--text-main); font-size: var(--fluid-xs); text-decoration: none; white-space: nowrap; }
.sb-nav-dropdown-item:hover { background: var(--bg-hover); color: var(--text-heading); text-decoration: none; }

/* ===== BUTTONS ===== */
.sb-btn { display: inline-flex; align-items: center; justify-content: center; gap: clamp(0.2rem, 0.5vw, 0.35rem); padding: var(--fluid-pad-xs) var(--fluid-pad-sm); background: var(--bg-header); color: var(--text-heading); border: 1px solid var(--border-accent); border-radius: 3px; font-family: inherit; font-size: var(--fluid-xs); font-weight: bold; cursor: pointer; white-space: nowrap; text-decoration: none; transition: background 0.15s, border-color 0.15s, box-shadow 0.15s; box-shadow: inset 0 1px 0 rgba(255,255,255,0.05), 0 1px 2px rgba(0,0,0,0.3); }
.sb-btn:hover { background: var(--bg-hover); border-color: var(--text-dim); text-decoration: none; color: #fff; box-shadow: inset 0 1px 0 rgba(255,255,255,0.08), 0 2px 6px rgba(0,0,0,0.4); }
.sb-btn:active { box-shadow: inset 0 2px 4px rgba(0,0,0,0.4); transform: translateY(1px); }
.sb-btn-primary { background: var(--accent-blue); border-color: #3858a0; color: #fff; box-shadow: inset 0 1px 0 rgba(255,255,255,0.1), 0 1px 3px rgba(0,0,0,0.3); }
.sb-btn-primary:hover { background: #5878b8; color: #fff; box-shadow: inset 0 1px 0 rgba(255,255,255,0.12), 0 2px 8px rgba(0,0,0,0.4); }
.sb-btn-green { background: var(--accent-green); border-color: #389038; color: #fff; box-shadow: inset 0 1px 0 rgba(255,255,255,0.1), 0 1px 3px rgba(0,0,0,0.3); }
.sb-btn-green:hover { background: #58b858; box-shadow: inset 0 1px 0 rgba(255,255,255,0.12), 0 2px 8px rgba(0,0,0,0.4); }
.sb-btn-premium { background: linear-gradient(180deg, #daa040 0%, #c89030 40%, #a87020 100%); border-color: #886018; color: #fff; font-weight: bold; box-shadow: inset 0 1px 0 rgba(255,255,255,0.2), inset 0 -1px 0 rgba(0,0,0,0.15), 0 1px 3px rgba(0,0,0,0.3); text-shadow: 0 1px 1px rgba(0,0,0,0.3); }
.sb-btn-premium:hover { background: linear-gradient(180deg, #e8b050 0%, #d8a040 40%, #b88030 100%); color: #fff; box-shadow: inset 0 1px 0 rgba(255,255,255,0.25), 0 2px 8px rgba(0,0,0,0.4); }
.sb-btn-danger { background: var(--accent-red); border-color: #a03838; color: #fff; box-shadow: inset 0 1px 0 rgba(255,255,255,0.1), 0 1px 3px rgba(0,0,0,0.3); }
.sb-btn-outline { background: transparent; border-color: var(--border-accent); color: var(--text-link); }
.sb-btn-outline:hover { background: var(--bg-panel-alt); }
.sb-btn-sm { padding: 2px var(--fluid-pad-xs); font-size: clamp(0.563rem, 0.5rem + 0.3vw, 0.625rem); }
.sb-btn-lg { padding: var(--fluid-pad-sm) var(--fluid-pad); font-size: var(--fluid-sm); }

/* ===== BADGE ===== */
.sb-badge { display: inline-block; padding: 2px clamp(6px, 0.6vw, 10px); border-radius: 10px; font-size: var(--fluid-xs); font-weight: bold; line-height: 1.4; text-transform: uppercase; letter-spacing: 0.3px; box-shadow: 0 1px 3px rgba(0,0,0,0.4); }
.sb-badge-blue { background: #1a2540; color: #6888c8; border: 1px solid #2a3a60; }
.sb-badge-gold { background: #28201a; color: var(--accent-gold); border: 1px solid var(--premium-border); }
.sb-badge-green { background: #1a2a1a; color: var(--accent-green); border: 1px solid #2a4a2a; }
.sb-badge-muted { background: var(--bg-header); color: var(--text-dim); border: 1px solid var(--border-main); }

/* ===== INPUT ===== */
.sb-input { background: var(--bg-input); border: 1px solid var(--border-main); border-radius: 3px; padding: var(--fluid-pad-xs) var(--fluid-pad-sm); color: var(--text-main); font-family: inherit; font-size: var(--fluid-base); width: 100%; transition: border-color 0.15s; }
.sb-input:focus { outline: none; border-color: var(--accent-blue); }
.sb-input::placeholder { color: var(--text-dim); }
.sb-select { background: var(--bg-input); border: 1px solid var(--border-main); border-radius: 3px; padding: var(--fluid-pad-xs) var(--fluid-pad-sm); color: var(--text-main); font-family: inherit; font-size: var(--fluid-base); cursor: pointer; }
.sb-select:focus { outline: none; border-color: var(--accent-blue); }

/* ===== BOOK CARD ===== */
.book-card { display: block; background: var(--bg-panel); border: 1px solid var(--border-main); border-radius: clamp(3px, 0.4vw, 6px); overflow: hidden; transition: border-color 0.2s, transform 0.2s, box-shadow 0.2s; text-decoration: none; box-shadow: var(--shadow-card); }
.book-card:hover { border-color: var(--accent-blue); transform: translateY(-3px); text-decoration: none; box-shadow: var(--shadow-elevated); }
.book-card .book-cover { position: relative; overflow: hidden; aspect-ratio: 1/1; border-bottom: 1px solid var(--border-main); background: var(--bg-header); }
.book-card .book-cover img { width: 100%; height: 100%; object-fit: cover; }
.book-card .book-cover::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 40%; background: linear-gradient(transparent, rgba(0,0,0,0.35)); pointer-events: none; z-index: 1; }
.book-card-info { padding: var(--fluid-pad-sm); background: linear-gradient(180deg, var(--bg-panel), rgba(16,16,22,0.6)); }

/* ===== STARS ===== */
.star-filled { color: var(--star-color); text-shadow: 0 0 4px rgba(212,160,32,0.4); }
.star-empty { color: #2a2a38; }
.sb-star { transition: color 0.15s, transform 0.15s; display: inline-block; font-size: clamp(1.1rem, 2vw, 1.4rem); }
.sb-star:hover { transform: scale(1.3); }

/* ===== PREMIUM GATE ===== */
.sb-premium-gate { background: var(--premium-bg); border: 1px solid var(--premium-border); border-radius: clamp(3px, 0.4vw, 6px); padding: var(--fluid-pad-lg); }

/* ===== TABLE ROWS ===== */
.sb-row { padding: var(--fluid-pad-sm) var(--fluid-pad); border-bottom: 1px solid var(--border-light); transition: background 0.1s; display: flex; align-items: center; }
.sb-row:hover { background: var(--bg-hover); }
.sb-row:nth-child(even) { background: var(--bg-alt-row); }
.sb-row:nth-child(even):hover { background: var(--bg-hover); }
.sb-row:last-child { border-bottom: none; }

/* ===== INFO BAR ===== */
.sb-infobar { background: #0a0a10; border-bottom: 1px solid var(--border-light); padding: clamp(2px, 0.3vw, 4px) 0; overflow: hidden; white-space: nowrap; font-size: var(--fluid-xs); color: var(--text-dim); }
.sb-infobar span { display: inline-block; animation: scroll 40s linear infinite; }
@keyframes scroll { from { transform: translateX(100vw); } to { transform: translateX(-100%); } }

/* ===== HEART BEAT ===== */
.sb-heart-beat { color: #e03030; display: inline-block; animation: heartbeat 1s ease-in-out infinite; font-size: 1em; line-height: 1; }
@keyframes heartbeat { 0%,100% { transform: scale(1); } 15% { transform: scale(1.25); } 30% { transform: scale(1); } 45% { transform: scale(1.15); } 60% { transform: scale(1); } }

/* ===== STAT ===== */
.sb-stat { text-align: center; padding: var(--fluid-pad-sm); }
.sb-stat-value { font-size: var(--fluid-2xl); font-weight: bold; color: var(--text-heading); line-height: 1.2; }
.sb-stat-label { font-size: var(--fluid-xs); color: var(--text-dim); text-transform: uppercase; letter-spacing: 0.5px; }

/* ===== SCROLLBAR ===== */
::-webkit-scrollbar { width: 10px; }
::-webkit-scrollbar-track { background: var(--bg-body); }
::-webkit-scrollbar-thumb { background: linear-gradient(180deg, #3a3a4a, #2a2a3a); border-radius: 5px; border: 2px solid var(--bg-body); }
::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg, #4a4a5a, #3a3a4a); }

/* ===== WRAPPER ===== */
.sb-wrapper { max-width: 1400px; width: 100%; margin: 0 auto; padding: 0 20px; }
/* Narrower container for form/tool pages (downloader, torrent, quickpost, profile, etc.) */
.sb-content-narrow { max-width: 900px; margin: 0 auto; }
/* Ensure content doesn't hide behind sticky nav */
/* spacing handled per-page in header.php */

/* ===== FLUID TEXT ===== */
.text-fluid-xs { font-size: var(--fluid-xs) !important; }
.text-fluid-sm { font-size: var(--fluid-sm) !important; }
.text-fluid-base { font-size: var(--fluid-base) !important; }
.text-fluid-lg { font-size: var(--fluid-lg) !important; }
.text-fluid-xl { font-size: var(--fluid-xl) !important; }
.text-fluid-2xl { font-size: var(--fluid-2xl) !important; }
.text-fluid-3xl { font-size: var(--fluid-3xl) !important; }

/* ===== SOCIAL SHARE ===== */
.sb-social-share { display: flex; gap: 0; margin-top: 1px; width: 100%; }
.sb-share-btn { flex: 1; height: clamp(36px, 5vw, 44px); padding: 0; font-size: clamp(16px, 2vw, 20px); text-align: center; text-decoration: none !important; color: #fff !important; border: 2px solid; border-radius: 0; transition: all 0.3s; display: flex; align-items: center; justify-content: center; }
.sb-share-btn:first-child { border-top-left-radius: 4px; border-bottom-left-radius: 4px; }
.sb-share-btn:last-child { border-top-right-radius: 4px; border-bottom-right-radius: 4px; }
.sb-share-btn:hover { transform: translateY(-2px); text-decoration: none !important; }
.sb-share-facebook { background: #1877F2; border-color: #1460d4; }
.sb-share-twitter { background: #1DA1F2; border-color: #1a8cd8; }
.sb-share-whatsapp { background: #25D366; border-color: #20ba5a; }
.sb-share-telegram { background: #0088cc; border-color: #0077b5; }

/* ===== UTILITY CLASSES (Tailwind replacements) ===== */
.flex { display: flex; }
.flex-col { flex-direction: column; }
.flex-row { flex-direction: row; }
.flex-wrap { flex-wrap: wrap; }
.flex-1 { flex: 1; }
.items-center { align-items: center; }
.items-start { align-items: flex-start; }
.justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }
.gap-1 { gap: 4px; }
.gap-2 { gap: 8px; }
.gap-3 { gap: 12px; }
.gap-fluid { gap: var(--fluid-gap); }
.gap-fluid-lg { gap: var(--fluid-gap-lg); }
.shrink-0 { flex-shrink: 0; }
.min-w-0 { min-width: 0; }
.w-full { width: 100%; }
.text-center { text-align: center; }
.text-right { text-align: right; }
.font-bold { font-weight: bold; }
.truncate { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.mt-1 { margin-top: 4px; }
.mt-2 { margin-top: 8px; }
.mt-3 { margin-top: 12px; }
.mb-1 { margin-bottom: 4px; }
.mb-2 { margin-bottom: 8px; }
.mb-3 { margin-bottom: 12px; }
.relative { position: relative; }
.absolute { position: absolute; }
.top-1 { top: 4px; }
.right-1 { right: 4px; }
.bottom-1 { bottom: 4px; }
.left-1 { left: 4px; }
.hidden { display: none; }

/* ===== GRID ===== */
.grid { display: grid; }
.grid-cols-2 { grid-template-columns: repeat(2, 1fr); }
.grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
.grid-cols-4 { grid-template-columns: repeat(4, 1fr); }
.grid-cols-6 { grid-template-columns: repeat(6, 1fr); }
@media (min-width: 640px) {
  .sm-grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
  .sm-grid-cols-4 { grid-template-columns: repeat(4, 1fr); }
}
@media (min-width: 768px) {
  .md-grid-cols-4 { grid-template-columns: repeat(4, 1fr); }
}
@media (min-width: 1024px) {
  .lg-grid-cols-6 { grid-template-columns: repeat(6, 1fr); }
}
@media (min-width: 1400px) {
  .lg-grid-cols-6 { grid-template-columns: repeat(6, 1fr); }
}

/* ===== RESPONSIVE ===== */
.hide-mobile { }
.show-mobile-only { display: none !important; }
@media (max-width: 640px) {
  .show-mobile-only { display: flex !important; }
  .hide-mobile { display: none !important; }
  .grid-cols-4 { grid-template-columns: repeat(2, 1fr); }
  .grid-cols-6 { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 641px) and (max-width: 767px) {
  .grid-cols-6 { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .grid-cols-6 { grid-template-columns: repeat(4, 1fr); }
}

/* ===== WP CONTENT LISTS ===== */
.sb-panel-body ul, .sb-panel-body ol { padding-left: 24px; }
.sb-panel-body li { margin-bottom: 4px; }

/* ===== WP SPECIFIC ===== */
.wp-block-image img { border-radius: 4px; }
.alignnone, .aligncenter { display: block; margin: 0 auto; }
.screen-reader-text { clip: rect(1px, 1px, 1px, 1px); position: absolute !important; height: 1px; width: 1px; overflow: hidden; }
.pagination { display: flex; justify-content: center; gap: 4px; padding: var(--fluid-pad); }
.pagination a, .pagination span { display: inline-block; padding: 4px 10px; background: var(--bg-header); border: 1px solid var(--border-main); border-radius: 3px; color: var(--text-link); font-size: var(--fluid-xs); text-decoration: none; }
.pagination a:hover { background: var(--bg-hover); }
.pagination .current { background: var(--accent-blue); color: #fff; border-color: #3858a0; }

/* ===== SINGLE POST LAYOUT ===== */
.sb-single-layout {
  display: grid;
  grid-template-columns: clamp(180px, 18vw, 280px) 1fr 1fr;
  gap: var(--fluid-gap-lg);
  align-items: start;
}
.sb-single-cover { display: flex; flex-direction: column; align-items: center; }
.sb-single-cover img { box-shadow: 0 4px 20px rgba(0,0,0,0.5); transition: box-shadow 0.3s; }
.sb-single-cover img:hover { box-shadow: 0 6px 28px rgba(0,0,0,0.6); }
.sb-single-info { min-width: 0; }
.sb-single-download {
  padding: var(--fluid-pad);
  background: var(--bg-panel-alt);
  border: 1px solid var(--premium-border);
  border-radius: clamp(3px, 0.4vw, 6px);
  box-shadow: var(--shadow-panel);
}
@media (max-width: 900px) {
  .sb-single-layout {
    grid-template-columns: 35% 1fr;
  }
  .sb-single-download {
    grid-column: 1 / -1;
  }
}
/* Share buttons: desktop under cover, mobile full width under downloads */
.sb-share-mobile { display: none; }
.sb-share-desktop { display: flex; }
/* Mobile: full width, edge-to-edge panels */
@media (max-width: 768px) {
  .sb-wrapper, main.sb-wrapper {
    max-width: 100% !important;
    width: 100% !important;
    padding-left: 6px !important;
    padding-right: 6px !important;
  }
  .sb-panel {
    border-radius: 0 !important;
    border-left: none !important;
    border-right: none !important;
  }
  .sb-nav-inner {
    padding: 0 8px !important;
    max-width: 100% !important;
    width: 100% !important;
  }
  .sb-logo-text { font-size: 18px !important; }
  .sb-logo-lottie { width: 20px !important; height: 20px !important; }
  .grid-cols-6 { grid-template-columns: repeat(2, 1fr) !important; }
  .grid-cols-4 { grid-template-columns: repeat(2, 1fr) !important; }
  .sb-panel-body { padding: var(--fluid-pad-sm) !important; }
  /* Single post: bigger cover, even split */
  .sb-single-layout {
    grid-template-columns: 40% 1fr !important;
    gap: 10px !important;
  }
  .sb-single-download { grid-column: 1 / -1 !important; }
  .sb-share-desktop { display: none !important; }
  .sb-share-mobile { display: block !important; }
  .sb-single-cover img { aspect-ratio: auto !important; }
}

/* ===== DESCRIPTION FORMATTING ===== */
.sb-description { font-size: var(--fluid-sm); line-height: 1.8; color: var(--text-main); }
.sb-description p { margin: 0 0 1em; }
.sb-description p:last-child { margin-bottom: 0; }
.sb-description-collapsed { max-height: 200px; overflow: hidden; position: relative; }
.sb-description-collapsed::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 60px;
  background: linear-gradient(transparent, var(--bg-panel));
  pointer-events: none;
}

/* ===== PREMIUM DOWNLOAD PLUGIN OVERRIDES ===== */
/* Override EVERYTHING the plugin outputs with inline styles */
.premium-download-wrapper {
  background: var(--bg-panel-alt) !important;
  border: 1px solid var(--border-main) !important;
  border-radius: 3px !important;
  padding: var(--fluid-pad) !important;
  font-family: inherit !important;
  color: var(--text-main) !important;
  margin: 0 0 8px 0 !important;
  max-width: 100% !important;
  box-shadow: none !important;
}
.premium-access-btn {
  display: block !important;
  width: 100% !important;
  padding: var(--fluid-pad-sm) var(--fluid-pad) !important;
  background: linear-gradient(180deg, #c89030, #a87020) !important;
  color: #fff !important;
  border: 1px solid #886018 !important;
  border-radius: 3px !important;
  font-family: inherit !important;
  font-size: var(--fluid-sm) !important;
  font-weight: bold !important;
  text-align: center !important;
  text-decoration: none !important;
  cursor: pointer !important;
  transition: background 0.15s !important;
  margin-bottom: 8px !important;
  box-shadow: none !important;
}
.premium-access-btn:hover {
  background: linear-gradient(180deg, #d8a040, #b88030) !important;
  color: #fff !important;
  text-decoration: none !important;
}
.premium-access-btn.locked {
  background: var(--bg-header) !important;
  color: var(--text-dim) !important;
  border-color: var(--border-accent) !important;
  cursor: not-allowed !important;
  box-shadow: none !important;
}
.premium-leech-btn {
  display: block !important;
  width: 100% !important;
  padding: var(--fluid-pad-sm) var(--fluid-pad) !important;
  background: #8b5cf6 !important;
  color: #fff !important;
  border: 1px solid #7c3aed !important;
  border-radius: 3px !important;
  font-family: inherit !important;
  font-size: var(--fluid-sm) !important;
  font-weight: bold !important;
  text-align: center !important;
  text-decoration: none !important;
  cursor: pointer !important;
  margin-top: 8px !important;
}
.premium-leech-btn:hover {
  background: #7c3aed !important;
  color: #fff !important;
  text-decoration: none !important;
}
.premium-leech-btn:disabled, .premium-leech-btn.generate-leech {
  opacity: 0.7 !important;
}
/* Override ALL inline colored text inside the alert msg */
.premium-alert-msg {
  color: var(--text-dim) !important;
  font-size: var(--fluid-xs) !important;
  margin-top: 10px !important;
  line-height: 1.6 !important;
  background: none !important;
  border: none !important;
}
.premium-alert-msg * {
  color: inherit !important;
  font-family: inherit !important;
  background: none !important;
}
.premium-alert-msg a {
  color: var(--accent-gold) !important;
  text-decoration: underline !important;
}
.premium-alert-msg strong {
  color: var(--text-heading) !important;
}
.premium-alert-msg span {
  color: var(--text-dim) !important;
}
/* Override the "Join Patreon" purple gradient button */
.premium-alert-msg a[style*="gradient"],
.premium-alert-msg a[style*="background"] {
  background: var(--accent-blue) !important;
  color: #fff !important;
  border-radius: 3px !important;
  padding: 6px 14px !important;
  font-family: inherit !important;
  text-decoration: none !important;
  display: inline-block !important;
}
/* Override the border-top divider inside alert */
.premium-alert-msg div[style*="border-top"] {
  border-top-color: var(--border-main) !important;
}
/* Report issue button */
.premium-download-wrapper button[style*="background"],
.premium-download-wrapper a[style*="background"] {
  font-family: inherit !important;
}
.credit-unlock-btn {
  background: var(--accent-blue) !important;
  color: #fff !important;
  border: 1px solid #3858a0 !important;
  border-radius: 3px !important;
  padding: var(--fluid-pad-xs) var(--fluid-pad-sm) !important;
  font-family: inherit !important;
  font-size: var(--fluid-xs) !important;
  font-weight: bold !important;
  cursor: pointer !important;
}
.credit-unlock-btn:hover {
  background: #5878b8 !important;
}

/* ===== GLOBAL PLUGIN NOTICE/WARNING OVERRIDES ===== */
/* Nuclear override: ANY div inside download areas with inline background gets dark themed */
.premium-download-wrapper div[style*="background"],
.sb-single-download div[style*="background"],
.leech-status div[style*="background"],
div[class*="leech-status"] div[style*="background"] {
  background: var(--bg-panel-alt) !important;
  border-color: var(--border-accent) !important;
  color: var(--text-main) !important;
}
/* Preserve the dark-themed status box the plugin already uses */
.premium-download-wrapper div[style*="background:#1a1a"],
.sb-single-download div[style*="background:#1a1a"],
div[style*="background:#1a1a"] {
  background: var(--bg-panel-alt) !important;
}
/* Force text colors inside any overridden notice */
.premium-download-wrapper div[style*="background"] *,
.sb-single-download div[style*="background"] *,
div[class*="leech-status"] div[style*="background"] * {
  color: var(--text-main) !important;
  font-family: inherit !important;
}
.premium-download-wrapper div[style*="background"] a,
.sb-single-download div[style*="background"] a,
div[class*="leech-status"] div[style*="background"] a {
  color: var(--text-link) !important;
  text-decoration: underline !important;
}
.premium-download-wrapper div[style*="background"] strong,
.sb-single-download div[style*="background"] strong,
div[class*="leech-status"] div[style*="background"] strong {
  color: var(--text-heading) !important;
}
/* Override border-left colored accents on warning boxes */
.premium-download-wrapper div[style*="border-left"],
.sb-single-download div[style*="border-left"],
div[class*="leech-status"] div[style*="border-left"] {
  border-left-color: var(--accent-gold) !important;
}
/* But don't break the download buttons themselves */
.premium-download-wrapper .premium-access-btn,
.premium-download-wrapper .premium-leech-btn,
.premium-download-wrapper .credit-unlock-btn {
  color: #fff !important;
}

/* ===== QUICKPOST PLUGIN OVERRIDES ===== */
.qpp-container {
  background: var(--bg-panel) !important;
  border: 1px solid var(--border-main) !important;
  border-radius: clamp(3px, 0.4vw, 6px) !important;
  color: var(--text-main) !important;
}
.qpp-section {
  background: var(--bg-panel-alt) !important;
  border-color: var(--border-main) !important;
}
.qpp-input, .qpp-select {
  background: var(--bg-input) !important;
  border-color: var(--border-main) !important;
  color: var(--text-main) !important;
}
.qpp-btn-primary {
  background: var(--accent-blue) !important;
  color: #fff !important;
}
.qpp-btn-success {
  background: var(--accent-green) !important;
  color: #fff !important;
}

/* ===== OAR REQUEST PLUGIN OVERRIDES ===== */
.oar-card {
  background: var(--bg-panel) !important;
  border-color: var(--border-main) !important;
  color: var(--text-main) !important;
  box-shadow: none !important;
}
.oar-card:hover {
  box-shadow: 0 4px 12px rgba(0,0,0,0.3) !important;
}
.oar-card-title {
  color: var(--text-heading) !important;
}
.oar-card-header {
  border-bottom-color: var(--border-main) !important;
}
.oar-modal-content {
  background: var(--bg-panel) !important;
  color: var(--text-main) !important;
}
.oar-modal-content input,
.oar-modal-content textarea {
  background: var(--bg-input) !important;
  border-color: var(--border-main) !important;
  color: var(--text-main) !important;
}
.oar-reply-thread {
  background: var(--bg-panel-alt) !important;
}
.oar-reply-box {
  background: var(--bg-panel) !important;
  border-left-color: var(--accent-blue) !important;
}

/* ===== SHARING PLUGIN OVERRIDES ===== */
.audiobooks-grid .audiobook-card,
.audiobook-card {
  background: var(--bg-panel) !important;
  border-color: var(--border-main) !important;
  color: var(--text-main) !important;
}

/* ===== MEDIA DOWNLOADER PLUGIN OVERRIDES ===== */
#tmd-container {
  background: var(--bg-panel) !important;
  border: 1px solid var(--border-main) !important;
  border-radius: clamp(3px, 0.4vw, 6px) !important;
  box-shadow: none !important;
  font-family: inherit !important;
}
#tmd-container > div:first-child {
  background: var(--bg-header-accent) !important;
  border-bottom: 1px solid var(--border-main) !important;
  padding: var(--fluid-pad-lg) var(--fluid-pad) !important;
}
#tmd-container h1 {
  font-size: var(--fluid-2xl) !important;
  text-shadow: none !important;
  font-family: inherit !important;
}
#tmd-container p { font-family: inherit !important; }
#tmd-container input[type="text"],
#tmd-container input[type="url"],
#tmd-container textarea {
  background: var(--bg-input) !important;
  border: 1px solid var(--border-main) !important;
  color: var(--text-main) !important;
  border-radius: 3px !important;
  font-family: inherit !important;
}
#tmd-container input:focus,
#tmd-container textarea:focus {
  border-color: var(--accent-blue) !important;
  outline: none !important;
  box-shadow: none !important;
}
#tmd-container button,
#tmd-container .tmd-btn,
#tmd-container input[type="submit"] {
  background: var(--accent-blue) !important;
  border: 1px solid #3858a0 !important;
  color: #fff !important;
  border-radius: 3px !important;
  font-family: inherit !important;
  font-weight: bold !important;
  cursor: pointer !important;
}
#tmd-container button:hover { background: #5878b8 !important; }
.tmd-service-tab {
  background: var(--bg-header) !important;
  border: 1px solid var(--border-accent) !important;
  color: var(--text-dim) !important;
  border-radius: 3px !important;
  font-family: inherit !important;
}
.tmd-service-tab.active {
  background: var(--accent-blue) !important;
  color: #fff !important;
  border-color: #3858a0 !important;
}
#tmd-container select {
  background: var(--bg-input) !important;
  border: 1px solid var(--border-main) !important;
  color: var(--text-main) !important;
  border-radius: 3px !important;
}

/* ===== TORRENT PLUGIN OVERRIDES ===== */
#sd-torrent-container {
  background: var(--bg-panel) !important;
  border: 1px solid var(--border-main) !important;
  border-radius: 3px !important;
  box-shadow: none !important;
  font-family: Verdana, Geneva, sans-serif !important;
  color: var(--text-main) !important;
  padding: 0 !important;
  max-width: 900px !important;
}
#sd-torrent-container > div {
  background: var(--bg-panel) !important;
  border-color: var(--border-main) !important;
  border-radius: 0 !important;
}
#sd-torrent-container > div:first-child {
  background: var(--bg-header-accent) !important;
  padding: var(--fluid-pad) !important;
}
#sd-torrent-container h1 {
  font-size: var(--fluid-lg) !important;
  text-shadow: none !important;
  font-family: inherit !important;
  color: var(--text-heading) !important;
  margin: 0 0 6px !important;
}
#sd-torrent-container h1 + p { font-size: var(--fluid-xs) !important; color: var(--text-dim) !important; }
#sd-torrent-container h2 { font-size: var(--fluid-sm) !important; font-family: inherit !important; color: var(--text-heading) !important; }
#sd-torrent-container p, #sd-torrent-container span, #sd-torrent-container label, #sd-torrent-container strong {
  font-family: inherit !important; color: var(--text-main) !important;
}
#sd-torrent-container input[type="text"],
#sd-torrent-container input[type="url"],
#sd-torrent-container textarea {
  background: var(--bg-panel-alt) !important;
  border: 1px solid var(--border-accent) !important;
  color: var(--text-main) !important;
  border-radius: 3px !important;
  font-family: monospace !important;
  font-size: var(--fluid-xs) !important;
  padding: 10px !important;
}
#sd-torrent-container input:focus, #sd-torrent-container textarea:focus {
  border-color: var(--accent-blue) !important;
  box-shadow: none !important;
  outline: none !important;
}
#sd-torrent-container button, #sd-torrent-container button[type="submit"], #sd-torrent-container button[type="button"] {
  border-radius: 3px !important;
  font-family: inherit !important;
  font-weight: bold !important;
  box-shadow: inset 1px 1px 0 rgba(255,255,255,0.05), inset -1px -1px 0 rgba(0,0,0,0.2) !important;
  transition: background 0.15s !important;
  transform: none !important;
}
#sd-torrent-container #submitBtn, #sd-torrent-container button[type="submit"] {
  background: var(--accent-green, #48a848) !important;
  border: 1px solid #388838 !important;
  color: #fff !important;
}
#sd-torrent-container #customFileButton {
  background: var(--accent-blue) !important;
  border: 1px solid #3858a0 !important;
  color: #fff !important;
}
#sd-torrent-container button:hover {
  transform: none !important;
  box-shadow: inset 1px 1px 0 rgba(255,255,255,0.1), inset -1px -1px 0 rgba(0,0,0,0.3) !important;
}
/* My Torrents panel */
#my-torrents-panel {
  background: var(--bg-panel) !important;
  border-top: 1px solid var(--border-main) !important;
  padding: var(--fluid-pad) !important;
}
#my-torrents-panel h2 { font-size: var(--fluid-sm) !important; color: var(--text-heading) !important; }
/* Feature cards in header */
#sd-torrent-container > div:first-child > div:last-child > div {
  background: var(--bg-panel-alt) !important;
  border: 1px solid var(--border-main) !important;
  border-radius: 3px !important;
  border-left: 3px solid var(--accent-blue) !important;
}
/* File list items */
#sd-torrent-container .file-item, #sd-torrent-container label[style*="cursor"] {
  border-bottom: 1px solid var(--border-light) !important;
}
/* OR divider */
#sd-torrent-container span[style*="background: rgba(255,255,255"] {
  background: var(--bg-panel) !important;
  color: var(--text-dim) !important;
}
#sd-torrent-container div[style*="background: #e1e8ed"],
#sd-torrent-container div[style*="background:#e1e8ed"] {
  background: var(--border-main) !important;
}
/* Result/download buttons */
#sd-torrent-container .download-btn, #sd-torrent-container a[style*="background: linear-gradient(135deg, #00b894"] {
  background: var(--accent-green) !important;
  border: 1px solid #388838 !important;
  border-radius: 3px !important;
}
/* Cancel/delete buttons */
#sd-torrent-container button[style*="background: linear-gradient(135deg, #e74c3c"],
#sd-torrent-container button[style*="e74c3c"] {
  background: var(--accent-red) !important;
  border: 1px solid #a83838 !important;
}
/* Info/FAQ sections */
#sd-torrent-container details { background: var(--bg-panel-alt) !important; border: 1px solid var(--border-main) !important; border-radius: 3px !important; }
#sd-torrent-container summary { color: var(--text-heading) !important; }

/* ===== OAR REQUEST PLUGIN FRONTEND OVERRIDES ===== */
.oar-admin-table {
  background: var(--bg-panel) !important;
  border-radius: clamp(3px, 0.4vw, 6px) !important;
  box-shadow: none !important;
  padding: var(--fluid-pad) !important;
  color: var(--text-main) !important;
}
.oar-admin-table table { border-collapse: collapse !important; }
.oar-admin-table th {
  background: var(--bg-header) !important;
  color: var(--text-heading) !important;
  border-color: var(--border-main) !important;
}
.oar-admin-table td {
  border-color: var(--border-main) !important;
  color: var(--text-main) !important;
}
.oar-card {
  background: var(--bg-panel) !important;
  border: 1px solid var(--border-main) !important;
  border-radius: clamp(3px, 0.4vw, 6px) !important;
  box-shadow: none !important;
  color: var(--text-main) !important;
}
.oar-card:hover { box-shadow: 0 4px 12px rgba(0,0,0,0.3) !important; transform: none !important; }
.oar-card-title { color: var(--text-heading) !important; }
.oar-card-header { border-bottom-color: var(--border-main) !important; }
.oar-card-meta { color: var(--text-dim) !important; }
.oar-meta-label { color: var(--text-heading) !important; }
.oar-reply-thread { background: var(--bg-panel-alt) !important; }
.oar-reply-box { background: var(--bg-panel) !important; border-left-color: var(--accent-blue) !important; }
.oar-reply-author { color: var(--accent-blue) !important; }
.oar-search-box {
  background: var(--bg-panel-alt) !important;
  border-radius: clamp(3px, 0.4vw, 6px) !important;
}
.oar-search-box input {
  background: var(--bg-input) !important;
  border: 1px solid var(--border-main) !important;
  color: var(--text-main) !important;
  border-radius: 3px !important;
}
.oar-search-box button {
  background: var(--accent-blue) !important;
  color: #fff !important;
  border-radius: 3px !important;
}
.oar-info-banner {
  background: var(--bg-panel-alt) !important;
  border-left-color: var(--accent-blue) !important;
  border-radius: clamp(3px, 0.4vw, 6px) !important;
}
.oar-info-banner-title { color: var(--text-heading) !important; }
.oar-info-banner-text { color: var(--text-dim) !important; }
.oar-panel-btn {
  background: var(--accent-blue) !important;
  color: #fff !important;
  border-radius: 3px !important;
  box-shadow: none !important;
}
.oar-fulfill-btn, .oar-reply-btn {
  background: var(--accent-green) !important;
  color: #fff !important;
  border-radius: 3px !important;
  box-shadow: none !important;
}
.oar-donate-btn {
  background: var(--accent-gold) !important;
  color: #fff !important;
  border-radius: 3px !important;
  box-shadow: none !important;
}
.oar-status-pending { background: #28201a !important; color: var(--accent-gold) !important; }
.oar-status-fulfilled { background: #1a2a1a !important; color: var(--accent-green) !important; }
.oar-modal { background: rgba(0,0,0,0.7) !important; backdrop-filter: blur(4px) !important; }
.oar-modal-content {
  background: var(--bg-panel) !important;
  border: 1px solid var(--border-main) !important;
  border-radius: clamp(3px, 0.4vw, 6px) !important;
  color: var(--text-main) !important;
  box-shadow: 0 10px 30px rgba(0,0,0,0.5) !important;
}
.oar-modal-header {
  background: var(--bg-header-accent) !important;
  color: var(--text-heading) !important;
}
.oar-modal-content input,
.oar-modal-content textarea {
  background: var(--bg-input) !important;
  border: 1px solid var(--border-main) !important;
  color: var(--text-main) !important;
  border-radius: 3px !important;
}
.oar-modal-content input:focus,
.oar-modal-content textarea:focus {
  border-color: var(--accent-blue) !important;
  box-shadow: none !important;
}
.oar-create-panel {
  background: var(--bg-panel) !important;
  border: 1px solid var(--border-main) !important;
  box-shadow: none !important;
}
.oar-create-panel input,
.oar-create-panel textarea {
  background: var(--bg-input) !important;
  border: 1px solid var(--border-main) !important;
  color: var(--text-main) !important;
}
.oar-create-panel button[type="submit"] {
  background: var(--accent-blue) !important;
  color: #fff !important;
  box-shadow: none !important;
}
.oar-pagination a {
  background: var(--bg-header) !important;
  color: var(--text-link) !important;
  border-radius: 3px !important;
}
.oar-pagination a.active {
  background: var(--accent-blue) !important;
  color: #fff !important;
}
.oar-stats-grid .oar-stat-card {
  border-radius: clamp(3px, 0.4vw, 6px) !important;
}
.oar-rules-panel #oar-rules-toggle {
  background: var(--bg-header) !important;
  color: var(--accent-gold) !important;
}
#oar-rules-content {
  background: var(--bg-panel-alt) !important;
  border-color: var(--border-main) !important;
  color: var(--text-main) !important;
}
.oar-fulfilled-toggle {
  background: var(--bg-panel-alt) !important;
  color: var(--text-heading) !important;
}

/* ===== SUBSTATUS PLUGIN OVERRIDES ===== */
.wrap h1 { color: var(--text-heading) !important; }
.wrap .card, .wrap .postbox {
  background: var(--bg-panel) !important;
  border: 1px solid var(--border-main) !important;
  color: var(--text-main) !important;
}

/* ===== QUICKPOST PLUGIN FRONTEND OVERRIDES ===== */
.qpp-container {
  background: var(--bg-panel) !important;
  border: 1px solid var(--border-main) !important;
  border-radius: clamp(3px, 0.4vw, 6px) !important;
  color: var(--text-main) !important;
  box-shadow: none !important;
}
.qpp-header h1 { color: var(--text-heading) !important; }
.qpp-header p { color: var(--text-dim) !important; }
.qpp-note {
  background: var(--bg-panel-alt) !important;
  border-color: var(--border-main) !important;
}
.qpp-note p { color: var(--text-dim) !important; }
.qpp-section {
  background: var(--bg-panel-alt) !important;
  border-color: var(--border-main) !important;
}
.qpp-section-title { color: var(--text-heading) !important; }
.qpp-input, .qpp-select {
  background: var(--bg-input) !important;
  border: 1px solid var(--border-main) !important;
  color: var(--text-main) !important;
}
.qpp-input:focus, .qpp-select:focus {
  border-color: var(--accent-blue) !important;
  box-shadow: none !important;
}
.qpp-checkbox-label { color: var(--text-body, var(--text-main)) !important; }
.qpp-btn-primary {
  background: var(--accent-blue) !important;
  color: #fff !important;
  box-shadow: none !important;
}
.qpp-btn-success {
  background: var(--accent-green) !important;
  color: #fff !important;
  box-shadow: none !important;
}
.qpp-btn-danger {
  background: var(--accent-red) !important;
  color: #fff !important;
  box-shadow: none !important;
}
.qpp-btn-secondary {
  background: var(--bg-header) !important;
  color: var(--text-heading) !important;
  border-color: var(--border-accent) !important;
}
.qpp-modal-content {
  background: var(--bg-panel) !important;
  color: var(--text-main) !important;
  box-shadow: 0 10px 30px rgba(0,0,0,0.5) !important;
}
.qpp-modal-header {
  background: var(--bg-header-accent) !important;
}

/* ===== NOT LOGGED IN DOWNLOAD OVERRIDE ===== */
/* The premium_download shortcode sometimes shows nothing for non-logged-in users.
   The theme handles this case directly in single.php, but just in case: */
.premium-download-wrapper a[href*="wp-login"],
.premium-download-wrapper a[href*="register"] {
  display: inline-block !important;
  padding: var(--fluid-pad-sm) var(--fluid-pad) !important;
  background: var(--accent-blue) !important;
  color: #fff !important;
  border: 1px solid #3858a0 !important;
  border-radius: 3px !important;
  font-weight: bold !important;
  text-decoration: none !important;
  margin: 4px !important;
}

/* ===== TRENDING CAROUSEL ===== */
.sb-trend-card {
  display: flex;
  flex-direction: column;
  transition: transform 0.2s;
}
.sb-trend-card:hover {
  transform: translateY(-3px);
}
.sb-trend-card:hover img {
  border-color: var(--accent-blue) !important;
}
.sb-trend-card:hover p:first-of-type {
  color: var(--text-heading);
}

/* ===== FOOTER ENHANCEMENT ===== */
footer { position: relative; }
footer::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.06), transparent);
}

/* ===== WP ADMIN BAR HIDE FOR NON-ADMINS ===== */
body:not(.logged-in) #wpadminbar,
.subscriber #wpadminbar {
  display: none !important;
}
body:not(.logged-in) { margin-top: 0 !important; }
html { margin-top: 0 !important; }

/* ===== NEUMORPHISM AUTH PAGES ===== */
.page-template-page-login .sb-panel,
.page-template-page-register .sb-panel,
.page-template-page-forgot-password .sb-panel {
  border: none;
  border-radius: 12px;
  box-shadow: 8px 8px 16px #0a0a10, -8px -8px 16px #1e1e30;
  background: var(--bg-panel);
}
.page-template-page-login .sb-panel-header,
.page-template-page-register .sb-panel-header,
.page-template-page-forgot-password .sb-panel-header {
  background: transparent;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.page-template-page-login .sb-input,
.page-template-page-register .sb-input,
.page-template-page-forgot-password .sb-input {
  background: #141420;
  border: none;
  border-radius: 8px;
  box-shadow: inset 3px 3px 6px #0a0a10, inset -3px -3px 6px #1e1e30;
  padding: 12px 14px;
  color: var(--text-main);
  transition: box-shadow 0.2s;
}
.page-template-page-login .sb-input:focus,
.page-template-page-register .sb-input:focus,
.page-template-page-forgot-password .sb-input:focus {
  outline: none;
  box-shadow: inset 3px 3px 6px #0a0a10, inset -3px -3px 6px #1e1e30, 0 0 0 2px rgba(72,104,168,0.4);
}
.page-template-page-login .sb-btn-primary,
.page-template-page-register .sb-btn-green,
.page-template-page-forgot-password .sb-btn-primary {
  border: none;
  border-radius: 8px;
  box-shadow: 4px 4px 10px #0a0a10, -4px -4px 10px #1e1e30, inset 0 1px 0 rgba(255,255,255,0.15);
  transition: box-shadow 0.2s, transform 0.15s;
}
.page-template-page-login .sb-btn-primary:hover,
.page-template-page-register .sb-btn-green:hover,
.page-template-page-forgot-password .sb-btn-primary:hover {
  box-shadow: 2px 2px 5px #0a0a10, -2px -2px 5px #1e1e30;
  transform: translateY(1px);
}
.page-template-page-login .sb-btn-primary:active,
.page-template-page-register .sb-btn-green:active,
.page-template-page-forgot-password .sb-btn-primary:active {
  box-shadow: inset 3px 3px 6px #0a0a10, inset -2px -2px 4px #1e1e30;
}
