/* ============================================================
   Przystanek Podhale — style
   Paleta: kość słoniowa + drewno/orzech (#a9744f)
   Display: Fraunces · Body: Inter · System fallback
   ============================================================ */

:root{
  /* ── Motyw „kość słoniowa & drewno" — jasny / ciepły / przytulny ── */
  --bg:          #f7f3ec;   /* kość słoniowa / krem */
  --bg-warm:     #f0e9dd;   /* ciepły piaskowy (sekcje) */
  --bg-deep:     #211b16;   /* ciemne drewno (stopka/akcenty ciemne) */
  --surface:     #fffdf8;   /* karta (prawie biel) */
  --surface-2:   #faf5ec;   /* karta podniesiona */
  --surface-3:   #efe7d8;   /* hover */
  --ink:         #2e2820;   /* espresso / ciemny brąz (tekst główny) */
  --ink-soft:    #6f6557;   /* przygaszony tekst (taupe) */
  --ink-dim:     #9a8e7c;   /* jeszcze jaśniejszy */
  --line:        #e4dac8;   /* linie/obramowania */
  --line-soft:   #eee6d7;
  --pine:        #5a6b54;   /* rezerwa (nieużywane) */
  --pine-deep:   #2a241e;   /* rezerwa */
  --slate:       #efe7d8;
  /* ── Akcent: ciepłe drewno / orzech ── */
  --accent:      #a9744f;   /* orzech / drewno — główny akcent */
  --accent-bright:#bd8a64;  /* jaśniejsze drewno (hover) */
  --accent-deep: #8a5a39;   /* ciemny orzech (wypełnienia) */
  --accent-soft: #f1e6d8;   /* tło pigułek (jasny piaskowy) */
  --accent-ink:  #ffffff;   /* tekst NA drewnie (biel) */
  --pop:         #b8602f;    /* terakotowa iskra — ciepły akcent dla CTA/detali */
  --pop-soft:    rgba(184,96,47,.1);
  --sand:        #c79a6a;   /* piaskowy/złoty akcent ozdobny */
  --gold:        #c79a6a;
  --gold-soft:   #f1e6d8;
  --shadow-sm: 0 1px 2px rgba(74,57,38,.06), 0 2px 12px rgba(74,57,38,.05);
  --shadow-md: 0 8px 28px rgba(74,57,38,.1), 0 2px 8px rgba(74,57,38,.06);
  --shadow-lg: 0 30px 70px rgba(74,57,38,.16);
  --glow: 0 0 0 1px rgba(169,116,79,.25), 0 20px 50px rgba(74,57,38,.14);
  --r-sm: 8px;
  --r:    14px;
  --r-lg: 22px;
  --ff-display: "Fraunces", Georgia, "Times New Roman", serif;
  --ff-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --container: 1200px;
  --header-h: 72px;
  --ease: cubic-bezier(.22,.61,.36,1);
  color-scheme: light;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  font-size:1.04rem;
  overflow-x:hidden;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:var(--ink); text-decoration:none; transition:color .2s var(--ease), opacity .2s var(--ease); }
a:hover{ opacity:.7; }
h1,h2,h3{ font-family:var(--ff-display); font-weight:600; line-height:1.04; color:var(--ink); margin:0 0 .4em; letter-spacing:-.025em; }
h1{ font-size:clamp(2.6rem, 7vw, 5.5rem); font-weight:600; letter-spacing:-.035em; }
h2{ font-size:clamp(2rem, 4.6vw, 3.4rem); letter-spacing:-.03em; }
h3{ font-size:1.3rem; letter-spacing:-.015em; }
p{ margin:0 0 1rem; }
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:clamp(1.4rem, 5vw, 2.4rem); }

/* ── Skip link ── */
.skip-link{
  position:absolute; left:-9999px; top:0; z-index:200;
  background:var(--accent); color:#fff; padding:.7rem 1.1rem; border-radius:0 0 var(--r-sm) 0;
}
.skip-link:focus{ left:0; color:#fff; }

/* ── Eyebrow / kicker ── */
.kicker{
  font-family:var(--ff-body);
  text-transform:uppercase;
  letter-spacing:.2em;
  font-size:.72rem;
  font-weight:500;
  color:var(--ink-soft);
  margin:0 0 1rem;
  display:inline-flex; align-items:center; gap:.65rem;
}
.kicker::before{
  content:""; width:24px; height:1px; background:var(--pop); display:inline-block;
}
.kicker-light{ color:rgba(255,255,255,.7); }
.kicker-light::before{ background:var(--pop); }
.kicker-center{ justify-content:center; }

/* ============================================================
   Buttons
   ============================================================ */
.btn{
  --pad-y:.82rem; --pad-x:1.5rem;
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  font-family:var(--ff-body); font-weight:500; font-size:.98rem; letter-spacing:-.01em;
  padding:var(--pad-y) var(--pad-x);
  border-radius:999px; border:1px solid transparent; cursor:pointer;
  transition:transform .2s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease), color .2s var(--ease), border-color .25s var(--ease), opacity .2s var(--ease);
  text-align:center; line-height:1.1;
}
.btn:hover{ transform:translateY(-1px); }
.btn:active{ transform:translateY(0); }
.btn-sm{ --pad-y:.55rem; --pad-x:1.1rem; font-size:.9rem; }
.btn-accent{
  background:var(--pop); color:#fff;
  box-shadow:0 6px 20px rgba(184,96,47,.28);
}
.btn-accent:hover{
  background:#c96d39; color:#fff;
  box-shadow:0 10px 30px rgba(184,96,47,.4);
}
.btn-light{ background:var(--ink); color:#fff; }
.btn-light:hover{ background:var(--accent-deep); color:#fff; }
.btn-ghost{ background:transparent; border-color:var(--line); color:var(--ink); }
.btn-ghost:hover{ border-color:var(--ink-soft); opacity:1; }
.btn-outline{ background:transparent; border-color:var(--accent); color:var(--accent-deep); }
.btn-outline:hover{ background:var(--accent); border-color:var(--accent); color:#fff; opacity:1; }

:focus-visible{ outline:2px solid var(--pop); outline-offset:2px; border-radius:4px; }

/* ============================================================
   Header / Nav  (sticky)
   ============================================================ */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:100;
  border-bottom:1px solid transparent;
  transition:box-shadow .3s var(--ease), border-color .3s var(--ease);
}
/* Tło-szkło pojawia się dopiero po scrollu; na górze header jest przezroczysty
   i nakłada się na hero (efekt Apple). Pseudo-element zamiast tła na .site-header,
   by backdrop-filter nie psuł position:fixed panelu mobilnego. */
.site-header::before{
  content:""; position:absolute; inset:0; z-index:-1;
  background:rgba(247,243,236,.8);
  backdrop-filter:saturate(120%) blur(14px);
  -webkit-backdrop-filter:saturate(120%) blur(14px);
  opacity:0; transition:opacity .3s var(--ease);
}
.site-header.scrolled{
  box-shadow:var(--shadow-sm);
  border-bottom-color:var(--line);
}
.site-header.scrolled::before{ opacity:1; }
.header-inner{
  max-width:1340px; margin-inline:auto;
  padding:.55rem clamp(1.2rem,4vw,2.6rem);
  display:flex; align-items:center; justify-content:space-between; gap:1.2rem;
  min-height:var(--header-h);
}
.brand{ display:inline-flex; align-items:center; gap:.65rem; color:var(--ink); }
.brand:hover{ color:var(--ink); opacity:1; }
.brand-mark{ display:inline-flex; }
.brand-mark img{ width:34px; height:34px; border-radius:9px; object-fit:cover; display:block; }
.footer-brand .brand-mark img{ width:40px; height:40px; border-radius:10px; }
/* Logo zawierające napis — skalowane po wysokości, pełne proporcje (bez kadrowania) */
.brand-logo-only{ gap:0; }
.brand-img{ height:38px; width:auto; max-width:210px; object-fit:contain; display:block; }
.footer-logo-img{ height:46px; width:auto; max-width:230px; object-fit:contain; display:block; margin-bottom:.9rem; }
.brand-text{ display:flex; flex-direction:column; line-height:1; }
.brand-name{ font-family:var(--ff-display); font-weight:600; font-size:1.18rem; letter-spacing:-.01em; }
.brand-sub{ font-family:var(--ff-body); font-size:.7rem; letter-spacing:.28em; text-transform:uppercase; color:var(--accent); margin-top:3px; }

.site-nav{ display:flex; align-items:center; gap:1.2rem; }
.site-nav ul{ display:flex; gap:.15rem; list-style:none; margin:0; padding:0; }
.site-nav ul a{
  display:block; padding:.5rem .8rem; color:var(--ink-soft); font-weight:500; font-size:.96rem;
  border-radius:999px; position:relative; transition:color .2s var(--ease), background .2s var(--ease);
}
.site-nav ul a::after{
  content:""; position:absolute; left:.8rem; right:.8rem; bottom:.32rem; height:2px;
  background:var(--pop); border-radius:2px; transform:scaleX(0); transform-origin:left; transition:transform .25s var(--ease);
}
.site-nav ul a:hover{ color:var(--ink); }
.site-nav ul a:hover::after,
.site-nav ul a[aria-current="page"]::after{ transform:scaleX(1); }
.site-nav ul a[aria-current="page"]{ color:var(--ink); }

.nav-actions{ display:flex; align-items:center; gap:1rem; }
.lang-switch{ display:inline-flex; align-items:center; gap:.4rem; font-size:.85rem; font-weight:600; color:var(--ink-soft); }
.lang-switch a{ color:var(--ink-soft); padding:.15rem .15rem; }
.lang-switch a.is-on{ color:var(--ink); }
.lang-switch a:hover{ color:var(--accent); }

/* Stan transparentny (header nad hero, przed scrollem) — jasny tekst dla czytelności na zdjęciu.
   Tylko desktop: na mobile menu to osobny jasny panel z ciemnym tekstem. */
@media (min-width:761px){
  .site-header:not(.scrolled) .brand{ color:#fff; }
  .site-header:not(.scrolled) .brand-sub{ color:rgba(255,255,255,.85); }
  /* Logo (obraz z napisem) nad ciemnym hero — delikatny cień dla czytelności na zdjęciu */
  .site-header:not(.scrolled) .brand-img{ filter:drop-shadow(0 2px 8px rgba(0,0,0,.55)); }
  .site-header:not(.scrolled) .site-nav ul a{ color:rgba(255,255,255,.82); }
  .site-header:not(.scrolled) .site-nav ul a:hover,
  .site-header:not(.scrolled) .site-nav ul a[aria-current="page"]{ color:#fff; }
  .site-header:not(.scrolled) .lang-switch,
  .site-header:not(.scrolled) .lang-switch a{ color:rgba(255,255,255,.75); }
  .site-header:not(.scrolled) .lang-switch a.is-on{ color:#fff; }
}
.site-header:not(.scrolled) .nav-burger span{ background:#fff; }
/* gdy mobilne menu otwarte — X nad jasnym panelem musi być ciemny */
.nav-toggle:checked ~ .header-inner .nav-burger span{ background:var(--ink); }

/* burger + toggle */
.nav-toggle{ position:absolute; }
.nav-burger{ display:none; width:44px; height:44px; border-radius:12px; cursor:pointer; align-items:center; justify-content:center; flex-direction:column; gap:5px; }
.nav-burger span{ width:22px; height:2px; background:var(--ink); border-radius:2px; transition:transform .3s var(--ease), opacity .2s var(--ease), background .2s var(--ease); }
.nav-scrim{ display:none; }

/* ============================================================
   Hero — wyśrodkowany, monumentalny (styl Apple)
   ============================================================ */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center; justify-content:center; overflow:hidden; text-align:center; }
.hero-media{ position:absolute; inset:0; z-index:0; }
.hero-media img,.hero-media video{ width:100%; height:100%; object-fit:cover; }
.hero-media::after{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(120% 100% at 50% 35%, rgba(8,8,10,.35) 0%, rgba(8,8,10,.55) 55%, rgba(8,8,10,.88) 100%),
    linear-gradient(180deg, rgba(8,8,10,.5) 0%, transparent 25%, transparent 60%, rgba(8,8,10,.85) 100%);
}
.hero-inner{ position:relative; z-index:1; width:100%; max-width:var(--container); margin-inline:auto; padding:6rem clamp(1.4rem,5vw,2.4rem) 4rem; color:#fff; }
.hero-centered{ display:flex; flex-direction:column; align-items:center; }
.hero-title{ color:#fff; max-width:16ch; margin:0 0 .5em; text-shadow:0 4px 50px rgba(0,0,0,.55); }
.hero-kicker{ color:rgba(255,255,255,.72); margin-bottom:1.5rem; }
.hero-sub{ color:rgba(255,255,255,.9); font-size:clamp(1.1rem,2vw,1.4rem); font-weight:400; max-width:50ch; margin:0 auto 2.2rem; text-shadow:0 2px 24px rgba(0,0,0,.5); line-height:1.5; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:.8rem; justify-content:center; }

/* wskaźnik scrollowania */
.hero-scroll{ position:absolute; bottom:2rem; left:50%; transform:translateX(-50%); z-index:2; width:26px; height:42px; border:1.5px solid rgba(255,255,255,.35); border-radius:14px; display:flex; justify-content:center; padding-top:7px; transition:border-color .2s var(--ease); }
.hero-scroll:hover{ border-color:rgba(255,255,255,.7); opacity:1; }
.hero-scroll span{ width:3px; height:8px; border-radius:2px; background:#fff; animation:scrollDot 1.8s var(--ease) infinite; }
@keyframes scrollDot{ 0%{ opacity:0; transform:translateY(-3px);} 40%{ opacity:1;} 80%{ opacity:0; transform:translateY(8px);} 100%{opacity:0;} }
@media (prefers-reduced-motion:reduce){ .hero-scroll span{ animation:none; } }

/* ============================================================
   Pasek statystyk
   ============================================================ */
.stats-band{ border-bottom:1px solid var(--line); background:var(--bg-warm); }
.stats-grid{ display:grid; grid-template-columns:repeat(4,1fr); }
.stat{ padding:clamp(1.8rem,4vw,2.8rem) 1rem; text-align:center; border-right:1px solid var(--line); }
.stat:last-child{ border-right:0; }
.stat-num{ display:block; font-family:var(--ff-display); font-size:clamp(2.2rem,4vw,3.2rem); font-weight:600; letter-spacing:-.03em; line-height:1; color:var(--ink); }
.stat-num small{ font-size:.42em; font-weight:500; color:var(--ink-soft); margin-left:.1em; letter-spacing:0; }
.stat-label{ display:block; margin-top:.6rem; font-size:.86rem; color:var(--ink-soft); letter-spacing:.01em; }

/* ============================================================
   Sections
   ============================================================ */
.section{ padding:clamp(4.5rem,10vw,8rem) 0; }
.section-tight{ padding:clamp(3rem,6vw,4.5rem) 0; }
.section-warm{ background:linear-gradient(180deg, var(--bg-warm), var(--bg)); }
.section-pine{
  background:linear-gradient(180deg, var(--surface) 0%, var(--bg-warm) 100%);
  color:var(--ink); position:relative; overflow:hidden;
  border-top:1px solid var(--line);
}
.section-pine::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(90deg, transparent, rgba(184,96,47,.4) 50%, transparent);
  height:2px; top:0;
}
.section-pine h2,.section-pine h3{ color:var(--ink); }
.section-pine .kicker,
.section-pine .kicker-light{ color:var(--ink-soft); }
.section-pine .kicker::before,
.section-pine .kicker-light::before{ background:var(--pop); }
.lead{ font-size:clamp(1.08rem,1.8vw,1.28rem); color:var(--ink-soft); max-width:60ch; }
.section-pine .lead{ color:var(--ink-soft); }

.split{ display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.split-media{ position:relative; }
.split-media img{ border-radius:var(--r-lg); box-shadow:var(--shadow-lg); aspect-ratio:5/4; object-fit:cover; width:100%; }
.split-media::before{
  content:""; position:absolute; inset:auto -16px -16px auto; width:62%; height:62%;
  border:2px solid var(--gold); border-radius:var(--r-lg); z-index:-1;
}
.eyebrow-num{ font-family:var(--ff-display); color:var(--gold); font-size:.95rem; }

/* ── Feature grid ── */
.features{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.1rem; margin-top:2.4rem; }
.feature{
  position:relative;
  background:linear-gradient(165deg, var(--surface-2), var(--surface));
  border:1px solid var(--line); border-radius:var(--r);
  padding:1.6rem 1.5rem; box-shadow:var(--shadow-sm);
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease);
  overflow:hidden;
}
.feature::before{
  content:""; position:absolute; left:0; right:0; top:0; height:2px;
  background:linear-gradient(90deg, transparent, var(--accent), transparent);
  opacity:0; transition:opacity .3s var(--ease);
}
.feature:hover{ transform:translateY(-5px); box-shadow:var(--shadow-md); border-color:rgba(169,116,79,.35); }
.feature:hover::before{ opacity:1; }
.feature-ico{
  width:48px; height:48px; border-radius:13px; display:grid; place-items:center;
  background:var(--accent-soft);
  color:var(--accent-deep); margin-bottom:1rem; border:1px solid rgba(169,116,79,.22);
}
.feature-ico svg{ width:24px; height:24px; }
.feature h3{ margin-bottom:.35rem; font-family:var(--ff-display); font-size:1.12rem; }
.feature p{ margin:0; color:var(--ink-soft); font-size:.96rem; }

/* ── Osady cards ── */
.osady{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; margin-top:2.6rem; }
.osada-card{
  position:relative; border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-md);
  min-height:460px; display:flex; align-items:flex-end; color:#fff; isolation:isolate;
  border:1px solid var(--line); transition:box-shadow .35s var(--ease), transform .35s var(--ease), border-color .35s var(--ease);
}
.osada-card img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2; transition:transform .8s var(--ease); }
.osada-card::after{
  content:""; position:absolute; inset:0; z-index:-1;
  background:
    linear-gradient(180deg, rgba(8,8,10,0) 25%, rgba(8,8,10,.55) 62%, rgba(8,8,10,.92) 100%),
    radial-gradient(90% 60% at 50% 120%, rgba(255,255,255,.06), transparent 60%);
}
.osada-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-lg), var(--glow); border-color:rgba(255,255,255,.2); }
.osada-card:hover img{ transform:scale(1.07); }
.osada-body{ padding:1.9rem; width:100%; }
.osada-body .kicker{ color:rgba(255,255,255,.75); }
.osada-body .kicker::before{ background:var(--pop); }
.osada-card h3{ color:#fff; font-size:1.8rem; margin-bottom:.5rem; }
.osada-card p{ color:rgba(255,255,255,.92); font-size:.98rem; margin-bottom:1.1rem; max-width:42ch; }
.osada-price{ font-family:var(--ff-display); color:var(--sand); font-weight:600; }
.osada-links{ display:flex; gap:.7rem; flex-wrap:wrap; }

/* ============================================================
   Page hero (subpages)
   ============================================================ */
.page-hero{ position:relative; min-height:58vh; display:flex; align-items:flex-end; overflow:hidden; padding-top:var(--header-h); }
.page-hero img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2; }
.page-hero::after{
  content:""; position:absolute; inset:0; z-index:-1;
  background:
    linear-gradient(180deg, rgba(8,8,10,.5) 0%, rgba(8,8,10,.18) 40%, rgba(8,8,10,.85) 100%);
}
.page-hero-inner{ color:#fff; padding-block:clamp(2.6rem,6vw,4.2rem); width:100%; }
.page-hero h1{ color:#fff; text-shadow:0 2px 40px rgba(0,0,0,.5); }
.page-hero .kicker{ color:rgba(255,255,255,.72); }
.page-hero .lead{ color:rgba(255,255,255,.92); }
.price-pill{
  display:inline-flex; align-items:baseline; gap:.4rem; margin-top:1.2rem;
  background:rgba(0,0,0,.3); color:#fff;
  padding:.55rem 1.2rem; border-radius:999px; font-family:var(--ff-body); font-weight:500; font-size:.98rem;
  border:1px solid rgba(255,255,255,.25); backdrop-filter:blur(8px);
}
.price-pill strong{ color:var(--sand); font-weight:600; }

/* breadcrumb */
/* Breadcrumbs ukryte wizualnie, ale dostępne dla czytników ekranu i Google
   (dane SEO BreadcrumbList w JSON-LD pozostają aktywne). */
.crumbs{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

/* ── Amenities row ── */
.amen-list{ display:flex; flex-wrap:wrap; gap:.7rem; margin:1.5rem 0 0; padding:0; list-style:none; }
.amen-list li{
  display:inline-flex; align-items:center; gap:.55rem;
  background:var(--surface); border:1px solid var(--line); border-radius:999px;
  padding:.55rem 1.05rem; font-size:.92rem; font-weight:500; color:var(--ink);
}
.amen-list svg{ width:18px; height:18px; color:var(--accent); flex:none; }

/* ── Prose ── */
.prose p{ color:var(--ink-soft); max-width:68ch; }
.prose p:first-of-type::first-letter{
  font-family:var(--ff-display); font-size:3.1em; line-height:.8; float:left;
  padding:.05em .12em 0 0; color:var(--accent); font-weight:600;
}

/* ── Gallery ── */
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); gap:.8rem; margin-top:1.8rem; }
.gallery a{ display:block; border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow-sm); aspect-ratio:3/2; }
.gallery img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.gallery a:hover img{ transform:scale(1.08); }
.gallery a:nth-child(1){ grid-column:span 2; grid-row:span 2; aspect-ratio:1/1; }

/* ── Tabs (atrakcje) — czysty CSS przez radio ── */
.tabs{ margin-top:2rem; }
.tabs input{ position:absolute; opacity:0; pointer-events:none; }
.tabs-labels{ display:flex; gap:.5rem; flex-wrap:wrap; border-bottom:1px solid var(--line); }
.tabs-labels label{
  padding:.7rem 1.1rem; cursor:pointer; font-weight:600; color:var(--ink-soft);
  border-bottom:2px solid transparent; margin-bottom:-1px; transition:color .2s, border-color .2s;
}
.tabs-labels label:hover{ color:var(--ink); }
.tab-panel{ display:none; padding-top:1.6rem; }
.tab-panel .split-media img{ aspect-ratio:3/2; }
#tab-1:checked ~ .tabs-labels label[for="tab-1"],
#tab-2:checked ~ .tabs-labels label[for="tab-2"]{ color:var(--accent); border-bottom-color:var(--accent); }
#tab-1:checked ~ .tab-panels #panel-1,
#tab-2:checked ~ .tab-panels #panel-2{ display:block; animation:fade .4s var(--ease); }

/* ============================================================
   Reservation
   ============================================================ */
.resv-wrap{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(1rem,2vw,1.4rem); box-shadow:var(--shadow-md); }
.resv-frame{ width:100%; min-height:560px; border:0; border-radius:var(--r); background:#fff; }
.resv-help{ display:flex; align-items:center; gap:.8rem; flex-wrap:wrap; margin-top:1.6rem; color:var(--ink-soft); }

/* ============================================================
   Contact
   ============================================================ */
.contact-grid{ display:grid; grid-template-columns:1.1fr 1fr; gap:clamp(2rem,5vw,4rem); align-items:start; }
.contact-cards{ display:grid; gap:1rem; }
.contact-card{
  display:flex; gap:1.1rem; align-items:flex-start;
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r); padding:1.5rem; box-shadow:var(--shadow-sm);
  transition:transform .2s var(--ease), box-shadow .2s var(--ease);
}
.contact-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow-md); }
.contact-ico{ width:50px; height:50px; flex:none; border-radius:14px; background:var(--accent-soft); color:var(--accent-deep); display:grid; place-items:center; border:1px solid rgba(169,116,79,.22); }
.contact-ico svg{ width:26px; height:26px; }
.contact-card h3{ margin:0 0 .25rem; font-size:1.05rem; }
.contact-card .big{ font-family:var(--ff-display); font-size:1.45rem; font-weight:600; color:var(--ink); word-break:break-word; }
.contact-card .muted{ color:var(--ink-soft); font-size:.9rem; margin:0; }
.contact-card a.big:hover{ color:var(--accent); }
.contact-media img{ border-radius:var(--r-lg); box-shadow:var(--shadow-lg); aspect-ratio:4/5; object-fit:cover; width:100%; }
.mail-reveal{ background:none; border:0; padding:0; font:inherit; color:var(--accent); cursor:pointer; text-decoration:underline; }

/* ============================================================
   Blog
   ============================================================ */
.blog-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; margin-top:2.6rem; }
.post-card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden;
  box-shadow:var(--shadow-sm); display:flex; flex-direction:column;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}
.post-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow-lg); }
.post-thumb{ aspect-ratio:3/2; overflow:hidden; }
.post-thumb img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.post-card:hover .post-thumb img{ transform:scale(1.06); }
.post-body{ padding:1.5rem; display:flex; flex-direction:column; gap:.7rem; flex:1; }
.post-tag{ align-self:flex-start; font-size:.72rem; text-transform:uppercase; letter-spacing:.12em; font-weight:600; color:var(--accent); background:var(--accent-soft); padding:.25rem .7rem; border-radius:999px; }
.post-card h3{ margin:0; font-size:1.22rem; }
.post-card h3 a{ color:var(--ink); }
.post-card h3 a:hover{ color:var(--accent); }
.post-meta{ font-size:.85rem; color:var(--ink-soft); margin-top:auto; display:flex; gap:.7rem; align-items:center; }
.post-excerpt{ color:var(--ink-soft); font-size:.96rem; margin:0; }
.read-link{ font-weight:600; display:inline-flex; align-items:center; gap:.35rem; }
.read-link svg{ width:16px; height:16px; transition:transform .2s var(--ease); }
.read-link:hover svg{ transform:translateX(3px); }

/* Article */
.article{ max-width:760px; margin-inline:auto; }
.article-hero{ position:relative; border-radius:var(--r-lg); overflow:hidden; margin-bottom:2.2rem; box-shadow:var(--shadow-lg); }
.article-hero img{ width:100%; aspect-ratio:16/9; object-fit:cover; }
.article h1{ font-size:clamp(2rem,4vw,2.9rem); }
.article-meta{ display:flex; gap:1rem; align-items:center; color:var(--ink-soft); font-size:.9rem; margin-bottom:1.8rem; flex-wrap:wrap; }
.article-content{ font-size:1.12rem; line-height:1.8; }
.article-content h2{ margin-top:2.4rem; }
.article-content h3{ margin-top:1.8rem; font-size:1.25rem; }
.article-content p{ color:var(--ink); }
.article-content blockquote{
  margin:2rem 0; padding:1.2rem 1.6rem; border-left:4px solid var(--accent);
  background:var(--accent-soft); border-radius:0 var(--r) var(--r) 0; font-family:var(--ff-display);
  font-size:1.2rem; color:var(--ink); font-style:italic;
}
.article-content ul{ padding-left:1.2rem; }
.article-content li{ margin-bottom:.5rem; color:var(--ink); }
.article-content img{ border-radius:var(--r); margin:1.8rem 0; box-shadow:var(--shadow-md); }
.article-tip{ background:var(--surface-2); border:1px solid var(--line); border-radius:var(--r); padding:1.3rem 1.5rem; margin:2rem 0; }
.article-tip strong{ color:var(--accent); }
.article-footer{ margin-top:3rem; padding-top:2rem; border-top:1px solid var(--line); display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem; }
.article-cta{ margin-top:2.6rem; }
.article-cta-inner{ background:var(--surface-2); border:1px solid var(--line); border-radius:var(--r-lg); padding:1.8rem 2rem; display:flex; align-items:center; justify-content:space-between; gap:1.5rem; flex-wrap:wrap; }
.article-cta-inner > div{ flex:1 1 18rem; }
.article-cta-inner .btn{ flex:0 0 auto; }

/* ============================================================
   CTA band + Footer
   ============================================================ */
/* ── Pasy „drewno + góral" — jasne naturalne drewno (dąb/sosna) z teksturą słojów ── */
.cta-band{
  position:relative; overflow:hidden;
  background:
    repeating-linear-gradient(90deg,
      rgba(150,108,66,.12) 0px, rgba(150,108,66,.12) 1px,
      transparent 1px, transparent 6px,
      rgba(120,82,48,.08) 6px, rgba(120,82,48,.08) 7px,
      transparent 7px, transparent 15px,
      rgba(150,108,66,.09) 15px, rgba(150,108,66,.09) 16px,
      transparent 16px, transparent 26px),
    linear-gradient(180deg, #e6cca3 0%, #dcbf90 55%, #d0ad80 100%);
  color:#43331f;
}
.cta-band-inner{ position:relative; z-index:1; display:flex; align-items:center; justify-content:space-between; gap:2rem; padding-block:clamp(2.8rem,5vw,3.8rem); flex-wrap:wrap; }
.cta-band h2{ color:#3a2c18; margin:0; }
.cta-band .lead,.cta-band p{ color:#5a4527; }
.cta-band .kicker-light{ color:#8a5a2f; }
.cta-band .kicker-light::before{ background:#8a5a2f; }
.cta-band-actions{ display:flex; gap:.8rem; flex-wrap:wrap; }

/* Góralski pas parzenicy — dekoracyjny zygzak na górze pasów drewnianych */
.goral-band{ position:relative; }
.goral-band::before{
  content:""; position:absolute; top:0; left:0; right:0; height:9px; z-index:2;
  background:
    linear-gradient(135deg, #8a5a2f 25%, transparent 25%) 0 0,
    linear-gradient(225deg, #8a5a2f 25%, transparent 25%) 0 0;
  background-size:14px 9px; background-repeat:repeat-x;
}

.site-footer{
  position:relative;
  background:
    repeating-linear-gradient(90deg,
      rgba(0,0,0,.14) 0px, rgba(0,0,0,.14) 1px,
      transparent 1px, transparent 6px,
      rgba(0,0,0,.09) 6px, rgba(0,0,0,.09) 7px,
      transparent 7px, transparent 15px,
      rgba(0,0,0,.11) 15px, rgba(0,0,0,.11) 16px,
      transparent 16px, transparent 26px),
    linear-gradient(180deg, #6b4a2e 0%, #5a3e26 60%, #4a321e 100%);
  color:rgba(243,237,226,.75); padding:clamp(2.8rem,5vw,4rem) 0 1.6rem;
}
.footer-grid{ display:grid; grid-template-columns:2fr 1fr 1fr 1.4fr; gap:2rem; }
.footer-name{ font-family:var(--ff-display); font-size:1.3rem; color:#fff; margin:.7rem 0 .4rem; }
.footer-tagline{ font-size:.94rem; color:rgba(243,237,226,.55); max-width:34ch; margin:0; }
.footer-col h3{ color:#fff; font-size:.85rem; text-transform:uppercase; letter-spacing:.14em; font-family:var(--ff-body); margin-bottom:1rem; }
.footer-col ul{ list-style:none; margin:0; padding:0; display:grid; gap:.6rem; }
.footer-col a{ color:rgba(243,237,226,.7); font-size:.96rem; }
.footer-col a:hover{ color:var(--sand); opacity:1; }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; gap:1rem; margin-top:2.6rem; padding-top:1.6rem; border-top:1px solid rgba(255,255,255,.12); font-size:.85rem; color:rgba(243,237,226,.5); flex-wrap:wrap; }

/* ============================================================
   Cookie bar
   ============================================================ */
.cookie-bar{
  position:fixed; left:1rem; right:1rem; bottom:1rem; z-index:150;
  max-width:560px; margin-inline:auto;
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r);
  box-shadow:var(--shadow-lg); padding:1.2rem 1.3rem;
  display:flex; gap:1rem; align-items:center; flex-wrap:wrap; justify-content:space-between;
  transform:translateY(140%); transition:transform .35s var(--ease);
}
.cookie-bar.show{ transform:translateY(0); }
.cookie-text{ margin:0; font-size:.9rem; color:var(--ink-soft); flex:1 1 260px; }
.cookie-actions{ display:flex; gap:.6rem; }

/* ============================================================
   Animacje wejścia (scroll-driven gdy wspierane, fallback bez)
   ============================================================ */
@keyframes fade{ from{opacity:0} to{opacity:1} }
@keyframes rise{ from{opacity:0; transform:translateY(26px)} to{opacity:1; transform:translateY(0)} }

.reveal{ animation:rise .7s var(--ease) both; }
@supports (animation-timeline: view()){
  .reveal{
    animation:rise linear both;
    animation-timeline:view();
    animation-range:entry 0% entry 42%;
  }
}
.d1{ animation-delay:.06s } .d2{ animation-delay:.12s } .d3{ animation-delay:.18s }
.d4{ animation-delay:.24s } .d5{ animation-delay:.30s } .d6{ animation-delay:.36s }

@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; }
  .reveal{ opacity:1 !important; transform:none !important; }
}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 960px){
  .split{ grid-template-columns:1fr; }
  .split-media{ order:-1; }
  .features{ grid-template-columns:repeat(2,1fr); }
  .osady{ grid-template-columns:repeat(2,1fr); }
  .contact-grid{ grid-template-columns:1fr; }
  .blog-grid{ grid-template-columns:repeat(2,1fr); }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:2rem 1.5rem; }
  .footer-brand{ grid-column:1 / -1; }
}

@media (max-width: 760px){
  :root{ --header-h:64px; }
  /* mobilne menu — pełnoekranowy panel przypięty do viewportu */
  .nav-burger{ display:flex; }
  .site-nav{
    position:fixed; top:0; right:0; bottom:0; left:auto;
    width:min(88vw,360px); height:100dvh; max-height:100dvh;
    background:var(--bg-warm);
    border-left:1px solid var(--line);
    flex-direction:column; align-items:stretch; justify-content:flex-start;
    gap:0; padding:calc(var(--header-h) + 1.4rem) 1.5rem 2rem;
    transform:translateX(101%); transition:transform .38s var(--ease);
    box-shadow:var(--shadow-lg); z-index:120; overflow-y:auto;
    -webkit-overflow-scrolling:touch;
  }
  .site-nav ul{ flex-direction:column; gap:.15rem; width:100%; }
  .site-nav ul a{ padding:.95rem .4rem; font-size:1.12rem; color:var(--ink); border-bottom:1px solid var(--line-soft); border-radius:0; }
  .site-nav ul a::after{ display:none; }
  .site-nav ul a[aria-current="page"]{ color:var(--accent-bright); }
  .nav-actions{ margin-top:1.6rem; flex-direction:column; align-items:stretch; gap:1rem; }
  .nav-actions .btn{ width:100%; }
  .lang-switch{ justify-content:center; font-size:1.05rem; }
  .nav-toggle:checked ~ .header-inner .site-nav{ transform:translateX(0); }
  .nav-scrim{ display:block; position:fixed; inset:0; background:rgba(0,0,0,.6); opacity:0; pointer-events:none; transition:opacity .3s var(--ease); z-index:110; }
  .nav-toggle:checked ~ .nav-scrim{ opacity:1; pointer-events:auto; }
  /* burger -> X */
  .nav-toggle:checked ~ .header-inner .nav-burger span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  .nav-toggle:checked ~ .header-inner .nav-burger span:nth-child(2){ opacity:0; }
  .nav-toggle:checked ~ .header-inner .nav-burger span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
  body:has(.nav-toggle:checked){ overflow:hidden; }

  .features{ grid-template-columns:1fr; }
  .osady{ grid-template-columns:1fr; gap:1.6rem; }
  .gallery{ grid-template-columns:repeat(2,1fr); }
  .gallery a:nth-child(1){ grid-column:span 2; grid-row:auto; aspect-ratio:3/2; }
  .blog-grid{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr; }
  .cta-band-inner,.footer-bottom{ flex-direction:column; align-items:flex-start; }
  .hero{ min-height:100svh; }
  .stats-grid{ grid-template-columns:repeat(2,1fr); }
  .stat:nth-child(2){ border-right:0; }
  .stat:nth-child(1),.stat:nth-child(2){ border-bottom:1px solid var(--line); }
}

/* fallback gdy :has nieobsługiwane — pokaż nav na desktop ok; mobile używa transform */
@supports not (selector(:has(*))){
  @media (max-width:760px){
    .nav-toggle:checked ~ .header-inner .site-nav{ transform:translateX(0); }
  }
}

/* drobny wzór cyfrowania jako separator sekcji */
.thread{ height:2px; background:repeating-linear-gradient(90deg, var(--gold) 0 10px, transparent 10px 20px); opacity:.5; border:0; margin:0; }
