/* ========================================================
   ZUŠ Rakúsy — Variant 4 „Bold kreatíva"
   Neo-brutalist / art-poster, leštený a profesionálny
   ======================================================== */

:root{
  --black:#0d0d0f;
  --ink:#14141a;
  --white:#ffffff;
  --paper:#f6f3ea;
  --yellow:#ffe600;
  --red:#ff2e2e;
  --blue:#2b59ff;
  --line:#0d0d0f;
  --rad:0px;
  --maxw:1200px;
  --shadow:6px 6px 0 var(--black);
  --shadow-lg:10px 10px 0 var(--black);
  --font:'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;
  --display:'Anton', 'Archivo', var(--font);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--font);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; }
input,textarea,select,button{ font-family:inherit; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 24px; }

/* ---------- HLAVIČKA ---------- */
.site-header{
  position:sticky; top:var(--vswitch-h,46px); z-index:900;
  background:var(--black); color:var(--white);
  border-bottom:4px solid var(--yellow);
}
.header-inner{
  max-width:var(--maxw); margin:0 auto; padding:0 24px;
  height:72px; display:flex; align-items:center; justify-content:space-between; gap:16px;
}
.brand{ display:flex; align-items:center; gap:12px; text-decoration:none; color:var(--white); }
.brand-logo{ width:48px; height:48px; border-radius:50%; border:3px solid var(--yellow); background:#fff; }
.brand-text{ font-family:var(--display); font-size:1.5rem; letter-spacing:1px; text-transform:uppercase; }
.brand-text b{ color:var(--yellow); }

.main-nav{ display:flex; align-items:center; gap:6px; }
.main-nav a{
  text-decoration:none; color:var(--white); font-weight:700; font-size:.92rem;
  text-transform:uppercase; letter-spacing:.5px; padding:9px 13px; position:relative;
  transition:color .15s;
}
.main-nav a::after{
  content:""; position:absolute; left:13px; right:13px; bottom:5px; height:3px;
  background:var(--yellow); transform:scaleX(0); transform-origin:left; transition:transform .2s;
}
.main-nav a:hover{ color:var(--yellow); }
.main-nav a:hover::after{ transform:scaleX(1); }
.main-nav .nav-cta{
  background:var(--yellow); color:var(--black); border-radius:0;
  border:2px solid var(--yellow);
}
.main-nav .nav-cta::after{ display:none; }
.main-nav .nav-cta:hover{ background:var(--white); border-color:var(--white); color:var(--black); }

/* Burger */
.burger{
  display:none; width:48px; height:48px; background:var(--yellow); border:2px solid var(--yellow);
  cursor:pointer; flex-direction:column; align-items:center; justify-content:center; gap:5px;
}
.burger span{ width:24px; height:3px; background:var(--black); transition:.25s; }
.burger.open span:nth-child(1){ transform:translateY(8px) rotate(45deg); }
.burger.open span:nth-child(2){ opacity:0; }
.burger.open span:nth-child(3){ transform:translateY(-8px) rotate(-45deg); }

/* Drawer */
.drawer-backdrop{
  position:fixed; inset:0; z-index:950; background:rgba(13,13,15,.55);
  opacity:0; pointer-events:none; transition:opacity .25s;
}
.drawer-backdrop.open{ opacity:1; pointer-events:auto; }
.drawer{
  position:fixed; top:0; right:0; bottom:0; z-index:960;
  width:min(86vw,340px); background:var(--black); color:var(--white);
  transform:translateX(105%); transition:transform .3s cubic-bezier(.4,0,.2,1);
  pointer-events:none; display:flex; flex-direction:column;
  border-left:5px solid var(--yellow); padding:22px;
}
.drawer.open{ transform:translateX(0); pointer-events:auto; }
.drawer-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:24px; }
.drawer-title{ font-family:var(--display); font-size:1.6rem; color:var(--yellow); letter-spacing:2px; }
.drawer-close{ background:none; border:none; color:var(--white); font-size:2.4rem; line-height:1; cursor:pointer; }
.drawer-nav{ display:flex; flex-direction:column; }
.drawer-nav a{
  text-decoration:none; color:var(--white); font-family:var(--display); font-size:1.5rem;
  letter-spacing:1px; text-transform:uppercase; padding:13px 0; border-bottom:2px solid rgba(255,255,255,.1);
  transition:color .15s,padding-left .15s;
}
.drawer-nav a:hover{ color:var(--yellow); padding-left:8px; }
.drawer-edupage{
  margin-top:auto; text-align:center; background:var(--yellow); color:var(--black);
  font-weight:800; text-decoration:none; padding:14px; text-transform:uppercase; letter-spacing:1px;
}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-block; font-weight:800; text-transform:uppercase; letter-spacing:.6px;
  font-size:.92rem; padding:15px 26px; text-decoration:none; cursor:pointer;
  border:3px solid var(--black); transition:transform .12s, box-shadow .12s, background .15s;
}
.btn-fill{ background:var(--yellow); color:var(--black); box-shadow:var(--shadow); }
.btn-fill:hover{ transform:translate(-3px,-3px); box-shadow:9px 9px 0 var(--black); }
.btn-line{ background:transparent; color:var(--black); box-shadow:var(--shadow); }
.btn-line:hover{ transform:translate(-3px,-3px); box-shadow:9px 9px 0 var(--black); background:var(--black); color:var(--yellow); }
.btn-line-light{ background:transparent; color:var(--white); border-color:var(--white); box-shadow:6px 6px 0 var(--yellow); }
.btn-line-light:hover{ transform:translate(-3px,-3px); background:var(--white); color:var(--black); }

/* ---------- HERO ---------- */
.hero{ background:var(--black); color:var(--white); padding:64px 0 0; position:relative; overflow:hidden; }
.hero::before{
  content:""; position:absolute; top:-120px; right:-120px; width:420px; height:420px;
  background:var(--red); border-radius:50%; opacity:.85; filter:blur(2px);
}
.hero-grid{
  max-width:var(--maxw); margin:0 auto; padding:0 24px;
  display:grid; grid-template-columns:1.45fr .9fr; gap:40px; align-items:center; position:relative; z-index:2;
  padding-bottom:64px;
}
.hero-eyebrow{
  display:inline-block; background:var(--yellow); color:var(--black); font-weight:800;
  text-transform:uppercase; letter-spacing:1px; font-size:.8rem; padding:7px 14px; margin-bottom:22px;
}
.hero-title{
  font-family:var(--display); font-weight:400; line-height:.92; letter-spacing:1px;
  font-size:clamp(3.4rem,11vw,6.2rem); text-transform:uppercase;
}
.hl{ display:inline-block; padding:0 .12em; }
.hl-y{ background:var(--yellow); color:var(--black); transform:rotate(-1.5deg); }
.hl-r{ background:var(--red); color:var(--white); transform:rotate(1deg); }
.hero-sub{ margin:28px 0 30px; font-size:1.12rem; max-width:46ch; color:#e9e9ef; }
.hero-btns{ display:flex; gap:16px; flex-wrap:wrap; }
.hero-btns .btn-line{ color:var(--white); border-color:var(--white); box-shadow:6px 6px 0 var(--yellow); }
.hero-btns .btn-line:hover{ background:var(--white); color:var(--black); }

.hero-side{ display:flex; flex-direction:column; gap:18px; }
.hero-card{
  border:3px solid var(--white); padding:22px; display:flex; flex-direction:column; gap:4px;
}
.hc-1{ background:var(--yellow); color:var(--black); border-color:var(--black); transform:rotate(-1.2deg); box-shadow:var(--shadow); }
.hc-2{ background:var(--blue); color:var(--white); transform:rotate(1.4deg); box-shadow:6px 6px 0 var(--yellow); }
.hc-3{ background:transparent; transform:rotate(-.6deg); }
.hc-num{ font-family:var(--display); font-size:2.6rem; line-height:1; }
.hc-icon{ font-size:2.2rem; line-height:1; }
.hc-lbl{ font-weight:700; text-transform:uppercase; letter-spacing:.5px; font-size:.82rem; }

/* ---------- MARQUEE ---------- */
.marquee{ background:var(--yellow); color:var(--black); border-top:4px solid var(--black); border-bottom:4px solid var(--black); overflow:hidden; padding:14px 0; }
.marquee-track{ display:flex; white-space:nowrap; width:max-content; animation:scroll 26s linear infinite; }
.marquee-track span{ font-family:var(--display); font-size:1.5rem; letter-spacing:2px; text-transform:uppercase; padding-right:30px; }
@keyframes scroll{ to{ transform:translateX(-50%); } }

/* ---------- SEKCIE GENERAL ---------- */
.section{ padding:84px 0; }
.sec-head{ margin-bottom:44px; }
.kicker{ display:inline-block; font-weight:800; text-transform:uppercase; letter-spacing:2px; font-size:.85rem; color:var(--red); margin-bottom:10px; }
.sec-title{
  font-family:var(--display); font-weight:400; font-size:clamp(2.6rem,7vw,4.6rem);
  text-transform:uppercase; letter-spacing:1px; line-height:.95;
}
.sec-head-dark .kicker{ color:var(--yellow); }
.sec-head-dark .sec-title{ color:var(--white); }

/* ---------- O ŠKOLE ---------- */
.about{ background:var(--paper); }
.about-grid{ display:grid; grid-template-columns:1.4fr 1fr; gap:50px; align-items:start; }
.about-text p{ margin-bottom:16px; font-size:1.05rem; }
.about-text .lead{ font-size:1.35rem; font-weight:600; line-height:1.4; }
.about-text .mission{
  border-left:6px solid var(--red); padding:14px 0 14px 20px; font-weight:700; font-size:1.1rem; margin-top:24px;
}
.stats{ display:grid; grid-template-columns:1fr 1fr; gap:0; border:3px solid var(--black); }
.stat{ padding:26px 18px; border:1.5px solid var(--black); display:flex; flex-direction:column; gap:6px; }
.stat:nth-child(1){ background:var(--yellow); }
.stat:nth-child(2){ background:var(--white); }
.stat:nth-child(3){ background:var(--white); }
.stat:nth-child(4){ background:var(--red); color:var(--white); }
.stat-num{ font-family:var(--display); font-size:3rem; line-height:1; }
.stat-lbl{ font-weight:700; text-transform:uppercase; letter-spacing:.5px; font-size:.8rem; }

/* ---------- ODBORY ---------- */
.fields{ background:var(--white); }
.fields-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:0; border:3px solid var(--black); }
.field{
  position:relative; padding:38px 32px 70px; border:1.5px solid var(--black);
  min-height:230px; transition:transform .15s;
}
.field-tag{
  font-family:var(--display); font-size:2.4rem; line-height:1; display:block; margin-bottom:12px;
}
.field h3{ font-size:1.5rem; font-weight:800; margin-bottom:12px; line-height:1.15; }
.field p{ font-size:1rem; }
.field-arrow{ position:absolute; bottom:26px; left:32px; font-size:1.8rem; font-weight:800; transition:transform .2s; }
.field:hover .field-arrow{ transform:translateX(10px); }
.f-y{ background:var(--yellow); color:var(--black); }
.f-r{ background:var(--red); color:var(--white); }
.f-b{ background:var(--blue); color:var(--white); }
.f-w{ background:var(--white); color:var(--black); }

/* ---------- OZNAMY ---------- */
.news{ background:var(--black); color:var(--white); }
.news-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.news-card{
  background:var(--white); color:var(--ink); border:3px solid var(--white);
  padding:24px; box-shadow:6px 6px 0 var(--yellow); transition:transform .15s, box-shadow .15s;
}
.news-card:hover{ transform:translate(-3px,-3px); box-shadow:9px 9px 0 var(--yellow); }
.news-feat{ grid-column:span 3; background:var(--yellow); box-shadow:8px 8px 0 var(--red); border-color:var(--black); }
.news-feat:hover{ box-shadow:11px 11px 0 var(--red); }
.news-date{ display:inline-block; background:var(--black); color:var(--yellow); font-weight:800; font-size:.8rem; letter-spacing:.5px; padding:5px 10px; margin-bottom:14px; }
.news-feat .news-date{ background:var(--red); color:var(--white); }
.news-card h3{ font-size:1.2rem; font-weight:800; margin-bottom:10px; line-height:1.2; }
.news-feat h3{ font-size:1.7rem; }
.news-card p{ font-size:.98rem; }

/* ---------- GALÉRIA ---------- */
.gallery{ background:var(--paper); }
.gallery-grid{ columns:4; column-gap:14px; }
.gallery-grid .g-item{
  break-inside:avoid; margin-bottom:14px; border:3px solid var(--black); cursor:pointer;
  position:relative; overflow:hidden; background:var(--black); display:block; width:100%;
}
.gallery-grid .g-item img{ width:100%; height:auto; transition:transform .35s, filter .25s; }
.gallery-grid .g-item:hover img{ transform:scale(1.06); filter:saturate(1.2); }
.gallery-grid .g-item::after{
  content:"＋"; position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-size:2.6rem; color:var(--yellow); background:rgba(13,13,15,.0); opacity:0; transition:.25s; font-weight:700;
}
.gallery-grid .g-item:hover::after{ opacity:1; background:rgba(13,13,15,.35); }

/* ---------- ZAMESTNANCI ---------- */
.staff{ background:var(--black); color:var(--white); }
.staff-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; border:3px solid var(--white); }
.staff-card{
  display:flex; gap:14px; align-items:flex-start; padding:22px; border:1.5px solid rgba(255,255,255,.2);
  transition:background .15s;
}
.staff-card:hover{ background:rgba(255,230,0,.08); }
.staff-init{
  flex:0 0 auto; width:48px; height:48px; background:var(--yellow); color:var(--black);
  font-family:var(--display); font-size:1.15rem; display:flex; align-items:center; justify-content:center;
  letter-spacing:.5px;
}
.staff-card div{ display:flex; flex-direction:column; gap:2px; }
.staff-card b{ font-size:1.02rem; }
.staff-card span{ font-size:.88rem; color:#c8c8d2; }

/* ---------- RADA ŠKOLY ---------- */
.board{ background:var(--white); }
.board-list{ list-style:none; border:3px solid var(--black); }
.board-list li{ display:flex; align-items:center; gap:22px; padding:22px 26px; border-bottom:1.5px solid var(--black); }
.board-list li:last-child{ border-bottom:none; }
.board-list li:nth-child(odd){ background:var(--paper); }
.board-no{ font-family:var(--display); font-size:2.2rem; color:var(--red); line-height:1; flex:0 0 auto; }
.board-list div{ display:flex; flex-direction:column; }
.board-list b{ font-size:1.15rem; }
.board-list span{ font-size:.95rem; color:#555; }

/* ---------- KONTAKT ---------- */
.contact{ background:var(--black); color:var(--white); }
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:36px; align-items:stretch; }
.contact-info{ display:grid; grid-template-columns:1fr 1fr; gap:22px; align-content:start; }
.ci-block{ border:2px solid rgba(255,255,255,.25); padding:18px; }
.ci-block:nth-child(3){ grid-column:span 2; }
.ci-lbl{ display:inline-block; background:var(--yellow); color:var(--black); font-weight:800; text-transform:uppercase; letter-spacing:1px; font-size:.75rem; padding:4px 10px; margin-bottom:12px; }
.ci-block p{ font-size:1rem; line-height:1.7; }
.ci-block a{ color:var(--yellow); text-decoration:none; }
.ci-block a:hover{ text-decoration:underline; }
.ci-btns{ grid-column:span 2; display:flex; gap:14px; flex-wrap:wrap; margin-top:4px; }
.contact-map{ border:3px solid var(--yellow); min-height:380px; }
.contact-map iframe{ width:100%; height:100%; min-height:380px; border:0; display:block; filter:grayscale(.2) contrast(1.05); }

/* ---------- FOOTER ---------- */
.site-footer{ background:var(--black); color:var(--white); border-top:5px solid var(--yellow); padding-top:56px; }
.footer-cols{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:36px; padding-bottom:44px; }
.footer-brand{ display:flex; align-items:center; gap:12px; margin-bottom:16px; }
.footer-brand img{ width:44px; height:44px; border-radius:50%; border:2px solid var(--yellow); background:#fff; }
.footer-brand span{ font-family:var(--display); font-size:1.4rem; text-transform:uppercase; letter-spacing:1px; }
.fcol-brand p{ color:#bcbcc8; font-size:.95rem; max-width:40ch; }
.fcol h4{ font-family:var(--display); font-size:1.25rem; text-transform:uppercase; letter-spacing:1px; color:var(--yellow); margin-bottom:16px; }
.fcol ul{ list-style:none; display:flex; flex-direction:column; gap:9px; }
.fcol li{ font-size:.95rem; color:#cfcfd8; }
.fcol a{ color:#cfcfd8; text-decoration:none; transition:color .15s; }
.fcol a:hover{ color:var(--yellow); }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.14); padding-top:20px; padding-bottom:24px; display:flex; justify-content:space-between; align-items:center; gap:14px; flex-wrap:wrap; font-size:.85rem; color:#9a9aa6; }
.fb-links{ display:flex; gap:18px; flex-wrap:wrap; }
.fb-links a{ color:#9a9aa6; text-decoration:none; }
.fb-links a:hover{ color:var(--yellow); }
.fb-made{ opacity:.7; font-size:.8rem; }

/* ---------- LIGHTBOX ---------- */
.lightbox{
  position:fixed; inset:0; z-index:99990; background:rgba(13,13,15,.94);
  display:flex; align-items:center; justify-content:center;
}
.lightbox[hidden]{ display:none; }
.lb-img{ max-width:90vw; max-height:82vh; border:4px solid var(--yellow); box-shadow:0 20px 60px rgba(0,0,0,.6); touch-action:pan-y; }
.lb-close{ position:absolute; top:18px; right:22px; background:var(--yellow); color:var(--black); border:none; width:50px; height:50px; font-size:2rem; line-height:1; cursor:pointer; font-weight:700; }
.lb-nav{ position:absolute; top:50%; transform:translateY(-50%); background:rgba(255,255,255,.12); color:#fff; border:2px solid rgba(255,255,255,.4); width:54px; height:64px; font-size:2.4rem; cursor:pointer; line-height:1; transition:background .15s; }
.lb-nav:hover{ background:var(--yellow); color:var(--black); }
.lb-prev{ left:18px; }
.lb-next{ right:18px; }
.lb-counter{ position:absolute; bottom:22px; left:50%; transform:translateX(-50%); color:var(--yellow); font-weight:800; letter-spacing:1px; font-size:.95rem; }

/* ---------- REVEAL ---------- */
[data-reveal]{ opacity:0; transform:translateY(26px); transition:opacity .6s ease, transform .6s ease; }
[data-reveal].in{ opacity:1; transform:none; }

/* ========================================================
   RESPONZÍVNE
   ======================================================== */
@media (max-width:1024px){
  .gallery-grid{ columns:3; }
  .footer-cols{ grid-template-columns:1fr 1fr; }
}

@media (max-width:880px){
  .main-nav{ display:none; }
  .burger{ display:flex; }
  .hero-grid{ grid-template-columns:1fr; gap:34px; }
  .hero-side{ flex-direction:row; flex-wrap:wrap; }
  .hero-card{ flex:1 1 160px; }
  .about-grid{ grid-template-columns:1fr; gap:34px; }
  .fields-grid{ grid-template-columns:1fr; }
  .news-grid{ grid-template-columns:1fr 1fr; }
  .news-feat{ grid-column:span 2; }
  .staff-grid{ grid-template-columns:1fr 1fr; }
  .contact-grid{ grid-template-columns:1fr; }
}

@media (max-width:600px){
  .wrap{ padding:0 16px; }
  .header-inner{ padding:0 16px; height:64px; }
  .brand-text{ font-size:1.25rem; }
  .brand-logo{ width:42px; height:42px; }
  .section{ padding:56px 0; }
  .hero{ padding-top:42px; }
  .hero-grid{ padding-bottom:46px; }
  .gallery-grid{ columns:2; column-gap:10px; }
  .gallery-grid .g-item{ margin-bottom:10px; }
  .news-grid{ grid-template-columns:1fr; }
  .news-feat{ grid-column:span 1; }
  .news-feat h3{ font-size:1.35rem; }
  .staff-grid{ grid-template-columns:1fr; }
  .contact-info{ grid-template-columns:1fr; }
  .ci-block:nth-child(3){ grid-column:span 1; }
  .ci-btns{ grid-column:span 1; }
  .footer-cols{ grid-template-columns:1fr; gap:28px; }
  .footer-bottom{ flex-direction:column; align-items:flex-start; }
  .marquee-track span{ font-size:1.2rem; }
  .lb-nav{ width:44px; height:54px; font-size:2rem; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; scroll-behavior:auto !important; }
  [data-reveal]{ opacity:1 !important; transform:none !important; transition:none !important; }
}
