/* =========================
   ZÁKLAD
========================= */
:root{
  --brown:#5c3b2e;
  --cream:#f5efe9;
  --accent:#b47d56;
  --ink:#2b1e19;
}

*{ box-sizing:border-box }
body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--cream);
  color:var(--ink);
}
.wrap{ max-width:1100px; margin:0 auto; padding:16px }

/* =========================
   HEADER
========================= */
.site-header{
  position:sticky; top:0; z-index:100;
  background:var(--brown);
  color:#fff;
}
.site-header a{ color:#fff; text-decoration:none }
.header-row{ display:flex; align-items:center; justify-content:space-between; gap:12px }

/* Logo */
.brand{ display:flex; align-items:center; gap:10px; text-decoration:none }
.brand-text{ font-weight:700; letter-spacing:.2px; color:#fff }

/* Rozumná veľkosť loga (už žiadne “obrovské”) */
.site-header .brand img{
  height:64px; width:auto; display:block;
}
@media (min-width:901px){
  .site-header .brand img{ height:90px }
}

/* Burger */
.burger{
  width:42px; height:36px; border:0; background:transparent;
  display:flex; flex-direction:column; justify-content:center; gap:5px;
  cursor:pointer;
}
.burger .b-line{
  height:2px; background:#fff; border-radius:2px;
  transition:transform .25s ease, opacity .2s ease;
}
.burger.is-open .b-line:nth-child(1){ transform:translateY(7px) rotate(45deg) }
.burger.is-open .b-line:nth-child(2){ opacity:0 }
.burger.is-open .b-line:nth-child(3){ transform:translateY(-7px) rotate(-45deg) }

/* =========================
   NAVIGÁCIA – spoločné
========================= */
.nav{ display:flex; gap:8px }
.nav a{ padding:9px 12px; border-radius:10px }
.nav a:hover{ background:rgba(255,255,255,.12) }
.nav a.active{ background:rgba(255,255,255,.18) }

/* =========================
   MOBIL: OFF-CANVAS MENU ZĽAVA
========================= */
@media (max-width:900px){
  /* panel = #mainmenu */
  .nav-drawer{
    position:fixed; top:0; left:0; bottom:0;
    width:min(82vw,360px);
    padding:88px 16px 16px;     /* priestor pod hlavičkou */
    display:flex; flex-direction:column; gap:8px;

    background:var(--brown);
    transform:translateX(-100%);
    transition:transform .25s ease;
    z-index:1000;
    overflow-y:auto;
  }
  .nav-drawer.is-open{ transform:translateX(0) }

  .nav-drawer .nav-btn{
    display:block; color:#fff; text-decoration:none;
    padding:12px 12px; border-radius:10px;
  }
  .nav-drawer .nav-btn:hover{ background:rgba(255,255,255,.10) }
  .nav-drawer .nav-btn.active{ background:#fff; color:var(--brown) }

  /* backdrop */
  .nav-backdrop{
    position:fixed; inset:0;
    background:rgba(0,0,0,.45);
    opacity:0; pointer-events:none;
    transition:opacity .2s ease;
    z-index:999;
  }
  .nav-backdrop.show{ opacity:1; pointer-events:auto }

  /* scroll lock pri otvorenom menu */
  body.nav-open{ overflow:hidden }

  /* rozloženie hlavičky na mobile */
  .header-row{ flex-wrap:nowrap }
  .brand{ flex:0 1 auto }
  .burger{ flex:0 0 auto; margin-left:auto }
}

/* =========================
   DESKTOP: klasické riadkové menu
========================= */
@media (min-width:901px){
  .burger{ display:none }
  .nav-drawer{
    position:static; transform:none !important;
    display:flex; align-items:center; gap:10px;
    padding:0; width:auto; height:auto;
    background:transparent;
  }
  .nav-drawer .nav-btn{
    display:inline-block; color:#fff;
  }
}

/* =========================
   FOOTER (jednoducho)
========================= */
.site-footer{
  background:F3E8D0; color:#3e281f; margin-top:40px;
  text-align:center; padding:20px 12px;
}
.site-footer a{ color:#3e281f; text-decoration:none }
.site-footer a:hover{ text-decoration:underline }

/* =========================
   (VOLITEĽNÉ) KARTY MENU – stručné
========================= */
.menu-card,.menu-daycard{
  background:#fff; border-radius:14px;
  box-shadow:0 8px 24px rgba(0,0,0,.08);
  padding:16px; margin:14px 0;
}
.day-title{ margin:0 0 8px; color:var(--brown) }
.menu-list{ display:flex; flex-direction:column; gap:8px }
.menu-list .row{
  display:flex; justify-content:space-between; gap:16px;
  border-top:1px dashed #eee; padding:10px 0;
}
.menu-list .row:first-child{ border-top:0 }
.row-price{
  white-space:nowrap; font-weight:700; color:var(--accent);
  padding:6px 10px; border-radius:999px; background:rgba(180,125,86,.10);
}

/* Mobilnejšie karty */
@media (max-width:768px){
  .menu-spinner{ display:flex; flex-direction:column; gap:18px; max-height:80vh; overflow-y:auto; scroll-snap-type:y mandatory }
  .menu-spinner .menu-daycard{ scroll-snap-align:start; padding:28px 20px; min-height:220px }
  /* ===== Off-canvas mobilný drawer POD headerom ===== */
@media (max-width: 900px){
  /* header musí byť navrchu */
  .site-header{ position: sticky; top: 0; z-index: 1000; }

  /* panel = #mainmenu */
  .nav-drawer{
    position: fixed;
    left: 0;
    top: var(--header-h, 72px);                 /* začne až pod headerom */
    height: calc(100vh - var(--header-h, 72px));/* nezasiahne do headeru */
    width: min(72vw, 320px);                    /* rozumná šírka panelu */
    padding: 14px 12px;
    display: flex !important;
    flex-direction: column;
    gap: 8px;

    background: rgba(92,59,46,.94);             /* var(--brown) s priehľadnosťou */
    backdrop-filter: saturate(115%) blur(6px);
    border-right: 1px solid rgba(255,255,255,.12);
    box-shadow: 8px 0 24px rgba(0,0,0,.28);

    transform: translateX(-100%);               /* skrytý mimo plochy */
    transition: transform .28s ease;
    z-index: 900;                                /* pod headerom */
    overflow-y: auto;

    /* zruš staré “max-height” a pod. */
    max-height: none !important;
    border-top: 0 !important;
  }
  .nav-drawer.is-open{ transform: translateX(0); }

  .nav-drawer .nav-btn{
    display:block;
    padding:12px 12px;
    border-radius:12px;
    color:#fff;
    text-decoration:none;
    background: rgba(255,255,255,.10);
    border: 1px solid rgba(255,255,255,.16);
    font-weight:600;
  }
  .nav-drawer .nav-btn:hover{ background: rgba(255,255,255,.18); }
  .nav-drawer .nav-btn.active{ background:#fff; color: var(--brown); }

  /* BACKDROP – tiež až pod headerom */
  .nav-backdrop{
    position: fixed;
    left: 0; right: 0;
    top: var(--header-h, 72px);
    height: calc(100vh - var(--header-h, 72px));
    background: rgba(0,0,0,.45);
    backdrop-filter: blur(2px);
    opacity: 0;
    pointer-events: none;
    transition: opacity .25s ease;
    z-index: 890;                                /* pod headerom, pod panelom */
  }
  .nav-backdrop.show{
    opacity: 1;
    pointer-events: auto;
  }

  /* keď je menu otvorené, zamknúť scroll */
  body.nav-open{ overflow: hidden; }
}

/* Desktop reset — nič sa neprekrýva */
@media (min-width: 901px){
  .nav-drawer{
    position: static !important;
    transform: none !important;
    height: auto; width: auto;
    padding: 0;
    display:flex !important; align-items:center; gap:10px;
    background: transparent; border:0; box-shadow:none;
    z-index: auto;
  }
  .nav-backdrop{ display:none !important; }
}

/* Rozumné logo (aby nebolo obrovské) */
.site-header .brand img{
  height: 64px;
  width: auto;
  display: block;
}
@media (min-width:901px){
  .site-header .brand img{ height: 90px; }
}
}
background: rgba(20,20,20,.0); /* var(--brown) s priehľadnosťou */
.board {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  background: #111;
  border: 1px solid #233148;
  min-height: 320px;
}
.board__bg {
  position:absolute; inset:0;
  background-size: cover; background-position:center;
  filter: brightness(.7);
}
.board__scrim {
  position:absolute; inset:0;
  background: radial-gradient(ellipse at 30% 0%, rgba(0,0,0,.35), transparent 60%),
              linear-gradient(180deg, rgba(0,0,0,.4), rgba(0,0,0,.6));
  backdrop-filter: blur(1px);
}
.board__panel {
  position: relative;
  z-index: 2;
  margin: 18px;
  padding: 18px;
  border-radius: 14px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 10px 30px rgba(0,0,0,.35) inset, 0 2px 8px rgba(0,0,0,.25);
}
.board__title {
  margin: 0 0 10px 0;
  font-size: 18px;
  letter-spacing: .02em;
}
.board__list {
  margin: 0; padding: 0; list-style: none;
  display: grid; grid-template-columns: 1fr auto; row-gap: 8px; column-gap: 14px;
}
.board__cat {
  display:inline-block; font-size: 12px; opacity:.75; margin-right: 8px;
}
.board__logo {
  position:absolute; right:14px; top:14px; width:54px; height:54px; border-radius:10px; border:1px solid rgba(255,255,255,.2);
  background:#fff; object-fit:cover;
}
.board__imgmenu {
  display:block; max-width:100%; border-radius:10px; border:1px solid #2b3544; margin-top:10px;
}
@media (max-width:900px){
  .board__panel{ margin: 12px; padding: 14px; }
  .board__title{ font-size: 16px; }
}
.btn-outline{
  display:inline-block; padding:8px 12px; border:1px solid #444; border-radius:10px;
  background:#fff; color:#222; text-decoration:none; cursor:pointer;
}
.btn-outline:hover{ background:#f6f6f6; }
/* Modal must be hidden by default */
#catalogModal[hidden]{
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
}
/* Header nech sa len prilepí navrch – pôvodný vzhľad nemeníme */
.site-header {
  position: fixed;     /* zafixuje hore */
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
}

/* Neviditeľný vyrovnávací blok pod headerom */
.header-spacer {
  height: var(--hdr-h, 0px);
}

/* Hero/banner už neposúvaj (spacer sa postará) */
.hero-section {
  margin-top: 0 !important;
}

/* VOLITEĽNÉ: ak chceš sklený efekt, len pridaj triedu .header--glass na .site-header */
.site-header.header--glass {
  background: rgba(92,59,46,0.72);    /* uprav podľa tvojej farby */
  backdrop-filter: blur(6px);
}
:root{
  --hdr-h: 72px;      /* vypĺňa tvoj JS, nechaj ako máš */
  --extra-top: 24px;  /* ⬅ sem si daj, o koľko chceš posunúť stránku dole */
}
.header-spacer{
  height: calc(var(--hdr-h, 200px) + var(--extra-top, 0px));
}
/* ===== HEADER (nový dizajn podľa indexu) ===== */
.site-header {
  background: linear-gradient(to top, #F3E8D0,#E5D2AA);
  color: #3e281f;
  box-shadow: 0 2px 6px rgba(0,0,0,0.15);
  border-bottom: 1px solid rgba(255,255,255,0.1);
}

/* Texty, odkazy a logotyp */
.site-header a,
.site-header .brand-text,
.site-header nav a {
  color: #3E281F;
  text-decoration: none;
  font-weight: 600;
}

/* Hover efekt */
.site-header a:hover {
  color: #8C4B24; /* keramicko-hnedý akcent */
}

/* Ak máš aj tlačidlá v headeri */
.site-header .btn {
  background: #3E281F;
  color: #F3E8D0;
  border: 1px solid #3E281F;
}
.site-header .btn:hover {
  background: #8C4B24;
  border-color: #8C4B24;
}
/* =========================
   Footer (separate)
========================= */
.site-footer{
  /* papier + jemná „drevo“ textúra, polopriehľadná */
  background:
    linear-gradient(to top, rgba(229,210,170,0.88), rgba(243,232,208,0.88)),
    url('/assets/img_old_sk/mob_wood.png') repeat;
  background-size: cover;
  color: #3E281F;
  padding: 30px 0;
  border-top: 1px solid rgba(255,255,255,0.3);
  box-shadow: 0 -4px 20px rgba(0,0,0,.06);
}

.site-footer .wrap{
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px;
  text-align: center;
}

.footer-brand{
  margin-bottom: 8px;
}
.footer-brand .brand-title{
  font-weight: 800;
  letter-spacing: .2px;
}
.footer-brand .brand-copy{
  display: block;
  color: #6b553f;
  margin-top: 4px;
}

.footer-nav{
  display: flex;
  justify-content: center;
  gap: 18px;
  flex-wrap: wrap;
  margin: 12px 0 6px;
}
.footer-nav .contact-link{
  color: #3E281F;
  text-decoration: none;
  font-weight: 600;
  padding: 4px 6px;
  border-radius: 6px;
  transition: background-color .2s ease, color .2s ease;
}
.footer-nav .contact-link:hover{
  background: rgba(62,40,31,0.08);
  color: #2b1e19;
}

.footer-social{
  display: flex;
  justify-content: center;
  gap: 14px;
  margin-top: 10px;
}
.footer-social .social-btn{
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  border-radius: 10px;
  background: rgba(255,255,255,0.7);
  border: 1px solid rgba(0,0,0,0.06);
  box-shadow: 0 2px 10px rgba(0,0,0,.06);
  transition: transform .15s ease, background .2s ease;
}
.footer-social .social-btn:hover{
  transform: translateY(-2px);
  background: rgba(255,255,255,0.9);
}
.footer-social svg{
  width: 22px;
  height: 22px;
  display: block;
  fill: currentColor;
}

/* Farby ikon */
.footer-social .ig{ color:#E1306C; }
.footer-social .fb{ color:#1877F2; }
.footer-social .yt{ color:#FF0000; }

/* Mobile */
@media (max-width: 640px){
  .site-footer{ padding: 22px 0; }
  .footer-nav{ gap: 12px; }
}
/* =========================
   HEADER – Matný (blur)
========================= */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(255, 255, 255, 0.25);      /* svetlý polopriehľadný základ */
  backdrop-filter: blur(12px) saturate(180%); /* kľúčový efekt – rozmazanie a sýtosť */
  -webkit-backdrop-filter: blur(12px) saturate(180%);
  color: #3e281f;
  border-bottom: 1px solid rgba(255, 255, 255, 0.3);
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
  transition: all 0.3s ease;
}

/* Jemné stmavenie pri scrollnutí (voliteľné) */
.site-header.scrolled {
  background: rgba(243, 232, 208, 0.55);
  backdrop-filter: blur(18px) saturate(180%);
  -webkit-backdrop-filter: blur(18px) saturate(180%);
}

/* Obsah headeru */
.site-header .wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 18px;
  max-width: 1100px;
  margin: 0 auto;
}
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(243, 232, 208, 0.4);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  color: #3e281f;
}
/* Linky a text */
.site-header a {
  color: #3e281f;
  font-weight: 600;
  text-decoration: none;
  transition: color 0.2s ease;
}
.site-header a:hover {
  color: #6c4029;
}
.hero {
  position: relative;
  margin-top: -60px;   /* posunie celú sekciu hore */
  z-index: 0;          /* banner ostáva pod headerom */
}

.hero img,
.hero-img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;   /* ak chceš, aby sa pekne natiahol */
}
/* --- FIX: realistická výška hlavičky --- */
:root{
  --hdr-h: 90px;     /* reálna výška headera */
  --extra-top: 0px;  /* žiadne extra odsadenie */
}

/* spacer nech tlačí obsah len o výšku headera */
.header-spacer{
  height: var(--hdr-h);
}

/* --- FIX: banner posuň HORE (prekry pod matným headerom) --- */
.hero,
.hero-section {
  margin-top: calc(-1 * var(--hdr-h)); /* napr. -90px */
  position: relative;
  z-index: 0; /* pod headerom */
}

.site-header{
  position: sticky;
  top: 100;
  z-index: 1000;               /* nad bannerom */
  background: rgba(243,232,208,0.40);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  color: #3e281f;
  border-bottom: 1px solid rgba(255,255,255,0.3);
}

/* pre istotu: žiadne ďalšie pravidlo nesmie .hero zasa posunúť dole */
.hero img,
.hero-img{
  display:block;
  width:100%;
  height:auto;
  object-fit:cover;
}
/* O koľko nech banner vlezie pod header (desktop/mobil môžeš doladiť) */
:root{
  --hdr-h: 90px;           /* reálna výška headera – už máš z JS */
  --hero-overlap: 32px;    /* + zväčši na 48/64 ak chceš viac „hore“ */
}

/* Hero posuň hore (negatívne) o overlap… */
.hero-section{ 
  margin-top: calc(-1 * var(--hero-overlap));
  position: relative;
  z-index: 0;
}

/* …a spacer zmenši o rovnakú hodnotu, aby sa zvyšok stránky nepohádal s headerom */
.header-spacer{
  height: calc(var(--hdr-h) - var(--hero-overlap));
  /* poistka, nech to nikdy nejde do mínusu */
  height: max(0px, calc(var(--hdr-h) - var(--hero-overlap)));
}

/* Ak chceš bannerový výrez ešte vyššie v rámci samotného obrázka */
:root{ --banner-shift: -20px; }        /* - = posun HORE v objekte */
@media (max-width:50px){
  :root{ --hero-overlap: 20px; --banner-shift: -12px; }
}
:root{
  --hero-overlap: 104px;   /* zvýš na 48/64 podľa oka */
  --banner-shift: -140px;  /* voliteľné: posun výrezu obrázka smerom hore */
}
/* Inverzia farieb v hlavnej navigácii (iba desktop) */
@media (min-width: 901px){
  /* základný stav – hnedý text, bez pozadia */
  .site-header .nav .nav-btn{
    color: var(--brown, #5c3b2e) !important;
    background: transparent !important;
    transition: color .15s ease, background .15s ease, border-color .15s ease;
  }

  /* hover + fokus – biely text na hnedom pozadí */
  .site-header .nav .nav-btn:hover,
  .site-header .nav .nav-btn:focus-visible{
    color: #fff !important;
    background: var(--brown, #5c3b2e) !important;
    border-color: var(--brown, #5c3b2e) !important;
    border-radius: 6px;
    outline: none;
  }

  /* aktívna stránka – nech vyzerá rovnako ako hover (jasný stav) */
  .site-header .nav .nav-btn.active,
  .site-header .nav .nav-btn[aria-current="page"]{
    color: #fff !important;
    background: var(--brown, #5c3b2e) !important;
    border-color: var(--brown, #5c3b2e) !important;
    border-radius: 6px;
  }

  /* CTA tlačidlo – okraj hnedý v základe, invert pri hoveri */
  .site-header .nav .nav-cta{
    border: 1px solid var(--brown, #5c3b2e) !important;
  }
  .site-header .nav .nav-cta:hover,
  .site-header .nav .nav-cta:focus-visible{
    border-color: var(--brown, #5c3b2e) !important;
  }
}

/* (Voliteľné) Zníž šancu, že ťa prebijú iné štýly z draweru */
@media (min-width: 901px){
  .site-header .nav.nav-drawer{ background: transparent !important; }
}
/* === Úprava tlačidla "Kontakt" (nav-cta) === */
@media (min-width: 901px){
  /* základ – žiadna linka, rovnaký štýl ako ostatné */
  .site-header .nav .nav-cta{
    border: none !important;
    background: transparent !important;
    color: var(--brown, #5c3b2e) !important;
  }

  /* hover/active – biely text, hnedé pozadie */
  .site-header .nav .nav-cta:hover,
  .site-header .nav .nav-cta:focus-visible,
  .site-header .nav .nav-cta.active,
  .site-header .nav .nav-cta[aria-current="page"]{
    background: var(--brown, #5c3b2e) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 6px;
  }
}
/* === Len text reaguje, nie logo === */
@media (min-width: 901px){
  /* vypneme hover efekt na celom odkaze */
  .site-header .brand:hover {
    background: none !important;
  }

  /* samotný text spraví efekt */
  .site-header .brand-text {
    color: var(--brown, #5c3b2e) !important;
    font-weight: 900;
    padding: 4px 8px;
    border-radius: 6px;
    transition: color .15s ease, background .15s ease;
  }
  .site-header .brand-text:hover,
  .site-header .brand-text:focus-visible {
    color: #fff !important;
    background: var(--brown, #5c3b2e) !important;
  }

  /* logo nech ostane neutrálne */
  .site-header .brand img {
    filter: none !important;
    transition: none;
  }
}
.site-header .brand-text {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 42px;              /* prispôsob výške tvojich nav-btn */
    line-height: 1;
    padding: 0 10px;           /* nech má rovnaké bočné odsadenie */
  }
