/* =================================================================
   Sport bar Atláč — designový systém
   Inspirace: hospoda za tmy, mosazný drát terče, elektronická
   skórovačka šipek. Tmavé dřevo + mosazný lesk piva + červená terče,
   čísla v "digitálním" patkovém monospace jako na skórovačce.
   ================================================================= */

:root{
  /* barvy */
  --inkoust:#17120F;       /* tmavé pozadí, jako bar za soumraku */
  --inkoust-2:#100C0A;
  --zed:#241C17;           /* panely / karty */
  --zed-2:#2D241D;
  --mosaz:#D8932E;         /* mosaz / pivní zlato — hlavní akcent */
  --mosaz-tmava:#A86E1E;
  --terc:#B8392B;          /* terč červená — CTA / důraz */
  --terc-tmava:#8C2A1F;
  --zelena:#5C8A4A;        /* "otevřeno" světlo */
  --krida:#F3E9D8;         /* hlavní text, jako křída na tabuli */
  --popel:#A8978A;         /* tlumený text */
  --popel-tmava:#6F6258;
  --linka: rgba(243,233,216,.14);

  /* typografie */
  --font-display:'Oswald', 'Arial Narrow', sans-serif;
  --font-text:'Work Sans', system-ui, sans-serif;
  --font-cislo:'Space Mono', 'Courier New', monospace;

  --radius: 4px;
  --kontejner-max: 1180px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--inkoust);
  color:var(--krida);
  font-family:var(--font-text);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3{ margin:0; font-family:var(--font-display); font-weight:600; text-transform:uppercase; letter-spacing:.02em; }
p{ margin:0; }
button{ font:inherit; }

.skip-link{
  position:absolute; left:-999px; top:0; background:var(--mosaz); color:var(--inkoust);
  padding:.6em 1em; z-index:200; font-weight:600;
}
.skip-link:focus{ left:1em; top:1em; }

:focus-visible{ outline:3px solid var(--mosaz); outline-offset:2px; }

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

/* ---------- eyebrow / nadpisy ---------- */
.eyebrow{
  font-family:var(--font-cislo);
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:.78rem;
  color:var(--mosaz);
  margin:0 0 .8em;
}
.eyebrow--stred{ text-align:center; }

.nadpis-sekce{ font-size:clamp(1.5rem,1.1rem + 1.6vw,2.3rem); margin-bottom:.6em; }
.nadpis-sekce--stred{ text-align:center; margin-inline:auto; max-width:32ch; }
.nadpis-stranky{ font-size:clamp(2rem,1.4rem + 2.4vw,3.4rem); margin-bottom:.3em; }
.text-sekce{ color:var(--popel); max-width:62ch; font-size:1.05rem; }
.sekce__obsah-uzky{ max-width:760px; }

/* ---------- tlačítka ---------- */
.tlacitko{
  display:inline-flex; align-items:center; gap:.5em;
  padding:.85em 1.6em;
  font-family:var(--font-display);
  text-transform:uppercase; letter-spacing:.04em; font-size:.92rem; font-weight:600;
  border-radius:var(--radius);
  border:2px solid transparent;
  transition:transform .15s ease, background .15s ease, border-color .15s ease;
}
.tlacitko:hover{ transform:translateY(-2px); }
.tlacitko--mosaz{ background:var(--mosaz); color:var(--inkoust-2); }
.tlacitko--mosaz:hover{ background:#EAA63F; }
.tlacitko--terc{ background:var(--terc); color:var(--krida); }
.tlacitko--terc:hover{ background:#D14433; }
.tlacitko--obrys{ border-color:var(--popel-tmava); color:var(--krida); }
.tlacitko--obrys:hover{ border-color:var(--mosaz); color:var(--mosaz); }

/* ---------- hlavička ---------- */
.hlavicka{ position:sticky; top:0; z-index:100; background:var(--inkoust-2); border-bottom:1px solid var(--linka); }
.hlavicka__pruh{ background:var(--inkoust); font-size:.82rem; color:var(--popel); }
.hlavicka__pruh-obsah{ display:flex; justify-content:space-between; gap:1em; padding-block:.4em; flex-wrap:wrap; }
.hlavicka__telefony{ display:flex; gap:1.2em; }
.hlavicka__telefony a:hover{ color:var(--mosaz); }

.hlavicka__hlavni{ display:flex; align-items:center; gap:1.5em; padding-block:.8em; }

.logo{ display:flex; flex-direction:column; line-height:1; margin-right:auto; }
.logo__znacka{ font-family:var(--font-display); font-size:1.6rem; font-weight:700; letter-spacing:.04em; color:var(--krida); }
.logo__doplnek{ font-family:var(--font-cislo); font-size:.65rem; letter-spacing:.3em; color:var(--mosaz); text-transform:uppercase; }
.logo__obrazek{ display:block; height:120px; width:auto; max-width:380px; object-fit:contain; }

.nav{ display:flex; gap:1.6em; }
.nav__odkaz{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:.03em; font-size:.92rem; color:var(--popel); padding-block:.3em; border-bottom:2px solid transparent; }
.nav__odkaz:hover{ color:var(--krida); }
.nav__odkaz--aktivni{ color:var(--mosaz); border-color:var(--mosaz); }

.nav__prepinac{ display:none; flex-direction:column; gap:5px; background:none; border:0; padding:6px; cursor:pointer; }
.nav__prepinac span{ width:24px; height:2px; background:var(--krida); display:block; }

/* skóre světlo v hlavičce */
.skore{ display:flex; align-items:center; gap:.6em; padding:.4em .8em; background:var(--zed); border-radius:var(--radius); border:1px solid var(--linka); }
.skore__svetlo{ width:10px; height:10px; border-radius:50%; flex:none; box-shadow:0 0 8px currentColor; }
.skore__svetlo--zelena{ background:var(--zelena); color:var(--zelena); }
.skore__svetlo--cervena{ background:var(--terc); color:var(--terc); }
.skore__text{ display:flex; flex-direction:column; line-height:1.2; }
.skore__stav{ font-family:var(--font-cislo); font-size:.72rem; letter-spacing:.1em; }
.skore__detail{ font-size:.7rem; color:var(--popel); }

/* ---------- hero ---------- */
.hero{ position:relative; overflow:hidden; border-bottom:1px solid var(--linka); }
.hero__pozadi{ position:absolute; inset:0; z-index:0; }
.hero__foto{ width:100%; height:100%; object-fit:cover; }
.hero__pozadi .placeholder{ height:100%; min-height:560px; border-radius:0; }
/* Vrstvy rotujícího karuselu fotek na pozadí hero sekce – viz vykresli_hero_karusel() */
.hero__foto--vrstva{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  opacity:0; transition:opacity 1.8s ease;
}
.hero__foto--vrstva.je-aktivni{ opacity:1; }
.hero__zatmeni{
  position:absolute; inset:0;
  background:
    radial-gradient(640px 640px at 82% 20%, rgba(216,147,46,.16), transparent 60%),
    linear-gradient(100deg, rgba(17,13,10,.97) 0%, rgba(17,13,10,.92) 38%, rgba(17,13,10,.62) 72%, rgba(17,13,10,.4) 100%);
}
.hero__obsah{
  position:relative; z-index:1;
  display:grid; grid-template-columns:1.4fr .9fr; gap:3rem; align-items:center;
  padding-block:5.5rem 4.5rem;
  min-height:560px;
}
.hero__nadpis{ font-size:clamp(2.3rem,1.6rem + 3.4vw,4.2rem); margin-bottom:.3em; }
.hero__podnadpis{ color:var(--popel); font-size:1.1rem; max-width:46ch; margin-bottom:1.6em; }
.hero__cta{ display:flex; gap:1em; flex-wrap:wrap; }

/* tabule — "elektronická skórovačka" otevírací doby, signature prvek */
.tabule{
  background:linear-gradient(180deg,#1C1209,#120B06);
  border:1px solid #3A2A14;
  border-radius:8px;
  padding:1.4em 1.5em 1.6em;
  box-shadow:0 18px 50px rgba(0,0,0,.55), inset 0 0 0 1px rgba(216,147,46,.06);
  position:relative;
}
.tabule::before{
  content:''; position:absolute; inset:0; border-radius:8px; pointer-events:none;
  background:repeating-linear-gradient(180deg, rgba(255,255,255,.02) 0 2px, transparent 2px 4px);
}
.tabule__mimoradne{
  font-family:var(--font-display); font-weight:700; font-size:1.05rem; line-height:1.45;
  color:var(--terc); background:rgba(184,57,43,.14); border:1px solid rgba(184,57,43,.45);
  border-radius:6px; padding:.75em .9em; margin-bottom:1.1em;
}
.tabule__radek--hlavicka{ display:flex; justify-content:space-between; align-items:center; font-family:var(--font-cislo); font-size:.72rem; letter-spacing:.14em; color:var(--popel); margin-bottom:.8em; }
.tabule__svetlo{ width:9px; height:9px; border-radius:50%; box-shadow:0 0 10px currentColor; }
.tabule__svetlo--zelena{ background:var(--zelena); color:var(--zelena); }
.tabule__svetlo--cervena{ background:var(--terc); color:var(--terc); }
.tabule__stav{
  font-family:var(--font-cislo); font-weight:700; font-size:1.05rem; letter-spacing:.16em;
  color:var(--mosaz); text-shadow:0 0 18px rgba(216,147,46,.55);
  margin-bottom:.5em;
}
.tabule__cas{ display:flex; align-items:baseline; gap:.4em; margin-bottom:.4em; }
.tabule__cislice{ font-family:var(--font-cislo); font-weight:700; font-size:2.6rem; color:var(--krida); letter-spacing:.02em; }
.tabule__pomlcka{ color:var(--popel-tmava); font-size:1.6rem; }
.tabule__detail-spodek{ font-size:.85rem; color:var(--popel); margin-bottom:1em; }
.tabule__odkaz{ font-family:var(--font-cislo); font-size:.74rem; letter-spacing:.06em; color:var(--mosaz); }
.tabule__odkaz:hover{ text-decoration:underline; }

/* ---------- sekce obecně ---------- */
.sekce{ padding-block:4.5rem; }
.sekce--tmava{ background:var(--zed); }
.sekce--vyzva{ background:linear-gradient(120deg, var(--zed-2), var(--inkoust-2)); border-top:1px solid var(--linka); border-bottom:1px solid var(--linka); text-align:center; }
.sekce--vyzva__obsah{ display:flex; flex-direction:column; align-items:center; gap:.9em; }
.sekce__cta-stred{ text-align:center; margin-top:2.4em; }

/* křídový seznam nabídky nápojů, jako popsaná tabule */
.krida-seznam{ margin-top:1.4em; border-top:1px dashed var(--linka); }
.krida-seznam li{
  padding:.65em 0; border-bottom:1px dashed var(--linka);
  font-family:var(--font-display); text-transform:uppercase; letter-spacing:.03em; font-size:1.02rem;
}
.krida-seznam li::before{ content:'— '; color:var(--mosaz); }

/* karty služeb */
.mrizka-karet{ display:grid; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); gap:1.4rem; margin-top:2rem; }
.karta{ background:var(--zed); border:1px solid var(--linka); border-radius:var(--radius); padding:1.6em; border-top:3px solid var(--mosaz); }
.karta__nadpis{ font-size:1.05rem; margin-bottom:.5em; color:var(--krida); }
.karta__text{ color:var(--popel); font-size:.95rem; }

/* řádek text + foto na stránce Naše služby */
.sluzba-radek{ display:grid; grid-template-columns:1.1fr .9fr; gap:3rem; align-items:center; }
.sluzba-radek--obracene{ direction:rtl; }
.sluzba-radek--obracene > *{ direction:ltr; }
.sluzba-radek__obrazek{ border-radius:var(--radius); width:100%; aspect-ratio:4/3; object-fit:cover; }

/* galerie */
.galerie{ display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; margin-top:2rem; }
.galerie__foto{ width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:var(--radius); }

/* placeholder (chybějící fotka) */
.placeholder{
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:.5em;
  background:repeating-linear-gradient(135deg, var(--zed) 0 14px, var(--zed-2) 14px 28px);
  border:1px dashed var(--popel-tmava);
  border-radius:var(--radius);
  color:var(--popel);
  font-size:.78rem; text-align:center; padding:1em;
  width:100%; aspect-ratio:4/3;
}
.placeholder__ikona{ width:28px; height:28px; fill:var(--popel-tmava); }

/* reference */
.mrizka-referenci{ display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:1.4rem; margin-top:2rem; }
.reference{ background:var(--zed); border:1px solid var(--linka); border-radius:var(--radius); padding:1.8em 1.6em; margin:0; }
.reference__terc{ font-size:1.3rem; }
.reference__text{ margin:.6em 0 1em; font-size:1rem; color:var(--krida); }
.reference__autor{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:.03em; font-size:.85rem; color:var(--mosaz); }
.reference__autor span{ color:var(--popel); text-transform:none; letter-spacing:0; font-family:var(--font-text); }

/* tým O nás */
.mrizka-tymu{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:1.6rem; margin-top:2rem; }
.osoba{ text-align:center; }
.osoba__foto-obal{ width:140px; margin:0 auto 1em; }
.osoba__foto{ width:140px; height:140px; border-radius:50%; object-fit:cover; border:2px solid var(--mosaz); }
.osoba__foto-obal .placeholder{ width:140px; height:140px; aspect-ratio:auto; border-radius:50%; padding:0; }
.osoba__foto-obal .placeholder__ikona{ width:22px; height:22px; }
.osoba__jmeno{ font-size:1.1rem; }
.osoba__pozice{ color:var(--mosaz); font-family:var(--font-cislo); font-size:.78rem; letter-spacing:.06em; text-transform:uppercase; margin:.3em 0 .6em; }
.osoba__popis{ color:var(--popel); font-size:.92rem; margin-bottom:.6em; }
.osoba__telefon{ color:var(--mosaz); font-family:var(--font-cislo); font-size:.85rem; }
.osoba__telefon:hover{ text-decoration:underline; }

/* ---------- menu / lupa ---------- */
.hlavicka-stranky{ padding-block:3.5rem 2.5rem; border-bottom:1px solid var(--linka); }
.lupa-menu{ display:grid; grid-template-columns:repeat(auto-fit,minmax(320px,1fr)); gap:2.4rem; margin-top:2rem; }
.lupa-menu__kategorie{ break-inside:avoid; }
.lupa-menu__nadpis-kat{ font-size:1rem; color:var(--mosaz); padding-bottom:.5em; border-bottom:2px solid var(--mosaz); margin-bottom:.7em; display:inline-block; }
.lupa-menu__radek{ display:flex; align-items:baseline; gap:.5em; padding:.45em 0; }
.lupa-menu__nazev{ flex:none; max-width:62%; }
.lupa-menu__popis{ display:block; color:var(--popel); font-size:.8rem; }
.lupa-menu__tecky{ flex:1; border-bottom:1px dotted var(--popel-tmava); margin-bottom:.35em; }
.lupa-menu__cena{ flex:none; font-family:var(--font-cislo); font-weight:700; color:var(--mosaz); font-size:1.02rem; }
.lupa-menu__poznamka{ margin-top:2rem; color:var(--popel); font-size:.85rem; }

/* ---------- aktuality ---------- */
.seznam-akci__radek{ display:flex; gap:1.4em; padding:1.3em 0; border-bottom:1px solid var(--linka); }
.seznam-akci__datum{
  flex:none; width:74px; text-align:center; background:var(--zed); border:1px solid var(--linka); border-radius:var(--radius);
  padding:.6em 0; font-family:var(--font-cislo);
}
.seznam-akci__den{ display:block; font-size:1.6rem; font-weight:700; color:var(--mosaz); line-height:1; }
.seznam-akci__mesic{ display:block; font-size:.68rem; text-transform:uppercase; letter-spacing:.06em; color:var(--popel); margin-top:.2em; }
.seznam-akci__nadpis{ font-size:1.15rem; margin-bottom:.3em; }
.seznam-akci__text{ color:var(--popel); font-size:.95rem; }

.galerie-letaku{ display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:1.4rem; margin-top:2rem; }
.galerie-letaku__polozka{ display:block; border:1px solid var(--linka); border-radius:var(--radius); overflow:hidden; background:var(--inkoust-2); }
.galerie-letaku__polozka img{ width:100%; aspect-ratio:3/4; object-fit:cover; transition:transform .25s ease; }
.galerie-letaku__polozka:hover img{ transform:scale(1.04); }
.galerie-letaku__popisek{ display:block; padding:.7em .8em; font-size:.85rem; color:var(--popel); }

/* ---------- kontakt ---------- */
.kontakt-mrizka{ display:grid; grid-template-columns:1fr 1fr; gap:3rem; }
.kontakt-seznam{ margin:1.2em 0 2em; display:flex; flex-direction:column; gap:.6em; }
.kontakt-seznam a:hover{ color:var(--mosaz); }
.tabulka-hodin{ width:100%; border-collapse:collapse; margin-top:1em; }
.tabulka-hodin th,.tabulka-hodin td{ text-align:left; padding:.5em .2em; border-bottom:1px solid var(--linka); font-weight:400; }
.tabulka-hodin td{ font-family:var(--font-cislo); text-align:right; }
.tabulka-hodin__dnes th, .tabulka-hodin__dnes td{ color:var(--mosaz); font-weight:700; }
.kontakt-poznamka{ margin-top:1em; color:var(--popel); font-size:.9rem; }

.formular{ display:flex; flex-direction:column; gap:1em; margin-top:1.2em; }
.formular__pole{ display:flex; flex-direction:column; gap:.4em; font-size:.85rem; color:var(--popel); }
.formular__pole input, .formular__pole textarea{
  font:inherit; background:var(--zed); border:1px solid var(--linka); border-radius:var(--radius);
  padding:.7em .8em; color:var(--krida);
}
.formular__pole input:focus, .formular__pole textarea:focus{ border-color:var(--mosaz); }
.formular__pole--skryte{ position:absolute; left:-9999px; }
.formular-info{ padding:.8em 1em; border-radius:var(--radius); margin-top:1em; font-size:.9rem; }
.formular-info--ok{ background:rgba(92,138,74,.18); border:1px solid var(--zelena); }
.formular-info--chyba{ background:rgba(184,57,43,.18); border:1px solid var(--terc); }

.mapa-obal{ border-radius:var(--radius); overflow:hidden; border:1px solid var(--linka); margin-top:1.5rem; filter:grayscale(.25) contrast(1.05); }

/* ---------- patička ---------- */
.paticka{ background:var(--inkoust-2); border-top:1px solid var(--linka); padding-block:3.5rem 0; }
.paticka__mrizka{ display:grid; grid-template-columns:1.3fr 1fr 1fr 1.2fr; gap:2.4rem; padding-bottom:3rem; }
.logo--paticka{ margin-bottom:.8em; }
.paticka__text{ color:var(--popel); font-size:.9rem; }
.paticka__nadpis{ font-size:.85rem; letter-spacing:.06em; color:var(--mosaz); margin-bottom:.9em; }
.paticka__nadpis--mensi{ margin-top:1.4em; }
.paticka__seznam{ display:flex; flex-direction:column; gap:.55em; }
.paticka__seznam a{ color:var(--popel); font-size:.9rem; }
.paticka__seznam a:hover{ color:var(--krida); }
.paticka__hodiny{ display:flex; flex-direction:column; gap:.45em; font-size:.88rem; }
.paticka__hodiny li{ display:flex; justify-content:space-between; color:var(--popel); }
.paticka__hodiny-cas{ font-family:var(--font-cislo); color:var(--krida); }
.paticka__spodek{ border-top:1px solid var(--linka); }
.paticka__spodek-obsah{ display:flex; justify-content:space-between; align-items:center; gap:1em; flex-wrap:wrap; padding-block:1.2em; font-size:.8rem; color:var(--popel-tmava); }
.paticka__spodek-odkazy{ display:flex; gap:1.4em; }
.paticka__admin{ color:var(--popel-tmava); }
.paticka__admin:hover{ color:var(--mosaz); }

/* ---------- právní text (ochrana osobních údajů) ---------- */
.pravni-text .nadpis-sekce{ margin-top:1.8em; }
.pravni-text .nadpis-sekce:first-of-type{ margin-top:0; }
.text-sekce{ margin-bottom:1em; }
.text-sekce--poznamka{ font-size:.88rem; font-style:italic; opacity:.8; margin-top:2em; }
.pravni-seznam{ color:var(--popel); max-width:62ch; margin:0 0 1.2em; padding-left:1.3em; }
.pravni-seznam li{ margin-bottom:.5em; line-height:1.5; }
.pravni-seznam strong{ color:var(--krida); }
.pravni-seznam--inline{ display:flex; gap:1.5em; flex-wrap:wrap; list-style:none; padding-left:0; }

/* ---------- mapa – čeká na souhlas s cookies ---------- */
.mapa-zastupny{
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1.2em;
  min-height:420px; padding:2.5em 1.5em; text-align:center;
  background:var(--zed-2); color:var(--popel);
}
.mapa-zastupny p{ max-width:48ch; margin:0; }

/* ---------- lišta se souhlasem s cookies ---------- */
.cookie-lista{
  position:fixed; left:0; right:0; bottom:0; z-index:300;
  background:var(--inkoust-2); border-top:1px solid var(--linka);
  padding-block:1em; box-shadow:0 -6px 24px rgba(0,0,0,.35);
}
.cookie-lista--skryta{ display:none; }
.cookie-lista__obsah{
  display:flex; align-items:center; justify-content:space-between; gap:1.5em; flex-wrap:wrap;
}
.cookie-lista__obsah p{ margin:0; font-size:.86rem; color:var(--popel); max-width:68ch; }
.cookie-lista__obsah a{ color:var(--mosaz); }
.cookie-lista__tlacitko{ flex-shrink:0; }

/* ================= responzivní úpravy ================= */
@media (max-width: 900px){
  .hero__obsah{ grid-template-columns:1fr; padding-block:3rem 2.5rem; }
  .sluzba-radek{ grid-template-columns:1fr; }
  .sluzba-radek--obracene{ direction:ltr; }
  .sluzba-radek__foto{ order:-1; }
  .galerie{ grid-template-columns:repeat(2,1fr); }
  .paticka__mrizka{ grid-template-columns:1fr 1fr; }
  .kontakt-mrizka{ grid-template-columns:1fr; }
}

@media (max-width: 720px){
  .hlavicka__pruh-obsah{ font-size:.74rem; justify-content:center; text-align:center; }
  .nav__prepinac{ display:flex; }
  .logo__obrazek{ height:64px; max-width:220px; }
  .nav{
    position:absolute; top:100%; left:0; right:0;
    background:var(--inkoust-2); border-bottom:1px solid var(--linka);
    flex-direction:column; padding:1em 24px; gap:0;
    display:none;
  }
  .nav.nav--otevrene{ display:flex; }
  .nav__odkaz{ padding-block:.7em; border-bottom:1px solid var(--linka); }
  .skore{ display:none; }
  .mrizka-karet{ grid-template-columns:1fr; }
  .galerie{ grid-template-columns:1fr 1fr; }
  .paticka__mrizka{ grid-template-columns:1fr; }
}
