/* Hole in Wine — static rebuild (Cloudflare Pages)
   Paleta dle originálu: modrá #2846a7 + magenta #e934dc, bílé pozadí, tučný sans. */
:root{
  --blue:#2846a7;        /* brandová modrá */
  --blue-dark:#1b3074;   /* tmavá modrá (nav/footer/dark sekce) */
  --magenta:#e934dc;     /* akcent */
  --magenta-soft:#cf22c2;
  --bg:#ffffff;
  --bg-2:#f4f5fb;        /* světlé sekce */
  --ink:#191b2e;
  --muted:#5b6072;
  --line:rgba(20,30,80,.14);
  --maxw:1180px;
  --radius:6px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* Display headings — bold sans (Montserrat) */
h1,h2,h3,.brand{
  font-family:"Montserrat",-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  font-weight:800;letter-spacing:.01em;margin:0;color:var(--blue);
}
.eyebrow{
  font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--magenta);font-weight:800;margin:0 0 .8rem;
}

/* ---------- Header / nav ---------- */
.site-header{
  position:sticky;top:0;z-index:40;
  background:var(--blue);border-bottom:1px solid rgba(255,255,255,.12);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{color:#fff;font-size:1.4rem;letter-spacing:.02em;text-transform:uppercase;display:flex;align-items:center}
.brand:hover{text-decoration:none;color:#fff}
.brand .logo{height:32px;width:auto;display:block}
.nav-links{display:flex;gap:28px}
.nav-links a{
  color:#fff;text-transform:uppercase;letter-spacing:.14em;
  font-size:.74rem;font-weight:700;padding:6px 0;border-bottom:2px solid transparent;
}
.nav-links a:hover,.nav-links a.active{text-decoration:none;border-color:var(--magenta);color:#fff}

/* ---------- Hero ---------- */
.hero{
  position:relative;min-height:80vh;display:flex;align-items:flex-end;
  color:#fff;text-align:left;
  background:linear-gradient(rgba(27,48,116,.10),rgba(27,48,116,.72)),var(--hero,var(--blue)) center/cover no-repeat;
}
.hero .wrap{padding-top:90px;padding-bottom:64px;width:100%}
.hero h1{font-size:clamp(3rem,9vw,6.4rem);line-height:.98;text-transform:uppercase;color:#fff}
.hero .tagline{
  text-transform:uppercase;letter-spacing:.26em;font-size:.92rem;font-weight:700;
  margin-top:1rem;color:#fff
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;background:var(--magenta);color:#fff;border:2px solid var(--magenta);
  padding:13px 32px;text-transform:uppercase;letter-spacing:.14em;font-size:.76rem;font-weight:800;
  border-radius:var(--radius);transition:.2s
}
.btn:hover{background:var(--magenta-soft);border-color:var(--magenta-soft);text-decoration:none;color:#fff}
.btn.ghost{background:transparent;border-color:#fff;color:#fff}
.btn.ghost:hover{background:#fff;color:var(--blue-dark)}

/* ---------- Sections ---------- */
section{padding:80px 0}
.section-tight{padding:54px 0}
.lede{font-size:1.18rem;max-width:760px;margin:0 auto;text-align:center;color:var(--ink)}
.center{text-align:center}
h2{font-size:clamp(2rem,5.5vw,3.4rem);text-transform:uppercase;margin-bottom:.4rem}
h2.with-rule:after{content:"";display:block;width:64px;height:4px;background:var(--magenta);margin:18px auto 0}
.alt{background:var(--bg-2)}
.dark{background:var(--blue-dark);color:#eaf0ff}
.dark h2,.dark h3{color:#fff}
.dark .lede{color:#d7e0ff}
.dark .eyebrow{color:#f4a9ef}

/* feature split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.split img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius);max-height:460px}
@media(max-width:820px){.split{grid-template-columns:1fr}}

/* organizers */
.orgs{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:1.6rem}
.orgs span{
  border:1px solid var(--line);padding:10px 20px;text-transform:uppercase;
  letter-spacing:.12em;font-size:.78rem;font-weight:700;background:#fff;color:var(--blue)
}

/* ---------- Program timeline ---------- */
.timeline{max-width:720px;margin:2.4rem auto 0;border-left:3px solid var(--magenta)}
.tl{position:relative;padding:14px 0 14px 28px}
.tl:before{content:"";position:absolute;left:-8px;top:20px;width:13px;height:13px;border-radius:50%;background:var(--magenta)}
.tl time{font-weight:800;letter-spacing:.04em;display:block;color:var(--blue)}
.tl span{display:block}
.facts{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:2.2rem}
.fact{background:#fff;border:1px solid var(--line);border-top:3px solid var(--magenta);padding:18px 22px;text-align:center;min-width:180px}
.fact b{display:block;text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;color:var(--magenta);font-weight:800;margin-bottom:.3rem}

/* ---------- Featured video (galerie ročníku) ---------- */
.feature-video{max-width:440px;margin:8px auto 40px}
.feature-video video{width:100%;height:auto;display:block;border-radius:var(--radius);background:#000;box-shadow:0 8px 40px rgba(27,48,116,.25)}

/* ---------- Gallery ---------- */
.gal-head{padding:60px 0 8px;text-align:center}
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;padding:24px 0 80px}
.gallery .ph{display:block;overflow:hidden;border-radius:4px;background:#dde;aspect-ratio:1/1}
.gallery .ph img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease}
.gallery .ph:hover img{transform:scale(1.06)}

/* ---------- Lightbox ---------- */
.lb{position:fixed;inset:0;background:rgba(12,18,46,.95);display:none;z-index:90;align-items:center;justify-content:center}
.lb.open{display:flex}
.lb img{max-width:94vw;max-height:90vh;object-fit:contain;box-shadow:0 10px 60px rgba(0,0,0,.6)}
.lb-btn{position:absolute;background:none;border:0;color:#fff;cursor:pointer;font-size:2.6rem;line-height:1;padding:14px;opacity:.85;user-select:none}
.lb-btn:hover{opacity:1}
.lb-close{top:8px;right:14px;font-size:2.2rem}
.lb-prev{left:8px;top:50%;transform:translateY(-50%)}
.lb-next{right:8px;top:50%;transform:translateY(-50%)}
.lb-count{position:absolute;bottom:16px;left:0;right:0;text-align:center;color:#c8d0f0;letter-spacing:.2em;font-size:.8rem}

/* ---------- Year tabs ---------- */
.yeartabs{display:inline-flex;gap:6px;margin-top:1.4rem;border:1px solid var(--line);border-radius:999px;padding:5px;background:#fff}
.dark .yeartabs{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.22)}
.ytab{border:0;background:none;cursor:pointer;font:inherit;font-weight:800;letter-spacing:.1em;padding:9px 28px;border-radius:999px;color:var(--muted);text-transform:uppercase;font-size:.82rem;transition:.2s}
.dark .ytab{color:#c5d0f5}
.ytab:hover{color:var(--magenta)}
.dark .ytab:hover{color:#fff}
.ytab.active{background:var(--magenta);color:#fff}
.ypane{display:none}
.ypane.active{display:block}
.empty-year{text-align:center;padding:72px 20px;color:var(--muted);border:1px dashed var(--line);border-radius:var(--radius);margin:10px 0 48px}
.empty-year strong{display:block;font-size:1.5rem;color:var(--blue);margin-bottom:.4rem;font-family:"Montserrat",sans-serif;font-weight:800;text-transform:uppercase}

/* ---------- Editions (úvodní rozcestník) ---------- */
.editions{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:840px;margin:2.4rem auto 0}
.edition{background:#fff;border:1px solid var(--line);border-top:4px solid var(--magenta);border-radius:var(--radius);padding:34px 28px;text-align:center}
.edition-year{font-family:"Montserrat",sans-serif;font-weight:900;font-size:3.6rem;line-height:1;color:var(--blue);display:block}
.edition-date{color:var(--muted);text-transform:uppercase;letter-spacing:.1em;font-size:.76rem;margin:.6rem 0 1.4rem}
.edition-links{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.edition-links .btn{padding:11px 22px}

/* ---------- Footer ---------- */
.site-footer{background:var(--blue-dark);color:#eaf0ff;padding:52px 0;text-align:center}
.site-footer .brand{display:inline-flex;font-size:1.5rem;letter-spacing:.04em;color:#fff}
.site-footer .logo{height:34px;width:auto}
.site-footer p{color:#c2cdf2;font-size:.86rem;margin:.6rem 0 0;letter-spacing:.04em}
.site-footer .orgs span{background:transparent;border-color:rgba(255,255,255,.22);color:#fff}

@media(max-width:600px){
  .nav-links{gap:18px}
  .brand .logo{height:26px}
  section{padding:58px 0}
  .editions{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(auto-fill,minmax(46%,1fr));gap:7px}
}
