/* ============================================================
   BLACKBOX THEATER CINEMA — Cassiopeia Dark Theme
   Inspired by original blackbox-theater-cinema.com
   Fonts: Nunito Sans (body) | Poppins (headings) | Roboto Condensed (nav)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Nunito+Sans:ital,wght@0,300;0,400;0,600;0,700;1,400&family=Poppins:wght@400;600;700;800&family=Roboto+Condensed:wght@300;400;700&display=swap');

/* ── Variables ───────────────────────────────────────────── */
:root {
  --bb-bg:          #131313;
  --bb-bg-card:     #1c1c1c;
  --bb-bg-header:   #0a0a0a;
  --bb-bg-sidebar:  #0f0f0f;
  --bb-text:        rgba(255, 255, 255, 0.82);
  --bb-text-muted:  rgba(255, 255, 255, 0.45);
  --bb-white:       #ffffff;
  --bb-accent:      #00b4ff;
  --bb-accent-hover:#66d4ff;
  --bb-border:      rgba(255, 255, 255, 0.08);

  /* Override Cassiopeia core vars */
  --cassiopeia-color-primary:  #00b4ff;
  --cassiopeia-color-link:     #00b4ff;
  --cassiopeia-color-hover:    #66d4ff;
  --link-color:                #00b4ff;
  --link-hover-color:          #66d4ff;
  --template-bg-light:         #1c1c1c;
  --template-text-dark:        rgba(255, 255, 255, 0.82);
  --template-text-light:       #ffffff;
  --template-link-color:       #00b4ff;
  --template-special-color:    #131313;
}

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

html, body {
  background-color: var(--bb-bg) !important;
  color: var(--bb-text) !important;
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  line-height: 1.75 !important;
}

/* ── Typography ──────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  font-family: 'Poppins', sans-serif !important;
  color: var(--bb-white) !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em;
  line-height: 1.25 !important;
}

h1 { font-size: 2.4rem !important; }
h2 { font-size: 1.8rem !important; }
h3 { font-size: 1.35rem !important; }

p { color: var(--bb-text) !important; }

strong, b { color: var(--bb-white) !important; }

hr {
  border-color: var(--bb-border) !important;
  opacity: 1 !important;
}

/* ── Links ───────────────────────────────────────────────── */
a {
  color: var(--bb-text) !important;
  font-family: 'Roboto Condensed', sans-serif !important;
  text-decoration: none !important;
  transition: color 0.2s ease !important;
}

a:hover, a:focus {
  color: var(--bb-accent) !important;
  text-decoration: none !important;
}

/* ── Header ──────────────────────────────────────────────── */
header.header,
.header,
.container-header {
  background-color: var(--bb-bg-header) !important;
  background-image: none !important;
  border-bottom: 1px solid rgba(255,255,255,0.1) !important;
  padding: 0.5rem 0 !important;
}

header.header.position-sticky {
  position: sticky !important;
  top: 0 !important;
  z-index: 1000 !important;
}

/* Dropdown submenu bg (Cassiopeia default is #fff) */
.container-header .mod-menu__sub,
.container-header :where(.mod-menu__sub:not(.mod-menu__sub *)) {
  background-color: #161616 !important;
  border: 1px solid var(--bb-border) !important;
}

/* ── Brand / Logo ────────────────────────────────────────── */
.navbar-brand,
.brand-logo {
  color: var(--bb-white) !important;
  font-family: 'Poppins', sans-serif !important;
  font-weight: 800 !important;
  font-size: 1.2rem !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
}

.navbar-brand:hover, .brand-logo:hover {
  color: var(--bb-accent) !important;
}

.brand-logo img {
  max-height: 75px !important;
  width: auto !important;
}

.site-description {
  color: var(--bb-text-muted) !important;
  font-size: 0.75rem !important;
  font-family: 'Roboto Condensed', sans-serif !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
}

/* ── Navigation ──────────────────────────────────────────── */
.container-nav, nav, .navbar {
  background-color: transparent !important;
}

/* Top-level menu links */
.mod-menu__link,
.nav-item > a,
.nav-link {
  color: rgba(255, 255, 255, 0.85) !important;
  font-family: 'Roboto Condensed', sans-serif !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  padding: 0.5rem 0.9rem !important;
  transition: color 0.2s ease !important;
}

.mod-menu__link:hover,
.nav-item > a:hover,
.nav-link:hover,
.mod-menu__link.active,
.nav-item.active > a,
.current .mod-menu__link {
  color: var(--bb-accent) !important;
}

/* Dropdown */
.dropdown-menu {
  background-color: #161616 !important;
  border: 1px solid var(--bb-border) !important;
  border-radius: 4px !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.6) !important;
}

.dropdown-item {
  color: rgba(255, 255, 255, 0.8) !important;
  font-family: 'Roboto Condensed', sans-serif !important;
  font-size: 13px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  padding: 0.5rem 1.2rem !important;
}

.dropdown-item:hover, .dropdown-item:focus {
  background-color: rgba(0, 180, 255, 0.1) !important;
  color: var(--bb-accent) !important;
}

/* ── Mobile hamburger ────────────────────────────────────── */
.navbar-toggler {
  border: 2px solid rgba(255,255,255,0.4) !important;
  border-radius: 4px !important;
  padding: 0.4rem 0.6rem !important;
  background: transparent !important;
  line-height: 1 !important;
}

.navbar-toggler:focus {
  box-shadow: 0 0 0 2px rgba(0,180,255,0.4) !important;
}

/* icomoon font icon — needs color not filter */
.icon-menu {
  color: #fff !important;
  font-size: 1.4rem !important;
  display: block !important;
  line-height: 1 !important;
}

/* Bootstrap SVG toggler-icon (fallback) */
.navbar-toggler-icon {
  filter: invert(1) brightness(2) !important;
}

/* ── Mobile nav dropdown ─────────────────────────────────── */
@media (max-width: 767px) {
  /* Hide brand text on desktop, show on mobile */
  .navbar-brand {
    font-size: 1rem !important;
    letter-spacing: 0.1em !important;
  }

  /* Collapsed menu panel */
  .navbar-collapse {
    background-color: #0d0d0d !important;
    border-top: 1px solid rgba(255,255,255,0.1) !important;
    margin-top: 0.5rem !important;
    padding: 0.5rem 0 !important;
  }

  /* Menu items in dropdown */
  .navbar-collapse .mod-menu__link,
  .navbar-collapse .nav-link,
  .navbar-collapse .nav-item > a {
    display: block !important;
    padding: 0.7rem 1.2rem !important;
    font-size: 14px !important;
    letter-spacing: 0.1em !important;
    border-bottom: 1px solid rgba(255,255,255,0.05) !important;
    color: rgba(255,255,255,0.8) !important;
  }

  .navbar-collapse .mod-menu__link:hover,
  .navbar-collapse .nav-item > a:hover {
    background-color: rgba(0,180,255,0.08) !important;
    color: var(--bb-accent) !important;
    border-left: 3px solid var(--bb-accent) !important;
    padding-left: calc(1.2rem - 3px) !important;
  }

  /* Hide desktop brand text, show mobile compact */
  .site-description { display: none !important; }

  /* Sidebar hidden on mobile (too cramped) */
  .container-sidebar-left { display: none !important; }

  /* Hero aspect ratio on mobile */
  .bb-hero { aspect-ratio: 16 / 9; max-height: 56vw; }
}

@media (min-width: 768px) {
  /* On desktop: hide the text brand (hero is the visual brand) */
  .navbar-brand { display: none !important; }
}

/* ── Site grid & containers ──────────────────────────────── */
.site-grid {
  background-color: var(--bb-bg) !important;
}

.container-component {
  background-color: var(--bb-bg) !important;
}

/* ── Sidebar ─────────────────────────────────────────────── */
.container-sidebar-left,
.container-sidebar-right {
  background-color: var(--bb-bg-sidebar) !important;
  border-right: 1px solid var(--bb-border) !important;
  align-self: start !important;
}

/* ── Cards (modules) ─────────────────────────────────────── */
.card {
  background-color: var(--bb-bg-card) !important;
  border: 1px solid var(--bb-border) !important;
  color: var(--bb-text) !important;
  border-radius: 6px !important;
}

.card-header {
  background-color: rgba(255,255,255,0.04) !important;
  border-bottom: 1px solid var(--bb-border) !important;
  color: var(--bb-white) !important;
  font-family: 'Poppins', sans-serif !important;
  font-weight: 700 !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
}

.card-body {
  color: var(--bb-text) !important;
}

/* ── Articles / Blog ─────────────────────────────────────── */
.com-content-article__body,
.com-content-blog,
.item-page {
  color: var(--bb-text) !important;
}

.article-header h2 a,
.page-header h1,
.com-content-article__header h1 {
  color: var(--bb-white) !important;
  font-family: 'Poppins', sans-serif !important;
}

.article-info,
.article-info dd,
.article-info dt,
.com-content-article__info {
  color: var(--bb-text-muted) !important;
  font-size: 13px !important;
}

.article-info a { color: var(--bb-text-muted) !important; }
.article-info a:hover { color: var(--bb-accent) !important; }

/* Read more button */
.readmore a,
a.btn-primary,
.btn-primary {
  background-color: var(--bb-accent) !important;
  border-color: var(--bb-accent) !important;
  color: #000 !important;
  font-family: 'Roboto Condensed', sans-serif !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  font-size: 13px !important;
  padding: 0.45rem 1.2rem !important;
  border-radius: 3px !important;
}

.readmore a:hover, a.btn-primary:hover, .btn-primary:hover {
  background-color: var(--bb-accent-hover) !important;
  color: #000 !important;
}

/* Blog separator */
.items-row + .items-row { border-top: 1px solid var(--bb-border) !important; padding-top: 2rem !important; }

/* Leading article: clear float so Read More appears BELOW image, not beside it */
.items-leading .com-content-article__body,
.items-leading .article-intro {
  overflow: hidden;
}

.items-leading .readmore {
  clear: both !important;
  display: block !important;
  padding-top: 1rem !important;
  margin-top: 0.5rem !important;
}

/* Intro articles (2-col grid): equal height feel */
.items-row .com-content-article__body,
.items-row .article-intro {
  min-height: 80px;
}

/* ── Breadcrumbs ─────────────────────────────────────────── */
.breadcrumb {
  background-color: transparent !important;
  padding: 0.5rem 0 !important;
}

.breadcrumb-item a {
  color: var(--bb-text-muted) !important;
}

.breadcrumb-item.active,
.breadcrumb-item + .breadcrumb-item::before {
  color: var(--bb-text-muted) !important;
}

/* ── Pagination ──────────────────────────────────────────── */
.page-link {
  background-color: var(--bb-bg-card) !important;
  border-color: var(--bb-border) !important;
  color: var(--bb-text) !important;
}

.page-link:hover {
  background-color: rgba(0,180,255,0.15) !important;
  color: var(--bb-accent) !important;
}

.page-item.active .page-link {
  background-color: var(--bb-accent) !important;
  border-color: var(--bb-accent) !important;
  color: #000 !important;
}

/* ── Tags & badges ───────────────────────────────────────── */
.badge,
.label {
  background-color: var(--bb-accent) !important;
  color: #000 !important;
}

/* ── Images ──────────────────────────────────────────────── */
img { max-width: 100%; height: auto; }

.item-image img,
.com-content-article__image img {
  border-radius: 4px !important;
}

/* ── Footer ──────────────────────────────────────────────── */
footer.footer,
.footer {
  background-color: var(--bb-bg-header) !important;
  border-top: 1px solid var(--bb-border) !important;
  color: var(--bb-text-muted) !important;
  padding: 2rem 0 !important;
  font-size: 14px !important;
}

footer.footer a, .footer a {
  color: var(--bb-text-muted) !important;
}

footer.footer a:hover, .footer a:hover {
  color: var(--bb-accent) !important;
}

/* ── Bootstrap overrides ─────────────────────────────────── */
.bg-light  { background-color: var(--bb-bg-card) !important; }
.bg-white  { background-color: var(--bb-bg-card) !important; }
.text-muted { color: var(--bb-text-muted) !important; }
.text-dark  { color: var(--bb-white) !important; }
.border     { border-color: var(--bb-border) !important; }

/* ── btn-secondary (pagination Prev/Next) ────────────────── */
.btn-secondary,
a.btn-secondary {
  --btn-bg: #3a3a3a;
  --btn-color: rgba(255,255,255,0.85);
  --btn-border-color: rgba(255,255,255,0.2);
  background-color: #3a3a3a !important;
  border-color: rgba(255,255,255,0.2) !important;
  color: rgba(255,255,255,0.85) !important;
}

.btn-secondary:hover,
a.btn-secondary:hover {
  --btn-hover-bg: rgba(0,180,255,0.15);
  --btn-hover-color: var(--bb-accent);
  --btn-hover-border-color: var(--bb-accent);
  background-color: rgba(0,180,255,0.15) !important;
  border-color: var(--bb-accent) !important;
  color: var(--bb-accent) !important;
}

.btn-secondary:disabled,
.btn-secondary.disabled {
  background-color: #2a2a2a !important;
  border-color: rgba(255,255,255,0.08) !important;
  color: rgba(255,255,255,0.3) !important;
}

/* ── Alerts ──────────────────────────────────────────────── */
.alert {
  background-color: var(--bb-bg-card) !important;
  border-color: var(--bb-border) !important;
  color: var(--bb-text) !important;
}

/* ── Tables ──────────────────────────────────────────────── */
table, .table {
  color: var(--bb-text) !important;
}

.table thead th {
  border-bottom-color: var(--bb-border) !important;
  color: var(--bb-white) !important;
  font-family: 'Poppins', sans-serif !important;
}

.table tbody tr { background-color: transparent !important; }
.table tbody tr:nth-child(even) { background-color: rgba(255,255,255,0.03) !important; }
.table td, .table th { border-color: var(--bb-border) !important; }

/* ── Forms ───────────────────────────────────────────────── */
.form-control, input, textarea, select,
.form-select, .custom-select {
  background-color: #1e1e1e !important;
  border-color: rgba(255,255,255,0.15) !important;
  color: var(--bb-white) !important;
}

.form-select, .custom-select {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23aaaaaa' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e") !important;
}

.form-control:focus, input:focus, textarea:focus,
.form-select:focus, .custom-select:focus {
  border-color: var(--bb-accent) !important;
  box-shadow: 0 0 0 3px rgba(0,180,255,0.2) !important;
  background-color: #1e1e1e !important;
  color: var(--bb-white) !important;
}

/* ── Back to top ─────────────────────────────────────────── */
#back-top {
  background-color: var(--bb-accent) !important;
  color: #000 !important;
  border-radius: 3px !important;
}

/* ── Phoca Gallery ───────────────────────────────────────── */

/* Hide branding & RSS */
#phocagallery .pg-top-icons,
#phocagallery [style*="Powered by"],
#phocagallery div[style*="color:#ccc"] {
  display: none !important;
}

/* Categories grid */
#phocagallery .pg-categories-items-box {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)) !important;
  gap: 1.5rem !important;
  padding: 1rem 0 !important;
}

/* Each category card */
#phocagallery .pg-category-box {
  position: relative !important;
  overflow: hidden !important;
  border-radius: 6px !important;
  background: var(--bb-bg-card) !important;
  border: 1px solid var(--bb-border) !important;
  transition: transform 0.25s ease, box-shadow 0.25s ease !important;
}

#phocagallery .pg-category-box:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 12px 32px rgba(0,0,0,0.6) !important;
}

/* Thumbnail — full width, fixed height, cover crop */
#phocagallery .pg-category-box-image {
  width: 100% !important;
  height: 200px !important;
  overflow: hidden !important;
  display: block !important;
}

#phocagallery .pg-category-box-image a {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
}

#phocagallery .pg-category-box-image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  transition: transform 0.4s ease !important;
}

#phocagallery .pg-category-box:hover .pg-category-box-image img {
  transform: scale(1.06) !important;
}

/* Hide category folder SVG icon */
#phocagallery .ph-si-category,
#phocagallery svg.ph-si {
  display: none !important;
}

/* Category info bar */
#phocagallery .pg-category-box-info {
  padding: 0.8rem 1rem !important;
  background: var(--bb-bg-card) !important;
}

#phocagallery .pg-category-box-title {
  font-family: 'Poppins', sans-serif !important;
  font-size: 0.95rem !important;
  font-weight: 600 !important;
  color: var(--bb-white) !important;
  letter-spacing: 0.03em !important;
}

#phocagallery .pg-category-box-title a {
  color: var(--bb-white) !important;
  font-family: 'Poppins', sans-serif !important;
}

#phocagallery .pg-category-box-title a:hover {
  color: var(--bb-accent) !important;
}

#phocagallery .pg-category-box-count {
  color: var(--bb-text-muted) !important;
  font-size: 0.8rem !important;
  font-weight: 400 !important;
}

/* ── Phoca Gallery image view (inside category) ──────────── */

/* Hide RSS, filenames, detail/download icons, SVG icon titles */
#phocagallery .pg-top-icons,
#phocagallery figcaption,
#phocagallery .pg-item-box-info,
#phocagallery .pg-item-box-icons-box,
#phocagallery [style*="Powered by"],
#phocagallery div[style*="color:#ccc"] {
  display: none !important;
}

/* Hide the first "back/parent" item (SVG folder nav) */
#phocagallery .pg-category-items-box .pg-item-box:first-child {
  display: none !important;
}

/* Image grid */
#phocagallery .pg-category-items-box,
#phocagallery #pg-msnr-container {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)) !important;
  gap: 0.6rem !important;
  padding: 1rem 0 !important;
}

/* Each item */
#phocagallery .pg-item-box {
  position: relative !important;
  overflow: hidden !important;
  border-radius: 4px !important;
  background: #000 !important;
  aspect-ratio: 4/3 !important;
  display: flex !important;
}

/* Image inside item */
#phocagallery .pg-item-box .pg-item-box-image {
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  flex: 1 !important;
}

#phocagallery .pg-item-box .pg-item-box-image a {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
}

#phocagallery .pg-item-box img.pg-image {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
  transition: transform 0.35s ease, opacity 0.35s ease !important;
}

#phocagallery .pg-item-box:hover img.pg-image {
  transform: scale(1.06) !important;
  opacity: 0.85 !important;
}

/* Navigation / pagination */
#phocagallery .pg-nav,
#phocagallery .pg-pagination {
  color: var(--bb-text-muted) !important;
  margin-top: 1.5rem !important;
}

#phocagallery .pg-pagination a {
  color: var(--bb-accent) !important;
}

/* ── Category list ───────────────────────────────────────── */
.categories-list h3 a,
.com-content-categories__title a {
  color: var(--bb-white) !important;
  font-family: 'Poppins', sans-serif !important;
}

/* ── Hero Slider (homepage animation) ───────────────────── */
.container-banner {
  padding: 0 !important;
  margin: 0 !important;
}

.bb-hero-module .module-ct { padding: 0 !important; }

.bb-hero {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  max-height: 90vh;
  overflow: hidden;
  background: #000;
}

.bb-hero__slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  opacity: 0;
  animation: bbCrossFade 18s infinite;
  will-change: opacity, transform;
}

/* Animation timing injected dynamically by mod_bbhero (based on slide count) */

/* Logo slide: lighter overlay */
.bb-hero__slide--logo ~ .bb-hero__overlay {
  background: linear-gradient(to bottom, rgba(0,0,0,0) 60%, rgba(0,0,0,0.4) 100%);
}

.bb-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0.15) 0%,
    rgba(0,0,0,0.65) 100%
  );
  z-index: 2;
}

.bb-hero__caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 3;
  padding: 2rem 3rem;
  text-align: left;
}

.bb-hero__title {
  font-family: 'Poppins', sans-serif !important;
  font-size: 2.8rem !important;
  font-weight: 800 !important;
  color: #fff !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  line-height: 1.1 !important;
  margin: 0 0 0.5rem !important;
  text-shadow: 0 2px 12px rgba(0,0,0,0.8) !important;
}

.bb-hero__title span {
  color: var(--bb-accent) !important;
  display: block;
  font-size: 1.6rem !important;
  letter-spacing: 0.2em !important;
}

.bb-hero__sub {
  font-family: 'Roboto Condensed', sans-serif !important;
  font-size: 1rem !important;
  color: rgba(255,255,255,0.75) !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  margin: 0 !important;
}

@media (max-width: 768px) {
  .bb-hero { aspect-ratio: 16 / 9; max-height: 60vh; }
  .bb-hero__caption { padding: 1rem 1.5rem; }
}

/* ── Hero dots ───────────────────────────────────────────── */
.bb-hero__dots {
  position: absolute;
  bottom: 1.2rem;
  right: 2rem;
  z-index: 4;
  display: flex;
  gap: 0.4rem;
  align-items: center;
}

.bb-hero__dot {
  height: 8px;
  width: 8px;
  border-radius: 4px;
  background: rgba(255,255,255,0.4);
  display: inline-block;
}

@media (max-width: 768px) {
  .bb-hero__dots { right: 1rem; bottom: 0.8rem; }
}

/* ── Featured articles — card grid ───────────────────────── */
.blog-featured .blog-items[class*="masonry-"],
.blog-featured .blog-items[class*="columns-"] {
  display: grid !important;
  column-count: unset !important;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)) !important;
  gap: 1.5rem !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding: 0 !important;
}

.blog-featured .blog-item {
  background: var(--bb-bg-card) !important;
  border: 1px solid var(--bb-border) !important;
  border-radius: 8px !important;
  overflow: hidden !important;
  padding: 0 !important;
  margin: 0 !important;
  width: 100% !important;
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease !important;
  display: flex !important;
  flex-direction: column !important;
}

.blog-featured .blog-item:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 12px 32px rgba(0,0,0,0.55) !important;
  border-color: rgba(0,180,255,0.35) !important;
}

.blog-featured .blog-item .item-image {
  aspect-ratio: 16 / 9 !important;
  width: 100% !important;
  margin: 0 !important;
  overflow: hidden !important;
  background: #000 !important;
  flex-shrink: 0 !important;
  float: none !important;
}

.blog-featured .blog-item .item-image a {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
}

.blog-featured .blog-item .item-image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
  transition: transform 0.4s ease !important;
}

.blog-featured .blog-item:hover .item-image img {
  transform: scale(1.06) !important;
}

.blog-featured .blog-item .item-content {
  padding: 1rem 1.2rem 1.2rem !important;
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
}

.blog-featured .blog-item .item-title {
  font-size: 0.95rem !important;
  line-height: 1.35 !important;
  margin: 0 0 0.5rem !important;
}

.blog-featured .blog-item .article-info {
  font-size: 0.75rem !important;
  margin-bottom: 0.5rem !important;
}

.blog-featured .blog-item .readmore {
  margin-top: auto !important;
  padding-top: 0.75rem !important;
  clear: none !important;
}

/* Leading article — image left, content right */
.blog-featured .items-leading {
  display: block !important;
  padding: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  margin-bottom: 1.5rem !important;
}

.blog-featured .items-leading .blog-item {
  flex-direction: row !important;
  min-height: 260px !important;
}

.blog-featured .items-leading .blog-item .item-image {
  aspect-ratio: unset !important;
  width: 42% !important;
  min-height: 260px !important;
}

.blog-featured .items-leading .blog-item .item-content {
  padding: 1.5rem 2rem !important;
}

.blog-featured .items-leading .blog-item .item-title {
  font-size: 1.3rem !important;
}

@media (max-width: 767px) {
  .blog-featured .items-leading .blog-item {
    flex-direction: column !important;
  }
  .blog-featured .items-leading .blog-item .item-image {
    width: 100% !important;
    aspect-ratio: 16/9 !important;
    min-height: unset !important;
  }
}

/* ── Sidebar navigation ──────────────────────────────────── */
.container-sidebar-left .mod-menu,
.container-sidebar-left nav {
  padding: 0.5rem 0 !important;
}

.container-sidebar-left .mod-menu a,
.container-sidebar-left .nav-link {
  display: block !important;
  padding: 0.55rem 1.2rem !important;
  color: rgba(255,255,255,0.7) !important;
  font-family: 'Roboto Condensed', sans-serif !important;
  font-size: 13px !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  border-left: 2px solid transparent !important;
  transition: all 0.2s ease !important;
}

.container-sidebar-left .mod-menu a:hover,
.container-sidebar-left .nav-link:hover,
.container-sidebar-left .mod-menu .active > a,
.container-sidebar-left .current > a {
  color: var(--bb-accent) !important;
  border-left-color: var(--bb-accent) !important;
  background-color: rgba(0,180,255,0.06) !important;
}
