/* =============================================
   SPNZ BLOG — Main Stylesheet
   Bootstrap 5 + Custom Theme
   Colors: Dark Gray #1A1A1A + Mustard #E8B84B
   ============================================= */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Barlow+Condensed:wght@400;600;700;800&family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap');

:root {
  --c-primary:      #E8B84B;
  --c-primary-dk:   #C9991A;
  --c-primary-lt:   #F5D07A;
  --c-bg:           #1A1A1A;
  --c-bg2:          #222222;
  --c-bg3:          #2C2C2C;
  --c-bg4:          #363636;
  --c-text:         #F0F0F0;
  --c-muted:        #A0A0A0;
  --c-faint:        #555555;
  --c-border:       #333333;
  --c-border2:      #444444;
  --f-display:      'Bebas Neue', Impact, sans-serif;
  --f-heading:      'Barlow Condensed', 'Arial Narrow', sans-serif;
  --f-body:         'DM Sans', 'Helvetica Neue', sans-serif;
  --shadow-card:    0 4px 24px rgba(0,0,0,.55);
  --shadow-glow:    0 0 28px rgba(232,184,75,.22);
  --radius-card:    12px;
  --transition:     .22s ease;

  /* Bootstrap overrides */
  --bs-body-bg:            #1A1A1A;
  --bs-body-color:         #F0F0F0;
  --bs-border-color:       #333;
  --bs-card-bg:            #222;
  --bs-card-border-color:  #333;
  --bs-dropdown-bg:        #2C2C2C;
  --bs-dropdown-color:     #F0F0F0;
  --bs-dropdown-link-color:#F0F0F0;
  --bs-dropdown-link-hover-bg: #363636;
  --bs-dropdown-link-hover-color: #E8B84B;
}

/* ── Reset & Base ── */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--f-body);
  background: var(--c-bg);
  color: var(--c-text);
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
}

h1,h2,h3,h4,h5,h6 { font-family: var(--f-heading); font-weight: 700; }

a { color: var(--c-primary); transition: color var(--transition); }
a:hover { color: var(--c-primary-lt); }

img { max-width: 100%; }

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

::-webkit-scrollbar { width: 7px; }
::-webkit-scrollbar-track { background: var(--c-bg2); }
::-webkit-scrollbar-thumb { background: var(--c-bg4); border-radius: 99px; }
::-webkit-scrollbar-thumb:hover { background: var(--c-primary); }

/* ── Bootstrap Button Variants ── */
.btn-spnz {
  background: var(--c-primary); border-color: var(--c-primary); color: #1a1a1a;
  font-family: var(--f-heading); font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; font-size: .875rem;
  transition: all var(--transition);
}
.btn-spnz:hover {
  background: var(--c-primary-lt); border-color: var(--c-primary-lt); color: #1a1a1a;
  box-shadow: var(--shadow-glow); transform: translateY(-1px);
}
.btn-outline-spnz {
  border-color: var(--c-primary); color: var(--c-primary);
  font-family: var(--f-heading); font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; font-size: .875rem; transition: all var(--transition);
}
.btn-outline-spnz:hover { background: var(--c-primary); color: #1a1a1a; border-color: var(--c-primary); }

.btn-dark-ghost {
  background: transparent; border: 1px solid var(--c-border2); color: var(--c-muted);
  font-family: var(--f-heading); font-weight: 600; text-transform: uppercase;
  letter-spacing: .06em; font-size: .8rem; transition: all var(--transition);
}
.btn-dark-ghost:hover { background: var(--c-bg3); color: var(--c-text); border-color: var(--c-border2); }

/* ── Badges ── */
.bg-spnz   { background: var(--c-primary) !important; }
.text-spnz { color: var(--c-primary) !important; }
.badge-spnz { background: var(--c-primary); color: #1a1a1a; font-family: var(--f-heading); font-weight: 700; text-transform: uppercase; letter-spacing: .06em; }
.badge-dark { background: var(--c-bg4); color: var(--c-muted); font-family: var(--f-heading); font-weight: 600; text-transform: uppercase; letter-spacing: .06em; }

/* ── Forms ── */
.form-control, .form-select {
  background: var(--c-bg3); border-color: var(--c-border2); color: var(--c-text);
  transition: border-color var(--transition), box-shadow var(--transition);
}
.form-control:focus, .form-select:focus {
  background: var(--c-bg3); border-color: var(--c-primary); color: var(--c-text);
  box-shadow: 0 0 0 3px rgba(232,184,75,.18);
}
.form-control::placeholder { color: var(--c-faint); }
.form-label { font-family: var(--f-heading); font-size: .8rem; text-transform: uppercase; letter-spacing: .08em; color: var(--c-muted); font-weight: 600; }
.form-check-input { background-color: var(--c-bg3); border-color: var(--c-border2); }
.form-check-input:checked { background-color: var(--c-primary); border-color: var(--c-primary); }

/* ── Cards ── */
.spnz-card {
  background: var(--c-bg2); border: 1px solid var(--c-border); border-radius: var(--radius-card);
  overflow: hidden; transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.spnz-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-card); border-color: var(--c-border2); }
.spnz-card .card-img-top { transition: transform .4s ease; height: 200px; object-fit: cover; }
.spnz-card:hover .card-img-top { transform: scale(1.04); }

/* ── Navbar ── */
.spnz-navbar {
  background: rgba(26,26,26,.97) !important;
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--c-border); padding-block: .75rem;
  transition: box-shadow var(--transition);
}
.spnz-navbar.scrolled { box-shadow: 0 4px 24px rgba(0,0,0,.7); }
.spnz-brand {
  font-family: var(--f-display); font-size: 1.8rem; letter-spacing: .12em;
  text-transform: uppercase; color: var(--c-primary) !important; text-decoration: none;
}
.spnz-brand:hover { opacity: .85; }
.spnz-navbar .nav-link {
  font-family: var(--f-heading); font-size: .875rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: .06em; color: var(--c-muted) !important;
  padding: .5rem .9rem !important; border-radius: 6px; transition: all var(--transition);
}
.spnz-navbar .nav-link:hover,
.spnz-navbar .nav-link.active { color: var(--c-primary) !important; background: rgba(232,184,75,.08); }
.navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28240,240,240,.8%29' stroke-width='2' stroke-linecap='round' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}
.navbar-toggler { border-color: rgba(255,255,255,.15); }
.dropdown-menu {
  background: var(--c-bg3); border-color: var(--c-border2);
  border-radius: 10px; box-shadow: 0 8px 32px rgba(0,0,0,.5);
}
.dropdown-item { color: var(--c-muted); font-family: var(--f-heading); font-size: .875rem; text-transform: uppercase; letter-spacing: .04em; }
.dropdown-item:hover { background: rgba(232,184,75,.08); color: var(--c-primary); }

/* ── Section titles ── */
.section-title {
  font-family: var(--f-display); font-size: clamp(1.75rem,3vw,2.5rem); text-transform: uppercase;
  letter-spacing: .05em; position: relative; padding-bottom: .75rem; margin-bottom: 0;
}
.section-title::after {
  content: ''; position: absolute; bottom: 0; left: 0;
  width: 48px; height: 3px; background: var(--c-primary); border-radius: 99px;
}

/* ── Hero ── */
.spnz-hero {
  position: relative; min-height: 85vh; display: flex; align-items: center; overflow: hidden;
}
.spnz-hero__bg {
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 60% 55% at 80% 50%, rgba(232,184,75,.13) 0%, transparent 65%),
              radial-gradient(ellipse 40% 60% at 5% 80%, rgba(232,184,75,.07) 0%, transparent 65%),
              linear-gradient(135deg, #1a1a1a 0%, #1e1e1e 100%);
}
.spnz-hero__bg::after {
  content: ''; position: absolute; inset: 0;
  background-image: repeating-linear-gradient(0deg, transparent, transparent 60px, rgba(255,255,255,.013) 60px, rgba(255,255,255,.013) 61px),
                    repeating-linear-gradient(90deg, transparent, transparent 60px, rgba(255,255,255,.013) 60px, rgba(255,255,255,.013) 61px);
}
.spnz-hero .container { position: relative; z-index: 1; }
.hero-title { font-family: var(--f-display) !important; line-height: .95 !important; letter-spacing: .02em !important; }

/* ── Post card ── */
.post-card { text-decoration: none; display: block; color: inherit; }
.post-card:hover { color: inherit; }
.post-card .spnz-card { height: 100%; }
.post-card__img { height: 200px; overflow: hidden; }
.post-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.post-card:hover .post-card__img img { transform: scale(1.05); }
.post-card__body { padding: 1.25rem; }
.post-card__cat { font-family: var(--f-heading); font-size: .7rem; text-transform: uppercase; letter-spacing: .1em; }
.post-card__title { font-family: var(--f-heading); font-size: 1.15rem; font-weight: 700; line-height: 1.3; margin-block: .4rem .5rem; color: var(--c-text); transition: color var(--transition); }
.post-card:hover .post-card__title { color: var(--c-primary); }
.post-card__meta { font-size: .75rem; color: var(--c-faint); }

/* ── Artist card ── */
.artist-card { text-decoration: none; display: block; color: inherit; }
.artist-card:hover { color: inherit; }
.artist-card__img { border-radius: 50%; width: 110px; height: 110px; object-fit: cover; border: 3px solid var(--c-border2); transition: border-color var(--transition); margin: 0 auto 1rem; display: block; }
.artist-card:hover .artist-card__img { border-color: var(--c-primary); }
.artist-card__name { font-family: var(--f-heading); font-weight: 700; color: var(--c-text); transition: color var(--transition); }
.artist-card:hover .artist-card__name { color: var(--c-primary); }

/* ── Single post ── */
.post-cover { width: 100%; max-height: 480px; object-fit: cover; border-radius: var(--radius-card); }
.post-title { font-family: var(--f-display); font-size: clamp(2rem,5vw,3.5rem); text-transform: uppercase; letter-spacing: .03em; line-height: 1.05; }
.post-body { line-height: 1.85; color: #d0d0d0; font-size: 1.05rem; }
.post-body h2,.post-body h3,.post-body h4 { font-family: var(--f-heading); margin-top: 2rem; margin-bottom: .75rem; }
.post-body p { margin-bottom: 1.25rem; }
.post-body ul,.post-body ol { padding-left: 1.5rem; margin-bottom: 1.25rem; }
.post-body ul { list-style: disc; }
.post-body blockquote { border-left: 4px solid var(--c-primary); padding-left: 1.25rem; color: var(--c-muted); font-style: italic; margin-left: 0; }
.post-body img { border-radius: 8px; max-width: 100%; }
.post-body a { text-decoration: underline; text-decoration-color: var(--c-primary); }

/* ── Comments ── */
.comment-item { background: var(--c-bg2); border: 1px solid var(--c-border); border-radius: 10px; padding: 1.25rem; }
.comment-avatar { width: 42px; height: 42px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }

/* ── Sidebar ── */
.sidebar-widget { background: var(--c-bg2); border: 1px solid var(--c-border); border-radius: var(--radius-card); padding: 1.5rem; margin-bottom: 1.5rem; }
.sidebar-widget__title { font-family: var(--f-heading); font-size: .8rem; text-transform: uppercase; letter-spacing: .1em; color: var(--c-muted); padding-bottom: .6rem; border-bottom: 1px solid var(--c-border); margin-bottom: 1rem; }

/* ── Auth pages ── */
.auth-card { background: var(--c-bg2); border: 1px solid var(--c-border); border-radius: 16px; padding: 2.5rem; max-width: 440px; width: 100%; }
.auth-page { min-height: 100vh; display: flex; align-items: center; justify-content: center; background: var(--c-bg); }
.auth-page::before {
  content: ''; position: fixed; inset: 0; pointer-events: none;
  background: radial-gradient(ellipse 50% 50% at 50% 50%, rgba(232,184,75,.07) 0%, transparent 70%);
}

/* ── Alerts ── */
.alert-success-spnz { background: rgba(78,160,78,.15); border: 1px solid #4ea04e; color: #7ee87e; }
.alert-danger-spnz  { background: rgba(229,57,53,.15);  border: 1px solid #e53935; color: #ff7b77; }

/* ── Pagination ── */
.spnz-page-link {
  background: var(--c-bg3); border-color: var(--c-border2); color: var(--c-text);
  font-weight: 600; border-radius: 8px !important; transition: all var(--transition);
}
.spnz-page-link:hover, .page-item.active .spnz-page-link {
  background: var(--c-primary); border-color: var(--c-primary); color: #1a1a1a;
}

/* ── Search form ── */
.spnz-search .form-control { background: var(--c-bg3); border-color: var(--c-border2); color: var(--c-text); }
.spnz-search .form-control:focus { border-color: var(--c-primary); box-shadow: 0 0 0 3px rgba(232,184,75,.15); }

/* ── Archive hero ── */
.archive-hero { background: var(--c-bg2); border-bottom: 1px solid var(--c-border); padding-block: 3rem; }

/* ── Footer ── */
.spnz-footer { background: var(--c-bg2); border-top: 1px solid var(--c-border); }
.spnz-footer__bottom { background: var(--c-bg); border-top: 1px solid var(--c-border); }
.footer-logo { font-family: var(--f-display); font-size: 2rem; letter-spacing: .1em; text-transform: uppercase; color: var(--c-primary); text-decoration: none; }
.footer-nav a { color: var(--c-faint); font-size: .8rem; text-decoration: none; transition: color var(--transition); }
.footer-nav a:hover { color: var(--c-primary); }

/* ── Breadcrumbs ── */
.breadcrumb { font-size: .8rem; background: none; padding: 0; }
.breadcrumb-item a { color: var(--c-muted); text-decoration: none; }
.breadcrumb-item.active { color: var(--c-faint); }
.breadcrumb-item + .breadcrumb-item::before { color: var(--c-border2); content: "/"; }

/* ── User avatar ── */
.user-avatar { width: 36px; height: 36px; border-radius: 50%; object-fit: cover; border: 2px solid var(--c-border2); }

/* ── Tag pills ── */
.tag-pill { display: inline-block; padding: 3px 10px; background: var(--c-bg4); color: var(--c-muted); border-radius: 99px; font-size: .72rem; font-family: var(--f-heading); font-weight: 600; text-transform: uppercase; letter-spacing: .08em; text-decoration: none; transition: all var(--transition); border: 1px solid var(--c-border2); }
.tag-pill:hover { background: var(--c-primary); color: #1a1a1a; border-color: var(--c-primary); }

/* ── Misc ── */
.text-display { font-family: var(--f-display); }
.text-heading { font-family: var(--f-heading); }
.ls-wide { letter-spacing: .1em; }
.divider { border: none; border-top: 1px solid var(--c-border); }

@media (max-width: 767px) {
  .spnz-hero { min-height: auto; padding-block: 4rem; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}
