/* ====== Dušan Žanta | styl webu ====== */
:root{
  --papir:#f4efe3;
  --papir-2:#efe7d6;
  --inkoust:#1d2b27;
  --evergreen:#13524a;
  --evergreen-2:#1c6c61;
  --evergreen-3:#0f3f39;
  --jantar:#c87d2e;
  --jantar-svetly:#e0a34e;
  --pisek:#e6dcc4;
  --linka:rgba(29,43,39,.14);
  --stin:0 1px 2px rgba(15,40,36,.06), 0 8px 24px rgba(15,40,36,.10);
  --stin-velky:0 24px 60px rgba(15,40,36,.28);
  --max:1120px;
  --radius:14px;
  --pismo-nadpis:"Fraunces", Georgia, "Times New Roman", serif;
  --pismo-text:"Karla", system-ui, -apple-system, "Segoe UI", sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--pismo-text);
  color:var(--inkoust);
  background-color:var(--papir);
  background-image:
    radial-gradient(900px 520px at 88% -8%, rgba(28,108,97,.10), transparent 60%),
    radial-gradient(760px 480px at 0% 8%, rgba(200,125,46,.08), transparent 55%);
  line-height:1.65;
  font-size:18px;
  -webkit-font-smoothing:antialiased;
}
/* jemná zrnitost */
body::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
}

a{color:var(--evergreen-2);text-underline-offset:3px}
a:hover{color:var(--jantar)}

.kontejner{width:100%;max-width:var(--max);margin:0 auto;padding:0 24px}

.preskoc{position:absolute;left:-999px;top:0;background:var(--evergreen);color:#fff;padding:10px 16px;border-radius:0 0 10px 0;z-index:200}
.preskoc:focus{left:0}

/* ---------- Hlavička ---------- */
.hlavicka{
  position:sticky;top:0;z-index:100;
  background:rgba(244,239,227,.86);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--linka);
}
.hlavicka-vnitrek{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:74px}
.znacka{display:flex;flex-direction:column;text-decoration:none;line-height:1.05}
.znacka-jmeno{font-family:var(--pismo-nadpis);font-weight:800;font-size:1.46rem;color:var(--evergreen-3);letter-spacing:.2px}
.znacka-podtitul{font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--jantar);font-weight:700}

.navigace ul{display:flex;gap:4px;list-style:none;margin:0;padding:0;flex-wrap:wrap;justify-content:flex-end}
.navigace a{
  display:inline-block;text-decoration:none;color:var(--inkoust);
  font-weight:500;font-size:.96rem;padding:9px 13px;border-radius:9px;
  transition:background .18s,color .18s;
}
.navigace a:hover{background:rgba(28,108,97,.10);color:var(--evergreen-3)}
.navigace a.je-aktivni{background:var(--evergreen);color:#fff}

.menu-tlacitko{display:none;flex-direction:column;gap:5px;width:46px;height:42px;
  border:1px solid var(--linka);border-radius:10px;background:#fff;cursor:pointer;
  align-items:center;justify-content:center}
.menu-tlacitko span{display:block;width:22px;height:2px;background:var(--evergreen-3);transition:.25s}
.menu-tlacitko[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-tlacitko[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-tlacitko[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{
  padding:64px 0 30px;
  background:
    linear-gradient(180deg, rgba(19,82,74,.05), transparent 70%);
  position:relative;
}
.hero::after{
  content:"";display:block;width:78px;height:4px;border-radius:4px;
  background:linear-gradient(90deg,var(--jantar),var(--jantar-svetly));
  margin-top:22px;
}
.hero-role{
  font-size:.8rem;letter-spacing:.04em;text-transform:uppercase;color:var(--evergreen-2);
  font-weight:700;margin:0 0 14px
}
.hero-nadpis{
  font-family:var(--pismo-nadpis);font-weight:800;
  font-size:clamp(2.2rem,6vw,4rem);line-height:1.02;margin:0;color:var(--evergreen-3);
  letter-spacing:-.5px;
}
.hero-tagline{
  font-family:var(--pismo-nadpis);font-style:italic;font-weight:500;
  font-size:clamp(1.15rem,2.6vw,1.6rem);color:var(--jantar);margin:14px 0 0
}

/* ---------- Sekce / text ---------- */
.sekce{padding:34px 24px}
.text-blok{max-width:820px}
.text-blok h2{
  font-family:var(--pismo-nadpis);font-weight:600;color:var(--evergreen-3);
  font-size:1.7rem;margin:2.1em 0 .5em;line-height:1.15
}
.text-blok h2:first-child{margin-top:0}
.text-blok p{margin:0 0 1.05em}
.perex{font-size:1.22rem;line-height:1.5;color:var(--evergreen-3);font-weight:500}
.podpis{font-family:var(--pismo-nadpis);font-style:italic;font-size:1.3rem;color:var(--jantar)}
.pripis{background:var(--papir-2);border-left:4px solid var(--jantar);padding:14px 18px;border-radius:8px}

.seznam-odrazky,.seznam-clenove,.seznam-kontakt{margin:0 0 1.1em;padding-left:0;list-style:none}
.seznam-odrazky li,.seznam-clenove li,.seznam-kontakt li{
  position:relative;padding-left:26px;margin-bottom:.5em
}
.seznam-odrazky li::before,.seznam-clenove li::before,.seznam-kontakt li::before{
  content:"";position:absolute;left:4px;top:.7em;width:8px;height:8px;border-radius:50%;
  background:var(--jantar)
}
.seznam-clenove li{margin-bottom:.65em}

/* ---------- Karty s odkazy ---------- */
.karty-odkazy{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}
.karta-odkaz{
  display:flex;flex-direction:column;gap:8px;text-decoration:none;color:var(--inkoust);
  background:#fff;border:1px solid var(--linka);border-radius:var(--radius);
  padding:22px 22px 18px;box-shadow:var(--stin);
  transition:transform .2s,box-shadow .2s,border-color .2s
}
.karta-odkaz:hover{transform:translateY(-4px);box-shadow:var(--stin-velky);border-color:rgba(28,108,97,.4)}
.karta-nadpis{font-family:var(--pismo-nadpis);font-weight:700;font-size:1.4rem;color:var(--evergreen-3)}
.karta-popis{color:#46554f;font-size:.98rem}
.karta-vice{margin-top:auto;color:var(--jantar);font-weight:700;font-size:.92rem}

/* ---------- Kontakt ---------- */
.kontakt-karta{background:#fff;border:1px solid var(--linka);border-radius:var(--radius);
  padding:26px 28px;box-shadow:var(--stin);max-width:560px}
.kontakt-jmeno{font-family:var(--pismo-nadpis);font-weight:700;font-size:1.4rem;color:var(--evergreen-3);margin:0 0 .6em}
.kontakt-seznam{display:grid;grid-template-columns:auto 1fr;gap:6px 22px;margin:0}
.kontakt-seznam dt{font-weight:700;color:var(--evergreen-2)}
.kontakt-seznam dd{margin:0}

/* ---------- Skladby ---------- */
.seznam-stopy{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:12px}
.stopa{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--linka);
  border-radius:10px;padding:10px 14px;box-shadow:var(--stin)}
.stopa-cislo{font-family:var(--pismo-nadpis);font-weight:800;color:var(--jantar);font-size:1.1rem;min-width:26px}
.stopa-nazev{font-weight:500;min-width:74px}
.stopa audio{height:34px;flex:1;min-width:0}

/* ---------- Galerie ---------- */
.galerie-blok{max-width:var(--max);margin:18px auto 0;padding:24px}
.nadpis-galerie{font-family:var(--pismo-nadpis);font-weight:600;color:var(--evergreen-3);
  font-size:1.7rem;margin:0 0 18px}
.galerie{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:12px}
.foto{
  display:block;aspect-ratio:4/3;overflow:hidden;border-radius:12px;
  background:linear-gradient(135deg,var(--pisek),#d7cbab);
  box-shadow:var(--stin);cursor:zoom-in;position:relative;
  border:1px solid var(--linka)
}
.foto img{width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .45s ease;background:var(--pisek)}
.foto:hover img{transform:scale(1.07)}
.foto::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(15,40,36,.22));
  opacity:0;transition:opacity .25s}
.foto:hover::after{opacity:1}

/* ---------- Lightbox ---------- */
.lb{position:fixed;inset:0;z-index:300;display:none;align-items:center;justify-content:center;
  background:rgba(12,26,23,.92);padding:20px}
.lb.otevreno{display:flex}
.lb img{max-width:94vw;max-height:86vh;border-radius:8px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lb-zavri,.lb-prev,.lb-next{position:absolute;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.25);
  color:#fff;width:52px;height:52px;border-radius:50%;font-size:1.5rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:background .2s}
.lb-zavri:hover,.lb-prev:hover,.lb-next:hover{background:rgba(255,255,255,.25)}
.lb-zavri{top:18px;right:18px}
.lb-prev{left:18px;top:50%;transform:translateY(-50%)}
.lb-next{right:18px;top:50%;transform:translateY(-50%)}

/* ---------- Patička ---------- */
.zpet{font-weight:700}
.paticka{margin-top:50px;background:var(--evergreen-3);color:#e9efec}
.paticka a{color:#cfe6e0}
.paticka a:hover{color:var(--jantar-svetly)}
.paticka-mrizka{display:flex;flex-wrap:wrap;gap:30px;justify-content:space-between;padding-top:40px;padding-bottom:20px}
.paticka-jmeno{font-family:var(--pismo-nadpis);font-weight:700;font-size:1.25rem;color:#fff;margin:0 0 .5em}
.paticka-nav{list-style:none;margin:0;padding:0;display:grid;gap:6px}
.paticka-spodek{border-top:1px solid rgba(255,255,255,.14);padding-top:16px;padding-bottom:26px;font-size:.86rem;color:#9db8b1}

/* ---------- Responsivita ---------- */
@media (max-width:760px){
  body{font-size:17px}
  .menu-tlacitko{display:flex}
  .navigace{position:absolute;top:74px;left:0;right:0;background:var(--papir);
    border-bottom:1px solid var(--linka);box-shadow:var(--stin);
    max-height:0;overflow:hidden;transition:max-height .3s ease}
  .navigace.otevreno{max-height:70vh}
  .navigace ul{flex-direction:column;align-items:stretch;padding:10px 16px 18px;gap:2px}
  .navigace a{padding:12px 14px;font-size:1.05rem}
  .hero{padding:40px 0 18px}
  .galerie{grid-template-columns:repeat(auto-fill,minmax(132px,1fr))}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto}
}

/* popisek fotky (např. u dokladů) */
.foto-popis{position:absolute;left:0;right:0;bottom:0;z-index:2;
  background:linear-gradient(transparent,rgba(15,40,36,.82));color:#fff;
  font-size:.78rem;padding:18px 10px 8px;opacity:0;transition:opacity .2s;line-height:1.25}
.foto:hover .foto-popis{opacity:1}
