:root{
  --green:#0f2a22;
  --green-2:#12352c;
  --gold:#c8a75a;
  --gold-2:#e3c980;
  --cream:#f7f3ea;
  --text:#eae7df;
  --muted:#c9c4b6;
  --shadow:rgba(0,0,0,.35);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji",sans-serif;
  color:var(--text);
  background:linear-gradient(180deg,#0b201a,#0f2a22);
  line-height:1.6;
}

img{max-width:100%;display:block}

.container{
  width:min(1150px,92%);
  margin-inline:auto;
}

.display{
  font-family:'Playfair Display',serif;
  font-weight:700;
  font-size:clamp(2rem,4vw,4rem);
  line-height:1.1;
}

h1,h2,h3,h4{
  font-family:'Playfair Display',serif;
  margin:0 0 .6rem 0;
}

h2{font-size:clamp(1.6rem,2.8vw,2.4rem)}
h3{font-size:1.35rem}
h4{font-size:1.1rem; letter-spacing:.5px}

.lead{font-size:1.125rem; color:var(--muted)}
.sub{color:var(--muted); max-width:62ch}
.small{font-size:.875rem;color:var(--muted)}

.accent{color:var(--gold)}

.section{padding:72px 0}
.section--tint{background:linear-gradient(180deg,var(--green-2),var(--green))}
.section--goldedge{
  position:relative;
  background:radial-gradient(80% 80% at 50% 20%,rgba(200,167,90,0.08),transparent 60%);
}
.section--goldedge::before{
  content:'';
  position:absolute; inset:0;
  border:1px solid rgba(232,201,121,.25);
  pointer-events:none;
}

.site-header{
  position:sticky; top:0; z-index:10;
  background:rgba(15,42,34,.75);
  backdrop-filter: blur(6px);
  border-bottom:1px solid rgba(232,201,121,.18);
}
.site-header .container{
  display:flex; align-items:center; justify-content:space-between; padding:12px 0;
}
.logo img{height:44px; width:auto; object-fit:contain; filter:drop-shadow(0 0 12px rgba(0,0,0,0.2))}
.nav a{
  color:var(--text); text-decoration:none; margin:0 14px; font-weight:500;
}
.nav .btn{margin-left:8px}
.nav-toggle{display:none; background:none; border:0; cursor:pointer}
.nav-toggle span{display:block;width:26px;height:2px;background:var(--text);margin:6px 0}

.hero{
  position:relative; min-height:70vh; display:flex; align-items:center;
}
.hero__bg{
  position:absolute; inset:0; background-size:cover; background-position:center;
  filter:brightness(.55) saturate(.9);
}
.hero__inner{ position:relative; padding:96px 0 }
.cta{margin-top:24px; display:flex; gap:12px; flex-wrap:wrap}
.btn{
  display:inline-block; padding:12px 20px; border-radius:999px;
  text-decoration:none; border:1px solid var(--gold); color:var(--gold);
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
  font-weight:600; letter-spacing:.3px;
}
.btn:hover{ transform:translateY(-2px); box-shadow:0 6px 20px var(--shadow) }
.btn--gold{ background:linear-gradient(135deg,var(--gold),var(--gold-2)); color:#12221b; border:0 }
.btn--outline{ background:transparent }

.grid2{ display:grid; grid-template-columns:1.2fr 1fr; gap:36px; align-items:center }
.grid3{ display:grid; grid-template-columns: repeat(3,1fr); gap:26px }
.center{ text-align:center }

.photo-frame{
  border:1px solid rgba(232,201,121,.35); padding:8px; border-radius:14px; background:rgba(0,0,0,.15);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.25), 0 20px 60px var(--shadow);
}

.ticks{list-style:none; padding:0; margin:18px 0 0 0}
.ticks li{
  padding-left:28px; position:relative; margin:8px 0; color:var(--text)
}
.ticks li::before{
  content:'✓'; position:absolute; left:0; color:var(--gold)
}

.cards{ display:grid; grid-template-columns: repeat(3, 1fr); gap:22px; margin-top:24px }
.card{
  background:rgba(18,53,44,.6); border:1px solid rgba(232,201,121,.18); border-radius:16px; overflow:hidden;
  box-shadow:0 20px 60px var(--shadow);
}
.card__media{ height:200px; background-size:cover; background-position:center }
.card__body{ padding:16px }
.pill{ display:inline-block; border:1px solid rgba(232,201,121,.35); color:var(--gold); border-radius:999px; padding:4px 10px; font-size:.8rem }

.note{ margin-top:18px; color:var(--muted) }

.badges{ display:flex; flex-wrap:wrap; gap:10px; margin-top:8px }
.badge{ border:1px dashed rgba(232,201,121,.35); color:var(--gold); padding:6px 10px; border-radius:999px; font-size:.85rem }

.gallery{
  display:grid; grid-template-columns: repeat(4, 1fr); gap:10px;
}
.gallery img{
  aspect-ratio: 4/3; object-fit:cover; width:100%;
  border-radius:12px; border:1px solid rgba(232,201,121,.25)
}

.packages{
  display:grid; grid-template-columns: repeat(3,1fr); gap:18px; margin-top:18px
}
.packages article{
  padding:18px; border:1px solid rgba(232,201,121,.25); border-radius:16px; background:rgba(18,53,44,.45)
}
.packages h4{ margin-bottom:8px }
.packages h4 span{ color:var(--gold) }
.packages ul{ padding-left:18px; margin:0 }
.packages li{ margin:6px 0 }

.contact-cards{
  display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:8px;
}
.ccard{
  border:1px solid rgba(232,201,121,.25); border-radius:12px; padding:14px; background:rgba(18,53,44,.45)
}
.ccard a{ color:var(--text); text-decoration:none }

.form{
  display:grid; gap:12px; border:1px solid rgba(232,201,121,.25); padding:20px; border-radius:16px; background:rgba(18,53,44,.45)
}
.form label{ display:grid; gap:6px; font-weight:500 }
.form input,.form textarea{
  background:rgba(255,255,255,.04); border:1px solid rgba(232,201,121,.18); color:var(--text); border-radius:10px; padding:10px 12px;
}
.form input:focus,.form textarea:focus{ outline:1px solid var(--gold) }
.hidden{ display:none }

.site-footer{
  border-top:1px solid rgba(232,201,121,.18); padding:28px 0; background:rgba(10,24,18,.85)
}
.footer-grid{ display:grid; grid-template-columns:1fr 1fr 1fr; align-items:center; gap:16px }
.footer-nav a{ color:var(--muted); text-decoration:none; margin-right:14px }
.footer-logo{ height:36px; width:auto; opacity:.9 }
.social a{ color:var(--gold); text-decoration:none }

.lightbox {
  display:none;
  position:fixed;
  z-index:1000;
  left:0; top:0; width:100%; height:100%;
  background:rgba(0,0,0,0.85);
  justify-content:center;
  align-items:center;
}
.lightbox-content {
  max-width:90%;
  max-height:90%;
  border:4px solid var(--gold);
  border-radius:8px;
}
.lightbox-close {
  position:absolute;
  top:20px; right:30px;
  font-size:40px;
  font-weight:bold;
  color:var(--gold);
  cursor:pointer;
}

/* -------------------- STÁLÉ MENU (platí pro desktop i mobil) -------------------- */
.menu-block{ margin-bottom:32px }
.menu-block h3{
  color:var(--gold);
  margin-bottom:12px;
  border-bottom:1px solid rgba(232,201,121,.25);
  padding-bottom:6px;
}

.menu-row{
  display:grid;
  grid-template-columns: 1fr auto; /* text | cena */
  column-gap:12px;
  align-items:baseline;
  padding:6px 0;
  border-bottom:1px dashed rgba(232,201,121,.15);
}
.menu-row span{display:block}
.menu-row .price{
  justify-self:end;
  color:var(--gold);
  font-weight:600;
  white-space:nowrap;          /* 590 + Kč drží pohromadě */
  font-variant-numeric:tabular-nums; /* hezké svislé zarovnání čísel */
}

/* -------------------- RESPONSIVE -------------------- */
@media (max-width: 900px){
  .grid2{ grid-template-columns:1fr; }
  .grid3, .cards, .packages{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns: repeat(2,1fr) }
  .nav{ display:none; position:absolute; top:64px; right:12px; background:#0f2a22; padding:10px 12px; border:1px solid rgba(232,201,121,.25); border-radius:10px }
  .nav a{ display:block; margin:10px 4px }
  .nav-toggle{ display:block }
}
