/* Hernice — fantasy téma (dark default, optional light) */

:root, html[data-theme="dark"]{
  --bg:#0e150f; --bg2:#16221a; --panel:#1c2a20; --gold:#c9a04a; --gold2:#e6c478;
  --text:#e9e0c9; --muted:#9aa68f; --line:#3a4a3c; --accent:#7a3e2a;
  --hero-overlay-1: rgba(14,21,15,.78);
  --hero-overlay-2: rgba(14,21,15,.92);
  --top-bg: rgba(0,0,0,.35);
  --panel-grad: linear-gradient(180deg, var(--panel), transparent);
  --shadow: 0 4px 20px rgba(0,0,0,.4);
}

html[data-theme="light"]{
  --bg:#f5efe1; --bg2:#ebe2cc; --panel:#fff8e8; --gold:#9e7a2c; --gold2:#6b5018;
  --text:#26201a; --muted:#6e6555; --line:#d9c89a; --accent:#9a4a30;
  --hero-overlay-1: rgba(245,239,225,.55);
  --hero-overlay-2: rgba(245,239,225,.92);
  --top-bg: rgba(255,255,255,.78);
  --panel-grad: linear-gradient(180deg, var(--panel), transparent);
  --shadow: 0 4px 16px rgba(120,90,30,.15);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:
    radial-gradient(1200px 600px at 80% -200px,#2a3a2c 0%,transparent 60%),
    radial-gradient(900px 500px at -10% 110%,#2a1d18 0%,transparent 55%),
    var(--bg);
  color:var(--text);
  font-family:'EB Garamond', Georgia, serif;
  line-height:1.65;
  font-size:18px;
}
html[data-theme="light"] body{
  background:
    radial-gradient(1100px 600px at 80% -200px, #f8e9bd 0%, transparent 60%),
    radial-gradient(900px 500px at -10% 110%, #ead5b3 0%, transparent 55%),
    var(--bg);
}

h1,h2,h3{font-family:'Cinzel', serif; letter-spacing:1.5px; color:var(--gold2); font-weight:700}
h1{font-size:2.8rem; margin:0 0 12px}
h2{font-size:1.8rem; margin:0 0 20px}
h3{font-size:1.2rem; margin:0 0 10px}
a{color:var(--gold2)}
.wrap{max-width:1100px; margin:0 auto; padding:0 24px}
.muted{color:var(--muted)}

/* ------ NAVIGACE ------ */
.top{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 24px; border-bottom:1px solid var(--line);
  background:var(--top-bg); position:sticky; top:0; z-index:20;
  backdrop-filter:blur(8px);
}
.top .brand{display:flex; align-items:center; gap:14px; text-decoration:none}
.top .brand img{width:48px; height:48px; filter:invert(78%) sepia(43%) saturate(370%) hue-rotate(7deg) brightness(98%)}
html[data-theme="light"] .top .brand img{filter:none}
.top .brand b{font-family:'Cinzel',serif; font-size:1.3rem; letter-spacing:3px; color:var(--gold2)}
nav{display:flex; align-items:center; flex-wrap:wrap; gap:6px}
nav a{
  margin:0 6px; text-decoration:none; font-family:'Cinzel', serif;
  font-size:.85rem; letter-spacing:2px; color:var(--text); text-transform:uppercase;
}
nav a:hover{color:var(--gold2)}
.icon-btn{
  margin-left:10px; border:1px solid var(--gold); padding:5px 10px;
  background:transparent; color:var(--gold); cursor:pointer;
  font-family:'Cinzel', serif; letter-spacing:2px; font-size:.8rem;
  border-radius:2px; transition:.15s;
}
.icon-btn:hover{background:var(--gold); color:var(--bg)}

/* ------ HERO ------ */
.hero{
  padding:110px 24px 130px; text-align:center; position:relative;
  border-bottom:1px solid var(--line);
  background: linear-gradient(var(--hero-overlay-1), var(--hero-overlay-2)), url('../img/IMG_0539.jpg') center/cover;
}
.hero::before{
  content:""; position:absolute; inset:0;
  background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="100" height="100"><path d="M50 5L60 40H95L66 60L75 95L50 75L25 95L34 60L5 40H40Z" fill="none" stroke="%23c9a04a" stroke-opacity=".06" stroke-width="1"/></svg>');
  opacity:.5; pointer-events:none;
}
.hero-logo{height:auto; margin:0 auto 24px; display:block; position:relative; filter:invert(78%) sepia(43%) saturate(370%) hue-rotate(7deg) brightness(98%); cursor:pointer}
html[data-theme="light"] .hero-logo{filter:none}
.hero h1{font-size:3.8rem; line-height:1.1; text-shadow:0 2px 20px rgba(0,0,0,.6); position:relative}
.hero p{font-style:italic; color:var(--text); opacity:.92; max-width:640px; margin:8px auto 32px; font-size:1.25rem; position:relative; text-shadow:0 1px 8px rgba(0,0,0,.5)}
html[data-theme="light"] .hero p{text-shadow:none}
.hero .cta-row{display:flex; gap:14px; justify-content:center; flex-wrap:wrap; position:relative}
.hero .cta{
  display:inline-block; padding:14px 32px; border:1px solid var(--gold);
  color:var(--gold2); text-decoration:none; font-family:'Cinzel', serif;
  letter-spacing:3px; font-size:.9rem; background:rgba(201,160,74,.08);
  transition:.2s;
}
.hero .cta:hover{background:var(--gold); color:var(--bg)}
.hero .cta.secondary{background:transparent}

/* ------ SEKCE ------ */
section{padding:70px 0; border-bottom:1px solid var(--line)}
.section-title{display:flex; align-items:center; gap:18px; margin-bottom:32px}
.section-title::before,.section-title::after{content:""; flex:1; height:1px; background:linear-gradient(90deg, transparent, var(--gold), transparent)}
.section-title h2{margin:0}

/* ------ ROZVRH ------ */
.ev{
  display:grid; grid-template-columns:200px 1fr; gap:24px;
  padding:18px 22px; background:var(--panel-grad);
  border:1px solid var(--line); border-left:4px solid var(--gold);
  margin-bottom:12px;
}
.ev-day{font-family:'Cinzel', serif; color:var(--gold2); font-size:1.05rem; letter-spacing:2px; text-transform:uppercase}
.ev-time{font-size:.85rem; color:var(--muted); letter-spacing:1px}
.ev-title{font-size:1.25rem; color:var(--text); font-weight:600; margin-bottom:4px}
.ev-meta{color:var(--muted); font-size:.95rem; font-style:italic; margin-bottom:6px}
.ev-note{color:var(--text); font-size:.95rem; opacity:.9}
.ev-link{display:inline-block; margin-top:10px; font-family:'Cinzel', serif; font-size:.85rem; letter-spacing:2px; color:var(--gold2); text-decoration:none; border-bottom:1px solid var(--gold)}
.ev-link:hover{color:var(--gold)}
.ev.occasion{border-left-color:var(--accent); background:linear-gradient(180deg, rgba(122,62,42,.18), transparent)}

.exceptions{margin-top:28px; padding:20px 24px; background:rgba(122,62,42,.15); border-left:4px solid var(--accent)}
.exceptions h3{margin:0 0 12px; color:#e0a48a; font-family:'Cinzel', serif; letter-spacing:2px}
.exceptions ul{margin:0; padding-left:20px}
.exceptions li{margin-bottom:8px}

.section-sub{margin:40px 0 18px; color:var(--gold2); font-family:'Cinzel', serif; letter-spacing:2px}

/* ------ GALERIE ------ */
.gallery{display:grid; grid-template-columns:repeat(auto-fill, minmax(220px, 1fr)); gap:12px}
.gallery-item{
  display:block; position:relative; overflow:hidden;
  border:2px solid var(--line); transition:.3s; aspect-ratio:1;
}
.gallery-item::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(0,0,0,.6));
  pointer-events:none;
}
html[data-theme="light"] .gallery-item::after{background:linear-gradient(180deg, transparent 50%, rgba(120,90,30,.25))}
.gallery-item img{width:100%; height:100%; object-fit:cover; display:block; transition:.6s; filter:saturate(1.05)}
.gallery-item:hover{border-color:var(--gold)}
.gallery-item:hover img{transform:scale(1.05)}

/* ------ ČLENSTVÍ / CENÍK ------ */
.pricing{display:grid; gap:10px; max-width:720px; margin:0 auto}
.price-row{
  display:flex; justify-content:space-between; align-items:baseline; gap:24px;
  padding:14px 20px; border:1px solid var(--line); background:var(--panel-grad);
  border-left:4px solid var(--gold);
}
.price-label{font-family:'Cinzel', serif; letter-spacing:1.5px; font-size:1rem; color:var(--text)}
.price-value{color:var(--gold2); font-style:italic; font-size:1.05rem}
.pricing-note{margin-top:18px; text-align:center; color:var(--muted); font-style:italic}

/* ------ FAQ ------ */
.faq-list{max-width:820px; margin:0 auto; display:grid; gap:10px}
.faq-item{
  border:1px solid var(--line); background:var(--panel-grad);
  border-left:4px solid var(--gold); padding:0;
}
.faq-item summary{
  cursor:pointer; padding:16px 22px; font-family:'Cinzel', serif;
  letter-spacing:1.5px; font-size:1rem; color:var(--gold2); list-style:none;
  display:flex; justify-content:space-between; align-items:center;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+"; color:var(--gold); font-size:1.4rem; transition:.2s}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{margin:0; padding:0 22px 18px; color:var(--text)}

/* ------ KONTAKT + MAPA ------ */
.contact-grid{display:grid; grid-template-columns:repeat(auto-fit, minmax(220px, 1fr)); gap:18px; margin-bottom:32px}
.contact-card{padding:24px; background:var(--panel); border:1px solid var(--line); text-align:center}
.contact-card .label{font-family:'Cinzel', serif; color:var(--gold); font-size:.8rem; letter-spacing:2px; margin-bottom:10px; text-transform:uppercase}
.contact-card a{color:var(--gold2); text-decoration:none; border-bottom:1px dotted var(--gold)}
.contact-card a:hover{color:var(--gold)}

.map-wrap{border:2px solid var(--line); overflow:hidden; position:relative; aspect-ratio:16/7; background:var(--panel)}
.map-wrap iframe{position:absolute; inset:0; width:100%; height:100%; border:0; filter:grayscale(.3) brightness(.85)}
html[data-theme="light"] .map-wrap iframe{filter:none}

/* ------ NEWS (skrytá pokud prázdná) ------ */
.news-grid{display:grid; grid-template-columns:repeat(auto-fit, minmax(280px, 1fr)); gap:20px}
.news-item{padding:24px; background:var(--panel); border:1px solid var(--line); position:relative}
.news-item::before{content:"❦"; position:absolute; top:10px; right:14px; color:var(--gold); opacity:.5; font-size:1.4rem}
.news-item time{color:var(--gold); font-family:'Cinzel', serif; font-size:.85rem; letter-spacing:2px}
.news-item h3{margin:8px 0 10px; font-size:1.2rem}

/* ------ FOOTER ------ */
footer{padding:40px 24px; text-align:center; color:var(--muted); font-style:italic}
footer .tagline{margin-top:6px; font-size:.9rem; opacity:.8}

/* ------ COOKIE BANNER ------ */
.cookie-banner{
  position:fixed; bottom:16px; left:16px; right:16px; max-width:560px; margin:0 auto;
  background:var(--panel); color:var(--text); border:1px solid var(--gold);
  padding:18px 22px; box-shadow:var(--shadow); z-index:100;
  font-size:.95rem; line-height:1.5;
  display:none;
}
.cookie-banner.show{display:block}
.cookie-banner h4{margin:0 0 6px; font-family:'Cinzel', serif; color:var(--gold2); font-size:1rem; letter-spacing:1.5px}
.cookie-banner p{margin:0 0 12px}
.cookie-banner .btns{display:flex; gap:8px; flex-wrap:wrap}
.cookie-banner button{
  flex:1; min-width:120px; padding:9px 14px; cursor:pointer;
  font-family:'Cinzel', serif; letter-spacing:1.5px; font-size:.8rem;
  border-radius:2px; border:1px solid var(--gold); background:transparent; color:var(--gold);
  transition:.15s;
}
.cookie-banner button.primary{background:var(--gold); color:var(--bg)}
.cookie-banner button:hover{background:var(--gold2); color:var(--bg); border-color:var(--gold2)}

/* ------ MOBIL ------ */
@media (max-width:780px){
  .hero{padding:70px 20px 90px}
  .hero h1{font-size:2.4rem}
  .hero-logo{max-width:100%}
  h1{font-size:2rem}
  .ev{grid-template-columns:1fr; gap:6px}
  .ev-day{font-size:1rem}
  nav{gap:2px}
  nav a{margin:0 4px; font-size:.75rem}
  .top{padding:12px 16px}
  .top .brand img{width:38px; height:38px}
  .top .brand b{font-size:1.05rem; letter-spacing:2px}
  .price-row{flex-direction:column; gap:4px; align-items:flex-start}
  section{padding:50px 0}
}

@media (max-width:520px){
  nav .nav-link{display:none}
  .icon-btn{padding:4px 8px; font-size:.7rem; margin-left:4px}
}

/* Tisk */
@media print{
  .top, .hero::before, .cookie-banner, .map-wrap, footer{display:none}
  body{background:#fff; color:#000}
  h1,h2,h3{color:#000}
}
