/* ===================================================
   AKADÉMIA UDRŽATEĽNOSTI – au-home.css  (v2)
   Načítava sa IBA na homepage.
   VŠETKY pravidlá sú zapuzdrené pod #au-homepage,
   takže majú dosť vysokú špecificitu a neprebije ich
   ani rodičovská téma, ani vlastné reset pravidlá.
   =================================================== */

:root {
  --au-navy:        #0a2463;
  --au-navy-deep:   #061740;
  --au-navy-mid:    #163a7a;
  --au-blue:        #2176c7;
  --au-blue-light:  #4a9ae6;
  --au-blue-pale:   #e8f1fa;
  --au-blue-wash:   #eef3fb;
  --au-green:       #1f8a4e;
  --au-green-light: #2cb866;
  --au-amber:       #f5b731;
  --au-amber-pale:  #fef5de;
  --au-coral:       #e8634a;
  --au-white:       #ffffff;
  --au-offwhite:    #f7f9fc;
  --au-cream-dark:  #eef2f7;
  --au-ink:         #0d1b2a;
  --au-ink-mid:     #3a4f6a;
  --au-ink-light:   #6b7f99;
  --au-font-display: 'Outfit', 'DM Sans', sans-serif;
  --au-font-body:    'DM Sans', system-ui, sans-serif;
  --au-radius-pill: 999px;
  --au-radius-lg:   28px;
  --au-radius-xl:   48px;
  --au-radius-md:   16px;
  --au-shadow-sm: 0 2px 8px rgba(10,36,99,.06);
  --au-shadow-md: 0 8px 28px rgba(10,36,99,.10);
  --au-shadow-lg: 0 20px 60px rgba(10,36,99,.14);
  --au-transition: .35s cubic-bezier(.25,.46,.45,.94);
}

/* ── WRAPPER & RESET (scoped) ── */
#au-homepage { font-family: var(--au-font-body); color: var(--au-ink); overflow-x: hidden; }
#au-homepage * { box-sizing: border-box; }
#au-homepage a { text-decoration: none; transition: var(--au-transition); }
#au-homepage ul { list-style: none; }
#au-homepage img { max-width: 100%; display: block; }
#au-homepage h1, #au-homepage h2, #au-homepage h3, #au-homepage h4 { margin: 0; }

/* ── SCROLL REVEAL ── */
#au-homepage .au-reveal { opacity: 0; transform: translateY(32px); transition: opacity .65s ease, transform .65s ease; }
#au-homepage .au-reveal.visible { opacity: 1; transform: none; }

/* ── CONTAINER & SECTION ── */
#au-homepage .au-container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
#au-homepage .au-section { padding: 100px 0; position: relative; }

/* ── SECTION HEADER ── */
#au-homepage .au-section__header { text-align: center; margin-bottom: 72px; }
#au-homepage .au-section__tag {
  display: inline-block; font-family: var(--au-font-display); font-weight: 600;
  font-size: .85rem; letter-spacing: .04em; color: var(--au-blue);
  background: var(--au-blue-pale); padding: 6px 18px; border-radius: var(--au-radius-pill); margin-bottom: 12px;
}
#au-homepage .au-section__tag--light { color: var(--au-amber); background: rgba(245,183,49,.14); }
#au-homepage .au-section__title {
  font-family: var(--au-font-display); font-size: clamp(2rem, 4vw, 3.2rem);
  font-weight: 800; color: var(--au-navy); line-height: 1.15; margin-bottom: 16px;
}
#au-homepage .au-section__title em { font-style: normal; color: var(--au-blue); }
#au-homepage .au-section__title--light { color: #fff; }
#au-homepage .au-section__sub { font-size: 1.1rem; color: var(--au-ink-mid); max-width: 560px; margin: 0 auto; line-height: 1.7; }
#au-homepage .au-section__sub--light { color: rgba(255,255,255,.7); }

/* ── BUTTONS ── */
#au-homepage .au-btn,
#au-homepage a.au-btn,
#au-homepage button.au-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  padding: 14px 28px !important;
  border-radius: var(--au-radius-pill) !important;
  font-family: var(--au-font-body) !important;
  font-weight: 600 !important;
  font-size: .95rem !important;
  cursor: pointer !important;
  border: none !important;
  transition: var(--au-transition) !important;
  text-decoration: none !important;
  line-height: 1.2 !important;
  text-align: center !important;
}

#au-homepage a.au-btn--primary,
#au-homepage button.au-btn--primary,
#au-homepage .au-btn--primary {
  background: var(--btn-clr, var(--au-navy)) !important;
  color: #ffffff !important; /* Toto už nebude prečiarknuté */
  box-shadow: 0 4px 16px rgba(10,36,99,.25) !important;
}

#au-homepage a.au-btn--primary:hover,
#au-homepage button.au-btn--primary:hover,
#au-homepage .au-btn--primary:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px rgba(10,36,99,.35) !important;
  filter: brightness(1.12) !important;
  color: #ffffff !important;
}

#au-homepage a.au-btn--outline,
#au-homepage .au-btn--outline {
  background: transparent !important;
  color: var(--au-navy) !important;
  border: 2px solid var(--au-blue) !important;
}

#au-homepage a.au-btn--outline:hover,
#au-homepage .au-btn--outline:hover {
  background: var(--au-blue-pale) !important;
  transform: translateY(-2px) !important;
  color: var(--au-navy) !important;
}

#au-homepage a.au-btn--outline-navy,
#au-homepage .au-btn--outline-navy {
  background: transparent !important;
  color: var(--au-navy) !important;
  border: 2px solid var(--au-navy) !important;
}

#au-homepage a.au-btn--outline-navy:hover,
#au-homepage .au-btn--outline-navy:hover {
  background: var(--au-navy) !important;
  color: #ffffff !important;
  transform: translateY(-2px) !important;
}

#au-homepage a.au-btn--ghost,
#au-homepage .au-btn--ghost {
  background: rgba(255,255,255,.5) !important;
  color: var(--au-navy) !important;
  border: 2px solid rgba(10,36,99,.2) !important;
  backdrop-filter: blur(8px) !important;
}

#au-homepage a.au-btn--ghost:hover,
#au-homepage .au-btn--ghost:hover {
  background: #ffffff !important;
  transform: translateY(-2px) !important;
  color: var(--au-navy) !important;
}

#au-homepage a.au-btn--white,
#au-homepage .au-btn--white {
  background: #ffffff !important;
  color: var(--au-navy) !important;
  box-shadow: var(--au-shadow-md) !important;
}

#au-homepage a.au-btn--white:hover,
#au-homepage .au-btn--white:hover {
  transform: translateY(-2px) !important;
  box-shadow: var(--au-shadow-lg) !important;
  color: var(--au-navy) !important;
}

#au-homepage .au-btn--large,
#au-homepage a.au-btn--large {
  padding: 18px 36px !important;
  font-size: 1.05rem !important;
}
/* ── HERO ── */
#au-homepage .au-hero {
  min-height: 92vh; display: flex; flex-direction: column; align-items: center; justify-content: center;
  position: relative; overflow: hidden; padding: 80px 24px; background: var(--au-offwhite);
}
#au-homepage .au-hero__bg-blobs { position: absolute; inset: 0; pointer-events: none; }
#au-homepage .au-blob { position: absolute; border-radius: 50%; filter: blur(80px); opacity: .45; animation: auBlobFloat 12s ease-in-out infinite; }
#au-homepage .au-blob--1 { width: 600px; height: 500px; background: var(--au-blue-pale); top: -100px; left: -150px; }
#au-homepage .au-blob--2 { width: 500px; height: 450px; background: var(--au-amber-pale); top: 100px; right: -100px; animation-delay: -4s; }
#au-homepage .au-blob--3 { width: 400px; height: 350px; background: rgba(33,118,199,.1); bottom: 0; left: 30%; animation-delay: -8s; }
@keyframes auBlobFloat { 0%,100%{transform:translate(0,0) scale(1);} 33%{transform:translate(30px,-20px) scale(1.05);} 66%{transform:translate(-20px,30px) scale(.97);} }
#au-homepage .au-hero__floating-elements { position: absolute; inset: 0; pointer-events: none; }
#au-homepage .au-float-el { position: absolute; left: var(--x); top: var(--y); font-size: 1.8rem; animation: auFloat 6s ease-in-out infinite; animation-delay: var(--d); opacity: .6; filter: drop-shadow(0 4px 8px rgba(0,0,0,.1)); }
@keyframes auFloat { 0%,100%{transform:translateY(0) rotate(0deg);} 50%{transform:translateY(-20px) rotate(5deg);} }
#au-homepage .au-hero__content { position: relative; z-index: 1; text-align: center; max-width: 760px; }
#au-homepage .au-hero__eyebrow { font-family: var(--au-font-display); font-size: .9rem; font-weight: 500; letter-spacing: .06em; text-transform: uppercase; color: var(--au-blue); margin-bottom: 20px; }
#au-homepage .au-hero__title { font-family: var(--au-font-display); font-size: clamp(3rem, 7vw, 5.5rem); font-weight: 800; color: var(--au-navy); line-height: 1.1; margin-bottom: 28px; }
#au-homepage .au-hero__title em { font-style: normal; color: var(--au-blue); }
#au-homepage .au-hero__sub { font-size: clamp(1rem, 2vw, 1.2rem); color: var(--au-ink-mid); line-height: 1.75; max-width: 580px; margin: 0 auto 40px; }
#au-homepage .au-hero__cta { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }
#au-homepage .au-hero__scroll-hint { position: absolute; bottom: 32px; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: 8px; font-size: .75rem; color: var(--au-ink-light); letter-spacing: .08em; text-transform: uppercase; z-index: 1; }
#au-homepage .au-scroll-indicator { width: 24px; height: 38px; border: 2px solid var(--au-blue-light); border-radius: 12px; position: relative; }
#au-homepage .au-scroll-indicator::after { content: ''; position: absolute; top: 6px; left: 50%; transform: translateX(-50%); width: 4px; height: 8px; background: var(--au-blue); border-radius: 2px; animation: auScrollDot 1.5s ease-in-out infinite; }
@keyframes auScrollDot { 0%{top:6px;opacity:1;} 100%{top:20px;opacity:0;} }

/* ── STATS ── */
#au-homepage .au-stats-strip { background: var(--au-white); padding: 48px 24px; border-top: 1px solid var(--au-blue-pale); border-bottom: 1px solid var(--au-blue-pale); }
#au-homepage .au-stats-strip__inner { max-width: 900px; margin: 0 auto; display: flex; align-items: center; justify-content: center; gap: 40px; flex-wrap: wrap; }
#au-homepage .au-stat-item { text-align: center; }
#au-homepage .au-stat-num { font-family: var(--au-font-display); font-size: clamp(2.5rem, 5vw, 4rem); font-weight: 800; color: var(--au-navy); line-height: 1; }
#au-homepage .au-stat-plus { font-family: var(--au-font-display); font-size: 2rem; font-weight: 800; color: var(--au-blue); }
#au-homepage .au-stat-item p { font-size: .9rem; color: var(--au-ink-mid); margin-top: 6px; }
#au-homepage .au-stat-divider { font-size: 1.5rem; opacity: .4; }

/* ── PROGRAMY ── */
#au-homepage .au-programy { background: var(--au-offwhite); }
#au-homepage .au-program-card {
  display: grid; grid-template-columns: 1fr 1.4fr; gap: 60px; align-items: center;
  background: var(--au-white); border-radius: var(--au-radius-xl); padding: 60px;
  margin-bottom: 32px; box-shadow: var(--au-shadow-md); transition: var(--au-transition);
}
#au-homepage .au-program-card:hover { transform: translateY(-4px); box-shadow: var(--au-shadow-lg); }
#au-homepage .au-program-card--flip { grid-template-columns: 1.4fr 1fr; }
#au-homepage .au-program-card__visual { display: flex; flex-direction: column; align-items: center; justify-content: center; position: relative; }
#au-homepage .au-program-card__icon-wrap { width: 180px; height: 180px; background: color-mix(in srgb, var(--clr) 12%, white); border-radius: 50%; display: flex; align-items: center; justify-content: center; position: relative; }
#au-homepage .au-program-card__emoji { font-size: 5rem; }
#au-homepage .au-program-card__deco { position: absolute; width: 220px; height: 220px; border: 2px dashed color-mix(in srgb, var(--clr, var(--au-blue)) 30%, transparent); border-radius: 50%; animation: auSpinDeco 20s linear infinite; }
@keyframes auSpinDeco { to { transform: rotate(360deg); } }
#au-homepage .au-program-card__tag { display: inline-block; font-size: .8rem; font-weight: 700; color: var(--clr, var(--au-blue)); background: color-mix(in srgb, var(--clr, var(--au-blue)) 10%, white); padding: 4px 14px; border-radius: var(--au-radius-pill); margin-bottom: 12px; letter-spacing: .04em; }
#au-homepage .au-program-card__title { font-family: var(--au-font-display); font-size: clamp(1.6rem, 3vw, 2.2rem); font-weight: 800; color: var(--au-navy); line-height: 1.15; margin-bottom: 16px; }
#au-homepage .au-program-card__text { font-size: 1rem; color: var(--au-ink-mid); line-height: 1.75; margin-bottom: 20px; }
#au-homepage .au-program-card__tags { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 28px; padding: 0; }
#au-homepage .au-program-card__tags li { font-size: .82rem; font-weight: 600; background: var(--au-blue-pale); color: var(--au-navy); padding: 6px 14px; border-radius: var(--au-radius-pill); }
#au-homepage .au-yesga-pillars { display: flex; flex-direction: column; gap: 16px; margin-bottom: 28px; }
#au-homepage .au-pillar { display: flex; align-items: flex-start; gap: 14px; }
#au-homepage .au-pillar > span { font-size: 1.6rem; flex-shrink: 0; }
#au-homepage .au-pillar strong { display: block; font-size: .95rem; color: var(--au-navy); margin-bottom: 2px; }
#au-homepage .au-pillar small { font-size: .82rem; color: var(--au-ink-mid); line-height: 1.5; }

/* ── EDU ── */
#au-homepage .au-edu { background: var(--au-offwhite); }
#au-homepage .au-edu__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
#au-homepage .au-edu__sub { font-family: var(--au-font-display); font-weight: 500; font-size: 1.05rem; color: var(--au-blue); margin-bottom: 16px; margin-top: 8px; }
#au-homepage .au-edu__content p { font-size: 1rem; color: var(--au-ink-mid); line-height: 1.75; margin-bottom: 28px; }
#au-homepage .au-edu__features { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 32px; }
#au-homepage .au-edu__feature { display: flex; align-items: center; gap: 10px; background: var(--au-blue-pale); padding: 12px 16px; border-radius: var(--au-radius-md); font-size: .9rem; font-weight: 600; color: var(--au-navy); }
#au-homepage .au-edu__feature span { font-size: 1.3rem; }
#au-homepage .au-edu__visual { display: flex; justify-content: center; }
#au-homepage .au-edu__visual-card { background: var(--au-white); border-radius: var(--au-radius-xl); padding: 40px; width: 100%; max-width: 400px; box-shadow: var(--au-shadow-md); }
#au-homepage .au-edu__visual-icon { font-size: 4rem; text-align: center; margin-bottom: 28px; }
#au-homepage .au-edu__visual-levels { display: flex; flex-direction: column; gap: 10px; }
#au-homepage .au-level { height: 36px; width: var(--w, 50%); background: var(--clr, var(--au-blue)); border-radius: var(--au-radius-pill); display: flex; align-items: center; padding-left: 14px; font-size: .8rem; font-weight: 700; color: #fff; transform: scaleX(0); transform-origin: left; opacity: 0; transition: transform .6s ease, opacity .4s ease; }
#au-homepage .au-level.animate { transform: scaleX(1); opacity: 1; }

/* ── FIRMY ── */
#au-homepage .au-firmy { background: var(--au-offwhite); }
#au-homepage .au-firmy__grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 28px; margin-bottom: 48px; }
#au-homepage .au-firmy-card { background: var(--au-white); border-radius: var(--au-radius-lg); padding: 40px 32px; text-align: center; transition: var(--au-transition); border: 2px solid transparent; }
#au-homepage .au-firmy-card:hover { transform: translateY(-6px); box-shadow: var(--au-shadow-md); border-color: var(--au-blue-pale); }
#au-homepage .au-firmy-card h4 { font-family: var(--au-font-display); font-size: 1.25rem; font-weight: 700; color: var(--au-navy); margin-bottom: 12px; }
#au-homepage .au-firmy-card p { font-size: .92rem; color: var(--au-ink-mid); line-height: 1.65; }
#au-homepage .au-firmy-card--featured { background: var(--au-navy); }
#au-homepage .au-firmy-card--featured h4 { color: var(--au-amber); }
#au-homepage .au-firmy-card--featured p { color: rgba(255,255,255,.8); }
#au-homepage .au-firmy-card__icon { font-size: 3rem; margin-bottom: 20px; display: block; }
#au-homepage .au-firmy__cta { text-align: center; }

/* ── PODUJATIA (komunita) – image 7 ── */
body #au-homepage section.au-podujatia,
body #au-homepage .au-podujatia {
  background: var(--au-blue-wash) !important;
  display: block !important;
  width: 100% !important;
  padding: 80px 0 !important; /* Pridané, ak by téma zmazala paddingy */
}

body #au-homepage div.au-podujatia__grid,
body #au-homepage .au-podujatia__grid {
  display: grid !important;
  grid-template-columns: 0.9fr 1.1fr !important;
  gap: 32px !important;
  align-items: stretch !important;
}

body #au-homepage div.au-festival-card,
body #au-homepage .au-festival-card {
  background: var(--au-navy) !important;
  border-radius: var(--au-radius-lg) !important;
  padding: 48px !important;
  position: relative !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  box-shadow: var(--au-shadow-md) !important;
}

body #au-homepage .au-festival-card::after {
  content: '🌍';
  position: absolute;
  right: -30px;
  bottom: -30px;
  font-size: 12rem;
  opacity: .08;
  pointer-events: none;
}

body #au-homepage .au-festival-card__tag {
  display: inline-block !important;
  align-self: flex-start !important;
  font-family: var(--au-font-display) !important;
  font-weight: 700 !important;
  font-size: .8rem !important;
  letter-spacing: .05em !important;
  text-transform: uppercase !important;
  color: var(--au-amber) !important;
  margin-bottom: 20px !important;
}

body #au-homepage .au-festival-card h3 {
  font-family: var(--au-font-display) !important;
  font-size: clamp(1.5rem, 2.6vw, 2rem) !important;
  font-weight: 800 !important;
  color: #ffffff !important;
  line-height: 1.2 !important;
  margin-bottom: 16px !important;
  position: relative !important;
  z-index: 1 !important;
}

body #au-homepage .au-festival-card p {
  font-size: .98rem !important;
  color: rgba(255,255,255,.78) !important;
  line-height: 1.7 !important;
  margin-bottom: 24px !important;
  position: relative !important;
  z-index: 1 !important;
}

body #au-homepage div.au-festival-card__stats,
body #au-homepage .au-festival-card__stats {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  margin-bottom: 28px !important;
  position: relative !important;
  z-index: 1 !important;
}

body #au-homepage .au-festival-card__stats span {
  font-size: .82rem !important;
  font-weight: 600 !important;
  color: #ffffff !important;
  background: rgba(255,255,255,.10) !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  padding: 7px 16px !important;
  border-radius: var(--au-radius-pill) !important;
  display: inline-block !important;
}

body #au-homepage .au-festival-card a.au-btn {
  align-self: flex-start !important;
  margin-top: auto !important;
  position: relative !important;
  z-index: 1 !important;
}

body #au-homepage div.au-events-list,
body #au-homepage .au-events-list {
  display: flex !important;
  flex-direction: column !important;
  gap: 16px !important;
  width: 100% !important;
}

body #au-homepage div.au-event-row,
body #au-homepage .au-event-row {
  display: flex !important;
  align-items: flex-start !important;
  gap: 16px !important;
  background: #ffffff !important;
  border-radius: var(--au-radius-md) !important;
  padding: 22px 24px !important;
  transition: var(--au-transition) !important;
}

body #au-homepage .au-event-row:hover {
  transform: translateX(4px) !important;
  box-shadow: var(--au-shadow-sm) !important;
}

body #au-homepage .au-event-row__icon {
  font-size: 1.8rem !important;
  flex-shrink: 0 !important;
  line-height: 1 !important;
}

body #au-homepage .au-event-row strong {
  display: block !important;
  font-family: var(--au-font-display) !important;
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  color: var(--au-navy) !important;
  margin-bottom: 4px !important;
}

body #au-homepage .au-event-row p {
  font-size: .9rem !important;
  color: var(--au-ink-mid) !important;
  line-height: 1.55 !important;
  margin: 0 !important;
}

body #au-homepage div.au-events-list__cta,
body #au-homepage .au-events-list__cta {
  display: flex !important;
  width: 100% !important;
  justify-content: center !important;
  margin-top: 8px !important;
}
/* ── EBOOKS – image 6 (dark navy glassmorphism) ── */
#au-homepage .au-ebooks {
  background: linear-gradient(160deg, #0d2b66 0%, var(--au-navy) 55%, var(--au-navy-deep) 100%);
}
#au-homepage .au-ebooks__grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 28px; margin-bottom: 48px; }
#au-homepage .au-ebook-card {
  display: block; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.10);
  border-radius: var(--au-radius-lg); padding: 40px 32px 36px; text-align: center;
  transition: var(--au-transition); backdrop-filter: blur(6px); color: inherit;
}
#au-homepage .au-ebook-card:hover { transform: translateY(-6px); background: rgba(255,255,255,.09); border-color: rgba(255,255,255,.2); box-shadow: 0 24px 50px rgba(0,0,0,.3); }
#au-homepage .au-ebook-card__cover {
  width: 96px; height: 116px; margin: 0 auto 28px; border-radius: 8px 14px 14px 8px;
  background: rgba(255,255,255,.08); border-left: 5px solid var(--au-blue-light);
  display: flex; align-items: center; justify-content: center; font-size: 3rem;
  box-shadow: 0 10px 24px rgba(0,0,0,.25);
}
#au-homepage .au-ebook-card h4 { font-family: var(--au-font-display); font-size: 1.2rem; font-weight: 700; color: #fff; margin-bottom: 12px; line-height: 1.3; }
#au-homepage .au-ebook-card p { font-size: .9rem; color: rgba(255,255,255,.65); line-height: 1.6; margin: 0; }
#au-homepage .au-ebooks__cta { text-align: center; }

/* ── RESPONSIVE ── */
@media (max-width: 1024px) {
  #au-homepage .au-program-card { grid-template-columns: 1fr; padding: 40px; gap: 40px; }
  #au-homepage .au-firmy__grid  { grid-template-columns: repeat(2,1fr); }
  #au-homepage .au-ebooks__grid { grid-template-columns: repeat(2,1fr); }
  #au-homepage .au-edu__inner { grid-template-columns: 1fr; }
  #au-homepage .au-podujatia__grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  #au-homepage .au-hero__cta { flex-direction: column; align-items: center; }
  #au-homepage .au-firmy__grid, #au-homepage .au-ebooks__grid { grid-template-columns: 1fr; }
  #au-homepage .au-edu__features { grid-template-columns: 1fr; }
  #au-homepage .au-stat-divider { display: none; }
  #au-homepage .au-stats-strip__inner { gap: 28px; }
  #au-homepage .au-section { padding: 60px 0; }
  #au-homepage .au-festival-card { padding: 32px; }
}
