/* =========================================================
   Kwiat Jabłonki — styles
   Palette inspired by the cabins: cream paper, forest green,
   warm cedar wood, navy interior accent.
   ========================================================= */
:root{
  --cream:#f5f1e8;
  --cream-2:#efe9dc;
  --paper:#fbf9f4;
  --forest:#2f4a3c;
  --forest-2:#3e5e4a;
  --forest-deep:#22382c;
  --wood:#b5774a;
  --wood-dark:#9a6238;
  --navy:#1d3a5f;
  --ink:#2b2a26;
  --muted:#6f6a5d;
  --line:rgba(43,42,38,.12);
  --white:#fff;
  --shadow-sm:0 2px 8px rgba(34,40,30,.07);
  --shadow:0 10px 30px rgba(34,40,30,.12);
  --shadow-lg:0 24px 60px rgba(34,40,30,.20);
  --radius:14px;
  --radius-lg:22px;
  --maxw:1180px;
  --ff-serif:Georgia,"Iowan Old Style","Times New Roman",serif;
  --ff-sans:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  font-family:var(--ff-sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-size:clamp(16px,1.05vw,17.5px);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--wood-dark);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:var(--ff-serif);font-weight:700;line-height:1.15;color:var(--forest-deep);margin:0 0 .5em}
p{margin:0 0 1rem}
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(18px,4vw,40px)}
.narrow{max-width:760px}
.center{text-align:center}
.narrow-inline{max-width:680px;margin-inline:auto}

.skip-link{position:absolute;left:-999px;top:0;background:var(--forest);color:#fff;padding:10px 16px;z-index:1000;border-radius:0 0 8px 0}
.skip-link:focus{left:0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--ff-sans);font-weight:600;font-size:1rem;
  padding:.85em 1.6em;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .25s var(--ease),background .25s,color .25s,box-shadow .25s;
  text-align:center;line-height:1.2;
}
.btn:hover{text-decoration:none;transform:translateY(-2px)}
.btn-primary{background:var(--wood);color:#fff;box-shadow:0 8px 20px rgba(181,119,74,.35)}
.btn-primary:hover{background:var(--wood-dark)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.7)}
.btn-ghost:hover{background:rgba(255,255,255,.14)}
.btn-ghost-dark{background:transparent;color:var(--forest);border-color:var(--forest)}
.btn-ghost-dark:hover{background:rgba(47,74,60,.08)}
.btn-dark{background:var(--forest);color:#fff}
.btn-dark:hover{background:var(--forest-deep)}
.btn-small{padding:.6em 1.15em;font-size:.92rem}
.btn-block{width:100%}

/* ---------- Header ---------- */
.site-header{position:fixed;inset:0 0 auto 0;z-index:100;transition:background .3s,box-shadow .3s,padding .3s;padding:.55rem 0}
.site-header::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,28,22,.55),rgba(20,28,22,0));opacity:1;transition:opacity .3s;pointer-events:none}
.site-header.scrolled{background:var(--paper);box-shadow:var(--shadow-sm)}
.site-header.scrolled::before{opacity:0}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;position:relative}

.brand{display:inline-flex;align-items:center;gap:.6rem;color:#fff;transition:color .3s}
.brand:hover{text-decoration:none}
.site-header.scrolled .brand{color:var(--forest)}
.brand-mark{width:42px;height:42px;flex:none}
.brand-text{display:flex;flex-direction:column;line-height:1.05}
.brand-text strong{font-family:var(--ff-serif);font-size:1.3rem;letter-spacing:.2px}
.brand-text small{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;opacity:.85;font-family:var(--ff-sans)}

/* ---------- Nav ---------- */
.nav-menu{list-style:none;display:flex;align-items:center;gap:.4rem;margin:0;padding:0}
.nav-menu a{color:#fff;font-weight:500;padding:.5rem .8rem;border-radius:999px;transition:background .25s,color .25s}
.nav-menu a:hover{text-decoration:none;background:rgba(255,255,255,.16)}
.nav-menu a.active{background:rgba(255,255,255,.2)}
.site-header.scrolled .nav-menu a{color:var(--ink)}
.site-header.scrolled .nav-menu a:hover,.site-header.scrolled .nav-menu a.active{background:rgba(47,74,60,.1);color:var(--forest)}
.nav-menu .nav-cta-li a.btn{color:#fff}
.site-header.scrolled .nav-menu .nav-cta-li a.btn{color:#fff}
.nav-menu .nav-cta-li a.btn:hover{background:var(--wood-dark)}

.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;background:rgba(0,0,0,.18);border:none;border-radius:12px;cursor:pointer;padding:0 11px}
.site-header.scrolled .nav-toggle{background:rgba(47,74,60,.1)}
.nav-toggle span{height:2.5px;width:100%;background:#fff;border-radius:2px;transition:transform .3s,opacity .3s}
.site-header.scrolled .nav-toggle span{background:var(--forest)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

@media (max-width:880px){
  .nav-toggle{display:flex}
  .nav-menu{
    position:absolute;top:calc(100% + 12px);right:0;width:min(300px,80vw);
    flex-direction:column;align-items:stretch;gap:.2rem;
    background:var(--paper);border-radius:16px;box-shadow:var(--shadow-lg);
    padding:.7rem;opacity:0;visibility:hidden;transform:translateY(-10px);
    transition:opacity .25s,transform .25s,visibility .25s;
  }
  .nav-menu.open{opacity:1;visibility:visible;transform:translateY(0)}
  .nav-menu a{color:var(--ink)!important;padding:.8rem 1rem;border-radius:10px}
  .nav-menu a:hover{background:rgba(47,74,60,.08)!important}
  .nav-cta-li{margin-top:.5rem}
  .nav-menu .nav-cta-li a.btn{width:100%;color:#fff!important;background:var(--wood)}
  .nav-menu .nav-cta-li a.btn:hover{background:var(--wood-dark)!important}
}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100svh;min-height:100vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero-media{position:absolute;inset:0;z-index:-1;background:#1a241c}
.hero-video,.hero-media{width:100%;height:100%}
.hero-video{object-fit:cover;position:absolute;inset:0}
.hero-overlay{position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(20,28,22,.45) 0%,rgba(20,28,22,.25) 35%,rgba(20,28,22,.6) 100%),
  radial-gradient(120% 80% at 20% 30%,rgba(20,28,22,.25),transparent)}
.hero-content{position:relative;padding-top:96px;padding-bottom:96px;max-width:780px}
.hero-eyebrow{font-size:.82rem;letter-spacing:.28em;text-transform:uppercase;font-weight:600;margin-bottom:1rem;opacity:.92}
.hero-title{color:#fff;font-size:clamp(2.6rem,7vw,5rem);margin:0 0 1rem;text-shadow:0 2px 30px rgba(0,0,0,.35);letter-spacing:-.5px}
.hero-lead{font-size:clamp(1.05rem,2vw,1.35rem);max-width:580px;margin-bottom:2rem;text-shadow:0 1px 12px rgba(0,0,0,.3);color:rgba(255,255,255,.95)}
.hero-actions{display:flex;flex-wrap:wrap;gap:1rem}
.hero-scroll{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);width:28px;height:46px;border:2px solid rgba(255,255,255,.6);border-radius:16px;display:flex;justify-content:center;padding-top:8px}
.hero-scroll span{width:4px;height:9px;background:#fff;border-radius:2px;animation:scrolldot 1.8s infinite}
@keyframes scrolldot{0%{opacity:0;transform:translateY(-3px)}40%{opacity:1}80%,100%{opacity:0;transform:translateY(9px)}}
@media (prefers-reduced-motion:reduce){.hero-scroll span{animation:none}}

/* ---------- Sections ---------- */
.section{padding:clamp(64px,9vw,120px) 0;position:relative}
.section-tint{background:var(--cream-2)}
.section-dark{background:var(--forest);color:rgba(255,255,255,.92)}
.section-dark .section-title{color:#fff}
.eyebrow{font-size:.8rem;letter-spacing:.24em;text-transform:uppercase;font-weight:700;color:var(--wood-dark);margin-bottom:.7rem}
.eyebrow-light{color:#e7c9ad}
.section-title{font-size:clamp(1.8rem,3.8vw,2.9rem);margin-bottom:1rem}
.lead{font-size:clamp(1.05rem,1.6vw,1.22rem);color:var(--muted)}
.section-dark .lead,.lead-light{color:rgba(255,255,255,.85)}

/* stats */
.stats{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(1.5rem,5vw,4.5rem);margin-top:3rem}
.stat{text-align:center}
.stat-num{display:block;font-family:var(--ff-serif);font-size:clamp(2.4rem,5vw,3.4rem);color:var(--wood);line-height:1}
.stat-label{display:block;margin-top:.4rem;font-size:.92rem;letter-spacing:.04em;color:var(--muted);text-transform:uppercase}

/* ---------- Features ---------- */
.features{list-style:none;margin:3rem 0 0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.4rem}
.feature{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:2rem 1.7rem;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s}
.feature:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.feature-ico{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:14px;background:rgba(181,119,74,.12);color:var(--wood-dark);margin-bottom:1.1rem}
.feature-ico svg{width:28px;height:28px}
.feature h3{font-size:1.3rem;margin-bottom:.4rem}
.feature p{margin:0;color:var(--muted)}

/* ---------- Split (domki) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;margin-top:clamp(2.5rem,5vw,4.5rem)}
.split-media img{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;aspect-ratio:3/2;object-fit:cover}
.split-text h3{font-size:clamp(1.5rem,2.6vw,2rem)}
.split-text p{color:var(--muted)}
.split-reverse .split-media{order:2}
@media (max-width:780px){
  .split{grid-template-columns:1fr;gap:1.6rem}
  .split-reverse .split-media{order:0}
}
.ticks{list-style:none;margin:1.2rem 0 0;padding:0;display:grid;gap:.6rem}
.ticks li{position:relative;padding-left:2rem;color:var(--ink)}
.ticks li::before{content:"";position:absolute;left:0;top:.15em;width:1.25rem;height:1.25rem;border-radius:50%;background:var(--forest) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/.8rem no-repeat}

/* ---------- Gallery ---------- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:3rem}
.g-item{margin:0}
.g-item button{display:block;width:100%;padding:0;border:none;background:none;cursor:pointer;position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);aspect-ratio:4/3}
.g-item.g-wide button{aspect-ratio:8/3}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .55s var(--ease)}
.g-item figcaption{position:absolute;inset:auto 0 0 0;padding:1.4rem .9rem .7rem;color:#fff;font-size:.9rem;font-weight:600;text-align:left;background:linear-gradient(180deg,transparent,rgba(20,28,22,.78));opacity:0;transform:translateY(8px);transition:opacity .3s,transform .3s}
.g-item button:hover img,.g-item button:focus-visible img{transform:scale(1.07)}
.g-item button:hover figcaption,.g-item button:focus-visible figcaption{opacity:1;transform:translateY(0)}
.g-item.g-wide{grid-column:span 2}
@media (max-width:780px){.gallery{grid-template-columns:repeat(2,1fr);gap:10px}.g-item.g-wide{grid-column:span 2}}
@media (max-width:460px){.gallery{grid-template-columns:1fr}.g-item.g-wide{grid-column:span 1}.g-item.g-wide button{aspect-ratio:4/3}}

/* ---------- Attractions ---------- */
.attractions{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.4rem;margin-top:3rem}
.attraction{background:var(--paper);border:1px solid var(--line);border-left:4px solid var(--wood);border-radius:12px;padding:1.6rem 1.7rem;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s}
.attraction:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.attraction h3{font-size:1.22rem;margin-bottom:.4rem}
.attraction p{margin:0;color:var(--muted);font-size:.98rem}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:0.85fr 1.15fr;gap:clamp(1.6rem,4vw,3.2rem);margin-top:3rem}
@media (max-width:880px){.contact-grid{grid-template-columns:1fr}}
.contact-list{list-style:none;margin:0 0 2rem;padding:0;display:grid;gap:1.2rem}
.contact-list li{display:flex;gap:1rem;align-items:flex-start}
.contact-list a{color:#fff;text-decoration:underline;text-underline-offset:3px;text-decoration-color:rgba(255,255,255,.4)}
.ci-ico{flex:none;width:46px;height:46px;border-radius:12px;background:rgba(255,255,255,.12);display:inline-flex;align-items:center;justify-content:center;color:#e7c9ad}
.ci-ico svg{width:24px;height:24px}
.season-note{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);border-radius:var(--radius);padding:1.5rem 1.6rem}
.season-note h3{color:#fff;font-size:1.25rem;margin-bottom:.7rem}
.season-note p{font-size:.97rem;color:rgba(255,255,255,.85);margin-bottom:.6rem}
.season-note p:last-child{margin-bottom:0}
.season-note strong{color:#e7c9ad}

/* form */
.contact-form-wrap{background:var(--paper);border-radius:var(--radius-lg);padding:clamp(1.5rem,3vw,2.5rem);box-shadow:var(--shadow-lg);color:var(--ink)}
.contact-form .field{margin-bottom:1.1rem}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media (max-width:480px){.field-row{grid-template-columns:1fr}}
.contact-form label{display:block;font-weight:600;font-size:.92rem;margin-bottom:.4rem;color:var(--forest-deep)}
.contact-form input,.contact-form textarea{
  width:100%;font:inherit;color:var(--ink);background:var(--white);
  border:1.5px solid var(--line);border-radius:10px;padding:.75rem .9rem;transition:border-color .2s,box-shadow .2s;
}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--wood);box-shadow:0 0 0 3px rgba(181,119,74,.18)}
.contact-form textarea{resize:vertical;min-height:120px}
.contact-form input:user-invalid,.contact-form textarea:user-invalid{border-color:#c0563f}
.field-check{display:flex;gap:.7rem;align-items:flex-start;margin:.4rem 0 1.3rem;font-size:.9rem;color:var(--muted)}
.field-check input{flex:none;width:20px;height:20px;margin-top:2px;accent-color:var(--forest)}
.field-check label{font-weight:400;margin:0;color:var(--muted)}
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-status{margin:1rem 0 0;font-weight:600;display:none}
.form-status.show{display:block}
.form-status.ok{color:var(--forest)}
.form-status.err{color:#c0563f}
.form-hint{font-size:.85rem;color:var(--muted);margin:.9rem 0 0}

/* map */
.map-wrap{margin-top:3rem}
.map-box{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);background:var(--forest-deep);aspect-ratio:16/7}
@media (max-width:680px){.map-box{aspect-ratio:4/5}}
.map-box iframe{width:100%;height:100%;border:0;display:block}
.map-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;text-align:center;padding:2rem;background:repeating-linear-gradient(45deg,rgba(255,255,255,.03),rgba(255,255,255,.03) 12px,transparent 12px,transparent 24px),var(--forest-deep);color:rgba(255,255,255,.9)}
.map-placeholder p{margin:0;max-width:420px}
.map-alt a{color:#e7c9ad}

/* ---------- Footer ---------- */
.site-footer{background:var(--forest-deep);color:rgba(255,255,255,.75);position:relative;padding-top:0}
.footer-band{width:100%;height:auto;opacity:.5;filter:invert(1) sepia(.2);margin-bottom:-2px;pointer-events:none}
.footer-inner{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:2.5rem;padding-top:3rem;padding-bottom:2.5rem}
@media (max-width:780px){.footer-inner{grid-template-columns:1fr;gap:1.8rem}}
.brand-footer{color:#fff;margin-bottom:1rem}
.footer-brand p{color:rgba(255,255,255,.6);font-size:.95rem;max-width:40ch}
.footer-nav h4,.footer-contact h4{color:#fff;font-family:var(--ff-serif);font-size:1.1rem;margin:0 0 .9rem}
.footer-nav ul{list-style:none;margin:0;padding:0;display:grid;gap:.5rem}
.footer-nav a,.footer-contact a{color:rgba(255,255,255,.75)}
.footer-nav a:hover,.footer-contact a:hover{color:#fff}
.footer-contact p{margin:0 0 .5rem;font-size:.95rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12)}
.footer-bottom-inner{display:flex;flex-wrap:wrap;justify-content:space-between;gap:.8rem;padding:1.3rem 0;font-size:.85rem}
.footer-bottom p{margin:0;color:rgba(255,255,255,.55)}
.footer-links{display:flex;gap:1.2rem;align-items:center}
.footer-links a{color:rgba(255,255,255,.7)}
.linklike{background:none;border:none;color:rgba(255,255,255,.7);cursor:pointer;font:inherit;padding:0;text-decoration:underline;text-underline-offset:3px}
.linklike:hover{color:#fff}

/* ---------- Lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:300;background:rgba(15,20,15,.92);display:flex;align-items:center;justify-content:center;padding:clamp(12px,4vw,48px);opacity:0;transition:opacity .3s}
.lightbox.open{opacity:1}
.lightbox[hidden]{display:none}
.lb-figure{margin:0;max-width:min(1100px,92vw);display:flex;flex-direction:column;align-items:center}
.lb-figure img{max-width:100%;max-height:82vh;border-radius:10px;box-shadow:0 30px 80px rgba(0,0,0,.5);background:#222}
.lb-figure figcaption{color:#fff;margin-top:1rem;font-weight:500;text-align:center}
.lb-close{position:absolute;top:18px;right:22px;width:48px;height:48px;font-size:2rem;line-height:1;color:#fff;background:rgba(255,255,255,.12);border:none;border-radius:50%;cursor:pointer;transition:background .2s}
.lb-close:hover{background:rgba(255,255,255,.25)}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:56px;height:56px;font-size:2.2rem;line-height:1;color:#fff;background:rgba(255,255,255,.12);border:none;border-radius:50%;cursor:pointer;transition:background .2s;display:flex;align-items:center;justify-content:center}
.lb-nav:hover{background:rgba(255,255,255,.25)}
.lb-prev{left:max(12px,2vw)}
.lb-next{right:max(12px,2vw)}
@media (max-width:560px){.lb-nav{width:46px;height:46px;font-size:1.7rem}}

/* ---------- Cookie banner ---------- */
.cookie-banner{position:fixed;left:50%;bottom:18px;transform:translateX(-50%) translateY(140%);z-index:250;width:min(960px,calc(100% - 28px));background:var(--paper);color:var(--ink);border-radius:var(--radius);box-shadow:var(--shadow-lg);border:1px solid var(--line);transition:transform .4s var(--ease)}
.cookie-banner.show{transform:translateX(-50%) translateY(0)}
.cookie-banner[hidden]{display:none}
.cookie-inner{display:flex;align-items:center;gap:1.4rem;padding:1.1rem 1.4rem;flex-wrap:wrap}
.cookie-text{margin:0;font-size:.92rem;color:var(--muted);flex:1;min-width:240px}
.cookie-actions{display:flex;gap:.7rem;flex-wrap:wrap}
@media (max-width:560px){.cookie-actions{width:100%}.cookie-actions .btn{flex:1}}

/* ---------- Reveal animation (only when JS is present) ---------- */
.js .reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.js .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.js .reveal{opacity:1;transform:none;transition:none}}

/* scroll offset for sticky header */
:target,section[id]{scroll-margin-top:84px}
