/**
 * ConstructInfo — News Portal Redesign v4.0
 * Data: Aprilie 2026
 * 
 * REDESIGN TARGETAT:
 * 1. Header: roșu + navigare reintegrată (linkuri albe)
 * 2. News Grid 3×3: featured (2 col, orizontal) + 7 știri verticale
 * 3. Video Grid 3×2: 6 video-uri recent, fără featured mare
 * 4. Harta: screenshot preview + dată ultimei actualizări
 * 5. Forum: header "FORUM - Discuții recente", 2 coloane, condensat
 * 6. Toate secțiunile: compact, proporțional, stil gsp.ro
 *
 * Changelog v4.0:
 * - Header: navigare reintegrată ca linkuri albe pe bandă roșie
 * - Video: secțiune featured video → grid 3×2 (6 carduri)
 * - Harta: screenshot preview redimensionat, text actualizare zilnică
 * - Forum: 2 coloane, header "FORUM", condensat, badge-uri mici
 * - Featured card: proporții thumbnail fixate (aspect-ratio)
 */

@import url('https://fonts.googleapis.com/css2?family=Merriweather+Sans:wght@400;600;700;800&display=swap');

:root {
  --ci-font-heading: 'Merriweather Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --ci-font-body: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
}


/* ==========================================================================
   1. BODY & GLOBALS
   ========================================================================== */

body {
  font-family: var(--ci-font-body) !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
  color: #1a1a1a !important;
  background: #FFFFFF !important;
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--ci-font-heading) !important;
  color: #1a1a1a !important;
  line-height: 1.25 !important;
}

p { color: #1a1a1a; }
a { color: #B91C1C; text-decoration: none; }
a:hover { color: #7F1D1D; }

.grid-container, .site-content .grid-container {
  max-width: 1140px !important;
}

.container {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 20px;
}


/* ==========================================================================
   2. HEADER — Bandă roșie + navigare ca linkuri albe
   ========================================================================== */

.site-header {
  background: #B91C1C !important;
  box-shadow: 0 2px 6px rgba(0,0,0,0.15) !important;
  padding: 0 !important;
}

.site-header .inside-header {
  padding: 10px 20px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  max-width: 1140px !important;
  margin: 0 auto !important;
}

/* Logo: ConstructInfo.ro */
.main-title {
  font-family: var(--ci-font-heading) !important;
  font-size: 20px !important;
  font-weight: 800 !important;
  line-height: 1.1 !important;
  margin: 0 !important;
}

.main-title a {
  color: #FFFFFF !important;
}


/* ⚠️ v5.0: Navigarea reintegrată — GP structure-aware
   GP generează 2 elemente nav separate:
   1. #mobile-menu-control-wrapper — buton toggle (sibling de header)
   2. #site-navigation — meniul real cu linkuri
   Pe desktop: ascundem #mobile-menu-control-wrapper, arătăm #site-navigation inline
   Pe mobile: arătăm #mobile-menu-control-wrapper ca hamburger, #site-navigation ca dropdown
*/

/* === DESKTOP: nav inline cu linkuri albe === */

/* Ascunde toggle-ul mobil pe desktop */
#mobile-menu-control-wrapper {
  display: none !important;
}

/* Navigarea principală — inline pe desktop */
#site-navigation {
  background: #B91C1C !important;
  margin: 0 !important;
  padding: 0 !important;
}

#site-navigation .inside-navigation {
  background: transparent !important;
  max-width: 1140px !important;
  margin: 0 auto !important;
  padding: 0 20px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
}

/* Ascunde toggle-ul din site-navigation pe desktop */
#site-navigation .menu-toggle {
  display: none !important;
}

#site-navigation .main-nav {
  display: flex !important;
  align-items: center !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

#site-navigation .main-nav > li {
  margin: 0 !important;
  padding: 0 !important;
}

#site-navigation .main-nav > li > a {
  color: #FFFFFF !important;
  font-family: var(--ci-font-heading) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  padding: 8px 14px !important;
  text-decoration: none !important;
  transition: background 150ms ease !important;
  display: block !important;
  background: transparent !important;
  border: none !important;
}

#site-navigation .main-nav > li > a:hover,
#site-navigation .main-nav > li.current-menu-item > a {
  background: rgba(255,255,255,0.15) !important;
  color: #FFFFFF !important;
}

/* Ascunde: sub-meniuri, header widget, header image */
#site-navigation .sub-menu,
.site-header .header-widget,
.site-header .header-image {
  display: none !important;
}


/* === MOBILE: hamburger în header + dropdown === */
@media (max-width: 768px) {
  /* Arată toggle-ul mobil GP, pozitionat în header dreapta */
  #mobile-menu-control-wrapper {
    display: flex !important;
    align-items: center !important;
    position: absolute !important;
    top: 0 !important;
    right: 10px !important;
    height: 48px !important;
    z-index: 1001 !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
  }
  
  #mobile-menu-control-wrapper .menu-toggle {
    background: transparent !important;
    border: none !important;
    color: #FFFFFF !important;
    font-size: 26px !important;
    cursor: pointer !important;
    padding: 8px !important;
  }

  /* Header-ul are position relative ca ancora */
  .site-header {
    position: relative !important;
    z-index: 1000 !important;
    min-height: 48px !important;
  }

  .site-header .inside-header {
    min-height: 48px !important;
  }

  /* Navigarea reală — ascunsă default pe mobile */
  #site-navigation {
    display: none !important;
  }
  
  /* Când GP adaugă .toggled — arată meniul ca dropdown */
  #site-navigation.toggled {
    display: block !important;
    background: #991B1B !important;
    position: relative !important;
    z-index: 999 !important;
  }
  
  #site-navigation.toggled .inside-navigation {
    padding: 0 !important;
    background: transparent !important;
    display: block !important;
  }
  
  /* Ascunde toggle-ul intern (îl folosim pe cel din #mobile-menu-control-wrapper) */
  #site-navigation.toggled .menu-toggle {
    display: none !important;
  }

  #site-navigation.toggled .main-nav {
    display: block !important;
  }
  
  #site-navigation.toggled .main-nav > li > a {
    font-size: 16px !important;
    padding: 12px 20px !important;
    color: #FFFFFF !important;
    border-bottom: 1px solid rgba(255,255,255,0.1) !important;
    display: block !important;
  }
}


/* ==========================================================================
   3. NEWS GRID 3×3 — Featured (2 col) + 7 știri
   ========================================================================== */

.ci-news-section {
  padding: 20px 0;
  border-bottom: 1px solid #e0e0e0;
}

.ci-news-section__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
  border-bottom: 2px solid #B91C1C;
  padding-bottom: 8px;
}

.ci-news-section__title {
  font-family: var(--ci-font-heading) !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.3px !important;
  margin: 0 !important;
  color: #1a1a1a !important;
}

.ci-news-section__link {
  font-family: var(--ci-font-heading) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  color: #B91C1C !important;
  text-decoration: none;
}

.ci-news-section__link:hover {
  text-decoration: underline;
}

/* Grid: 3 coloane */
.ci-news-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

/* --- FEATURED CARD — span 2 col, layout orizontal --- */
.ci-news-card {
  display: flex;
  flex-direction: row;
  text-decoration: none;
  color: inherit;
  background: #FFFFFF;
  border: 1px solid #e0e0e0;
  border-radius: 4px;
  overflow: hidden;
  transition: box-shadow 200ms ease, transform 200ms ease;
}

.ci-news-card:hover {
  box-shadow: 0 2px 8px rgba(0,0,0,0.1);
  transform: translateY(-1px);
  text-decoration: none;
  color: inherit;
}

.ci-news-card__thumb {
  width: 120px;
  min-width: 120px;
  overflow: hidden;
  background: #f0f0f0;
  flex-shrink: 0;
}

.ci-news-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.ci-news-card__body {
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
  flex: 1;
}

.ci-news-card__title {
  font-family: var(--ci-font-heading) !important;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.3;
  color: #1a1a1a;
  margin: 4px 0 6px;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.ci-news-card:hover .ci-news-card__title {
  color: #B91C1C;
}

.ci-news-card__excerpt {
  font-size: 12px;
  color: #555;
  line-height: 1.4;
  margin: 0 0 6px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.ci-news-card__date {
  font-size: 11px;
  color: #999;
}

/* --- FEATURED CARD — span 2 coloane, outline roșu, proporții fixate --- */
.ci-news-card--featured {
  grid-column: span 2;
  border: 2px solid #B91C1C;
}

/* ⚠️ v4.0 FIX: Thumbnail featured cu aspect-ratio fix, fără trunchi */
.ci-news-card--featured .ci-news-card__thumb {
  width: 340px;
  min-width: 340px;
  aspect-ratio: 16 / 10;
}

.ci-news-card--featured .ci-news-card__body {
  padding: 16px 20px;
}

.ci-news-card--featured .ci-news-card__title {
  font-size: 20px;
  font-weight: 800;
  line-height: 1.25;
  -webkit-line-clamp: 3;
  margin: 6px 0 10px;
}

.ci-news-card--featured .ci-news-card__excerpt {
  font-size: 14px;
  line-height: 1.5;
  -webkit-line-clamp: 3;
  color: #444;
}

/* Responsive: tablet 2 col, mobile 1 col */
@media (max-width: 1024px) {
  .ci-news-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .ci-news-grid {
    grid-template-columns: 1fr;
  }
  
  .ci-news-card--featured {
    grid-column: span 1;
  }
  
  .ci-news-card--featured .ci-news-card__thumb {
    width: 140px;
    min-width: 140px;
  }
  
  .ci-news-card--featured .ci-news-card__title {
    font-size: 16px;
  }
  
  .ci-news-card--featured .ci-news-card__excerpt {
    font-size: 13px;
    -webkit-line-clamp: 2;
  }
}


/* ==========================================================================
   4. BADGES — Compact
   ========================================================================== */

.ci-badge {
  font-family: var(--ci-font-heading) !important;
  font-size: 9px !important;
  font-weight: 700 !important;
  padding: 2px 7px !important;
  border-radius: 2px !important;
  letter-spacing: 0.4px !important;
  text-transform: uppercase !important;
}


/* ==========================================================================
   5. SECȚIUNI HOMEPAGE — Spacing redus, compact
   ========================================================================== */

.ci-homepage-latest-news { padding: 20px 0 !important; }
.ci-homepage-featured-video { padding: 20px 0 !important; }
.homepage-latest-videos { padding: 20px 0 !important; }
.homepage-youtube { padding: 20px 0 !important; }
.ci-homepage-stats-widget { padding: 20px 0 !important; }
.ci-homepage-map-widget { padding: 20px 0 !important; }
.ci-homepage-subscribe { padding: 16px 0 !important; }
.ci-homepage-forum-recent { padding: 20px 0 !important; }


/* ==========================================================================
   6. SECTION HEADERS — Compact cu linie roșie
   ========================================================================== */

.section-header,
.homepage-latest-videos .section-header,
.ci-homepage-latest-news .section-header,
.ci-homepage-featured-video .section-header,
.video-page .section-header {
  border-bottom: 2px solid #B91C1C !important;
  padding-bottom: 8px !important;
  margin-bottom: 16px !important;
}

.section-header h2,
.homepage-latest-videos .section-header h2,
.ci-homepage-latest-news .section-header h2,
.ci-homepage-featured-video .section-header h2,
.video-page .section-header h2 {
  font-family: var(--ci-font-heading) !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  margin: 0 !important;
  color: #1a1a1a !important;
}

.section-link {
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  color: #B91C1C !important;
}


/* ==========================================================================
   7. VIDEO GRID 3×2 — 6 carduri video (înlocuiește featured video mare)
   ========================================================================== */

.ci-video-grid-section {
  padding: 20px 0;
  border-bottom: 1px solid #e0e0e0;
}

.ci-video-grid-section__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
  border-bottom: 2px solid #B91C1C;
  padding-bottom: 8px;
}

.ci-video-grid-section__title {
  font-family: var(--ci-font-heading) !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  margin: 0 !important;
  color: #1a1a1a !important;
}

.ci-video-grid-section__link {
  font-family: var(--ci-font-heading) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  color: #B91C1C !important;
  text-decoration: none;
}

.ci-video-grid-section__link:hover {
  text-decoration: underline;
}

/* Grid: 3 coloane × 2 rânduri */
.ci-video-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

/* Card video vertical: thumbnail sus, info jos */
.ci-video-grid__card {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  background: #FFFFFF;
  border: 1px solid #e0e0e0;
  border-radius: 4px;
  overflow: hidden;
  transition: box-shadow 200ms ease, transform 200ms ease;
}

.ci-video-grid__card:hover {
  box-shadow: 0 2px 8px rgba(0,0,0,0.1);
  transform: translateY(-1px);
  text-decoration: none;
  color: inherit;
}

.ci-video-grid__thumb {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: #0f0f0f;
}

.ci-video-grid__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Play button overlay */
.ci-video-grid__play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 44px;
  height: 32px;
  opacity: 0;
  transition: opacity 150ms ease;
}

.ci-video-grid__card:hover .ci-video-grid__play {
  opacity: 1;
}

.ci-video-grid__info {
  padding: 8px 10px;
  display: flex;
  flex-direction: column;
  gap: 3px;
  flex: 1;
}

.ci-video-grid__badge {
  display: inline-block;
  font-family: var(--ci-font-heading) !important;
  font-size: 9px;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 2px;
  text-transform: uppercase;
  background: var(--ci-red-100, #FEE2E2);
  color: var(--ci-red-800, #991B1B);
  align-self: flex-start;
}

.ci-video-grid__title {
  font-family: var(--ci-font-heading) !important;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.3;
  color: #1a1a1a;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.ci-video-grid__card:hover .ci-video-grid__title {
  color: #B91C1C;
}

.ci-video-grid__meta {
  font-size: 11px;
  color: #999;
}

.ci-video-grid__channel {
  font-weight: 500;
  color: #666;
}

.ci-video-grid__date::before {
  content: '·';
  margin: 0 4px;
}

/* Responsive */
@media (max-width: 1024px) {
  .ci-video-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .ci-video-grid {
    grid-template-columns: 1fr;
  }
}


/* ==========================================================================
   7b. VIDEO CARDS vechi (homepage-latest-videos) — Compact override
   ========================================================================== */

.video-card {
  border-radius: 4px !important;
}

.video-card__thumb {
  max-height: 160px !important;
}

.video-card__info { padding: 8px 10px !important; }
.video-card__badge { font-size: 9px !important; padding: 1px 6px !important; margin-bottom: 4px !important; }
.video-card__title { font-size: 13px !important; font-weight: 600 !important; }
.video-card__meta { font-size: 11px !important; }

.video-card--featured {
  grid-row: auto !important;
  flex-direction: column !important;
}

.video-card--featured .video-card__thumb {
  width: 100% !important;
  max-width: 100% !important;
  max-height: 200px !important;
}

.video-card--featured .video-card__title { font-size: 15px !important; font-weight: 700 !important; }

.latest-videos-grid {
  grid-template-columns: 1fr !important;
  grid-template-rows: auto !important;
  gap: 10px !important;
}

@media (min-width: 768px) {
  .latest-videos-grid { grid-template-columns: 1fr 1fr !important; }
}

@media (max-width: 768px) {
  .latest-videos-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    overflow-x: visible !important;
  }
  .video-card, .video-card--featured {
    min-width: auto !important;
  }
  .video-card__thumb, .video-card--featured .video-card__thumb {
    max-height: 160px !important;
  }
}


/* ==========================================================================
   8. VIDEO PAGE GRID & YOUTUBE CARDS — Compact
   ========================================================================== */

.video-grid { gap: 12px !important; }
.video-grid-card { border-radius: 4px !important; }
.video-grid-card__thumb { max-height: 140px !important; }
.video-grid-card__title { font-size: 13px !important; }
.video-grid-card__meta { font-size: 11px !important; }
.video-grid-card__badge { font-size: 9px !important; padding: 1px 6px !important; }

.youtube-grid { gap: 12px !important; }
.youtube-card { border-radius: 4px !important; }
.youtube-card-thumb { max-height: 140px !important; }
.youtube-card-title { font-size: 13px !important; padding: 8px 10px !important; }


/* ==========================================================================
   9. FEATURED VIDEO vechi — Compact (DEPRECATED, păstrat pentru fallback)
   ========================================================================== */

.ci-featured-video-embed { max-height: 350px !important; }
.ci-featured-video-info { padding: 12px 16px !important; }
.ci-featured-video-info h3 { font-size: 15px !important; margin: 4px 0 !important; }
.ci-featured-video-badge { font-size: 10px !important; padding: 2px 8px !important; }


/* ==========================================================================
   10. MAP CTA — Cu screenshot preview + dată actualizare
   ========================================================================== */

.ci-map-cta { padding: 24px !important; border-radius: 6px !important; }
.ci-map-cta__content h2 { font-size: 18px !important; color: #FFFFFF !important; }
.ci-map-cta__content p { font-size: 13px !important; }

/* ⚠️ v4.0: Screenshot preview harta cu dimensiuni corecte */
.ci-map-cta__preview {
  border-radius: 6px;
  overflow: hidden;
  border: 2px solid rgba(255,255,255,0.3);
}

.ci-map-cta__preview img {
  width: 100% !important;
  height: 200px !important;
  object-fit: cover !important;
  border-radius: 4px !important;
  box-shadow: 0 4px 16px rgba(0,0,0,0.25) !important;
  display: block;
}

.ci-map-cta__update-date {
  font-size: 11px;
  color: rgba(255,255,255,0.7);
  margin-top: 8px;
  font-style: italic;
}


/* ==========================================================================
   11. STATS — Compact
   ========================================================================== */

.ci-stats-cta { padding: 24px !important; border-radius: 6px !important; }
.ci-stats-cta__header h2 { font-size: 18px !important; }
.ci-stats-cta__header p { font-size: 13px !important; }
.ci-stat-item__value { font-size: 24px !important; font-weight: 800 !important; color: #B91C1C !important; }
.ci-stat-item__label { font-size: 11px !important; color: #666 !important; }


/* ==========================================================================
   12. FORUM — Condensat, 2 coloane, header "FORUM - Discuții recente"
   ========================================================================== */

/* ⚠️ v4.0: Forum section complet restiilizat */
.ci-homepage-forum-recent {
  padding: 20px 0 !important;
  border-bottom: 1px solid #e0e0e0;
}

/* Header cu titlu FORUM - Discuții recente */
.ci-forum-recent-header {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  border-bottom: 2px solid #B91C1C !important;
  padding-bottom: 8px !important;
  margin-bottom: 12px !important;
}

.ci-forum-recent-header h3 {
  font-family: var(--ci-font-heading) !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  margin: 0 !important;
  color: #1a1a1a !important;
}

.ci-forum-recent-header a {
  font-family: var(--ci-font-heading) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  color: #B91C1C !important;
  text-decoration: none !important;
}

.ci-forum-recent-header a:hover {
  text-decoration: underline !important;
}

/* Lista topicuri: 2 coloane, condensată */
.ci-forum-recent-list {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 0 !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.ci-forum-recent-list li,
.ci-forum-recent-item {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 8px 10px !important;
  border-bottom: 1px solid #f0f0f0 !important;
  transition: background 150ms ease;
}

.ci-forum-recent-list li:hover,
.ci-forum-recent-item:hover {
  background: #fafafa !important;
}

/* Badge-uri forum mai mici */
.ci-forum-recent-badge {
  font-size: 8px !important;
  padding: 1px 5px !important;
  border-radius: 2px !important;
  white-space: nowrap !important;
  flex-shrink: 0 !important;
}

/* Titlu topic */
.ci-forum-recent-title {
  font-size: 12px !important;
  font-weight: 600 !important;
  line-height: 1.3 !important;
  flex: 1 !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.ci-forum-recent-title a {
  color: #1a1a1a !important;
  text-decoration: none !important;
}

.ci-forum-recent-title a:hover {
  color: #B91C1C !important;
}

/* Meta info: răspunsuri, timp */
.ci-forum-recent-meta {
  font-size: 10px !important;
  color: #999 !important;
  white-space: nowrap !important;
  flex-shrink: 0 !important;
}

/* Responsive: 1 coloană pe mobile */
@media (max-width: 768px) {
  .ci-forum-recent-list {
    grid-template-columns: 1fr !important;
  }
}


/* ==========================================================================
   13. SUBSCRIBE — Compact
   ========================================================================== */

.ci-subscribe-bar { padding: 14px 20px !important; font-size: 13px !important; }


/* ==========================================================================
   14. BUTTONS — Compact
   ========================================================================== */

.ci-btn, .btn {
  font-family: var(--ci-font-heading) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  padding: 8px 18px !important;
  border-radius: 4px !important;
}


/* ==========================================================================
   15. CATEGORY BAR — Compact
   ========================================================================== */

.ci-category-bar {
  padding: 8px 20px !important;
  gap: 6px !important;
  background: #FFFFFF !important;
  border-bottom: 2px solid #B91C1C !important;
}

.ci-category-pill {
  font-size: 10px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  padding: 4px 10px !important;
  border-radius: 2px !important;
  min-height: 30px !important;
}


/* ==========================================================================
   16. SINGLE ARTICLE — Lizibil
   ========================================================================== */

.ci-single-title, .single .entry-title {
  font-size: 26px !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;
}

.ci-single-content, .single .entry-content {
  font-size: 15px !important;
  line-height: 1.65 !important;
}

.ci-single-meta, .single .entry-meta {
  font-size: 11px !important;
  color: #888 !important;
  border-bottom: 1px solid #e0e0e0 !important;
}

.ci-single-hero__img { max-height: 400px !important; }


/* ==========================================================================
   17. ARCHIVE, SIDEBAR, RELATED, FOOTER — Compact
   ========================================================================== */

.ci-archive__title { font-size: 20px !important; font-weight: 800 !important; text-transform: uppercase !important; }
.ci-archive__grid { gap: 14px !important; }
.ci-article-card__image { height: 130px !important; max-height: 130px !important; }
.ci-article-card__title { font-size: 14px !important; font-weight: 700 !important; margin: 4px 0 6px !important; }
.ci-article-card__meta { font-size: 11px !important; color: #888 !important; }
.ci-article-card__content { padding: 10px 12px !important; }

.ci-related-videos { padding: 16px !important; margin: 20px 0 !important; }
.ci-related-videos h3 { font-size: 14px !important; text-transform: uppercase !important; border-bottom: 2px solid #B91C1C !important; padding-bottom: 8px !important; }
.ci-related-video-card img { max-height: 100px !important; }
.ci-related-video-card__title { font-size: 12px !important; padding: 6px 8px !important; }

.widget-title { font-size: 12px !important; font-weight: 800 !important; text-transform: uppercase !important; border-bottom: 2px solid #B91C1C !important; padding-bottom: 6px !important; }

.site-footer { background: #1a1a1a !important; font-size: 12px !important; }
.site-info { font-size: 11px !important; }

.video-group__header { padding: 10px 14px !important; }
.video-group__header h3 { font-size: 14px !important; }

.site-content, .inside-article, .entry-content { color: #1a1a1a !important; }


/* ==========================================================================
   18. RESPONSIVE
   ========================================================================== */

@media (max-width: 768px) {
  .main-title { font-size: 16px !important; }
  .section-header h2 { font-size: 14px !important; }
  .ci-single-title, .single .entry-title { font-size: 20px !important; }
  .ci-stat-item__value { font-size: 20px !important; }
  .ci-stats-cta, .ci-map-cta { padding: 16px !important; }
  .ci-category-bar { padding: 6px 12px !important; }
  .ci-article-card__image { height: 100px !important; }
  
  .ci-map-cta__preview img {
    height: 140px !important;
  }
}

@media print {
  body { font-size: 11pt !important; color: #000 !important; }
  .ci-bottom-nav, .ci-pwa-install { display: none !important; }
}

/* FORUM FIX v4.1 */
.ci-forum-recent-list { gap: 0 20px !important; }
.ci-forum-recent-item { padding: 10px 6px !important; gap: 10px !important; }
.ci-forum-recent-badge { font-size: 10px !important; padding: 3px 8px !important; border-radius: 3px !important; min-width: 70px !important; text-align: center !important; }
.ci-forum-recent-title { font-size: 14px !important; font-weight: 600 !important; white-space: normal !important; overflow: visible !important; line-height: 1.35 !important; }
.ci-forum-recent-title a { font-size: 14px !important; }
.ci-forum-recent-meta { font-size: 12px !important; color: #777 !important; }

/* NAV BACKGROUND FIX — transparent pe toate containerele GP */
.main-navigation,
.main-navigation .inside-navigation,
.navigation-search {
  background: transparent !important;
}


/* ==========================================================================
   19. v3 REDESIGN — Header alb + Featured hero (Aprilie 2026)
   ========================================================================== */

/* --- 19.1 HEADER ALB --- */
.site-header {
  background: #FFFFFF !important;
  border-bottom: 1px solid #E5E7EB !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04) !important;
}

.site-header .inside-header {
  padding: 12px 20px !important;
}

#site-navigation {
  background: #FFFFFF !important;
  border-top: 1px solid #F1F5F9 !important;
}

#site-navigation .inside-navigation {
  background: transparent !important;
}

/* Ascundem textul ConstructInfo.ro și site description (logo-ul îl înlocuiește) */
.main-title,
.site-description {
  display: none !important;
}

/* Logo via Customizer — dimensiune mai mare */
.site-logo,
.header-image,
.site-logo img,
.header-image.is-logo-image {
  max-width: 96px !important;
  width: auto !important;
  height: auto !important;
  display: block !important;
}

/* --- 19.2 NAV LINKS roșii bold cu underline activ --- */
#site-navigation .main-nav > li > a {
  color: #B91C1C !important;
  font-family: var(--ci-font-heading) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.6px !important;
  padding: 18px 16px !important;
  border-bottom: 3px solid transparent !important;
  background: transparent !important;
  transition: all 0.15s ease !important;
}

#site-navigation .main-nav > li > a:hover {
  background: #FEF2F2 !important;
  color: #991B1B !important;
}

#site-navigation .main-nav > li.current-menu-item > a {
  background: transparent !important;
  border-bottom-color: #B91C1C !important;
  color: #B91C1C !important;
}

/* Hamburger mobile — roșu pe alb */
#mobile-menu-control-wrapper,
#mobile-menu-control-wrapper .menu-toggle,
.menu-toggle {
  color: #B91C1C !important;
  background: #FFFFFF !important;
}

#mobile-menu-control-wrapper .menu-toggle .gp-icon {
  color: #B91C1C !important;
}

#mobile-menu-control-wrapper .menu-toggle .gp-icon * {
  fill: #B91C1C !important;
  stroke: #B91C1C !important;
}

/* --- 19.3 SCOATERE category bar (badge-urile pe carduri o înlocuiesc) --- */
.ci-category-bar {
  display: none !important;
}

/* --- 19.4 FEATURED CARD: border 5px + hero roșu cu badge alb/albastru --- */
.ci-news-card--featured {
  border: 5px solid #B91C1C !important;
}

.ci-news-card--featured .ci-news-card__body {
  padding: 0 !important;
}

/* Hero — banda roșie comună pentru badge + titlu */
.ci-news-card--featured .ci-news-card__hero {
  background: #B91C1C !important;
  padding: 14px 20px 16px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
}

/* Badge: fundal alb, text albastru pe banda roșie */
.ci-news-card--featured .ci-news-card__hero .ci-badge {
  background: #FFFFFF !important;
  color: #1D4ED8 !important;
  align-self: flex-start !important;
  border: none !important;
}

/* Titlu: alb bold pe banda roșie (toate stările) */
.ci-news-card--featured .ci-news-card__hero .ci-news-card__title,
.ci-news-card--featured:hover .ci-news-card__hero .ci-news-card__title {
  color: #FFFFFF !important;
  margin: 0 !important;
  font-size: 22px !important;
  font-weight: 800 !important;
  line-height: 1.25 !important;
}

/* Excerpt + dată: rămân pe alb sub banda roșie */
.ci-news-card--featured .ci-news-card__excerpt {
  padding: 14px 20px 8px !important;
  margin: 0 !important;
  color: #444 !important;
}

.ci-news-card--featured .ci-news-card__date {
  padding: 0 20px 16px !important;
  display: block !important;
  color: #999 !important;
  font-size: 11px !important;
}

/* --- 19.5 RESPONSIVE mobile --- */
@media (max-width: 768px) {
  .site-header .inside-header {
    padding: 8px 16px !important;
  }
  .site-logo img,
  .header-image.is-logo-image {
    max-width: 64px !important;
  }
  .ci-news-card--featured .ci-news-card__hero {
    padding: 12px 14px 14px !important;
  }
  .ci-news-card--featured .ci-news-card__hero .ci-news-card__title {
    font-size: 16px !important;
  }
  .ci-news-card--featured .ci-news-card__excerpt {
    padding: 12px 14px 6px !important;
    font-size: 13px !important;
  }
  .ci-news-card--featured .ci-news-card__date {
    padding: 0 14px 12px !important;
  }
}


/* ==========================================================================
   19.6 MOBILE MENU v3 — Hamburger custom (animat) + slide-down panel
   GeneratePress face deja toggle (.toggled + aria-expanded), noi doar stilăm.
   ========================================================================== */

@media (max-width: 768px) {

  /* Site-header position relative (pentru ancorarea meniului) */
  .site-header {
    position: relative !important;
  }

  /* Forțăm afișarea hamburger-ului pe mobile (override la display:none global) */
  #mobile-menu-control-wrapper {
    display: block !important;
  }

  /* === HAMBURGER — buton 44x44 alb cu border + 3 bare roșii === */
  #mobile-menu-control-wrapper .menu-toggle,
  .site-header .menu-toggle {
    width: 44px !important;
    height: 44px !important;
    background-color: #FFFFFF !important;
    background-image: linear-gradient(#B91C1C, #B91C1C) !important;
    background-size: 18px 2.5px !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
    border: 1px solid #E5E7EB !important;
    border-radius: 8px !important;
    padding: 0 !important;
    position: relative !important;
    color: transparent !important;
    font-size: 0 !important;
    line-height: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: background-color .15s, border-color .15s !important;
  }

  /* Ascundem icon-urile default GP + texte */
  .site-header .menu-toggle svg,
  .site-header .menu-toggle .gp-icon,
  .site-header .menu-toggle .mobile-menu {
    display: none !important;
  }

  /* Bara de sus + bara de jos prin pseudo-elements */
  .site-header .menu-toggle::before,
  .site-header .menu-toggle::after {
    content: '' !important;
    position: absolute !important;
    left: 50% !important;
    width: 18px !important;
    height: 2.5px !important;
    background: #B91C1C !important;
    border-radius: 2px !important;
    margin-left: -9px !important;
    transition: transform .25s ease, top .2s ease, margin-top .2s ease !important;
  }
  .site-header .menu-toggle::before {
    top: calc(50% - 8px) !important;
  }
  .site-header .menu-toggle::after {
    top: calc(50% + 6px) !important;
  }

  .site-header .menu-toggle:hover {
    background-color: #FEF2F2 !important;
    border-color: #FEE2E2 !important;
  }

  /* === Animație X când meniul e deschis (aria-expanded="true" sau .toggled) === */
  .site-header .menu-toggle[aria-expanded="true"],
  .site-header .menu-toggle.toggled {
    background-image: none !important;
  }
  .site-header .menu-toggle[aria-expanded="true"]::before,
  .site-header .menu-toggle.toggled::before {
    top: 50% !important;
    margin-top: -1.25px !important;
    transform: rotate(45deg) !important;
  }
  .site-header .menu-toggle[aria-expanded="true"]::after,
  .site-header .menu-toggle.toggled::after {
    top: 50% !important;
    margin-top: -1.25px !important;
    transform: rotate(-45deg) !important;
  }

  /* === MENIUL DESCHIS — slide-down alb sub header === */
  #site-navigation {
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    background: #FFFFFF !important;
    border-top: none !important;
    border-bottom: 3px solid #B91C1C !important;
    box-shadow: 0 8px 16px rgba(15, 23, 42, 0.08) !important;
    transform: translateY(-12px) !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transition: transform .25s ease, opacity .2s ease, visibility 0s linear .25s !important;
    z-index: 50 !important;
    margin: 0 !important;
    padding: 0 !important;
    max-height: none !important;
  }

  /* GP toggle-ează clasa .toggled pe nav când meniul e deschis */
  #site-navigation.toggled {
    transform: translateY(0) !important;
    opacity: 1 !important;
    visibility: visible !important;
    transition: transform .25s ease, opacity .2s ease, visibility 0s !important;
  }

  #site-navigation .inside-navigation {
    padding: 0 !important;
    max-width: none !important;
    background: transparent !important;
    display: block !important;
  }

  /* Lista de link-uri — vertical full-width */
  #site-navigation .main-nav,
  #site-navigation .menu,
  #site-navigation ul.menu {
    flex-direction: column !important;
    align-items: stretch !important;
    width: 100% !important;
    display: block !important;
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  #site-navigation .main-nav > li,
  #site-navigation .menu > li {
    width: 100% !important;
    border-bottom: 1px solid #F1F5F9 !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  #site-navigation .main-nav > li:last-child,
  #site-navigation .menu > li:last-child {
    border-bottom: none !important;
  }

  /* Link-uri: roșu bold cu border-left la activ */
  #site-navigation .main-nav > li > a,
  #site-navigation .menu > li > a {
    padding: 16px 20px !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    color: #B91C1C !important;
    border-bottom: none !important;
    border-left: 4px solid transparent !important;
    background: transparent !important;
    text-align: left !important;
    width: 100% !important;
    display: block !important;
    text-transform: uppercase !important;
    letter-spacing: 0.4px !important;
    transition: background .15s, border-left-color .15s, color .15s !important;
  }

  #site-navigation .main-nav > li > a:hover,
  #site-navigation .menu > li > a:hover {
    background: #FEF2F2 !important;
    border-left-color: #FEE2E2 !important;
    color: #991B1B !important;
  }

  #site-navigation .main-nav > li.current-menu-item > a,
  #site-navigation .menu > li.current-menu-item > a {
    background: #FEF2F2 !important;
    border-left-color: #B91C1C !important;
    color: #991B1B !important;
  }
}


/* ==========================================================================
   19.7 v3.1 FIX OVERRIDES — Forțează prioritate peste GP Customizer settings
   GeneratePress generează CSS inline cu specificity mare prin Customizer Colors.
   Aceste reguli au specificity SUPERIOR (body + multiple selectors) ca să câștige.
   ========================================================================== */

/* ---- DESKTOP: text roșu pe nav, background transparent ---- */
body .site-header #site-navigation .main-navigation .main-nav > li > a,
body .site-header #site-navigation .main-nav > li > a,
body #site-navigation .menu > li > a,
body .main-navigation .menu > li > a,
body #site-navigation li.menu-item > a {
  color: #B91C1C !important;
  background-color: transparent !important;
  background-image: none !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.6px !important;
  border-bottom: 3px solid transparent !important;
  transition: all 0.15s ease !important;
}

body .site-header #site-navigation .main-navigation .main-nav > li > a:hover,
body #site-navigation .menu > li > a:hover,
body #site-navigation li.menu-item > a:hover {
  color: #991B1B !important;
  background-color: #FEF2F2 !important;
  background-image: none !important;
}

body #site-navigation .main-nav > li.current-menu-item > a,
body #site-navigation .menu > li.current-menu-item > a,
body #site-navigation li.current-menu-item > a {
  color: #B91C1C !important;
  background-color: transparent !important;
  background-image: none !important;
  border-bottom: 3px solid #B91C1C !important;
}

/* ---- MOBILE: hamburger centrat + items pe fundal alb ---- */
@media (max-width: 768px) {

  /* Hamburger ancorat absolute la header (rezolvă centrarea când e sibling, nu copil) */
  .site-header #mobile-menu-control-wrapper {
    position: absolute !important;
    right: 16px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    z-index: 60 !important;
    margin: 0 !important;
    padding: 0 !important;
    width: 44px !important;
    height: 44px !important;
    display: block !important;
  }

  /* Forțăm fundal alb/transparent pe toate containerele și items-urile meniului */
  body #site-navigation,
  body .main-navigation,
  body #site-navigation .inside-navigation,
  body .main-navigation .inside-navigation {
    background: #FFFFFF !important;
    background-color: #FFFFFF !important;
    background-image: none !important;
  }

  body #site-navigation .main-nav,
  body #site-navigation .menu,
  body #site-navigation ul.menu,
  body .main-navigation .main-nav,
  body .main-navigation .menu {
    background: transparent !important;
    background-color: transparent !important;
    background-image: none !important;
  }

  body #site-navigation .main-nav > li,
  body #site-navigation .menu > li,
  body #site-navigation li.menu-item,
  body .main-navigation li.menu-item {
    background: transparent !important;
    background-color: transparent !important;
    background-image: none !important;
  }

  /* Link-uri mobile menu — background transparent, doar hover/active au pal red */
  body #site-navigation .main-nav > li > a,
  body #site-navigation .menu > li > a,
  body #site-navigation li.menu-item > a,
  body .main-navigation li.menu-item > a {
    color: #B91C1C !important;
    background: transparent !important;
    background-color: transparent !important;
    background-image: none !important;
    border-left: 4px solid transparent !important;
    border-bottom: none !important;
    padding: 16px 20px !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.4px !important;
    text-align: left !important;
    display: block !important;
    width: 100% !important;
  }

  body #site-navigation .main-nav > li > a:hover,
  body #site-navigation .menu > li > a:hover,
  body #site-navigation li.menu-item > a:hover,
  body .main-navigation li.menu-item > a:hover {
    color: #991B1B !important;
    background: #FEF2F2 !important;
    background-color: #FEF2F2 !important;
    border-left-color: #FEE2E2 !important;
  }

  body #site-navigation .main-nav > li.current-menu-item > a,
  body #site-navigation .menu > li.current-menu-item > a,
  body #site-navigation li.current-menu-item > a,
  body .main-navigation li.current-menu-item > a {
    color: #991B1B !important;
    background: #FEF2F2 !important;
    background-color: #FEF2F2 !important;
    border-left-color: #B91C1C !important;
    border-bottom: none !important;
  }

  /* Separator subtil între items */
  body #site-navigation .main-nav > li,
  body #site-navigation .menu > li {
    border-bottom: 1px solid #F1F5F9 !important;
  }
  body #site-navigation .main-nav > li:last-child,
  body #site-navigation .menu > li:last-child {
    border-bottom: none !important;
  }
}


/* ==========================================================================
   19.8 v3.2 NUCLEAR OVERRIDE — Forțează totul pe meniul mobile
   GP setează background roșu pe <li> direct, nu pe <a>. Selectori universali.
   ========================================================================== */

@media (max-width: 768px) {

  /* Toate posibilele containere nav: fundal alb forțat */
  body .site-header #site-navigation,
  body .site-header .main-navigation,
  body .site-header nav.main-navigation,
  body .site-header nav#site-navigation,
  body #site-navigation,
  body .main-navigation,
  body nav.main-navigation {
    background: #FFFFFF !important;
    background-color: #FFFFFF !important;
    background-image: none !important;
  }

  /* TOATE ul-urile din nav: transparent */
  body .site-header #site-navigation ul,
  body .site-header .main-navigation ul,
  body #site-navigation ul,
  body .main-navigation ul,
  body #site-navigation .menu,
  body #site-navigation .main-nav,
  body #site-navigation .sub-menu,
  body .main-navigation .menu,
  body .main-navigation .main-nav {
    background: transparent !important;
    background-color: transparent !important;
    background-image: none !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  /* TOATE li-urile din nav: transparent (nuclear — orice variantă) */
  body .site-header #site-navigation li,
  body .site-header #site-navigation ul li,
  body .site-header .main-navigation li,
  body .site-header .main-navigation ul li,
  body .site-header nav li,
  body #site-navigation li,
  body #site-navigation ul li,
  body #site-navigation li.menu-item,
  body #site-navigation li.page_item,
  body #site-navigation .menu li,
  body #site-navigation .main-nav li,
  body .main-navigation li,
  body .main-navigation li.menu-item {
    background: transparent !important;
    background-color: transparent !important;
    background-image: none !important;
    border-left: none !important;
    border-right: none !important;
    border-top: none !important;
    border-bottom: 1px solid #F1F5F9 !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
  }

  /* Last child fără border */
  body #site-navigation li:last-child,
  body .main-navigation li:last-child {
    border-bottom: none !important;
  }

  /* Forțăm și pe link-uri să fie pe alb cu text roșu (re-întăresc regulile) */
  body .site-header #site-navigation li > a,
  body .site-header .main-navigation li > a,
  body #site-navigation li > a,
  body .main-navigation li > a {
    background: transparent !important;
    background-color: transparent !important;
    background-image: none !important;
    color: #B91C1C !important;
    border-left: 4px solid transparent !important;
    border-bottom: none !important;
    padding: 16px 20px !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.4px !important;
    text-align: left !important;
    display: block !important;
    width: 100% !important;
    line-height: 1.3 !important;
  }

  /* Hover */
  body .site-header #site-navigation li > a:hover,
  body #site-navigation li > a:hover,
  body .main-navigation li > a:hover {
    background: #FEF2F2 !important;
    background-color: #FEF2F2 !important;
    color: #991B1B !important;
    border-left-color: #FEE2E2 !important;
  }

  /* Item activ (current) — bandă roșie stânga + fundal pal */
  body .site-header #site-navigation li.current-menu-item > a,
  body #site-navigation li.current-menu-item > a,
  body .main-navigation li.current-menu-item > a,
  body #site-navigation li.current_page_item > a {
    background: #FEF2F2 !important;
    background-color: #FEF2F2 !important;
    color: #991B1B !important;
    border-left-color: #B91C1C !important;
  }
}


/* ==========================================================================
   19.9 v3.3 HAMBURGER VISIBILITY FIX
   Border roșu evident + z-index 100 ca să fie vizibil mereu, deasupra meniului
   ========================================================================== */

@media (max-width: 768px) {

  /* Wrapper la z-index foarte mare — peste meniu */
  body .site-header #mobile-menu-control-wrapper {
    position: absolute !important;
    right: 16px !important;
    top: 14px !important;
    transform: none !important;
    z-index: 100 !important;
    width: 44px !important;
    height: 44px !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
  }

  /* Buton hamburger — border ROȘU evident (nu palid), bara mijloc roșie */
  body .site-header #mobile-menu-control-wrapper .menu-toggle,
  body .site-header #mobile-menu-control-wrapper button,
  body .site-header .menu-toggle,
  body .site-header button.menu-toggle {
    width: 44px !important;
    height: 44px !important;
    background-color: #FFFFFF !important;
    background-image: linear-gradient(#B91C1C, #B91C1C) !important;
    background-size: 18px 2.5px !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
    border: 2px solid #B91C1C !important;
    border-radius: 8px !important;
    padding: 0 !important;
    margin: 0 !important;
    position: relative !important;
    color: transparent !important;
    font-size: 0 !important;
    line-height: 0 !important;
    z-index: 101 !important;
    cursor: pointer !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.1) !important;
    overflow: visible !important;
  }

  /* Bara sus + bara jos prin pseudo-elements (orice variantă de selector) */
  body .site-header #mobile-menu-control-wrapper .menu-toggle::before,
  body .site-header .menu-toggle::before,
  body .site-header button.menu-toggle::before {
    content: '' !important;
    display: block !important;
    position: absolute !important;
    left: 50% !important;
    top: calc(50% - 8px) !important;
    width: 18px !important;
    height: 2.5px !important;
    background: #B91C1C !important;
    border-radius: 2px !important;
    margin-left: -9px !important;
    transition: transform .25s ease, top .2s ease, margin-top .2s ease !important;
  }
  body .site-header #mobile-menu-control-wrapper .menu-toggle::after,
  body .site-header .menu-toggle::after,
  body .site-header button.menu-toggle::after {
    content: '' !important;
    display: block !important;
    position: absolute !important;
    left: 50% !important;
    top: calc(50% + 6px) !important;
    width: 18px !important;
    height: 2.5px !important;
    background: #B91C1C !important;
    border-radius: 2px !important;
    margin-left: -9px !important;
    transition: transform .25s ease, top .2s ease, margin-top .2s ease !important;
  }

  /* Animația X când meniul e deschis */
  body .site-header .menu-toggle.toggled,
  body .site-header .menu-toggle[aria-expanded="true"],
  body .site-header button.menu-toggle.toggled,
  body .site-header button.menu-toggle[aria-expanded="true"] {
    background-image: none !important;
  }
  body .site-header .menu-toggle.toggled::before,
  body .site-header .menu-toggle[aria-expanded="true"]::before {
    top: 50% !important;
    margin-top: -1.25px !important;
    transform: rotate(45deg) !important;
  }
  body .site-header .menu-toggle.toggled::after,
  body .site-header .menu-toggle[aria-expanded="true"]::after {
    top: 50% !important;
    margin-top: -1.25px !important;
    transform: rotate(-45deg) !important;
  }

  /* Ascunde icon-uri default GP */
  body .site-header .menu-toggle svg,
  body .site-header .menu-toggle .gp-icon,
  body .site-header .menu-toggle .mobile-menu {
    display: none !important;
  }
}


/* ==========================================================================
   20. PAGINA STIRI v3.4 — Grid + filtru categorii + paginare
   Folosit de home.php (toate articolele) și archive.php (per categorie)
   ========================================================================== */

.ci-stiri-page {
  padding: 32px 24px;
  background: #FFFFFF;
}

.ci-stiri-container {
  max-width: 1280px;
  margin: 0 auto;
}

/* Header pagină — titlu + meta */
.ci-stiri-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding-bottom: 14px;
  border-bottom: 4px solid #B91C1C;
  margin-bottom: 24px;
  gap: 16px;
}

.ci-stiri-title {
  font-family: var(--ci-font-heading) !important;
  font-size: 28px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.02em !important;
  color: #0F172A !important;
  margin: 0 !important;
  line-height: 1.2 !important;
}
.ci-stiri-title span {
  color: #B91C1C !important;
}

.ci-stiri-meta {
  font-size: 13px;
  color: #64748B;
  font-weight: 500;
  white-space: nowrap;
}

/* ----- Filtru categorii — pill-uri orizontale ----- */
.ci-category-filter {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 28px;
}

.ci-category-filter a {
  padding: 7px 14px;
  font-family: var(--ci-font-heading) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  color: #334155 !important;
  background: #F1F5F9 !important;
  border-radius: 4px !important;
  text-decoration: none !important;
  transition: all 0.15s ease !important;
}

.ci-category-filter a:hover {
  background: #FEF2F2 !important;
  color: #B91C1C !important;
}

.ci-category-filter a.active {
  background: #B91C1C !important;
  color: #FFFFFF !important;
}

/* ----- Grid 3 coloane ----- */
.ci-stiri-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.ci-stiri-card {
  background: #FFFFFF;
  border: 1px solid #E2E8F0;
  border-radius: 6px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  text-decoration: none !important;
  color: inherit !important;
  transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
}

.ci-stiri-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.08);
  border-color: #CBD5E1;
}

.ci-stiri-card__image {
  aspect-ratio: 16 / 10;
  background-size: cover;
  background-position: center;
  background-color: #F1F5F9;
}

.ci-stiri-card__image--placeholder {
  background: linear-gradient(135deg, #CBD5E1, #94A3B8);
}

.ci-stiri-card__body {
  padding: 14px 16px 18px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}

.ci-stiri-card__title {
  font-family: var(--ci-font-heading) !important;
  font-size: 15px !important;
  line-height: 1.3 !important;
  font-weight: 700 !important;
  color: #0F172A !important;
  margin: 0 !important;
  transition: color 0.15s !important;
}

.ci-stiri-card:hover .ci-stiri-card__title {
  color: #B91C1C !important;
}

.ci-stiri-card__meta {
  margin-top: auto;
  padding-top: 4px;
  font-size: 11px;
  font-weight: 500;
  color: #64748B;
}

/* ----- Paginare ----- */
.ci-stiri-pagination {
  margin-top: 36px;
  padding-top: 24px;
  border-top: 1px solid #E2E8F0;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.ci-stiri-pagination a,
.ci-stiri-pagination span {
  min-width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 12px;
  font-family: var(--ci-font-heading) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  border-radius: 6px !important;
  text-decoration: none !important;
  color: #334155 !important;
  background: #FFFFFF !important;
  border: 1px solid #E2E8F0 !important;
  transition: all 0.15s !important;
}

.ci-stiri-pagination a:hover {
  background: #FEF2F2 !important;
  border-color: #FEE2E2 !important;
  color: #B91C1C !important;
}

.ci-stiri-pagination .current,
.ci-stiri-pagination .page-numbers.current {
  background: #B91C1C !important;
  color: #FFFFFF !important;
  border-color: #B91C1C !important;
}

.ci-stiri-pagination .dots {
  border: none !important;
  background: transparent !important;
  color: #64748B !important;
}

/* ----- Empty state ----- */
.ci-stiri-empty {
  text-align: center;
  padding: 60px 20px;
  color: #64748B;
  font-size: 16px;
}
.ci-stiri-empty a {
  color: #B91C1C;
  font-weight: 600;
  text-decoration: none;
}
.ci-stiri-empty a:hover {
  text-decoration: underline;
}

/* ----- Responsive: tablet 2 col ----- */
@media (max-width: 1024px) and (min-width: 769px) {
  .ci-stiri-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ----- Responsive: mobile 1 col ----- */
@media (max-width: 768px) {
  .ci-stiri-page {
    padding: 20px 16px;
  }
  .ci-stiri-header {
    padding-bottom: 10px;
    margin-bottom: 18px;
    border-bottom-width: 3px;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
  .ci-stiri-title {
    font-size: 20px !important;
  }
  .ci-stiri-meta {
    font-size: 12px;
  }
  /* Filtru: scroll orizontal pe mobile */
  .ci-category-filter {
    flex-wrap: nowrap;
    overflow-x: auto;
    margin-left: -16px;
    margin-right: -16px;
    margin-top: -4px;
    margin-bottom: 20px;
    padding: 4px 16px;
    scrollbar-width: none;
  }
  .ci-category-filter::-webkit-scrollbar {
    display: none;
  }
  .ci-category-filter a {
    white-space: nowrap;
    flex-shrink: 0;
  }
  .ci-stiri-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .ci-stiri-card__body {
    padding: 12px 14px 16px;
  }
  .ci-stiri-card__title {
    font-size: 14px !important;
  }
  .ci-stiri-pagination a,
  .ci-stiri-pagination span {
    min-width: 36px;
    height: 36px;
    padding: 0 10px;
    font-size: 12px !important;
  }
}


/* ==========================================================================
   21. PAGINA STIRI + ARCHIVE + CATEGORY v3.4 (folosind clasele ci-archive*)
   Suprascrie/extinde stilurile minimale existente pentru .ci-archive*
   Override la regula 19.3 care ascunde .ci-category-bar (re-afișată pe arhive)
   ========================================================================== */

/* ----- Wrapper general ----- */
.ci-archive {
  padding: 32px 24px;
  background: #FFFFFF;
  max-width: 1280px;
  margin: 0 auto;
}

/* ----- Header pagină — titlu + meta inline ----- */
.ci-archive__header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding-bottom: 14px;
  border-bottom: 4px solid #B91C1C;
  margin-bottom: 24px;
  gap: 16px;
  flex-wrap: wrap;
}

/* Header pe pagini de categorie — vertical (badge sus, titlu, descriere, count) */
.ci-archive__header--category {
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
}

.ci-archive__title {
  font-family: var(--ci-font-heading) !important;
  font-size: 28px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.02em !important;
  color: #0F172A !important;
  margin: 0 !important;
  line-height: 1.2 !important;
}
.ci-archive__title span {
  color: #B91C1C !important;
}

.ci-archive__meta {
  font-size: 13px !important;
  color: #64748B !important;
  font-weight: 500 !important;
  margin: 0 !important;
  white-space: nowrap;
}

.ci-archive__badge {
  font-size: 11px !important;
  padding: 4px 12px !important;
}

.ci-archive__description {
  font-size: 14px !important;
  color: #475569 !important;
  line-height: 1.5 !important;
  margin: 4px 0 !important;
  max-width: 800px;
}
.ci-archive__description p {
  margin: 0 !important;
}

.ci-archive__count {
  font-size: 13px !important;
  color: #64748B !important;
  font-weight: 600 !important;
  margin: 0 !important;
}

/* ----- CATEGORY BAR — re-afișată pe arhive (override la 19.3 display:none) ----- */
.ci-category-bar.ci-archive__category-bar {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  padding: 0 !important;
  margin-bottom: 28px !important;
  background: transparent !important;
  border: none !important;
}

/* Pill-uri categorii — stil mockup */
.ci-archive__category-bar .ci-category-pill {
  padding: 7px 14px !important;
  font-family: var(--ci-font-heading) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  border-radius: 4px !important;
  text-decoration: none !important;
  min-height: auto !important;
  transition: all 0.15s ease !important;
  display: inline-flex !important;
  align-items: center !important;
}

.ci-archive__category-bar .ci-category-pill--inactive {
  background: #F1F5F9 !important;
  color: #334155 !important;
}

.ci-archive__category-bar .ci-category-pill--inactive:hover {
  background: #FEF2F2 !important;
  color: #B91C1C !important;
}

.ci-archive__category-bar .ci-category-pill--active {
  background: #B91C1C !important;
  color: #FFFFFF !important;
}

/* ----- Grid 3 coloane ----- */
.ci-archive__grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 24px !important;
}

/* ----- Card articol (override stiluri minimale existente) ----- */
.ci-article-card {
  background: #FFFFFF !important;
  border: 1px solid #E2E8F0 !important;
  border-radius: 6px !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  text-decoration: none !important;
  color: inherit !important;
  transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s !important;
}

.ci-article-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.08);
  border-color: #CBD5E1 !important;
}

.ci-article-card__image {
  aspect-ratio: 16 / 10 !important;
  height: auto !important;
  max-height: none !important;
  width: 100% !important;
  object-fit: cover !important;
  background-color: #F1F5F9;
  display: block;
}

.ci-article-card__content {
  padding: 14px 16px 18px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  flex: 1 !important;
}

.ci-article-card__title {
  font-family: var(--ci-font-heading) !important;
  font-size: 15px !important;
  line-height: 1.3 !important;
  font-weight: 700 !important;
  color: #0F172A !important;
  margin: 0 !important;
  transition: color 0.15s !important;
}

.ci-article-card:hover .ci-article-card__title {
  color: #B91C1C !important;
}

.ci-article-card__meta {
  margin-top: auto !important;
  padding-top: 4px !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  color: #64748B !important;
}

/* ----- PAGINARE ----- */
.ci-pagination {
  margin-top: 36px;
  padding-top: 24px;
  border-top: 1px solid #E2E8F0;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.ci-pagination__item {
  display: inline-flex;
}

.ci-pagination .page-numbers,
.ci-pagination__item > a,
.ci-pagination__item > span {
  min-width: 40px !important;
  height: 40px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 12px !important;
  font-family: var(--ci-font-heading) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  border-radius: 6px !important;
  text-decoration: none !important;
  color: #334155 !important;
  background: #FFFFFF !important;
  border: 1px solid #E2E8F0 !important;
  transition: all 0.15s !important;
}

.ci-pagination .page-numbers:hover,
.ci-pagination__item > a:hover {
  background: #FEF2F2 !important;
  border-color: #FEE2E2 !important;
  color: #B91C1C !important;
}

.ci-pagination .page-numbers.current,
.ci-pagination .current {
  background: #B91C1C !important;
  color: #FFFFFF !important;
  border-color: #B91C1C !important;
}

.ci-pagination .page-numbers.dots,
.ci-pagination .dots {
  border: none !important;
  background: transparent !important;
  color: #64748B !important;
}

/* ----- Empty state ----- */
.ci-archive__empty {
  text-align: center;
  padding: 60px 20px;
  color: #64748B;
}
.ci-archive__empty-text {
  font-size: 16px !important;
  margin: 0 0 16px !important;
}
.ci-archive__empty-cta {
  display: inline-block;
  color: #B91C1C !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  font-size: 14px;
}
.ci-archive__empty-cta:hover {
  text-decoration: underline !important;
}

/* ----- Responsive: tablet 2 col ----- */
@media (max-width: 1024px) and (min-width: 769px) {
  .ci-archive__grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* ----- Responsive: mobile 1 col ----- */
@media (max-width: 768px) {
  .ci-archive {
    padding: 20px 16px;
  }
  .ci-archive__header {
    padding-bottom: 10px;
    margin-bottom: 18px;
    border-bottom-width: 3px;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
  .ci-archive__title {
    font-size: 20px !important;
  }
  .ci-archive__meta {
    font-size: 12px !important;
  }
  /* Filtru: scroll orizontal pe mobile */
  .ci-category-bar.ci-archive__category-bar {
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    margin-left: -16px !important;
    margin-right: -16px !important;
    padding: 4px 16px !important;
    margin-bottom: 20px !important;
    scrollbar-width: none;
  }
  .ci-archive__category-bar::-webkit-scrollbar {
    display: none;
  }
  .ci-archive__category-bar .ci-category-pill {
    white-space: nowrap !important;
    flex-shrink: 0 !important;
  }
  .ci-archive__grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }
  .ci-article-card__content {
    padding: 12px 14px 16px !important;
  }
  .ci-article-card__title {
    font-size: 14px !important;
  }
  .ci-pagination .page-numbers,
  .ci-pagination__item > a,
  .ci-pagination__item > span {
    min-width: 36px !important;
    height: 36px !important;
    padding: 0 10px !important;
    font-size: 12px !important;
  }
}


/* ==========================================================================
   22. v3.5 MOBILE OVERFLOW FIX — paginile archive/category/home
   Previne scroll orizontal accidental și asigură full-width pe toate elementele
   ========================================================================== */

@media (max-width: 768px) {

  /* Previne scroll orizontal global pe pagini archive */
  body.archive,
  body.category,
  body.blog,
  body.home {
    overflow-x: hidden !important;
  }

  /* Main container archive — full width, fără padding/margin agresiv */
  main.ci-archive,
  .ci-archive {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    padding: 20px 16px !important;
    margin: 0 !important;
  }

  /* Header + filtru + grid + paginare — full width */
  .ci-archive__header,
  .ci-archive__grid,
  .ci-pagination {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  /* Category bar: scot margin negativ care cauza overflow pe anumite teme parent */
  .ci-category-bar.ci-archive__category-bar {
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding: 4px 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  /* Card articol — full width + prevent shrink în flex parent */
  .ci-article-card {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    min-width: 0 !important;
  }

  /* Imagini în carduri — constrânse la container */
  .ci-article-card__image,
  .ci-article-card img {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    display: block !important;
    object-fit: cover !important;
  }

  /* Text — wrap corect, fără overflow */
  .ci-article-card__title,
  .ci-archive__title,
  .ci-archive__description,
  .ci-archive__header h1,
  .ci-archive__header p {
    word-wrap: break-word !important;
    overflow-wrap: break-word !important;
    hyphens: auto !important;
  }

  /* Paginare — wrap pe mobile dacă sunt prea multe butoane */
  .ci-pagination {
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 4px !important;
  }
}


/* ==========================================================================
   23. LAYOUT FIX HOMEPAGE — B-C22-10
   --------------------------------------------------------------------------
   Bug: pe desktop ≥1280px, cele 6 widget-uri homepage (map, news, video,
   stats, forum, subscribe) se compresau orizontal pe un singur rând (~150-
   200px fiecare), text spart vertical.
   
   Cauză: GeneratePress aplică display:flex pe #content.site-content cu
   flex-direction:row pe desktop (default pentru layout cu sidebar).
   Homepage-ul n-are sidebar → cele 6 <section> devin "coloane" pe rând.
   Pe mobile, GeneratePress comută la flex-direction:column → de aia merge.
   
   Fix: forțăm column la TOATE viewport-urile, scoped strict la body.home.
   ========================================================================== */

body.home #content.site-content {
  flex-direction: column !important;
}
