/* Restaurace Šachty – globální CSS */
/* https://cdn.4webs.net/restauracesachtycz/css/global.css */

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
:root{--g:#064026;--gm:#0a5c37;--ga:#1a8a52;--gc:#2dcc76;--cream:#f5f0e8;--dark:#0d1a10}
body{font-family:'Open Sans',sans-serif;background:#0a1409;color:#fff;overflow-x:hidden}

/* NAV */
#nav{position:fixed;top:0;left:0;right:0;z-index:200;padding:26px 52px;display:flex;align-items:center;justify-content:space-between;transition:all .5s}
#nav.solid{background:rgba(6,64,38,.97);padding:15px 52px;backdrop-filter:blur(12px)}
.nav-brand{display:flex;align-items:center;text-decoration:none}
.nav-brand img{width:48px;height:48px;object-fit:contain;opacity:0;transform:scale(.7) translateY(-6px);transition:opacity .4s ease,transform .4s ease}
#nav.solid .nav-brand img{opacity:1;transform:scale(1) translateY(0)}
.nav-links{display:flex;gap:38px;list-style:none}
.nav-links a{font-size:10.5px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.7);text-decoration:none;transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--gc)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:rgba(6,64,38,.7);border:1px solid rgba(255,255,255,.15);border-radius:2px}
.hamburger span{width:22px;height:1.5px;background:#fff;display:block}

/* SOCIAL + FOOTER */
.social-bar{background:#04100a;padding:54px 0;border-top:1px solid rgba(255,255,255,.05)}
.social-inner{max-width:1100px;margin:0 auto;padding:0 52px;display:flex;align-items:center;justify-content:space-between;gap:32px}
.social-label{font-family:'Oswald',sans-serif;font-size:22px;font-weight:300;color:rgba(255,255,255,.55)}
.social-icons{display:flex;gap:10px}
.si{width:46px;height:46px;border-radius:50%;border:1px solid rgba(255,255,255,.13);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.55);text-decoration:none;transition:all .22s}
.si:hover{border-color:var(--gc);color:var(--gc);background:rgba(45,204,118,.07)}
.si svg{width:17px;height:17px}
footer{background:#020a04;padding:34px 0;text-align:center}
footer p{font-size:11.5px;color:rgba(255,255,255,.18);letter-spacing:.04em}
footer a{color:rgba(255,255,255,.28);text-decoration:none}

/* POPUP */
.popup-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .3s ease}
.popup-box{background:var(--g);border-radius:16px;padding:48px 40px 40px;max-width:540px;width:100%;text-align:center;position:relative;border:2px solid rgba(255,255,255,.12);box-shadow:0 24px 80px rgba(0,0,0,.6);animation:popIn .4s cubic-bezier(.22,1,.36,1)}
.popup-icon{font-size:48px;margin-bottom:16px}
.popup-title{font-family:'Oswald',sans-serif;font-size:clamp(26px,4vw,38px);font-weight:700;color:#fff;letter-spacing:.04em;margin-bottom:20px}
.popup-divider{width:48px;height:2px;background:var(--gc);margin:0 auto 20px}
.popup-msg{font-size:15px;font-weight:300;line-height:1.8;color:rgba(255,255,255,.8);white-space:pre-line}
.popup-close{margin-top:32px;padding:14px 48px;background:var(--cream);border:none;border-radius:40px;font-family:'Oswald',sans-serif;font-size:16px;font-weight:600;color:var(--dark);cursor:pointer;transition:transform .15s,box-shadow .15s;letter-spacing:.05em}
.popup-close:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(0,0,0,.3)}

/* COOKIE LIŠTA */
#cookie-bar{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:#fff;border-top:1px solid rgba(6,64,38,.12);box-shadow:0 -4px 24px rgba(0,0,0,.08);padding:18px 24px;animation:cookieSlideUp .35s cubic-bezier(.22,1,.36,1)}
@keyframes cookieSlideUp{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}
#cookie-bar-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;gap:24px;flex-wrap:wrap}
#cookie-bar-text{flex:1;min-width:260px}
#cookie-bar-text strong{font-family:'Open Sans',sans-serif;font-size:14px;font-weight:600;color:#064026;display:block;margin-bottom:5px}
#cookie-bar-text p{font-size:13px;font-weight:300;line-height:1.6;color:rgba(15,35,20,.65);margin:0}
#cookie-more{font-size:12px;color:#064026;text-decoration:underline;margin-top:4px;display:inline-block}
#cookie-bar-btns{display:flex;gap:10px;flex-shrink:0}
#cookie-accept,#cookie-reject{padding:10px 22px;font-family:'Open Sans',sans-serif;font-size:12px;font-weight:600;letter-spacing:.08em;border:none;cursor:pointer;border-radius:2px;transition:opacity .2s;white-space:nowrap}
#cookie-accept{background:#064026;color:#fff}
#cookie-accept:hover{opacity:.85}
#cookie-reject{background:transparent;color:#064026;border:1px solid rgba(6,64,38,.3)}
#cookie-reject:hover{background:rgba(6,64,38,.05)}

/* COOKIE IKONKA */
#cookie-icon-btn{position:fixed;bottom:20px;left:20px;z-index:9998;width:40px;height:40px;border-radius:50%;background:rgba(6,64,38,.9);border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.8);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .2s,opacity .2s;backdrop-filter:blur(4px);padding:0}
#cookie-icon-btn:hover{background:#064026;transform:scale(1.1);color:#fff}
#cookie-icon-btn.hidden{opacity:0;pointer-events:none}

@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes popIn{from{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}

@media(max-width:880px){
  .nav-links{display:none}
  .hamburger{display:flex}
  #nav,#nav.solid{padding:16px 22px}
  .social-inner{flex-direction:column;text-align:center;padding:0 22px}
}
@media(max-width:600px){
  #cookie-bar-inner{flex-direction:column;align-items:flex-start;gap:14px}
  #cookie-bar-btns{width:100%}
  #cookie-accept,#cookie-reject{flex:1;text-align:center}
}

/* ── Utility třídy (nahrazují inline styly) ── */
.btext-mt{margin-top:14px}
.btext-quote{margin-top:14px;font-style:italic;color:rgba(255,255,255,.32)}
.eyebrow-dim{color:rgba(255,255,255,.45)}
.partners-label{font-size:14px;color:rgba(15,35,20,.5);margin-bottom:28px;font-weight:300}
[data-delay="1"]{transition-delay:.15s}
[data-delay="2"]{transition-delay:.2s}
.ic-link{color:var(--g);font-weight:500;text-decoration:none}

/* ══════════════════════════════════════════
   HOMEPAGE – specifické styly
   ══════════════════════════════════════════ */

/* HERO */
.hero{height:100vh;min-height:680px;position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center}
.hero-bg{position:absolute;inset:0;background:#061a0c}
.hero-atmo{position:absolute;inset:0;background-size:cover;background-position:center 40%}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(4,12,6,.25) 0%,rgba(4,12,6,.45) 50%,rgba(4,12,6,.82) 100%)}
.hero-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:22px;animation:riseIn 1.5s cubic-bezier(.22,1,.36,1) both}
.hero-logo-img{width:280px;height:280px;object-fit:contain;filter:drop-shadow(0 8px 32px rgba(0,0,0,.45))}
.hero-h1{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.hero-cta{margin-top:10px;display:flex;gap:14px}
.btn-p{padding:13px 34px;background:var(--g);border:1px solid rgba(255,255,255,.18);font-size:10.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:#fff;text-decoration:none;transition:background .2s}
.btn-p:hover{background:var(--gm)}
.btn-o{padding:13px 34px;background:transparent;border:1px solid rgba(255,255,255,.28);font-size:10.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.75);text-decoration:none;transition:background .2s,border-color .2s}
.btn-o:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.45)}
.hero-scroll{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:9px;color:rgba(255,255,255,.3);font-size:9px;letter-spacing:.25em;text-transform:uppercase}
.scrollbar{width:1px;height:46px;background:rgba(255,255,255,.18);animation:pulse 2.2s ease-in-out infinite}
@keyframes riseIn{from{opacity:0;transform:translateY(44px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:.18;transform:scaleY(1)}50%{opacity:.55;transform:scaleY(1.1)}}

/* PANELS */
.panel{position:relative;overflow:hidden;padding:110px 0}
.panel-a{background:#0b1c11}
.panel-b{background:#0e2017}
.panel-c{background:#091408}
.panel-cream{background:var(--cream);color:var(--dark)}
.container{max-width:1100px;margin:0 auto;padding:0 52px}

/* TYPOGRAPHY */
.eyebrow{font-size:10px;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:var(--gc);margin-bottom:18px}
.eyebrow-d{color:var(--ga)}
.disp{font-family:'Oswald',sans-serif;font-size:clamp(42px,5vw,66px);font-weight:400;line-height:1.05;color:#fff}
.disp em{font-style:italic;font-weight:300}
.disp-d{color:var(--dark)}
.rule{width:42px;height:1px;background:var(--ga);margin:26px 0 38px}
.btext{font-size:15.5px;font-weight:300;line-height:1.9;color:rgba(255,255,255,.58);max-width:530px}

/* REVEAL */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .75s ease,transform .75s ease}
.reveal.in{opacity:1;transform:translateY(0)}
/* Fallback – pokud JS selže, obsah zůstane viditelný */
.no-js .reveal, body:not(.js-ready) .reveal{opacity:1;transform:translateY(0)}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:96px;align-items:center}
.img-stack{position:relative}
.img-main{aspect-ratio:4/5;overflow:hidden;position:relative}
.img-main img{width:100%;height:100%;object-fit:cover;display:block}
.img-badge{position:absolute;bottom:-20px;right:-20px;width:132px;height:132px;border-radius:50%;background:var(--g);border:4px solid #0b1c11;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2}
.img-badge .yr{font-family:'Oswald',sans-serif;font-size:33px;color:#fff}
.img-badge .yl{font-size:8.5px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.45)}
.img-deco{position:absolute;top:-18px;left:-18px;width:72px;height:72px;border:1px solid rgba(45,204,118,.22)}

/* CHEF */
.chef-grid{display:grid;grid-template-columns:5fr 7fr;gap:76px;align-items:start}
.chef-portrait{aspect-ratio:3/4;position:relative;overflow:hidden}
.chef-portrait img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.chef-plate{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(4,12,6,.95),transparent);padding:28px 22px 22px}
.chef-plate .cn{font-family:'Oswald',sans-serif;font-size:20px;font-weight:500;color:#fff}
.chef-plate .cr{font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--gc);margin-top:4px}
.chef-body h3{font-family:'Oswald',sans-serif;font-size:clamp(28px,2.8vw,42px);font-weight:400;color:#fff;line-height:1.1;margin-top:6px}
.chef-body p{font-size:15.5px;font-weight:300;line-height:1.9;color:rgba(255,255,255,.58);margin-top:18px}
.chef-stat{margin-top:40px;display:flex;align-items:baseline;gap:12px;border-left:2px solid var(--ga);padding-left:20px}
.chef-stat .num{font-family:'Oswald',sans-serif;font-size:54px;font-weight:300;color:var(--gc);line-height:1}
.chef-stat .lbl{font-size:12.5px;color:rgba(255,255,255,.38);line-height:1.5}

/* GALERIE */
.gallery-panel{background:#080f09;padding:80px 0}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;max-width:1100px;margin:0 auto;padding:0 52px}
.gallery-grid img{width:100%;height:100%;object-fit:cover;display:block}
.g1{grid-column:1;grid-row:1}.g2{grid-column:2;grid-row:1}
.g3{grid-column:3/5;grid-row:1/3}.g4{grid-column:1/3;grid-row:2/4}
.g5{grid-column:3;grid-row:3}.g6{grid-column:4;grid-row:3}
.g7{grid-column:1;grid-row:4}.g8{grid-column:2;grid-row:4}.g9{grid-column:3/5;grid-row:4}
.g1,.g2,.g5,.g6,.g7,.g8{aspect-ratio:4/3}
.g3{min-height:300px}.g4{min-height:280px}.g9{aspect-ratio:16/6}

/* FILOZOFIE */
.phil-layout{display:grid;grid-template-columns:1fr 1fr;gap:80px}
.phil-cards{display:flex;flex-direction:column}
.phil-card{padding:34px 30px;border-bottom:1px solid rgba(255,255,255,.07);transition:background .22s}
.phil-card:first-child{border-top:1px solid rgba(255,255,255,.07)}
.phil-card:hover{background:rgba(255,255,255,.03)}
.pc-num{font-family:'Oswald',sans-serif;font-size:11px;color:rgba(255,255,255,.18);letter-spacing:.15em}
.pc-title{font-size:12.5px;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:#fff;margin:10px 0 11px}
.pc-text{font-size:14.5px;font-weight:300;line-height:1.78;color:rgba(255,255,255,.52)}

/* REZERVACE */
.rez-strip{background:var(--g);padding:76px 0}
.rez-inner{display:flex;align-items:center;justify-content:space-between;gap:48px}
.rez-inner h2{font-family:'Oswald',sans-serif;font-size:clamp(26px,3.2vw,42px);font-weight:400;color:#fff}
.rez-phone{display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.rez-label{font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.4)}
.rez-phone a{font-family:'Oswald',sans-serif;font-size:36px;font-weight:400;color:#fff;text-decoration:none;transition:color .2s}
.rez-phone a:hover{color:var(--gc)}

/* OTEVÍRACÍ DOBA + LOKALITA */
.hl-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px}
.hour-row{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.hour-row:first-child{border-top:1px solid rgba(255,255,255,.06)}
.hour-row .day{font-size:13px;font-weight:400;color:rgba(255,255,255,.5)}
.hour-row .time{font-family:'Oswald',sans-serif;font-size:19px;color:#fff}
.hour-row.today{background:rgba(45,204,118,.05);padding:16px 10px;margin:0 -10px}
.hour-row.today .day,.hour-row.today .time{color:var(--gc)}
.loc-block p{font-size:15px;font-weight:300;line-height:1.85;color:rgba(255,255,255,.52);margin-top:18px}
.map-wrap{margin-top:32px;border:1px solid rgba(255,255,255,.1);overflow:hidden}
.map-wrap iframe{width:100%;height:290px;display:block;filter:grayscale(35%) brightness(.82)}

/* KONTAKT */
.ct-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;margin-top:58px}
.ct-block h3{font-family:'Oswald',sans-serif;font-size:26px;font-weight:500;color:var(--dark);margin-bottom:26px}
.cline{display:flex;gap:13px;align-items:flex-start;margin-bottom:17px}
.cline svg{width:15px;height:15px;flex-shrink:0;margin-top:3px;color:var(--ga);stroke:currentColor;fill:none;stroke-width:1.5}
.cline-body{font-size:14.5px;font-weight:300;line-height:1.6;color:rgba(15,35,20,.68)}
.cline-body a{color:var(--g);font-weight:500;text-decoration:none}
.cline-meta{font-size:11.5px;color:rgba(15,35,20,.38);margin-top:2px}

/* PARTNEŘI */
.partner-logos{display:flex;flex-direction:column;gap:0;margin-top:8px}
.plogo{display:flex;align-items:center;gap:16px;padding:18px 0;border-bottom:1px solid rgba(6,64,38,.08);text-decoration:none;transition:opacity .2s}
.plogo:first-child{border-top:1px solid rgba(6,64,38,.08)}
.plogo:hover{opacity:.6}
.plogo img{height:36px;width:auto;max-width:140px;object-fit:contain;display:block}
.plogo-name{font-size:13px;font-weight:500;color:rgba(15,35,20,.55)}

@media(max-width:880px){
  .about-grid,.chef-grid,.phil-layout,.hl-grid,.ct-grid{grid-template-columns:1fr;gap:44px}
  .rez-inner{flex-direction:column;text-align:center}
  .rez-phone{align-items:center}
  .hero-cta{flex-direction:column;align-items:center}
  .img-badge{bottom:-14px;right:-10px;width:108px;height:108px}
  .gallery-grid{grid-template-columns:1fr 1fr;padding:0 22px}
  .g3,.g4,.g9{grid-column:auto;grid-row:auto;min-height:0;aspect-ratio:4/3}
  .container{padding:0 22px}
  .panel{padding:76px 0}
}
