:root{
  --forest:#2d4a32; --forest-d:#1e3322; --moss:#5a7d52; --sage:#8aa17a;
  --sand:#e9e2d4; --cream:#f6f3ec; --bark:#3d342a; --text:#26302a;
  --muted:#6b7569; --gold:#c08a3e; --white:#fff;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',-apple-system,sans-serif;color:var(--text);background:var(--cream);line-height:1.65}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:600;line-height:1.1;color:var(--forest-d)}
a{color:inherit}
img,video{display:block;max-width:100%}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;justify-content:space-between;
  align-items:center;padding:16px 40px;background:rgba(30,51,34,.0);transition:.3s}
.nav .logo{font-family:'Fraunces',serif;font-size:22px;font-weight:600;color:#fff;text-decoration:none;
  text-shadow:0 1px 6px rgba(0,0,0,.4)}
.nav .logo span{font-weight:500;opacity:.85}
.nav nav{display:flex;gap:26px;align-items:center}
.nav nav a{color:#fff;text-decoration:none;font-size:15px;font-weight:500;opacity:.92;
  text-shadow:0 1px 6px rgba(0,0,0,.4)}
.nav nav a:hover{opacity:1}
.btn-nav{background:var(--gold);padding:9px 18px;border-radius:30px;text-shadow:none!important}
.btn-nav:hover{background:#a9762f}

/* HERO */
.hero{position:relative;height:100vh;min-height:600px;display:flex;align-items:center;justify-content:center;
  text-align:center;overflow:hidden;color:#fff}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
  background:linear-gradient(135deg,#2d4a32,#5a7d52)}
.hero-overlay{position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(20,35,24,.45) 0%,rgba(20,35,24,.25) 45%,rgba(20,35,24,.65) 100%)}
.hero-content{position:relative;z-index:2;padding:0 20px;max-width:820px}
.hero-kicker{text-transform:uppercase;letter-spacing:.28em;font-size:13px;font-weight:600;margin-bottom:18px;opacity:.95}
.hero h1{font-size:clamp(48px,9vw,104px);color:#fff;letter-spacing:-.5px;text-shadow:0 2px 30px rgba(0,0,0,.35)}
.hero h1 span{display:block;font-weight:500;opacity:.9}
.hero-sub{font-size:clamp(16px,2.2vw,20px);margin:24px auto 36px;max-width:560px;text-shadow:0 1px 10px rgba(0,0,0,.4)}
.hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:2;color:#fff;
  font-size:26px;text-decoration:none;animation:bob 2s infinite;opacity:.85}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* ═══ SCROLLYTELLING ═══ */
.scrolly{position:relative;height:400vh}            /* výška = délka zážitku; ~3-5 s videa na jeden zátah */
.sticky{position:sticky;top:0;height:100vh;overflow:hidden;display:flex;align-items:center;justify-content:center}
.scrolly-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
  background:linear-gradient(135deg,#2d4a32,#5a7d52)}
.scrolly-tint{position:absolute;inset:0;z-index:1;
  background:radial-gradient(120% 80% at 50% 50%,rgba(20,35,24,.15),rgba(20,35,24,.6))}
.scene{position:absolute;z-index:2;text-align:center;color:#fff;padding:0 24px;max-width:860px;
  opacity:0;will-change:opacity,transform;text-shadow:0 2px 24px rgba(0,0,0,.45)}
.s-kicker{text-transform:uppercase;letter-spacing:.3em;font-size:13px;font-weight:600;margin-bottom:18px;opacity:.95}
.s-title{font-size:clamp(50px,10vw,120px);color:#fff;line-height:.95;letter-spacing:-1px}
.s-title span{display:block;font-weight:500;opacity:.9}
.s-title.sm{font-size:clamp(38px,7vw,76px)}
.s-sub{font-size:clamp(17px,2.4vw,24px);margin-top:22px;opacity:.95}
.s-h{font-size:clamp(32px,5.5vw,60px);color:#fff;margin-bottom:18px}
.s-p{font-size:clamp(16px,2.2vw,21px);max-width:600px;margin:0 auto;opacity:.95}
.s-hint{margin-top:40px;font-size:14px;letter-spacing:.2em;text-transform:uppercase;opacity:.8;
  animation:bob 2s infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}
.s-stats{display:flex;gap:36px;justify-content:center;flex-wrap:wrap;margin-top:14px}
.s-stats strong{display:block;font-family:'Fraunces',serif;font-size:40px}
.s-stats span{font-size:14px;opacity:.9}
.scrolly-progress{position:absolute;left:0;right:0;bottom:0;height:4px;background:rgba(255,255,255,.18);z-index:3}
.scrolly-progress span{display:block;height:100%;width:0;background:var(--gold);transition:width .1s linear}
.btn-primary.big{margin-top:30px;font-size:18px;padding:16px 38px}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* BUTTONS */
.btn-primary{display:inline-block;background:var(--gold);color:#fff;padding:14px 30px;border-radius:32px;
  text-decoration:none;font-weight:600;border:none;cursor:pointer;font-size:16px;transition:.2s}
.btn-primary:hover{background:#a9762f;transform:translateY(-2px)}
.btn-primary.full{width:100%;margin-top:10px}
.btn-ghost{display:inline-block;background:rgba(255,255,255,.12);color:#fff;padding:14px 28px;border-radius:32px;
  text-decoration:none;font-weight:600;border:1.5px solid rgba(255,255,255,.6);backdrop-filter:blur(4px);transition:.2s}
.btn-ghost:hover{background:rgba(255,255,255,.22)}

/* SECTIONS */
.sec{padding:96px 0}
.sec.alt{background:var(--sand)}
.rezervace-sec{background:linear-gradient(180deg,var(--forest) 0%,var(--forest-d) 100%);color:var(--cream)}
.rezervace-sec h2,.rezervace-sec .kicker{color:#fff}
.wrap{max-width:1140px;margin:0 auto;padding:0 28px}
.wrap.narrow{max-width:720px}
.kicker{text-transform:uppercase;letter-spacing:.22em;font-size:13px;font-weight:700;color:var(--gold);margin-bottom:12px}
.kicker.center,.center{text-align:center}
h2{font-size:clamp(28px,4vw,42px);margin-bottom:22px}
.muted{color:var(--muted)} .small{font-size:13px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.two-col p{margin-bottom:14px;font-size:17px}

/* STATS */
.stats{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.stat{background:var(--cream);border:1px solid #e0d8c8;border-radius:16px;padding:24px;text-align:center}
.stat strong{display:block;font-family:'Fraunces',serif;font-size:30px;color:var(--forest)}
.stat span{font-size:14px;color:var(--muted)}

/* CARDS */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:36px}
.card{background:var(--cream);border-radius:18px;padding:30px;border:1px solid #e6ddcd;transition:.2s}
.card:hover{transform:translateY(-4px);box-shadow:0 14px 34px rgba(45,74,50,.12)}
.card .ic{font-size:34px;margin-bottom:14px}
.card h3{font-size:20px;margin-bottom:8px}
.card p{font-size:15px;color:var(--muted)}

/* CENÍK */
.cenik{max-width:640px;margin:36px auto 16px;background:var(--cream);border-radius:18px;overflow:hidden;
  border:1px solid #e6ddcd}
.cenik-row{display:flex;justify-content:space-between;padding:18px 26px;border-bottom:1px solid #ece4d4;font-size:17px}
.cenik-row:last-child{border-bottom:none}
.cenik-row .cena{font-weight:700;color:var(--forest)}

/* GALERIE */
.galerie{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:36px}
.g-item{border-radius:14px;overflow:hidden;aspect-ratio:4/3;display:block}
.g-item img{width:100%;height:100%;object-fit:cover;transition:.4s}
.g-item:hover img{transform:scale(1.06)}
.galerie .g-item:first-child{grid-column:span 2;grid-row:span 2;aspect-ratio:auto}
@media(max-width:820px){.galerie{grid-template-columns:repeat(2,1fr)}.galerie .g-item:first-child{grid-column:span 2}}

/* OKOLÍ */
.okoli{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:36px}
.okoli-box{background:var(--cream);border-radius:18px;padding:28px;border:1px solid #e6ddcd}
.okoli-box h3{font-size:20px;margin-bottom:14px}
.okoli-box ul{list-style:none}
.okoli-box li{padding:6px 0 6px 22px;position:relative;font-size:15px;color:var(--text)}
.okoli-box li::before{content:'›';position:absolute;left:4px;color:var(--gold);font-weight:700}
.vylet-fotky{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-top:36px}
.vylet-fotky img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:14px;display:block;box-shadow:0 6px 20px rgba(0,0,0,.10);transition:transform .4s ease}
.vylet-fotky img:hover{transform:scale(1.04)}
@media(max-width:820px){.vylet-fotky{grid-template-columns:repeat(3,1fr)}}
@media(max-width:480px){.vylet-fotky{grid-template-columns:repeat(2,1fr)}}

/* FORM */
.rez-form{margin-top:34px;background:rgba(255,255,255,.06);padding:30px;border-radius:20px;
  border:1px solid rgba(255,255,255,.15)}
.rez-form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.rez-form label{display:flex;flex-direction:column;font-size:14px;font-weight:600;gap:7px;color:var(--cream)}
.rez-form input,.rez-form select,.rez-form textarea{padding:12px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.25);
  background:rgba(255,255,255,.95);font-size:15px;font-family:inherit;color:var(--text)}
.rez-form textarea{margin-bottom:16px}
.checks{display:flex;gap:24px;flex-wrap:wrap;margin-bottom:16px}
.chk{flex-direction:row!important;align-items:center;gap:9px!important;font-weight:500!important}
.chk input{width:18px;height:18px}

/* KONTAKT */
.kontakt-line{font-size:17px;margin-bottom:10px}
.kontakt-line a{color:var(--forest);font-weight:600}
.map-box{border-radius:18px;overflow:hidden;border:1px solid #e0d8c8;height:340px}
.map-box iframe{width:100%;height:100%;border:0}

/* FOOTER */
.footer{background:var(--forest-d);color:#cfd8cc;padding:60px 28px 28px}
.footer-in{max-width:1140px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.footer h4{color:#fff;margin-bottom:12px;font-size:18px}
.footer p,.footer a{font-size:14px;color:#cfd8cc;text-decoration:none}
.footer a:hover{color:#fff}
.copy{text-align:center;margin-top:40px;padding-top:24px;border-top:1px solid rgba(255,255,255,.12);
  font-size:13px;color:#9aa893}

/* FLASH + ADMIN */
.flash{position:fixed;top:80px;left:50%;transform:translateX(-50%);z-index:60;background:#fff;
  color:var(--forest-d);padding:14px 24px;border-radius:12px;box-shadow:0 8px 30px rgba(0,0,0,.18);
  border-left:4px solid var(--gold)}
.grid-wrap{overflow-x:auto}
.admin-tbl{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;margin-top:20px}
.admin-tbl th,.admin-tbl td{padding:12px 14px;border-bottom:1px solid #eee;text-align:left;font-size:14px;vertical-align:top}
.admin-tbl thead th{background:var(--forest);color:#fff;font-weight:600}

/* SCROLLED NAV */
.nav.scrolled{background:var(--forest-d);padding:12px 40px;box-shadow:0 2px 18px rgba(0,0,0,.2)}

@media(max-width:820px){
  .nav{padding:14px 18px}
  .nav nav{gap:14px} .nav nav a:not(.btn-nav){display:none}
  .two-col,.cards,.okoli,.stats,.rez-form .row,.footer-in{grid-template-columns:1fr}
  .sec{padding:64px 0}
}

/* Provozní řád */
.rad h3{font-size:19px;margin:26px 0 8px;color:var(--forest,#2d4a32)}
.rad p{margin-bottom:10px}
.rad ul{margin:0 0 10px 20px}
.rad li{padding:4px 0}
.btn-secondary{display:inline-block;padding:12px 22px;border-radius:30px;border:1px solid #cdbfa6;color:var(--text);text-decoration:none;font-weight:600}
.btn-secondary:hover{background:#efe7d8}

/* KALENDÁŘ / MŘÍŽKA OBSAZENOSTI */
.kalendar{background:var(--cream);border:1px solid #e6ddcd;border-radius:18px;padding:24px 22px;margin:8px 0 10px}
.kal-head{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:8px}
.kal-title{font-family:'Fraunces',serif;font-size:21px;min-width:170px;text-align:center;text-transform:capitalize;color:var(--forest-d)}
.kal-nav{background:#fff;border:1px solid #d8cdb6;border-radius:9px;width:36px;height:36px;font-size:20px;line-height:1;cursor:pointer;color:var(--forest)}
.kal-nav:hover{background:#efe7d8}
.kal-legenda{display:flex;gap:18px;justify-content:center;font-size:12px;color:var(--muted);margin-bottom:14px;flex-wrap:wrap}
.kal-legenda .dot{display:inline-block;width:12px;height:12px;border-radius:50%;vertical-align:-1px;margin-right:5px}
.dot.free{background:#bfe3c0}.dot.part{background:#f2d9a8}.dot.full{background:#f2b8b8}.dot.sel{background:var(--gold)}
.kal-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:6px}
.kal-table{border-collapse:collapse;user-select:none;margin:0 auto}
.kal-table th,.kal-table td{text-align:center}
.kal-corner{position:sticky;left:0;background:var(--cream);z-index:3}
.kal-rowname{position:sticky;left:0;background:var(--cream);text-align:left;padding:0 16px 0 4px;font-size:14px;font-weight:600;
  white-space:nowrap;z-index:2;min-width:104px;color:var(--forest-d)}
.kal-dhead{font-size:12px;color:var(--muted);padding:0 0 7px;width:34px;line-height:1.3}
.kal-dhead b{display:block;font-size:14px;color:var(--text);font-weight:600}
.kal-dhead.we b{color:#b06a3a}
.kal-cell{width:34px;height:38px;padding:2px}
.kal-cell .c{width:30px;height:30px;line-height:30px;margin:0 auto;border-radius:50%;font-size:12.5px;transition:.1s}
.kal-cell.free .c{background:#d6f0d7;color:#2d6a34;cursor:pointer}
.kal-cell.busy .c{background:#f6cccc;color:#c46;cursor:not-allowed}
.kal-cell.past .c{background:#ececec;color:#bbb}
.kal-cell.sel .c{background:var(--gold);color:#fff;transform:scale(1.06)}
.kal-cell.free .c:hover{outline:2px solid var(--gold);outline-offset:-2px}
.kal-vyber{margin-top:14px;font-size:14px}
.kal-vyber.ok{color:#2d7d3a;font-weight:600}
@media(max-width:600px){.kal-rowname{min-width:76px;font-size:12px}.kal-cell{width:27px}.kal-cell .c{width:22px;height:22px;line-height:22px}}
