/* ==========================================================================
   SCOALA SIMINICEA — CASSIOPEIA THEME 2026
   Armonioasa · Calda · Moderna · Accesibila
   Apply to: /templates/cassiopeia/css/user.css
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Lora:ital,wght@0,500;0,700;1,500&display=swap');

/* Variabile de design */
:root {
  --c-bg:      #f5f8f5;
  --c-paper:   #ffffff;
  --c-paper-2: #eef5f1;

  --c-p900: #0d3323;
  --c-p800: #145238;
  --c-p700: #1a7250;
  --c-p600: #22936a;
  --c-p500: #2aad7c;
  --c-p200: #c4e8d8;
  --c-p100: #e4f5ed;
  --c-p50:  #f2faf6;

  --c-g500: #d4a017;
  --c-g300: #f0c840;
  --c-g100: #fdf4cf;

  --c-ink:   #19291f;
  --c-ink-2: #3a5546;
  --c-muted: #78998a;
  --c-line:  #d8e8e0;
  --c-line2: #bfd4ca;

  --r:    14px;
  --r-lg: 22px;
  --r-xl: 30px;

  --s1: 0 2px 8px rgba(13,51,35,.07),0 1px 2px rgba(13,51,35,.04);
  --s2: 0 8px 24px rgba(13,51,35,.10),0 2px 6px rgba(13,51,35,.05);
  --s3: 0 20px 48px rgba(13,51,35,.14),0 4px 12px rgba(13,51,35,.06);

  --t: .22s cubic-bezier(.4,0,.2,1);

  --f-body:  'Plus Jakarta Sans','Segoe UI',system-ui,sans-serif;
  --f-title: 'Lora','Georgia','Times New Roman',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}

/* Body */
body {
  font-family: var(--f-body) !important;
  font-size: 16px !important;
  line-height: 1.72 !important;
  color: var(--c-ink) !important;
  background-color: var(--c-bg) !important;
  background-image:
    radial-gradient(ellipse 70% 50% at 3% 2%, rgba(26,114,80,.13) 0%,transparent 50%),
    radial-gradient(ellipse 55% 45% at 98% 95%,rgba(42,173,124,.10) 0%,transparent 45%) !important;
  background-attachment: fixed !important;
  -webkit-font-smoothing: antialiased;
}

/* Tipografie */
h1,h2,h3,h4,h5,h6 {
  font-family: var(--f-title) !important;
  font-weight: 700 !important;
  line-height: 1.25 !important;
  color: var(--c-p900) !important;
  letter-spacing: -.015em;
}
h1{font-size:clamp(1.9rem,2.6vw + 1rem,3rem)}
h2{font-size:clamp(1.5rem,1.5vw + .9rem,2.2rem)}
h3{font-size:clamp(1.2rem,.8vw + .9rem,1.6rem)}
p,li,td,th{font-family:var(--f-body) !important}

a{color:var(--c-p700) !important;text-decoration-thickness:1.5px;text-underline-offset:.2em;transition:color var(--t)}
a:hover{color:var(--c-p500) !important}

*:focus-visible{
  outline:3px solid var(--c-g300) !important;
  outline-offset:3px;
  box-shadow:0 0 0 6px rgba(212,160,23,.22) !important;
  border-radius:6px
}

/* Header */
.header.container-header,header.header{
  position:sticky !important;
  top:0 !important;
  z-index:1400 !important;
  background:linear-gradient(135deg,var(--c-p900) 0%,#1a4f38 60%,#1f6447 100%) !important;
  border-bottom:3px solid var(--c-g500) !important;
  box-shadow:0 4px 20px rgba(13,51,35,.35) !important;
}

.header .grid-child{display:flex;align-items:center;padding:14px 24px !important}
.navbar-brand,.header .navbar-brand{padding:4px 0 !important}
.brand-logo,.navbar-brand .brand-logo{
  display:inline-flex !important;
  align-items:center !important;
  gap:14px !important;
  text-decoration:none !important
}

.brand-logo img,.navbar-brand .brand-logo img{
  max-height:72px !important;
  width:auto !important;
  border-radius:10px !important;
  filter:drop-shadow(0 2px 8px rgba(0,0,0,.35)) !important
}

.brand-logo span,.navbar-brand .brand-logo span{
  font-family:var(--f-body) !important;
  font-size:clamp(.95rem,.6vw + .7rem,1.2rem) !important;
  font-weight:700 !important;
  color:#fff !important;
  letter-spacing:.01em !important;
  text-shadow:0 1px 4px rgba(0,0,0,.3) !important;
  line-height:1.3 !important
}

/* Navigatie */
.container-nav{
  background:rgba(13,51,35,.55) !important;
  backdrop-filter:blur(8px) !important;
  border-top:1px solid rgba(255,255,255,.1) !important
}

.mod-menu.nav,.container-nav .mod-menu{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:4px !important;
  list-style:none !important;
  margin:0 !important;
  padding:6px 16px !important
}

.mod-menu > .nav-item > a,.container-nav .mod-menu > li > a{
  display:inline-flex !important;
  align-items:center !important;
  min-height:38px !important;
  padding:0 16px !important;
  border-radius:999px !important;
  font-size:.88rem !important;
  font-weight:650 !important;
  font-family:var(--f-body) !important;
  color:rgba(255,255,255,.88) !important;
  text-decoration:none !important;
  letter-spacing:.01em !important;
  transition:background var(--t),color var(--t),transform var(--t) !important;
  border:1px solid transparent !important
}
.mod-menu > .nav-item > a:hover,.mod-menu > .nav-item.active > a,.mod-menu > .nav-item.current > a{
  background:rgba(255,255,255,.16) !important;
  border-color:rgba(255,255,255,.22) !important;
  color:#fff !important;
  transform:translateY(-1px) !important
}
.mod-menu > .nav-item.active > a,.mod-menu > .nav-item.current > a{
  background:var(--c-g500) !important;
  border-color:var(--c-g300) !important;
  color:var(--c-p900) !important;
  font-weight:700 !important
}

/* Submeniu */
.mod-menu__sub,.nav-child{
  background:var(--c-paper) !important;
  border:1px solid var(--c-line) !important;
  border-top:3px solid var(--c-p600) !important;
  border-radius:0 0 var(--r) var(--r) !important;
  box-shadow:var(--s3) !important;
  padding:6px !important;
  list-style:none !important;
  min-width:200px !important
}
.mod-menu__sub .nav-item a{
  display:block !important;
  padding:9px 14px !important;
  border-radius:8px !important;
  color:var(--c-ink) !important;
  font-size:.875rem !important;
  transition:background var(--t),color var(--t),padding-left var(--t) !important
}
.mod-menu__sub .nav-item a:hover{background:var(--c-p50) !important;color:var(--c-p700) !important;padding-left:18px !important}

/* Breadcrumb */
nav[aria-label="Breadcrumbs"],nav.breadcrumb{
  background:var(--c-p50) !important;
  border-radius:var(--r) !important;
  padding:8px 16px !important;
  margin-bottom:20px !important;
  border:1px solid var(--c-p200) !important;
  font-size:.8rem !important
}
nav[aria-label="Breadcrumbs"] ol{display:flex;align-items:center;gap:6px;list-style:none;margin:0;padding:0}
nav[aria-label="Breadcrumbs"] li:not(:last-child)::after{content:'>';margin-left:6px;color:var(--c-muted)}

/* Grid & Layout */
.site-grid{
  max-width:1200px !important;
  margin:28px auto 72px !important;
  padding:0 20px !important;
  gap:24px !important
}

/* Card / Modul */
.card,.moduletable{
  background:var(--c-paper) !important;
  border:1px solid var(--c-line) !important;
  border-radius:var(--r-lg) !important;
  box-shadow:var(--s1) !important;
  overflow:hidden !important;
  transition:box-shadow var(--t),transform var(--t),border-color var(--t) !important
}
.card:hover,.moduletable:hover{
  box-shadow:var(--s2) !important;
  border-color:var(--c-p200) !important;
  transform:translateY(-2px) !important
}

/* Titlu modul */
.card > .card-header,.moduletable h3,.moduletable > .moduletable__header{
  background:linear-gradient(135deg,var(--c-p800) 0%,var(--c-p700) 100%) !important;
  color:#fff !important;
  font-family:var(--f-body) !important;
  font-size:.78rem !important;
  font-weight:700 !important;
  letter-spacing:.07em !important;
  text-transform:uppercase !important;
  padding:12px 20px !important;
  margin:0 !important;
  border:none !important
}

/* Continut modul */
.card-body,.moduletable .mod-content,.card .card-body{padding:18px 20px !important}

/* Componenta principala */
.grid-child.container-component{
  background:var(--c-paper) !important;
  border:1px solid var(--c-line) !important;
  border-radius:var(--r-xl) !important;
  box-shadow:var(--s2) !important;
  padding:clamp(18px,2.5vw,36px) !important
}

/* Titlul paginii */
.page-header{margin-bottom:24px !important;padding-bottom:16px !important;border-bottom:2px solid var(--c-line) !important;position:relative !important}
.page-header::after{
  content:'' !important;
  display:block !important;
  position:absolute !important;
  left:0 !important;bottom:-2px !important;
  width:64px !important;height:3px !important;
  background:linear-gradient(90deg,var(--c-p600),var(--c-g500)) !important;
  border-radius:999px !important
}

/* Articole */
.blog-item,.items-leading .blog-item,.item-page{
  background:var(--c-paper) !important;
  border:1px solid var(--c-line) !important;
  border-radius:var(--r-lg) !important;
  box-shadow:var(--s1) !important;
  overflow:hidden !important;
  margin-bottom:28px !important;
  transition:box-shadow var(--t),transform var(--t) !important
}
.blog-item:hover{box-shadow:var(--s3) !important;transform:translateY(-3px) !important}
.blog-item .item-content,.item-page .item-content{padding:clamp(16px,2vw,28px) !important}
.blog-item img,.item-page img{border-radius:12px !important;box-shadow:var(--s1) !important}

/* Inputuri */
input[type="text"],input[type="email"],input[type="password"],input[type="search"],textarea,select{
  width:100% !important;
  min-height:44px !important;
  background:var(--c-bg) !important;
  border:1.5px solid var(--c-line2) !important;
  border-radius:10px !important;
  padding:10px 14px !important;
  font-family:var(--f-body) !important;
  font-size:.93rem !important;
  color:var(--c-ink) !important;
  transition:border-color var(--t),box-shadow var(--t) !important;
  box-shadow:inset 0 1px 3px rgba(0,0,0,.04) !important
}
input:focus,textarea:focus,select:focus{
  border-color:var(--c-p500) !important;
  box-shadow:0 0 0 4px rgba(42,173,124,.18),inset 0 1px 3px rgba(0,0,0,.04) !important;
  outline:none !important;
  background:#fff !important
}
input::placeholder,textarea::placeholder{color:var(--c-muted) !important}

/* Butoane */
.btn,button.btn,a.btn,input[type="submit"],button[type="submit"]{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:7px !important;
  min-height:44px !important;
  padding:10px 22px !important;
  border-radius:10px !important;
  font-family:var(--f-body) !important;
  font-size:.9rem !important;
  font-weight:700 !important;
  border:2px solid transparent !important;
  cursor:pointer !important;
  transition:all var(--t) !important;
  text-decoration:none !important;
  letter-spacing:.02em !important
}
.btn-primary,button.btn-primary,input[type="submit"]{
  background:linear-gradient(140deg,var(--c-p800),var(--c-p600)) !important;
  color:#fff !important;
  border-color:var(--c-p800) !important;
  box-shadow:0 6px 18px rgba(22,82,56,.28) !important
}
.btn-primary:hover,button.btn-primary:hover,input[type="submit"]:hover{
  background:linear-gradient(140deg,var(--c-p900),var(--c-p700)) !important;
  box-shadow:0 10px 24px rgba(22,82,56,.38) !important;
  transform:translateY(-1px) !important
}

/* Contact */
.com-contact h2,.com-contact__container h2{padding-bottom:12px;border-bottom:2px solid var(--c-line);margin-bottom:20px}
.com-contact__container h2::after,.com-contact h2::after{
  content:'';display:block;width:64px;height:4px;margin-top:8px;border-radius:999px;
  background:linear-gradient(90deg,var(--c-p600),var(--c-g500))
}
.com-contact .control-label label{font-weight:650 !important;color:var(--c-ink-2) !important;font-size:.875rem !important}
.com-contact .control-group{margin-bottom:16px !important}
.com-contact dl.contact-address{background:var(--c-p50) !important;border:1px solid var(--c-p200) !important;border-radius:var(--r) !important;padding:16px 20px !important}

/* Alerte */
.alert,joomla-alert{border-radius:var(--r) !important;border-left:4px solid !important;padding:14px 18px !important;font-weight:500 !important}
.alert-success{border-color:var(--c-p500) !important;background:var(--c-p50) !important;color:var(--c-p900) !important}
.alert-warning{border-color:var(--c-g500) !important;background:var(--c-g100) !important;color:#6b4d00 !important}
.alert-danger{border-color:#e05252 !important;background:#fdf2f2 !important;color:#7a1e1e !important}
.alert-info{border-color:var(--c-p600) !important;background:var(--c-p100) !important;color:var(--c-p800) !important}

/* Tabele */
table{width:100%;border-collapse:separate !important;border-spacing:0 !important;border-radius:var(--r) !important;overflow:hidden !important;box-shadow:var(--s1) !important}
thead th{background:var(--c-p800) !important;color:#fff !important;font-weight:700 !important;padding:12px 16px !important}
tbody tr{transition:background var(--t)}
tbody tr:nth-child(even){background:var(--c-p50) !important}
tbody tr:hover{background:var(--c-p100) !important}
td,th{padding:11px 16px !important;border-bottom:1px solid var(--c-line) !important}

/* Paginatie */
.pagination{display:flex !important;gap:6px !important;justify-content:center !important;list-style:none !important;padding:0 !important;margin:28px 0 0 !important}
.pagination .page-item .page-link{display:inline-flex !important;align-items:center !important;justify-content:center !important;min-width:38px !important;min-height:38px !important;border-radius:8px !important;border:1px solid var(--c-line2) !important;background:var(--c-paper) !important;color:var(--c-ink) !important;font-weight:600 !important;transition:all var(--t) !important}
.pagination .page-item.active .page-link{background:var(--c-p700) !important;border-color:var(--c-p700) !important;color:#fff !important;box-shadow:0 4px 10px rgba(26,114,80,.3) !important}
.pagination .page-item .page-link:hover{background:var(--c-p100) !important;border-color:var(--c-p500) !important;color:var(--c-p800) !important;transform:translateY(-1px) !important}

/* Footer */
.footer-wrapper,.footer,#footer,footer{
  background:linear-gradient(135deg,var(--c-p900) 0%,#112e1e 100%) !important;
  color:rgba(255,255,255,.8) !important;
  border-top:3px solid var(--c-g500) !important;
  padding:32px 24px 24px !important
}
.footer a,.footer-wrapper a{color:var(--c-p200) !important}
.footer a:hover,.footer-wrapper a:hover{color:var(--c-g300) !important}

/* Animatii intrare */
@keyframes smFadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.grid-child.container-component,.moduletable,.card,.blog-item{animation:smFadeUp .5s ease both}
.grid-child.container-component{animation-delay:.05s}
.moduletable:nth-child(1){animation-delay:.1s}
.moduletable:nth-child(2){animation-delay:.18s}
.blog-item:nth-child(1){animation-delay:.08s}
.blog-item:nth-child(2){animation-delay:.14s}
.blog-item:nth-child(3){animation-delay:.2s}

/* Widget accesibilitate */
#a11y-widget #a11y-toggle{background:linear-gradient(145deg,var(--c-p700),var(--c-p500)) !important;box-shadow:0 8px 22px rgba(26,114,80,.48),0 0 0 3px rgba(255,255,255,.12) !important}

/* Responsive */
@media(max-width:991px){
  .header.container-header{position:static !important}
  .site-grid{margin-top:18px !important}
  .grid-child.container-component{padding:18px !important}
}
@media(max-width:640px){
  body{font-size:15.5px !important}
  .site-grid{padding:0 12px !important}
  .grid-child.container-component,.card,.moduletable{border-radius:18px !important}
  .mod-menu.nav{padding:4px 8px !important}
  .mod-menu > .nav-item > a{min-height:34px !important;padding:0 10px !important;font-size:.82rem !important}
}

/* Sidebar menu links — override the white nav color from header nav */
.container-sidebar-right .mod-menu > .nav-item > a,
.container-sidebar-left .mod-menu > .nav-item > a{
  color:var(--c-p800) !important;
  background:transparent !important;
  border-color:transparent !important;
  font-weight:500 !important;
  padding:8px 14px !important;
  min-height:auto !important;
  border-radius:8px !important;
  display:block !important
}
.container-sidebar-right .mod-menu > .nav-item > a:hover,
.container-sidebar-left .mod-menu > .nav-item > a:hover{
  background:var(--c-p50) !important;
  color:var(--c-p700) !important;
  transform:none !important;
  border-color:transparent !important;
  padding-left:20px !important
}
.container-sidebar-right .mod-menu > .nav-item.active > a,
.container-sidebar-right .mod-menu > .nav-item.current > a{
  background:var(--c-p100) !important;
  color:var(--c-p800) !important;
  font-weight:700 !important;
  border-left:3px solid var(--c-g500) !important;
  border-radius:0 8px 8px 0 !important
}
.container-sidebar-right .mod-menu.nav,
.container-sidebar-left .mod-menu.nav{
  flex-direction:column !important;
  gap:2px !important;
  padding:4px 8px !important
}

/* Skip-link (accesibilitate WCAG 2.1 AA) */
.skiplink,.skip-to-content{
  position:absolute;
  left:-999px;
  width:1px;
  height:1px;
  overflow:hidden;
  white-space:nowrap
}
.skiplink:focus,.skip-to-content:focus{
  left:50%;
  transform:translateX(-50%);
  top:8px;
  width:auto;
  height:auto;
  padding:10px 24px;
  background:var(--c-g500);
  color:#000;
  font-weight:700;
  font-size:1rem;
  border-radius:8px;
  z-index:99999;
  text-decoration:none;
  box-shadow:0 4px 12px rgba(0,0,0,.3)
}

/* Print */
@media print{
  .header.container-header,.container-nav,#a11y-widget,.footer,.footer-wrapper,#gdpr-banner{display:none !important}
  body{background:#fff !important;color:#000 !important}
}
