/* =================================================================
   Willa Danuta — Kwatery Prywatne, Busko-Zdrój
   Kierunek: przytulny pensjonat uzdrowiskowy — beż / szałwia / drewno
   Typografia: Cormorant (display serif) + Karla (humanistyczny grotesk)
   Mobile-first · WCAG AA · soft UI
   ================================================================= */

/* ---------- Fonty self-host ---------- */
@font-face{font-family:"Cormorant";src:url("assets/fonts/cormorant-600-latin-ext.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap;unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:"Cormorant";src:url("assets/fonts/cormorant-600-latin.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"Cormorant";src:url("assets/fonts/cormorant-700-latin-ext.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap;unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:"Cormorant";src:url("assets/fonts/cormorant-700-latin.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"Cormorant";src:url("assets/fonts/cormorant-500-latin-ext.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap;unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:"Cormorant";src:url("assets/fonts/cormorant-500-latin.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}

@font-face{font-family:"Karla";src:url("assets/fonts/karla-400-latin-ext.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap;unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:"Karla";src:url("assets/fonts/karla-400-latin.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"Karla";src:url("assets/fonts/karla-500-latin-ext.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap;unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:"Karla";src:url("assets/fonts/karla-500-latin.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"Karla";src:url("assets/fonts/karla-600-latin-ext.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap;unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:"Karla";src:url("assets/fonts/karla-600-latin.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"Karla";src:url("assets/fonts/karla-700-latin-ext.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap;unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:"Karla";src:url("assets/fonts/karla-700-latin.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}

/* ---------- Tokeny ---------- */
:root{
  --paper:#FBF7EF;        /* główne tło */
  --cream:#F3EBDD;        /* sekcja alternatywna */
  --cream2:#EFE6D5;
  --card:#FFFFFF;
  --ink:#26241F;         /* tekst główny — kontrast na paper ~13:1 */
  --ink-soft:#4A463E;    /* tekst drugorzędny — ~7:1 */
  --muted:#6B6557;       /* podpisy — ~4.7:1 */
  --line:#E2D7C3;        /* delikatne linie */
  --line-strong:#D2C4AB;

  --sage:#3C5A4A;        /* brand głęboka szałwia */
  --sage-deep:#2E4639;   /* ciemniejsza */
  --sage-soft:#6E8C77;   /* jaśniejsza szałwia */
  --sage-tint:#E7EEE7;   /* delikatne zielone tło */

  --clay:#985430;        /* terakota — primary CTA / eyebrow (AA na bieli, cream, cream2) */
  --clay-deep:#7E4427;   /* hover */
  --gold:#C9A86A;        /* złoty detal */

  /* kolory na ciemnej szałwii */
  --on-sage:#F4EFE3;        /* tekst — kontrast na #3C5A4A ~9.7:1 */
  --on-sage-mut:#CEDACF;    /* drugorzędny na szałwii ~6.4:1 */
  --on-sage-acc:#E8C98B;    /* akcent gold-jasny na szałwii ~6.0:1 */

  --radius:16px;
  --radius-lg:22px;
  --radius-sm:10px;
  --shadow:0 1px 2px rgba(38,36,31,.05), 0 8px 26px -12px rgba(38,36,31,.18);
  --shadow-lg:0 2px 6px rgba(38,36,31,.06), 0 22px 50px -22px rgba(38,36,31,.30);
  --wrap:1140px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::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;background:var(--paper);color:var(--ink);
  font-family:"Karla",system-ui,-apple-system,Segoe UI,sans-serif;
  font-size:17px;line-height:1.65;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:"Cormorant",Georgia,serif;font-weight:700;line-height:1.08;margin:0;letter-spacing:.2px}
h1{font-size:clamp(2.5rem,7vw,4.4rem);font-weight:600}
h2{font-size:clamp(2rem,4.6vw,3.1rem);font-weight:600}
h3{font-size:1.42rem}
h4{font-size:1.12rem;font-family:"Karla",sans-serif;font-weight:700;letter-spacing:.3px}
p{margin:0 0 1rem}
em{font-style:italic;color:var(--clay)}
.tnum{font-variant-numeric:tabular-nums}

/* ---------- Layout ---------- */
.wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:20px}
.section{padding:clamp(3.2rem,8vw,6rem) 0}
.section--cream{background:var(--cream)}
.section--cream2{background:var(--cream2)}
.section--sage{background:var(--sage);color:var(--on-sage)}
.section--sage-deep{background:var(--sage-deep);color:var(--on-sage)}
.mt-1{margin-top:.6rem}.mt-2{margin-top:1.4rem}.mt-3{margin-top:2.4rem}
.center{text-align:center}

.skip-link{position:absolute;left:-999px;top:8px;background:var(--sage);color:var(--on-sage);
  padding:10px 16px;border-radius:8px;z-index:200}
.skip-link:focus{left:12px}

:focus-visible{outline:3px solid var(--clay);outline-offset:3px;border-radius:6px}
.section--sage :focus-visible,.section--sage-deep :focus-visible,.on-sage :focus-visible{outline-color:var(--on-sage-acc)}

/* ---------- Eyebrow / ornament ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:.55rem;font-family:"Karla",sans-serif;
  font-weight:700;font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--clay);margin-bottom:1rem}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold)}
.on-sage .eyebrow,.section--sage .eyebrow,.section--sage-deep .eyebrow{color:var(--on-sage-acc)}
.on-sage .eyebrow::before,.section--sage .eyebrow::before,.section--sage-deep .eyebrow::before{background:var(--on-sage-acc)}
.ornament{margin:1.1rem auto 0;width:42px;color:var(--gold)}
.ornament svg{width:42px;height:auto}

.section-head{max-width:46rem}
.section-head--center{margin-inline:auto;text-align:center}
.section-head p{color:var(--ink-soft);font-size:1.08rem;max-width:40rem}
.section-head--center p{margin-inline:auto}
.section--sage .section-head p,.section--sage-deep .section-head p{color:var(--on-sage-mut)}

.lead{font-size:1.14rem;color:var(--ink-soft)}
.section--sage .lead,.section--sage-deep .lead,.on-sage .lead{color:var(--on-sage-mut)}

/* ---------- Ikony ---------- */
.ico{width:1.3em;height:1.3em;flex:none;stroke-width:1.6;vertical-align:middle}

/* ---------- Przyciski ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:"Karla",sans-serif;font-weight:600;font-size:1rem;line-height:1;
  padding:.92rem 1.5rem;border-radius:999px;border:1.5px solid transparent;cursor:pointer;
  white-space:nowrap;transition:transform .2s var(--ease),background .2s,box-shadow .2s,color .2s,border-color .2s;
  min-height:48px}
.btn .ico{width:1.15em;height:1.15em}
.btn--primary{background:var(--clay);color:#fff;box-shadow:0 10px 24px -12px rgba(168,94,56,.8)}
.btn--primary:hover{background:var(--clay-deep);transform:translateY(-2px)}
.btn--sage{background:var(--sage);color:var(--on-sage)}
.btn--sage:hover{background:var(--sage-deep);transform:translateY(-2px)}
.btn--ghost{background:transparent;border-color:var(--line-strong);color:var(--ink)}
.btn--ghost:hover{border-color:var(--sage);color:var(--sage);transform:translateY(-2px)}
.on-sage .btn--ghost,.section--sage .btn--ghost,.section--sage-deep .btn--ghost{border-color:rgba(244,239,227,.4);color:var(--on-sage)}
.on-sage .btn--ghost:hover,.section--sage .btn--ghost:hover,.section--sage-deep .btn--ghost:hover{border-color:var(--on-sage-acc);color:var(--on-sage-acc)}
.btn--gold{background:var(--on-sage-acc);color:var(--sage-deep)}
.btn--gold:hover{background:#f0d49a;transform:translateY(-2px)}
.stack-cta{display:flex;flex-wrap:wrap;gap:.8rem}

/* ===================== HEADER ===================== */
.site-header{position:sticky;top:0;z-index:100;background:rgba(251,247,239,.86);
  backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line);
  transition:box-shadow .25s,background .25s}
.site-header.scrolled{box-shadow:0 6px 24px -16px rgba(38,36,31,.4);background:rgba(251,247,239,.96)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:74px}
.brand{display:inline-flex;align-items:center;gap:.7rem}
.brand__mark{width:46px;height:46px;flex:none;border-radius:13px;box-shadow:0 4px 12px -6px rgba(38,36,31,.5)}
.brand__text{display:flex;flex-direction:column;line-height:1.05}
.brand__name{font-family:"Cormorant",serif;font-weight:700;font-size:1.5rem;color:var(--ink)}
.brand__tag{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:600}

.nav__toggle{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;
  width:46px;height:46px;border:1px solid var(--line-strong);border-radius:11px;background:var(--card);cursor:pointer}
.nav__toggle span{display:block;width:21px;height:2px;background:var(--ink);margin-inline:auto;border-radius:2px;transition:transform .25s,opacity .2s}
.nav.open .nav__toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav.open .nav__toggle span:nth-child(2){opacity:0}
.nav.open .nav__toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.nav__links{list-style:none;margin:0;padding:0}
.nav__links a{font-family:"Karla",sans-serif;font-weight:600;color:var(--ink-soft);white-space:nowrap}
.nav__links>li>a[aria-current="page"]{color:var(--sage)}
.nav__phone{display:inline-flex;align-items:center;gap:.45rem;font-weight:700;color:var(--sage)}
.nav__scrim{display:none}

/* Mobile nav */
@media (max-width:1023px){
  .nav__links{position:fixed;inset:74px 0 auto 0;flex-direction:column;gap:0;
    background:var(--paper);border-bottom:1px solid var(--line);
    padding:.6rem 20px 1.4rem;transform:translateY(-12px);opacity:0;pointer-events:none;
    transition:transform .28s var(--ease),opacity .22s;max-height:calc(100dvh - 74px);overflow:auto;display:flex}
  .nav.open .nav__links{transform:none;opacity:1;pointer-events:auto}
  .nav__links li{width:100%}
  .nav__links>li>a{display:block;padding:.95rem .4rem;font-size:1.12rem;border-bottom:1px solid var(--line)}
  .nav__links>li>a[aria-current="page"]{color:var(--sage)}
  .nav__cta{display:flex;flex-direction:column;gap:.7rem;margin-top:1rem}
  .nav__cta .btn{width:100%}
  .nav__phone{padding:.6rem .4rem;font-size:1.12rem}
  .nav.open .nav__scrim{display:block;position:fixed;inset:74px 0 0 0;background:rgba(38,36,31,.34);z-index:-1}
}
@media (min-width:1024px){
  .nav__toggle{display:none}
  .nav__links{display:flex;align-items:center;gap:1.55rem}
  .nav__cta{display:flex;align-items:center;gap:1rem;margin-left:.4rem}
}

/* ===================== HERO ===================== */
.hero{position:relative;overflow:hidden;background:var(--sage);color:var(--on-sage)}
.hero::before{content:"";position:absolute;inset:0;
  background:
    radial-gradient(70% 90% at 88% -10%, rgba(201,168,106,.20), transparent 60%),
    radial-gradient(60% 70% at -10% 110%, rgba(110,140,119,.30), transparent 60%),
    linear-gradient(160deg,#43614f 0%,#3C5A4A 48%,#2E4639 100%);
  z-index:0}
.hero__inner{position:relative;z-index:1;padding:clamp(3rem,9vw,6rem) 0 clamp(3rem,8vw,5rem);max-width:50rem}
.hero h1{color:var(--on-sage);margin-bottom:1.1rem}
.hero h1 em{color:var(--on-sage-acc);font-style:italic}
.hero__lead{font-size:1.18rem;color:var(--on-sage-mut);max-width:36rem;margin-bottom:1.8rem}
.hero__cta{display:flex;flex-wrap:wrap;gap:.85rem;margin-bottom:2.2rem}
.hero__trust{display:flex;flex-wrap:wrap;gap:.6rem}
.pill{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .9rem;border-radius:999px;
  background:rgba(244,239,227,.08);border:1px solid rgba(232,201,139,.3);
  font-size:.9rem;font-weight:600;color:var(--on-sage)}
.pill .ico{width:1.05em;height:1.05em;color:var(--on-sage-acc)}

/* subtelny ornamentowy łuk po prawej (tylko desktop) */
.hero__deco{display:none}
@media (min-width:980px){
  .hero__deco{display:block;position:absolute;right:-60px;top:50%;transform:translateY(-50%);
    width:420px;height:420px;z-index:0;opacity:.5}
}

/* ---------- Breadcrumb (na podstronach) ---------- */
.subhero{background:var(--sage);color:var(--on-sage);position:relative;overflow:hidden}
.subhero::before{content:"";position:absolute;inset:0;
  background:radial-gradient(60% 90% at 90% 0%,rgba(201,168,106,.18),transparent 60%),linear-gradient(160deg,#43614f,#2E4639);z-index:0}
.subhero__inner{position:relative;z-index:1;padding:clamp(2.2rem,6vw,3.6rem) 0 clamp(2rem,5vw,3rem);max-width:48rem}
.subhero h1{color:var(--on-sage);font-size:clamp(2.2rem,5.5vw,3.4rem)}
.subhero p{color:var(--on-sage-mut);font-size:1.1rem;margin-top:.6rem;max-width:36rem}
.breadcrumb{margin-bottom:1rem}
.breadcrumb ol{list-style:none;display:flex;flex-wrap:wrap;gap:.45rem;margin:0;padding:0;
  font-size:.85rem;color:var(--on-sage-mut);font-weight:600}
.breadcrumb a{color:var(--on-sage-mut)}
.breadcrumb a:hover{color:var(--on-sage-acc)}
.breadcrumb li+li::before{content:"›";margin-right:.45rem;color:var(--gold)}
.breadcrumb [aria-current]{color:var(--on-sage)}

/* ---------- Split ---------- */
.split{display:grid;gap:2rem;align-items:center}
@media (min-width:880px){.split{grid-template-columns:1fr 1fr;gap:3.2rem}.split--rev .split__media{order:2}}
.split__text h2{margin-bottom:1rem}
.split__text p{color:var(--ink-soft)}

/* ---------- Photo placeholder (uczciwy, do wymiany na realne foto) ---------- */
.photo{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:
   linear-gradient(140deg,#e9e0cf,#f2ead9 55%,#e3eae3);
   border:1px solid var(--line);box-shadow:var(--shadow)}
.photo--tall{aspect-ratio:4/5}
.photo--wide{aspect-ratio:16/11}
.photo--sq{aspect-ratio:1/1}
.photo__center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:.7rem;text-align:center;padding:1.5rem;color:var(--muted)}
.photo__center svg{width:38px;height:38px;color:var(--sage-soft);opacity:.85}
.photo__center span{font-size:.86rem;max-width:15rem;line-height:1.4}
.photo__label{position:absolute;left:14px;bottom:14px;right:14px;display:flex;flex-direction:column;
  background:rgba(255,255,255,.9);backdrop-filter:blur(4px);border:1px solid var(--line);
  border-radius:12px;padding:.55rem .8rem}
.photo__label .k{font-weight:700;font-size:.92rem;color:var(--ink)}
.photo__label .v{font-size:.78rem;color:var(--muted)}

/* ---------- Grid kart ---------- */
.grid{display:grid;gap:1.3rem}
.grid--2{grid-template-columns:1fr}
.grid--3{grid-template-columns:1fr}
.grid--4{grid-template-columns:1fr 1fr}
@media (min-width:640px){.grid--3{grid-template-columns:1fr 1fr}}
@media (min-width:880px){.grid--2{grid-template-columns:1fr 1fr}.grid--3{grid-template-columns:repeat(3,1fr)}.grid--4{grid-template-columns:repeat(4,1fr)}}

.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.6rem;box-shadow:var(--shadow);transition:transform .25s var(--ease),box-shadow .25s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.card__icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;
  border-radius:13px;background:var(--sage-tint);color:var(--sage);border:1px solid #d6e2d8;margin-bottom:1rem}
.card__icon .ico{width:1.5em;height:1.5em}
.card h3{margin-bottom:.5rem;color:var(--ink)}
.card p{color:var(--ink-soft);font-size:.98rem;margin:0}
.section--sage .card,.section--sage-deep .card{background:rgba(244,239,227,.06);border-color:rgba(232,201,139,.24)}
.section--sage .card h3,.section--sage-deep .card h3{color:var(--on-sage)}
.section--sage .card p,.section--sage-deep .card p{color:var(--on-sage-mut)}
.section--sage .card__icon,.section--sage-deep .card__icon{background:rgba(232,201,139,.12);border-color:rgba(232,201,139,.3);color:var(--on-sage-acc)}

/* ---------- Karty pokoi ---------- */
.rooms{display:grid;gap:1.6rem}
@media (min-width:760px){.rooms{grid-template-columns:1fr 1fr}}
.room{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);transition:transform .25s var(--ease),box-shadow .25s}
.room:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.room__media{position:relative;aspect-ratio:16/10}
.room__media .photo{height:100%;border:0;border-radius:0;box-shadow:none}
.room__tag{position:absolute;top:12px;left:12px;background:var(--sage);color:var(--on-sage);
  font-size:.74rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:.32rem .7rem;border-radius:999px}
.room__body{padding:1.5rem 1.5rem 1.7rem;display:flex;flex-direction:column;flex:1}
.room__body h3{color:var(--ink);margin-bottom:.3rem}
.room__meta{display:flex;flex-wrap:wrap;gap:.4rem .8rem;margin:.2rem 0 .9rem;color:var(--muted);font-size:.84rem;font-weight:600}
.room__meta span{display:inline-flex;align-items:center;gap:.35rem}
.room__meta .ico{width:1em;height:1em;color:var(--sage-soft)}
.room__body p{color:var(--ink-soft);font-size:.97rem}
.amen{list-style:none;margin:.4rem 0 1.1rem;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:.4rem .8rem}
.amen li{display:flex;align-items:flex-start;gap:.45rem;font-size:.9rem;color:var(--ink-soft)}
.amen .ico{width:1.05em;height:1.05em;color:var(--sage);margin-top:.15rem;flex:none}
.room__foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding-top:1rem;border-top:1px solid var(--line)}
.room__price{font-family:"Cormorant",serif;font-size:1.3rem;font-weight:600;color:var(--sage)}
.room__price small{display:block;font-family:"Karla",sans-serif;font-size:.72rem;font-weight:600;color:var(--muted);letter-spacing:.04em}

/* ---------- Facts band ---------- */
.facts{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem 1rem}
@media (min-width:760px){.facts{grid-template-columns:repeat(4,1fr)}}
.fact{text-align:center}
.fact strong{display:block;font-family:"Cormorant",serif;font-size:clamp(2.4rem,6vw,3.2rem);
  font-weight:600;color:var(--on-sage-acc);line-height:1;min-height:1.05em}
.fact span{display:block;margin-top:.4rem;font-size:.92rem;color:var(--on-sage-mut)}

/* ---------- Steps ---------- */
.steps{display:grid;gap:1.3rem;counter-reset:step}
@media (min-width:760px){.steps{grid-template-columns:repeat(3,1fr)}}
.step{position:relative;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.6rem 1.6rem 1.5rem;box-shadow:var(--shadow)}
.step::before{counter-increment:step;content:counter(step);position:absolute;top:-16px;left:1.5rem;
  width:42px;height:42px;display:flex;align-items:center;justify-content:center;
  font-family:"Cormorant",serif;font-weight:700;font-size:1.35rem;color:var(--on-sage);
  background:var(--sage);border-radius:12px;box-shadow:0 8px 16px -8px rgba(60,90,74,.7)}
.step h3{margin:1rem 0 .4rem;color:var(--ink)}
.step p{color:var(--ink-soft);font-size:.96rem;margin:0}

/* ---------- Lista atutów (check) ---------- */
.checks{list-style:none;margin:1.2rem 0 0;padding:0;display:grid;gap:.7rem}
.checks li{display:flex;align-items:flex-start;gap:.7rem;color:var(--ink-soft)}
.checks .ico{width:1.3em;height:1.3em;color:var(--sage);flex:none;margin-top:.18rem}
.section--sage .checks li,.section--sage-deep .checks li,.on-sage .checks li{color:var(--on-sage-mut)}
.section--sage .checks .ico,.on-sage .checks .ico{color:var(--on-sage-acc)}

/* ---------- Atrakcje (feature list) ---------- */
.feature{display:grid;gap:1.1rem;grid-template-columns:auto 1fr;align-items:start;
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.5rem;box-shadow:var(--shadow)}
.feature__icon{width:50px;height:50px;border-radius:13px;display:flex;align-items:center;justify-content:center;
  background:var(--sage-tint);color:var(--sage);border:1px solid #d6e2d8;flex:none}
.feature__icon .ico{width:1.55em;height:1.55em}
.feature h3{color:var(--ink);margin-bottom:.35rem}
.feature p{color:var(--ink-soft);font-size:.97rem;margin:0}
.feature .dist{display:inline-flex;align-items:center;gap:.35rem;margin-top:.6rem;font-size:.82rem;
  font-weight:700;color:var(--clay)}
.feature .dist .ico{width:1em;height:1em}

/* ---------- Reviews (jakościowe, bez fabrykacji) ---------- */
.reviews{display:grid;gap:1.3rem}
@media (min-width:760px){.reviews{grid-template-columns:repeat(3,1fr)}}
.review{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.6rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:.8rem}
.review__stars{display:inline-flex;gap:2px;color:var(--gold)}
.review__stars .ico{width:1.15em;height:1.15em;fill:var(--gold);stroke:none}
.review p{color:var(--ink);font-style:italic;font-family:"Cormorant",serif;font-size:1.28rem;line-height:1.4;margin:0}
.review__who{margin-top:auto;font-size:.85rem;color:var(--muted);font-weight:600}

/* ---------- Galeria ---------- */
.gallery{display:grid;gap:.9rem;grid-template-columns:1fr 1fr}
@media (min-width:760px){.gallery{grid-template-columns:repeat(3,1fr)}}
.gallery .photo{aspect-ratio:4/5}
.gallery-group{margin-top:2rem}
.gallery-group h3{margin-bottom:1rem;color:var(--ink)}

/* ---------- CTA band ---------- */
.cta-band{text-align:center}
.cta-band .wrap{max-width:44rem}
.cta-band h2{color:var(--on-sage);margin-bottom:.8rem}
.cta-band__actions{display:flex;flex-wrap:wrap;gap:.85rem;justify-content:center;margin-top:1.6rem}

/* ---------- Tabela udogodnień ---------- */
.amen-table{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.7rem;box-shadow:var(--shadow)}
.amen-grid{list-style:none;margin:0;padding:0;display:grid;gap:.85rem;grid-template-columns:1fr}
@media (min-width:600px){.amen-grid{grid-template-columns:1fr 1fr}}
@media (min-width:920px){.amen-grid{grid-template-columns:1fr 1fr 1fr}}
.amen-grid li{display:flex;align-items:flex-start;gap:.6rem;color:var(--ink-soft);font-size:.97rem}
.amen-grid .ico{width:1.25em;height:1.25em;color:var(--sage);flex:none;margin-top:.15rem}

/* ---------- Info-box / zasady ---------- */
.notebox{background:var(--sage-tint);border:1px solid #d6e2d8;border-left:4px solid var(--sage);
  border-radius:var(--radius);padding:1.4rem 1.6rem}
.notebox h3{color:var(--sage-deep);margin-bottom:.6rem;font-family:"Karla",sans-serif;font-size:1.1rem;font-weight:700}
.notebox p{color:var(--ink-soft);margin:0 0 .5rem;font-size:.97rem}
.notebox p:last-child{margin:0}

/* ---------- Regulamin list ---------- */
.rules{list-style:none;margin:1.5rem 0 0;padding:0;display:grid;gap:1rem;counter-reset:rule}
.rules li{position:relative;padding-left:3.2rem;color:var(--ink-soft)}
.rules li::before{counter-increment:rule;content:counter(rule);position:absolute;left:0;top:-2px;
  width:34px;height:34px;display:flex;align-items:center;justify-content:center;
  font-family:"Cormorant",serif;font-weight:700;color:var(--sage);background:var(--sage-tint);
  border:1px solid #d6e2d8;border-radius:10px;font-size:1rem}
.rules strong{color:var(--ink)}

/* ===================== FORMULARZ ===================== */
.contact-grid{display:grid;gap:2rem}
@media (min-width:920px){.contact-grid{grid-template-columns:1.05fr .95fr;gap:3rem;align-items:start}}
.form{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(1.5rem,4vw,2.2rem);box-shadow:var(--shadow)}
.form__row{display:grid;gap:1.1rem}
@media (min-width:560px){.form__row.two{grid-template-columns:1fr 1fr}}
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.1rem}
.field label{font-weight:700;font-size:.92rem;color:var(--ink)}
.field .req{color:var(--clay)}
.field input,.field select,.field textarea{
  font-family:"Karla",sans-serif;font-size:1rem;color:var(--ink);background:var(--paper);
  border:1.5px solid var(--line-strong);border-radius:12px;padding:.8rem .9rem;min-height:48px;width:100%;
  transition:border-color .2s,box-shadow .2s}
.field textarea{min-height:120px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--sage);
  box-shadow:0 0 0 3px rgba(60,90,74,.16)}
.field__error{font-size:.82rem;color:#b3261e;min-height:0;font-weight:600}
.field.has-error input,.field.has-error select,.field.has-error textarea{border-color:#b3261e;box-shadow:0 0 0 3px rgba(179,38,30,.14)}
.field.has-error .field__error{min-height:1.1em}
.form__status{margin-top:1rem;border-radius:12px;font-weight:600;font-size:.96rem}
.form__status.is-ok{background:var(--sage-tint);border:1px solid #cfe0d2;color:var(--sage-deep);padding:.9rem 1.1rem}
.form__hint{font-size:.86rem;color:var(--muted);margin-top:.4rem}

/* ---------- Kontakt info ---------- */
.contact-info{display:grid;gap:1rem}
.cinfo{display:flex;gap:.9rem;align-items:flex-start;background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);padding:1.1rem 1.3rem;box-shadow:var(--shadow)}
.cinfo__ico{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  background:var(--sage-tint);color:var(--sage);border:1px solid #d6e2d8;flex:none}
.cinfo h3{font-family:"Karla",sans-serif;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);margin:0 0 .2rem;font-weight:700}
.cinfo a,.cinfo p{font-size:1.08rem;color:var(--ink);font-weight:600;margin:0}
.cinfo a:hover{color:var(--sage)}
.cinfo small{display:block;font-size:.84rem;color:var(--muted);font-weight:500;margin-top:.15rem}

/* ---------- Mapa (w swoim kontenerze) ---------- */
.map{margin-top:1.4rem;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--shadow);max-width:100%}
.map iframe{display:block;width:100%;height:340px;border:0}

/* ===================== FOOTER ===================== */
.site-footer{background:var(--sage-deep);color:var(--on-sage);padding:3.2rem 0 1.6rem}
.footer-grid{display:grid;gap:2rem}
@media (min-width:760px){.footer-grid{grid-template-columns:1.6fr 1fr 1.4fr}}
.footer-brand .brand__name{color:var(--on-sage)}
.footer-brand .brand__tag{color:var(--on-sage-mut)}
.footer-brand p{color:var(--on-sage-mut);font-size:.95rem;margin-top:1rem;max-width:24rem}
.footer-col h4{color:var(--on-sage-acc);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:1rem}
.footer-col ul{list-style:none;margin:0;padding:0;display:grid;gap:.6rem}
.footer-col a,.footer-col p{color:var(--on-sage-mut);font-size:.96rem;display:inline-flex;align-items:flex-start;gap:.5rem;margin:0}
.footer-col a:hover{color:var(--on-sage)}
.footer-col .ico{width:1.1em;height:1.1em;color:var(--on-sage-acc);flex:none;margin-top:.2rem}
.footer-bottom{margin-top:2.4rem;padding-top:1.4rem;border-top:1px solid rgba(244,239,227,.16);
  display:flex;flex-wrap:wrap;gap:.6rem;justify-content:space-between;align-items:center;
  font-size:.86rem;color:var(--on-sage-mut)}
.footer-credit strong{color:var(--on-sage-acc)}

/* ===================== ANIMACJE WEJŚCIA ===================== */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.is-visible{opacity:1;transform:none}
/* LCP: nagłówek hero NIE może startować ukryty (fade-in opóźniałby LCP). Hero widoczny od razu. */
.hero__inner.reveal{opacity:1;transform:none;transition:none}
.reveal[data-d="1"]{transition-delay:.06s}
.reveal[data-d="2"]{transition-delay:.13s}
.reveal[data-d="3"]{transition-delay:.2s}
.reveal[data-d="4"]{transition-delay:.27s}
.reveal-instant .reveal{opacity:1!important;transform:none!important;transition:none!important}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;transition:none!important}
  .btn:hover,.card:hover,.room:hover{transform:none}
}
