/* =========================
   1) THEME + TYPO VARS (TU MENÍŠ VEĽKOSTI)
   ========================= */
:root{
  --bg:#0b1220;
  --card:#111a2e;
  --text:#e9eefc;
  --muted:#b9c6f0;
  --accent:#7aa2ff;
  --line:rgba(255,255,255,.12);
  --shadow: 0 14px 40px rgba(0,0,0,.35);

  /* ===== TYPO (DESKTOP) – MENIŤ TU ===== */
  --fs-body: 18px;
  --lh-body: 1.6;

  --fs-brand-name: 16px;
  --fs-brand-sub: 13px;

  --fs-hero-h1: 34px;
  --lh-hero-h1: 1.18;
  --fs-hero-p: 16px;

  --fs-card-h2: 25px;
  --lh-card-h2: 1.25;

  --fs-badge: 22px;
  --fs-small: 18px;
  --fs-footer: 15px;

  /* ===== GALÉRIA – MENIŤ TU ===== */
  --gallery-tile-h: 220px;   /* výška dlaždice (thumbnail) */

  /* ===== TYPO (MOBILE) – MENIŤ TU ===== */
  --fs-brand-name-m: 18px;
  --fs-brand-sub-m: 13px;

  --fs-hero-h1-m: 28px;
  --lh-hero-h1-m: 1.12;
  --fs-badge-m: 12px;

  --fs-hero-h1-xs: 24px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}

body{
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: radial-gradient(1200px 600px at 20% 0%, rgba(122,162,255,.25), transparent 55%),
              radial-gradient(900px 500px at 80% 10%, rgba(190,90,255,.18), transparent 55%),
              var(--bg);
  color: var(--text);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
}

a{color:var(--text); text-decoration:none}
a:hover{color:white}

img{max-width:100%; height:auto;}
.name, .sub, .muted, .card, .hero p{ overflow-wrap:anywhere; }

/* =========================
   2) LAYOUT
   ========================= */
.container{max-width:1350px;margin:0 auto;padding:22px 16px 64px}

/* =========================
   3) TOPBAR / NAV
   ========================= */
.topbar{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:14px 16px;border:1px solid var(--line);border-radius:18px;
  background: rgba(17,26,46,.68); backdrop-filter: blur(10px);
  box-shadow: var(--shadow);
  position: sticky; top: 12px; z-index: 10;
}

.brand{display:flex;align-items:center;gap:12px;min-width:220px}

/* LOGO box */
.logo{
  width:48px;
  height:48px;
  border-radius:14px;
  border:1px solid var(--line);
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(255,255,255,.06);
  overflow:hidden;
}
.logo img{
  width:100%;
  height:100%;
  object-fit:contain;
}

.brand .name{
  font-weight:800;
  letter-spacing:.2px;
  font-size: var(--fs-brand-name);
}
.brand .sub{
  font-size: var(--fs-brand-sub);
  color:var(--muted);
  margin-top:-2px;
}

.nav{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.nav a{
  padding:9px 12px;border-radius:12px;
  border:1px solid transparent;
  color:var(--muted);
}
.nav a.active, .nav a:hover{
  border-color: var(--line);
  background: rgba(255,255,255,.06);
  color: var(--text);
}

/* =========================
   4) HERO + GRID
   ========================= */
.hero{
  margin-top:18px;
  padding:26px 20px;
  border:1px solid var(--line);
  border-radius:22px;
  background: rgba(17,26,46,.55);
  box-shadow: var(--shadow);
}

.hero h1{
  margin:0 0 8px;
  font-size: var(--fs-hero-h1);
  line-height: var(--lh-hero-h1);
}
.hero p{
  margin:0;
  color:var(--muted);
  max-width:75ch;
  font-size: var(--fs-hero-p);
}

/* HERO GRID: presná polovica 50/50 */
.grid{
  margin-top:8px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:8px;
}

/* HERO – karty musia mať rovnakú výšku */
.hero .grid{ align-items: stretch; }
.hero .grid > div{ display:flex; }
.hero .card{ display:flex; flex-direction:column; }
.hero .media-item{ margin-top:auto; }

/* =========================
   5) CARDS / COMMON UI
   ========================= */
.card{
  border:1px solid var(--line);
  border-radius:18px;
  background: rgba(17,26,46,.55);
  box-shadow: var(--shadow);
  padding:8px;
}

.card h2{
  margin:0 0 10px;
  font-size: var(--fs-card-h2);
  line-height: var(--lh-card-h2);
}

.muted{color:var(--muted)}

.badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 10px;border-radius:999px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.06);
  color: var(--muted);
  font-size: var(--fs-badge);
}

.list{margin:0;padding-left:18px;color:var(--muted)}
hr.sep{border:none;border-top:1px solid var(--line);margin:18px 0}

.small{font-size: var(--fs-small);}

.notice{
  border:1px dashed var(--line);
  border-radius:14px;
  padding:12px 14px;
  color: var(--muted);
  background: rgba(255,255,255,.04);
}

.is-hidden{display:none!important}

/* =========================
   6) KV
   ========================= */
.kv{
  display:grid;
  grid-template-columns: 140px 1fr;
  gap:8px 12px;
  margin-top:10px;
}
.kv .row{display:contents}
.kv div{padding:8px 0;border-bottom:1px solid var(--line)}
.kv div:nth-last-child(-n+2){border-bottom:none}
.kv .k{color:var(--muted)}

/* =========================
   7) BUTTONS
   ========================= */
.btnrow{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 12px;border-radius:14px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.06);
  color: var(--text);
  font-weight:600;
  cursor:pointer;
}
.btn:hover{background: rgba(255,255,255,.10)}
.btn.primary{
  background: linear-gradient(135deg, rgba(122,162,255,.55), rgba(255,255,255,.08));
}

/* =========================
   8) MEDIA (poster / video)
   ========================= */
.poster{
  width:100%;
  height:auto;
  border-radius:16px;
  border:1px solid var(--line);
  display:block;
}

.media-grid{
  margin-top: 14px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:16px;
}

.media-item{
  border:1px solid var(--line);
  border-radius:16px;
  overflow:hidden;
  background: rgba(17,26,46,.55);
  box-shadow: var(--shadow);
}

.media-item img,
.media-item video{
  width:100%;
  height:auto;
  display:block;
}

video{max-width:100%}

/* =========================
   9) GALÉRIA (dlaždice + lightbox)
   ========================= */
.gallery-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:12px;
  margin-top:12px;
}

.gallery-tile{
  border:1px solid var(--line);
  border-radius:16px;
  overflow:hidden;
  background: rgba(17,26,46,.55);
  box-shadow: var(--shadow);
  cursor: zoom-in;
}

.gallery-tile img{
  width:100%;
  height: var(--gallery-tile-h);
  object-fit: cover;
  display:block;
}

.gallery-tile .cap{
  padding:10px 12px;
  color: var(--muted);
  font-size:14px;
}

/* LIGHTBOX */
.lightbox{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  padding:18px;
  background: rgba(0,0,0,.75);
  z-index:9999;
}
.lightbox.open{display:flex;}

.lightbox-inner{
  max-width: min(1100px, 96vw);
  max-height: 92vh;
  width:100%;
}

.lightbox-media{
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--line);
  background: rgba(17,26,46,.85);
  box-shadow: var(--shadow);
}

.lightbox-media img{
  width:100%;
  height:auto;
  max-height:78vh;
  object-fit: contain;
  display:block;
  background:#000;
}

.lightbox-bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-top:10px;
  color: var(--muted);
  font-size:14px;
}

.lightbox-btn{
  border:1px solid var(--line);
  background: rgba(255,255,255,.08);
  color: var(--text);
  border-radius:12px;
  padding:8px 10px;
  cursor:pointer;
}
.lightbox-btn:hover{background: rgba(255,255,255,.12);}

/* =========================
   10) FOOTER
   ========================= */
.footer{
  margin-top:28px;
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  color:var(--muted);
  font-size: var(--fs-footer);
  opacity:.9;
}

/* =========================
   11) RESPONSIVE
   ========================= */
@media (max-width: 1100px){
  .gallery-grid{ grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 900px){
  .grid{grid-template-columns:1fr}
  .brand{min-width:auto}
  .media-grid{grid-template-columns: 1fr;}
  .gallery-grid{ grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 980px){
  .container{
    padding-left: 16px;
    padding-right: 16px;
  }
}

@media (max-width: 700px){
  .topbar{
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 12px !important;
  }

  .brand{ width: 100% !important; }

  .logo{
    width: 44px !important;
    height: 44px !important;
  }
  .logo img{
    width: 44px !important;
    height: 44px !important;
    object-fit: contain;
    display: block;
  }

  /* typografia – mobile cez premenné */
  .name{ font-size: var(--fs-brand-name-m) !important; line-height: 1.2 !important; }
  .sub{ font-size: var(--fs-brand-sub-m) !important; }
  .hero h1{ font-size: var(--fs-hero-h1-m) !important; line-height: var(--lh-hero-h1-m) !important; }
  .hero .badge{ font-size: var(--fs-badge-m) !important; }

  .nav{
    width: 100% !important;
    overflow-x: auto;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 2px;
  }
  .nav a{
    display: inline-block;
    flex: 0 0 auto;
    padding: 10px 12px !important;
    margin-right: 6px;
  }

  .card{
    padding: 16px !important;
    border-radius: 14px !important;
  }

  .kv{
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }
  .kv .k{
    margin-top: 10px;
    font-weight: 700;
  }
  .kv div{
    border-bottom: none;
    padding: 4px 0;
  }

  .poster{ border-radius: 14px !important; }
  .media-item{ border-radius: 14px; }
}

@media (max-width: 420px){
  .hero h1{ font-size: var(--fs-hero-h1-xs) !important; }
  .gallery-grid{ grid-template-columns: 1fr; }
}

/* program.html – plagát nech nie je obrovský */
#progPoster{
  width: 100%;
  max-width: 520px;   /* šírka náhľadu – uprav si */
  height: auto;
  max-height: 70vh;   /* max 70% výšky obrazovky */
  object-fit: contain;
  display: block;
  margin: 10px auto 0; /* vycentrovanie */
}


/* =========================
   TABUĽKY (Archív inscenácií)
   ========================= */
.table-wrap{
  margin-top: 12px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(17,26,46,.35);
}

.tbl{
  width: 100%;
  border-collapse: collapse;
  min-width: 720px; /* aby sa na mobile radšej scrollovalo než lámalo */
}

.tbl th,
.tbl td{
  padding: 10px 12px;
  border-bottom: 1px solid var(--line);
  color: var(--text);
  vertical-align: top;
}

.tbl th{
  text-align: left;
  color: var(--muted);
  font-weight: 700;
  background: rgba(255,255,255,.04);
}

.tbl tr:last-child td{ border-bottom: 0; }

/* jemné zebra pruhy */
.tbl tr:nth-child(even) td{
  background: rgba(255,255,255,.02);
}

/* čísla zarovnať lepšie */
.tbl td:first-child,
.tbl th:first-child{
  width: 52px;
  text-align: right;
  color: var(--muted);
}
