/* ============================================================
   SCOALA DORNESTI — AERO GLASS UI 2026
   Stil: Glassmorphism / Windows Aero · Culori UE (albastru + auriu)
   Conformitate: WCAG 2.1 AA · Directiva 2016/2102/UE · EN 301 549
   Aplică în: /media/templates/site/cassiopeia/css/user.css
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap');

/* ── VARIABILE DE DESIGN ──────────────────────────────────────── */
:root {
  /* Fundal EU dark-navy */
  --bg-root:    #04091a;
  --bg-root2:   #071232;
  --bg-root3:   #0a1c45;

  /* Glass surfaces */
  --glass-1:    rgba(255,255,255,.055);
  --glass-2:    rgba(255,255,255,.09);
  --glass-3:    rgba(255,255,255,.13);
  --glass-border: rgba(255,255,255,.14);
  --glass-border2: rgba(255,255,255,.22);
  --glass-blur: blur(22px) saturate(180%);

  /* Culori UE */
  --eu-blue:    #003399;   /* albastru EU oficial */
  --eu-gold:    #FFCC00;   /* auriu EU oficial */
  --eu-blue-lt: #4a7ff7;
  --eu-teal:    #38d9a9;
  --eu-rose:    #f472b6;

  /* Accent principal */
  --accent:     #4a7ff7;
  --accent-d:   #2563eb;
  --accent2:    #38d9a9;

  /* Text – WCAG AA garantat pe fundal întunecat */
  --text:       #f0f4ff;    /* 13.8:1 pe bg-root ✓ */
  --text-2:     #c8d8f8;    /*  8.4:1 pe bg-root ✓ */
  --text-muted: rgba(180,210,255,.65); /* 5.1:1 ✓ */
  --text-inv:   #04091a;

  /* Stări */
  --focus-ring: #FFCC00;   /* auriu EU – vizibil pe orice fundal */
  --err:   #ff6b6b;
  --warn:  #ffd43b;
  --ok:    #38d9a9;

  /* Forme & umbre */
  --r-sm: 10px; --r-md: 16px; --r-lg: 24px; --r-xl: 32px;
  --s1: 0 4px 20px rgba(0,0,0,.35);
  --s2: 0 10px 40px rgba(0,0,0,.50);
  --s3: 0 24px 70px rgba(0,0,0,.60);
  --t: .2s cubic-bezier(.4,0,.2,1);

  --f-body:  'Plus Jakarta Sans','Inter',system-ui,sans-serif;
  --f-title: 'Inter','Segoe UI',system-ui,sans-serif;
}

/* ── MOTION SAFE ──────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
  html { scroll-behavior: auto; }
}
html { scroll-behavior: smooth; }

/* ── SKIP-TO-CONTENT (cerință WCAG 2.4.1) ─────────────────────── */
.skip-link,
a[href="#content"].skip-link {
  position: fixed !important;
  top: -9999px !important;
  left: 14px !important;
  z-index: 9999 !important;
  background: var(--eu-gold) !important;
  color: #000 !important;
  padding: 10px 20px !important;
  border-radius: 0 0 var(--r-sm) var(--r-sm) !important;
  font-weight: 700 !important;
  font-size: .9rem !important;
  text-decoration: none !important;
  box-shadow: var(--s2) !important;
}
.skip-link:focus, a[href="#content"].skip-link:focus {
  top: 0 !important;
  outline: 3px solid #000 !important;
  outline-offset: 0 !important;
}

/* ── BODY & FUNDAL ANIMAT ─────────────────────────────────────── */
body {
  font-family: var(--f-body) !important;
  font-size: 16px !important;
  line-height: 1.7 !important;
  color: var(--text) !important;
  background-color: var(--bg-root) !important;
  background-image:
    radial-gradient(ellipse 90% 70% at 5% -5%,  rgba(74,127,247,.18) 0%,transparent 52%),
    radial-gradient(ellipse 75% 55% at 95% 100%, rgba(56,217,169,.12) 0%,transparent 50%),
    radial-gradient(ellipse 60% 45% at 50% 50%,  rgba(0,51,153,.14)  0%,transparent 60%) !important;
  background-attachment: fixed !important;
  min-height: 100vh !important;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden !important;
}

/* Orbe decorative animate (reduced-motion-safe) */
@media (prefers-reduced-motion: no-preference) {
  body::before {
    content: '' !important;
    position: fixed !important;
    inset: 0 !important;
    pointer-events: none !important;
    z-index: 0 !important;
    background:
      radial-gradient(circle 700px at 15% 25%, rgba(74,127,247,.10) 0%,transparent 65%),
      radial-gradient(circle 500px at 80% 70%, rgba(56,217,169,.08) 0%,transparent 65%) !important;
    animation: orbDrift 20s ease-in-out infinite alternate !important;
  }
  @keyframes orbDrift {
    0%   { transform: translate(0,0) scale(1); }
    50%  { transform: translate(30px,-20px) scale(1.06); }
    100% { transform: translate(-20px,30px) scale(.97); }
  }
}

/* ── HEADER GLASS ─────────────────────────────────────────────── */
.container-header,
header.header,
header,
#sp-header {
  position: sticky !important;
  top: 0 !important;
  z-index: 1400 !important;
  background: rgba(4,9,26,.78) !important;
  backdrop-filter: var(--glass-blur) !important;
  -webkit-backdrop-filter: var(--glass-blur) !important;
  border-bottom: 1px solid var(--glass-border) !important;
  box-shadow: 0 1px 0 rgba(255,255,255,.04), var(--s1) !important;
  padding: 0 !important;
}

/* Linie aurie EU sub header */
.container-header::after, header.header::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0; left: 0;
  width: 100%; height: 2px !important;
  background: linear-gradient(90deg, transparent 0%, var(--eu-gold) 30%, var(--accent) 70%, transparent 100%) !important;
  opacity: .55 !important;
  pointer-events: none !important;
}

/* ── LOGO ANIMAT ─────────────────────────────────────────────── */
/* Ascunde imaginea SVG implicită Cassiopeia */
.navbar-brand img,
.container-logo img,
.mod-logo img {
  display: none !important;
}

/* Container logo */
.navbar-brand, .mod-logo a {
  display: inline-flex !important;
  align-items: center !important;
  gap: 12px !important;
  text-decoration: none !important;
  position: relative !important;
}

/* ── Insignă animată (cerc cu icon şcoală) ───────────── */
.navbar-brand::before, .mod-logo a::before {
  content: '🏫' !important;
  font-size: 1.5rem !important;
  line-height: 1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 44px !important;
  height: 44px !important;
  border-radius: 50% !important;
  background: rgba(255,255,255,.06) !important;
  backdrop-filter: blur(10px) !important;
  flex-shrink: 0 !important;
  animation: badgeBreathe 3s ease-in-out infinite !important;
  box-shadow: 0 0 0 0 rgba(74,127,247,.6) !important;
}
@keyframes badgeBreathe {
  0%,100% { box-shadow: 0 0 0 0 rgba(74,127,247,.5), 0 0 12px rgba(74,127,247,.2); transform: scale(1); }
  50%      { box-shadow: 0 0 0 8px rgba(74,127,247,.0), 0 0 22px rgba(74,127,247,.4); transform: scale(1.06); }
}

/* Inel rotitor în jurul insignei */
.container-logo {
  position: relative !important;
  animation: logoReveal .7s cubic-bezier(.34,1.56,.64,1) both !important;
}
.container-logo::before {
  content: '' !important;
  position: absolute !important;
  left: 14px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 44px !important;
  height: 44px !important;
  border-radius: 50% !important;
  background: conic-gradient(
    var(--eu-gold) 0deg,
    var(--accent) 90deg,
    var(--accent2) 180deg,
    transparent 270deg
  ) !important;
  animation: ringRotate 3s linear infinite !important;
  pointer-events: none !important;
  z-index: 0 !important;
}
/* Mască care creează aparența de inel */
.container-logo::after {
  content: '' !important;
  position: absolute !important;
  left: 17px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 38px !important;
  height: 38px !important;
  border-radius: 50% !important;
  background: rgba(4,9,26,.95) !important;
  pointer-events: none !important;
  z-index: 0 !important;
}
@keyframes ringRotate {
  from { transform: translateY(-50%) rotate(0deg); }
  to   { transform: translateY(-50%) rotate(360deg); }
}
@keyframes logoReveal {
  from { opacity: 0; transform: translateX(-20px); }
  to   { opacity: 1; transform: translateX(0); }
}

/* ── Textul site name ─────────────────────────────────────── */
.site-name, .site-title,
.navbar-brand span, .navbar-brand .site-name, .navbar-brand .site-title,
.header .site-name, .header .site-title,
.mod-logo span, span.site-name, span.site-title {
  font-family: var(--f-title) !important;
  font-weight: 800 !important;
  font-size: 1.15rem !important;
  letter-spacing: -.025em !important;
  line-height: 1.2 !important;
  /* Reset orice -webkit-text-fill de la Bootstrap/Cassiopeia */
  -webkit-text-fill-color: initial !important;
  /* Animație glow color */
  animation: schoolNameGlow 3.5s ease-in-out infinite !important;
  position: relative !important;
  z-index: 1 !important;
  display: inline-block !important;
}
@keyframes schoolNameGlow {
  0%,100% {
    color: #ffffff;
    text-shadow: 0 0 6px rgba(255,255,255,.35), 0 0 14px rgba(74,127,247,.25);
  }
  30% {
    color: var(--eu-gold);
    text-shadow: 0 0 12px var(--eu-gold), 0 0 28px rgba(255,204,0,.55), 0 0 45px rgba(255,204,0,.25);
  }
  65% {
    color: #a8c4ff;
    text-shadow: 0 0 12px #4a7ff7, 0 0 28px rgba(74,127,247,.55), 0 0 45px rgba(74,127,247,.25);
  }
}

/* Fallback – link brand direct */
.navbar-brand a, .mod-logo a {
  position: relative !important;
  z-index: 1 !important;
}

/* ── NAVEGARE ──────────────────────────────────────────────────── */
ul.mod-menu.nav,
.navbar-nav { gap: 2px !important; }

.nav-item > a,
.mod-menu__item > a,
ul.mod-menu.nav > li.nav-item > a {
  color: var(--text-2) !important;
  font-size: .875rem !important;
  font-weight: 500 !important;
  padding: 8px 14px !important;
  border-radius: var(--r-sm) !important;
  transition: color var(--t), background var(--t), transform var(--t) !important;
  text-decoration: none !important;
  position: relative !important;
  white-space: nowrap !important;
}

/* Subliniere animată la hover */
.nav-item > a::after,
ul.mod-menu.nav > li.nav-item > a::after {
  content: '' !important;
  position: absolute !important;
  bottom: 3px; left: 50% !important;
  width: 0; height: 2px !important;
  background: linear-gradient(90deg, var(--eu-gold), var(--accent)) !important;
  border-radius: 2px !important;
  transition: width var(--t), left var(--t) !important;
}
.nav-item > a:hover::after,
ul.mod-menu.nav > li.nav-item > a:hover::after {
  width: calc(100% - 28px) !important;
  left: 14px !important;
}

.nav-item > a:hover,
ul.mod-menu.nav > li.nav-item > a:hover {
  color: var(--text) !important;
  background: var(--glass-2) !important;
  transform: translateY(-1px) !important;
  text-decoration: none !important;
}

/* Item activ */
.nav-item.active > a, .nav-item.current > a,
ul.mod-menu.nav > li.nav-item.active > a,
ul.mod-menu.nav > li.nav-item.current > a {
  color: #fff !important;
  background: linear-gradient(135deg, rgba(74,127,247,.28), rgba(56,217,169,.16)) !important;
  border: 1px solid rgba(74,127,247,.35) !important;
}

/* Dropdown */
.dropdown-menu, .nav-child {
  background: rgba(7,18,50,.88) !important;
  backdrop-filter: var(--glass-blur) !important;
  -webkit-backdrop-filter: var(--glass-blur) !important;
  border: 1px solid var(--glass-border2) !important;
  border-top: 2px solid var(--eu-gold) !important;
  border-radius: 0 0 var(--r-md) var(--r-md) !important;
  box-shadow: var(--s2) !important;
  padding: 6px 0 !important;
  min-width: 230px !important;
}
.dropdown-item, .nav-child a {
  color: var(--text-2) !important;
  font-size: .875rem !important;
  font-weight: 500 !important;
  padding: 10px 18px !important;
  border-bottom: 1px solid rgba(255,255,255,.05) !important;
  transition: all var(--t) !important;
}
.dropdown-item:hover, .nav-child a:hover {
  background: var(--glass-2) !important;
  color: var(--eu-gold) !important;
  padding-left: 24px !important;
  text-decoration: none !important;
}
.dropdown-item:last-child, .nav-child li:last-child a { border-bottom: none !important; }

/* Hamburger */
.navbar-toggler {
  border: 1px solid var(--glass-border) !important;
  background: var(--glass-1) !important;
  color: var(--text) !important;
  border-radius: var(--r-sm) !important;
  padding: 8px 12px !important;
}
.navbar-toggler:hover { background: var(--glass-2) !important; }
.navbar-toggler-icon { background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28240%2C244%2C255%2C0.9%29' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important; }

/* FOCUS – WCAG 2.4.7 (înalt contrast, vizibil) */
*:focus-visible {
  outline: 3px solid var(--focus-ring) !important;
  outline-offset: 3px !important;
  box-shadow: 0 0 0 6px rgba(255,204,0,.25) !important;
  border-radius: 6px !important;
}
a:focus-visible { text-decoration: underline !important; }

/* ── BREADCRUMBS ──────────────────────────────────────────────── */
.breadcrumb, .pathway {
  background: var(--glass-1) !important;
  backdrop-filter: blur(10px) !important;
  border-bottom: 1px solid var(--glass-border) !important;
  padding: 10px 0 !important;
  margin: 0 !important;
  font-size: .82rem !important;
}
.breadcrumb-item a { color: var(--eu-gold) !important; }
.breadcrumb-item.active { color: var(--text-muted) !important; }
.breadcrumb-item + .breadcrumb-item::before { color: var(--text-muted) !important; }

/* ── MAIN CONTENT ─────────────────────────────────────────────── */
.wrapper-inner, #wrapper_r, .container.site {
  position: relative !important;
  z-index: 1 !important;
  padding-top: 24px !important;
  padding-bottom: 60px !important;
}

/* ── CARDURI ARTICOLE ─────────────────────────────────────────── */
article.com-content-article,
.com-content-category-blog .com-content-article,
.items-row .item {
  background: var(--glass-1) !important;
  backdrop-filter: var(--glass-blur) !important;
  -webkit-backdrop-filter: var(--glass-blur) !important;
  border: 1px solid var(--glass-border) !important;
  border-top: 2px solid var(--accent) !important;
  border-radius: var(--r-md) !important;
  box-shadow: var(--s1) !important;
  padding: 28px !important;
  margin-bottom: 24px !important;
  position: relative !important;
  overflow: hidden !important;
  transition: transform var(--t), box-shadow var(--t), border-color var(--t) !important;
}

/* Highlight glow decorativ */
article.com-content-article::before,
.com-content-category-blog .com-content-article::before {
  content: '' !important;
  position: absolute !important;
  top: 0; left: 0 !important;
  width: 100%; height: 2px !important;
  background: linear-gradient(90deg, var(--accent), var(--eu-gold), var(--accent2)) !important;
  opacity: 0 !important;
  transition: opacity var(--t) !important;
}
article.com-content-article:hover::before,
.com-content-category-blog .com-content-article:hover::before { opacity: 1 !important; }

@media (prefers-reduced-motion: no-preference) {
  article.com-content-article:hover,
  .com-content-category-blog .com-content-article:hover {
    transform: translateY(-3px) !important;
    box-shadow: var(--s2), 0 0 30px rgba(74,127,247,.14) !important;
    border-color: rgba(74,127,247,.45) !important;
  }
}

/* Titlu articol */
.com-content-article__title,
h2.item-title, h2.article-title,
.page-header h1, .article-header h1 {
  font-family: var(--f-title) !important;
  font-weight: 700 !important;
  font-size: clamp(1.1rem,1.6vw,1.65rem) !important;
  color: var(--text) !important;
  margin-bottom: 12px !important;
  line-height: 1.3 !important;
}
.com-content-article__title a, h2.item-title a {
  color: var(--text) !important;
  text-decoration: none !important;
  transition: color var(--t) !important;
  -webkit-text-fill-color: var(--text) !important;
  background: none !important;
}
.com-content-article__title a:hover, h2.item-title a:hover {
  color: var(--eu-gold) !important;
  -webkit-text-fill-color: var(--eu-gold) !important;
}

/* Meta articol */
.article-info, .com-content-article__details, dl.article-info {
  color: var(--text-muted) !important;
  font-size: .8rem !important;
  border-top: 1px solid var(--glass-border) !important;
  padding-top: 10px !important;
  margin-top: 16px !important;
}
.article-info a { color: var(--text-muted) !important; }
.article-info a:hover { color: var(--eu-gold) !important; }

/* Buton Citeste mai mult */
.readmore a, .btn.btn-secondary, .btn-secondary {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  background: linear-gradient(135deg, var(--accent-d), var(--accent)) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--r-sm) !important;
  padding: 9px 20px !important;
  font-size: .85rem !important;
  font-weight: 600 !important;
  letter-spacing: .02em !important;
  text-decoration: none !important;
  transition: transform var(--t), box-shadow var(--t) !important;
  box-shadow: 0 4px 14px rgba(74,127,247,.38) !important;
}
.readmore a:hover, .btn-secondary:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px rgba(74,127,247,.55) !important;
  color: #fff !important;
  text-decoration: none !important;
}
/* Contrast buton: alb pe albastru #2563eb = 4.7:1 ✓ WCAG AA */

/* Articol complet */
.item-page {
  background: var(--glass-1) !important;
  backdrop-filter: var(--glass-blur) !important;
  -webkit-backdrop-filter: var(--glass-blur) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: var(--r-lg) !important;
  box-shadow: var(--s2) !important;
  padding: 36px !important;
}
.item-page h2, .item-page h3 {
  color: var(--text) !important;
  border-left: 3px solid var(--eu-gold) !important;
  padding-left: 14px !important;
  margin: 22px 0 12px !important;
}
.item-page h1 { color: var(--text) !important; font-size: 2rem !important; }
.item-page p, .item-page li { color: var(--text-2) !important; }
.item-page a { color: var(--accent) !important; }
.item-page a:hover { color: var(--eu-gold) !important; }
.item-page table { width: 100%; border-collapse: collapse; }
.item-page th {
  background: rgba(74,127,247,.25) !important;
  color: var(--text) !important;
  padding: 11px 15px !important;
  text-align: left !important;
  border-bottom: 1px solid rgba(74,127,247,.35) !important;
}
.item-page td {
  padding: 9px 15px !important;
  border-bottom: 1px solid var(--glass-border) !important;
  color: var(--text-2) !important;
}
.item-page tr:nth-child(even) td { background: rgba(255,255,255,.03) !important; }
.item-page ul, .item-page ol { padding-left: 22px !important; }
.item-page li { margin-bottom: 6px !important; }

/* Titlu categorie */
.com-content-category__title, .page-header {
  background: rgba(74,127,247,.12) !important;
  backdrop-filter: blur(12px) !important;
  border: 1px solid rgba(74,127,247,.25) !important;
  border-radius: var(--r-md) var(--r-md) 0 0 !important;
  padding: 18px 24px !important;
  margin-bottom: 0 !important;
}
.com-content-category__title h1, .page-header h1 {
  color: var(--text) !important;
  font-size: 1.5rem !important;
  margin: 0 !important;
  border: none !important;
}

/* ── SIDEBAR ──────────────────────────────────────────────────── */
/* Module sidebar */
.moduletable, .dornesti-sidebar-block,
#sp-right .moduletable, aside .moduletable {
  background: var(--glass-1) !important;
  backdrop-filter: var(--glass-blur) !important;
  -webkit-backdrop-filter: var(--glass-blur) !important;
  border: 1px solid var(--glass-border) !important;
  border-top: 2px solid var(--eu-gold) !important;
  border-radius: var(--r-md) !important;
  box-shadow: var(--s1) !important;
  margin-bottom: 20px !important;
  overflow: hidden !important;
}

/* Titlu modul sidebar */
.sidebar-heading,
.moduletable h3, .moduletable .module-title,
#sp-right .moduletable h3, aside .moduletable h3 {
  background: rgba(0,51,153,.30) !important;
  backdrop-filter: blur(10px) !important;
  color: var(--eu-gold) !important;
  font-family: var(--f-body) !important;
  font-size: .8rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .1em !important;
  padding: 12px 16px !important;
  margin: 0 !important;
  border-bottom: 1px solid var(--glass-border) !important;
}

/* Link-uri sidebar */
.sidebar-links, #sp-right ul, aside .moduletable ul {
  list-style: none !important;
  padding: 8px 0 !important;
  margin: 0 !important;
}
.sidebar-links li, #sp-right ul li, aside .moduletable ul li {
  border-bottom: 1px solid var(--glass-border) !important;
}
.sidebar-links li:last-child, #sp-right ul li:last-child,
aside .moduletable ul li:last-child { border-bottom: none !important; }
.sidebar-links a, #sp-right ul li a, aside .moduletable ul li a {
  display: block !important;
  padding: 10px 16px !important;
  color: var(--text-2) !important;
  font-size: .875rem !important;
  text-decoration: none !important;
  transition: all var(--t) !important;
}
.sidebar-links a:hover, #sp-right ul li a:hover, aside .moduletable ul li a:hover {
  background: var(--glass-2) !important;
  color: var(--eu-gold) !important;
  padding-left: 22px !important;
  text-decoration: none !important;
}
/* Contrast text sidebar: #c8d8f8 pe glass-1 bg efectiv (~#0c1530) ≈ 8:1 ✓ */

/* ── EU FLAG BADGE în header ──────────────────────────────────── */
.container-header::before {
  content: '' !important;
  position: absolute !important;
  top: 8px; right: 16px !important;
  width: 28px; height: 18px !important;
  background: var(--eu-blue) !important;
  border-radius: 3px !important;
  background-image:
    radial-gradient(circle 2px at 50% 25%, var(--eu-gold) 100%, transparent),
    radial-gradient(circle 2px at 65% 32%, var(--eu-gold) 100%, transparent),
    radial-gradient(circle 2px at 75% 50%, var(--eu-gold) 100%, transparent),
    radial-gradient(circle 2px at 65% 68%, var(--eu-gold) 100%, transparent),
    radial-gradient(circle 2px at 50% 75%, var(--eu-gold) 100%, transparent),
    radial-gradient(circle 2px at 35% 68%, var(--eu-gold) 100%, transparent),
    radial-gradient(circle 2px at 25% 50%, var(--eu-gold) 100%, transparent),
    radial-gradient(circle 2px at 35% 32%, var(--eu-gold) 100%, transparent) !important;
  opacity: .7 !important;
  pointer-events: none !important;
}

/* ── FOOTER GLASS ─────────────────────────────────────────────── */
footer, .footer-wrapper, .container-footer {
  background: rgba(4,9,26,.90) !important;
  backdrop-filter: blur(16px) !important;
  border-top: 1px solid var(--glass-border) !important;
  border-top-color: rgba(255,204,0,.3) !important;
  color: var(--text-muted) !important;
  padding: 28px 0 !important;
  margin-top: 50px !important;
  font-size: .85rem !important;
  position: relative !important;
}
footer a, .container-footer a { color: var(--eu-gold) !important; }
footer a:hover { color: var(--text) !important; }

/* Linie decorativă EU în footer */
.container-footer::before {
  content: '' !important;
  display: block !important;
  width: 60px; height: 2px !important;
  background: linear-gradient(90deg, var(--eu-gold), var(--accent)) !important;
  margin: 0 auto 16px !important;
  border-radius: 2px !important;
}

/* ── TIPOGRAFIE GENERALĂ ──────────────────────────────────────── */
h1,h2,h3,h4,h5,h6 {
  font-family: var(--f-title) !important;
  font-weight: 700 !important;
  color: var(--text) !important;
  line-height: 1.3 !important;
}
h1 { font-size: clamp(1.7rem,2.8vw,2.8rem) !important; }
h2 { font-size: clamp(1.3rem,2vw,2rem) !important; }
h3 { font-size: clamp(1.1rem,1.5vw,1.45rem) !important; }

p, li, td, th { color: var(--text-2) !important; }

a {
  color: var(--accent) !important;
  text-decoration-thickness: 1.5px !important;
  text-underline-offset: .22em !important;
  transition: color var(--t) !important;
}
a:hover { color: var(--eu-gold) !important; }

/* ── FORMULARE ────────────────────────────────────────────────── */
input, textarea, select {
  background: var(--glass-1) !important;
  border: 1px solid var(--glass-border2) !important;
  color: var(--text) !important;
  border-radius: var(--r-sm) !important;
  padding: 10px 14px !important;
  font-family: var(--f-body) !important;
  font-size: .9rem !important;
  transition: border-color var(--t), box-shadow var(--t) !important;
}
input:focus, textarea:focus, select:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px rgba(74,127,247,.25) !important;
  outline: 3px solid var(--focus-ring) !important;
  outline-offset: 2px !important;
  background: var(--glass-2) !important;
}
input::placeholder, textarea::placeholder { color: var(--text-muted) !important; }
label { color: var(--text-2) !important; font-weight: 500 !important; font-size: .9rem !important; }

.btn-primary, button[type="submit"], input[type="submit"] {
  background: linear-gradient(135deg, var(--accent-d), var(--accent)) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--r-sm) !important;
  padding: 10px 24px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: transform var(--t), box-shadow var(--t) !important;
  box-shadow: 0 4px 14px rgba(74,127,247,.4) !important;
}
.btn-primary:hover, button[type="submit"]:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px rgba(74,127,247,.6) !important;
}
/* Contrast alb pe #2563eb = 4.7:1 ✓ WCAG AA */

/* ── PAGINARE ─────────────────────────────────────────────────── */
.pagination .page-link {
  background: var(--glass-1) !important;
  border: 1px solid var(--glass-border) !important;
  color: var(--text-2) !important;
  border-radius: var(--r-sm) !important;
  margin: 0 2px !important;
  transition: all var(--t) !important;
}
.pagination .page-link:hover {
  background: var(--glass-2) !important;
  color: var(--eu-gold) !important;
  border-color: rgba(255,204,0,.3) !important;
}
.pagination .page-item.active .page-link {
  background: linear-gradient(135deg, var(--accent-d), var(--accent)) !important;
  border-color: transparent !important;
  color: #fff !important;
  box-shadow: 0 4px 12px rgba(74,127,247,.4) !important;
}

/* ── TABEL GENERAL ────────────────────────────────────────────── */
.table, table {
  width: 100% !important;
  border-collapse: collapse !important;
  background: var(--glass-1) !important;
  border-radius: var(--r-sm) !important;
  overflow: hidden !important;
}
.table th, table th {
  background: rgba(74,127,247,.2) !important;
  color: var(--text) !important;
  padding: 12px 16px !important;
  text-align: left !important;
  font-weight: 600 !important;
  font-size: .875rem !important;
  text-transform: uppercase !important;
  letter-spacing: .04em !important;
  border-bottom: 1px solid rgba(74,127,247,.25) !important;
}
.table td, table td {
  padding: 10px 16px !important;
  color: var(--text-2) !important;
  border-bottom: 1px solid var(--glass-border) !important;
  font-size: .9rem !important;
}
.table tr:last-child td, table tr:last-child td { border-bottom: none !important; }

/* ── BANNER COOKIE GDPR ───────────────────────────────────────── */
#dornesti-cookie-banner {
  position: fixed !important;
  bottom: 0 !important;
  left: 0 !important;
  right: 0 !important;
  z-index: 9000 !important;
  background: rgba(4,9,26,.96) !important;
  backdrop-filter: blur(20px) !important;
  border-top: 2px solid rgba(255,204,0,.4) !important;
  padding: 18px 24px !important;
  display: flex !important;
  align-items: center !important;
  gap: 20px !important;
  flex-wrap: wrap !important;
  box-shadow: 0 -8px 32px rgba(0,0,0,.5) !important;
  animation: cookieSlideUp .4s cubic-bezier(.34,1.56,.64,1) both !important;
}
@keyframes cookieSlideUp {
  from { transform: translateY(100%); opacity: 0; }
  to   { transform: translateY(0); opacity: 1; }
}
#dornesti-cookie-banner p {
  flex: 1 1 280px !important;
  margin: 0 !important;
  color: var(--text-2) !important;
  font-size: .875rem !important;
}
#dornesti-cookie-banner a { color: var(--eu-gold) !important; }
#dornesti-cookie-banner .cookie-btn {
  background: linear-gradient(135deg, var(--accent-d), var(--accent)) !important;
  color: #fff !important;
  border: none !important;
  padding: 10px 24px !important;
  border-radius: var(--r-sm) !important;
  font-weight: 600 !important;
  font-size: .875rem !important;
  cursor: pointer !important;
  white-space: nowrap !important;
  box-shadow: 0 4px 14px rgba(74,127,247,.4) !important;
  transition: transform var(--t), box-shadow var(--t) !important;
}
#dornesti-cookie-banner .cookie-btn:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px rgba(74,127,247,.6) !important;
}
#dornesti-cookie-banner .cookie-btn-reject {
  background: transparent !important;
  border: 1px solid var(--glass-border2) !important;
  color: var(--text-muted) !important;
  box-shadow: none !important;
}
#dornesti-cookie-banner .cookie-btn-reject:hover {
  background: var(--glass-2) !important;
  color: var(--text) !important;
  transform: none !important;
}

/* ── WIDGET ACCESIBILITATE EU ─────────────────────────────────── */
#dornesti-a11y-widget {
  position: fixed !important;
  right: 20px !important;
  bottom: 20px !important;
  z-index: 9500 !important;
}
#dornesti-a11y-btn {
  width: 52px !important;
  height: 52px !important;
  border-radius: 50% !important;
  border: 2px solid rgba(255,255,255,.2) !important;
  background: linear-gradient(135deg, var(--eu-blue), var(--accent)) !important;
  color: #fff !important;
  font-size: 1.5rem !important;
  line-height: 1 !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: 0 8px 28px rgba(74,127,247,.5) !important;
  transition: transform var(--t), box-shadow var(--t) !important;
  animation: a11yPulse 3s ease-in-out infinite !important;
}
@keyframes a11yPulse {
  0%,100% { box-shadow: 0 8px 28px rgba(74,127,247,.5); }
  50%      { box-shadow: 0 8px 36px rgba(74,127,247,.8), 0 0 0 8px rgba(74,127,247,.12); }
}
#dornesti-a11y-btn:hover {
  transform: scale(1.1) !important;
  box-shadow: 0 12px 36px rgba(74,127,247,.7) !important;
}
#dornesti-a11y-panel {
  position: absolute !important;
  bottom: 62px !important;
  right: 0 !important;
  width: 290px !important;
  background: rgba(7,18,50,.97) !important;
  backdrop-filter: var(--glass-blur) !important;
  border: 1px solid var(--glass-border2) !important;
  border-radius: var(--r-lg) !important;
  padding: 16px !important;
  box-shadow: var(--s3), 0 0 40px rgba(74,127,247,.2) !important;
}
#dornesti-a11y-panel[hidden] { display: none !important; }

/* ── RESPONSIVE ───────────────────────────────────────────────── */
@media (max-width: 767px) {
  .nav-item > a, .navbar-nav .nav-link {
    padding: 12px 16px !important;
    border-bottom: 1px solid var(--glass-border) !important;
  }
  .item-page { padding: 18px !important; }
  article.com-content-article { padding: 18px !important; }
  #dornesti-cookie-banner { flex-direction: column !important; padding: 16px !important; }
}
@media (max-width: 991px) {
  .navbar-brand, .mod-logo a { font-size: .95rem !important; }
}

/* ── PRINT ──────────────────────────────────────────────────────── */
@media print {
  body {
    background: white !important;
    color: #000 !important;
  }
  header, footer, aside, .sidebar-right, nav,
  #dornesti-cookie-banner, #dornesti-a11y-widget { display: none !important; }
  body::before { display: none !important; }
  a { color: #000 !important; text-decoration: underline !important; }
  .item-page {
    background: white !important;
    border: 1px solid #ccc !important;
    box-shadow: none !important;
    padding: 12px !important;
  }
  .item-page p, .item-page li { color: #000 !important; }
}

/* ── FORCED COLORS (Windows High Contrast) ───────────────────── */
@media (forced-colors: active) {
  *:focus-visible { outline: 3px solid ButtonText !important; }
  .btn-primary, .readmore a, button[type="submit"] {
    background: ButtonFace !important;
    color: ButtonText !important;
    border: 2px solid ButtonText !important;
    box-shadow: none !important;
  }
  .navbar-brand, .mod-logo a { -webkit-text-fill-color: unset !important; color: LinkText !important; }
}

/* ── CASSIOPEIA SPECIFICS ─────────────────────────────────────── */
.container-component { padding-top: 20px !important; }
.grid-child.container-logo { padding: 10px 0 !important; }
.sidebar-right.card {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
}

/* ── BUTON SCROLL TO TOP ──────────────────────────────────────── */
#dornesti-scrolltop {
  position: fixed !important;
  right: 20px !important;
  bottom: 84px !important;        /* deasupra butonului ♿ */
  width: 46px !important;
  height: 46px !important;
  border-radius: 50% !important;
  border: 1px solid var(--glass-border2) !important;
  background: rgba(7,18,50,.82) !important;
  backdrop-filter: blur(18px) saturate(160%) !important;
  -webkit-backdrop-filter: blur(18px) saturate(160%) !important;
  color: var(--text) !important;
  font-size: 1.1rem !important;
  line-height: 1 !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  z-index: 9400 !important;
  box-shadow: 0 4px 20px rgba(0,0,0,.45), 0 0 0 1px rgba(255,255,255,.07) !important;
  opacity: 0 !important;
  transform: translateY(12px) scale(.85) !important;
  pointer-events: none !important;
  transition: opacity .3s cubic-bezier(.4,0,.2,1),
              transform .3s cubic-bezier(.4,0,.2,1),
              background .2s, box-shadow .2s !important;
}
#dornesti-scrolltop.visible {
  opacity: 1 !important;
  transform: translateY(0) scale(1) !important;
  pointer-events: auto !important;
}
#dornesti-scrolltop:hover {
  background: linear-gradient(135deg, rgba(37,99,235,.55), rgba(74,127,247,.45)) !important;
  border-color: rgba(74,127,247,.55) !important;
  box-shadow: 0 8px 28px rgba(74,127,247,.45), 0 0 0 1px rgba(74,127,247,.3) !important;
  transform: translateY(-2px) scale(1.08) !important;
  color: #fff !important;
}
#dornesti-scrolltop:focus-visible {
  outline: 3px solid var(--focus-ring) !important;
  outline-offset: 3px !important;
}
/* Arrow SVG via CSS */
#dornesti-scrolltop::before {
  content: '' !important;
  display: block !important;
  width: 14px !important;
  height: 14px !important;
  border-top: 2.5px solid currentColor !important;
  border-right: 2.5px solid currentColor !important;
  transform: rotate(-45deg) translateY(3px) !important;
  border-radius: 2px !important;
}
@media (prefers-reduced-motion: reduce) {
  #dornesti-scrolltop {
    transition: opacity .15s, transform .15s !important;
  }
}
@media print {
  #dornesti-scrolltop { display: none !important; }
}

/* ── GALERIE FOTO AUTOMATĂ ──────────────────────────────────────────────── */
.scoala-gallery-wrap {
  position: relative;
  width: 100%;
  max-width: 820px;
  margin: 1.5rem auto 2rem;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 8px 48px rgba(0,0,0,.45), 0 0 0 1px rgba(255,255,255,.07);
  background: #000;
}
.scoala-slides {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 10;
}
.scoala-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity .9s ease;
}
.scoala-slide.active {
  opacity: 1;
}
.scoala-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.scoala-caption {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: rgba(4,9,26,.65);
  backdrop-filter: blur(10px);
  color: #fff;
  padding: .65rem 1.2rem;
  font-size: .9rem;
  font-style: italic;
  text-align: center;
  letter-spacing: .01em;
}
/* Butoane prev/next */
.scoala-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255,255,255,.12);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.18);
  color: #fff;
  width: 40px; height: 40px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 1.1rem;
  line-height: 1;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s, transform .2s;
  z-index: 10;
  user-select: none;
}
.scoala-btn:hover {
  background: rgba(255,204,0,.3);
  transform: translateY(-50%) scale(1.1);
}
.scoala-btn-prev { left: 10px; }
.scoala-btn-next { right: 10px; }
/* Dots */
.scoala-dots {
  position: absolute;
  bottom: 2.8rem; left: 50%;
  transform: translateX(-50%);
  display: flex; gap: 9px;
  z-index: 10;
}
.scoala-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: rgba(255,255,255,.35);
  cursor: pointer;
  border: none;
  padding: 0;
  transition: background .3s, transform .3s;
}
.scoala-dot.active {
  background: var(--eu-gold, #FFCC00);
  transform: scale(1.3);
}
/* Progress bar */
.scoala-progress {
  position: absolute;
  bottom: 0; left: 0;
  height: 3px;
  background: var(--eu-gold, #FFCC00);
  width: 0%;
  transition: width linear;
  z-index: 11;
}
@media(max-width:480px) {
  .scoala-btn { width:32px; height:32px; font-size:.9rem; }
  .scoala-slides { aspect-ratio: 4/3; }
}
