/* ═══════════════════════════════════
   HERO (index)
═══════════════════════════════════ */
.hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 62vh;
  border-bottom: var(--border);
}
.hero__text {
  padding: clamp(2.5rem, 7vw, 5rem) clamp(1.5rem, 4vw, 3rem);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 0.875rem;
  border-right: var(--border);
  background: var(--c-paper);
}
.hero__tagline { font-size: 0.82rem; color: var(--c-smoke); line-height: 1.9; }
.hero__ctas { display: flex; gap: 0.75rem; flex-wrap: wrap; margin-top: 0.5rem; }
.hero__cta-book { align-self: flex-start; width: fit-content; max-width: 100%; margin-top: 0.25rem; }
.hero__img { min-height: 380px; overflow: hidden; }
.hero__img img { width: 100%; height: 100%; object-fit: cover; }

@media (max-width: 768px) {
  .hero { grid-template-columns: 1fr; }
  .hero__text { border-right: none; border-bottom: var(--border); }
  .hero__img  { min-height: 260px; }
}

/* ═══════════════════════════════════
   CABINS GRID (index)
═══════════════════════════════════ */
.cabins-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-bottom: var(--border);
}
.cabin-col { padding: clamp(1.5rem, 4vw, 2.5rem) clamp(1.25rem, 3vw, 2rem); }
.cabin-col + .cabin-col { border-left: var(--border); }
.cabin-col__num {
  font-family: var(--f-serif);
  font-size: clamp(5rem, 12vw, 9rem);
  color: var(--c-mist);
  line-height: 1;
  margin-bottom: -0.75rem;
  pointer-events: none;
}
.cabin-col__title { margin-bottom: 0.375rem; }
.cabin-col__sub   { font-size: 0.8rem; margin-bottom: 0.875rem; }
.cabin-col__img   { height: 180px; margin: 0.875rem 0; overflow: hidden; }
.cabin-col__img img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 600ms var(--ease-premium);
}
.cabin-col:hover .cabin-col__img img,
.cabin-col:focus-within .cabin-col__img img { transform: scale(1.04); }

@media (min-width: 900px) {
  .cabin-col__img { height: 260px; }
}

@media (max-width: 600px) {
  .cabins-grid { grid-template-columns: 1fr; }
  .cabin-col + .cabin-col { border-left: none; border-top: var(--border); }
}

/* ═══════════════════════════════════
   STORY TEASER (index)
═══════════════════════════════════ */
.story-teaser {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-bottom: var(--border);
  max-height: 520px;
}
.story-teaser__text {
  padding: clamp(2rem, 5vw, 3.5rem) clamp(1.5rem, 4vw, 2.5rem);
  border-right: var(--border);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.story-teaser__text h2 { margin: 0.5rem 0 1rem; }
.story-teaser__text p  { font-size: 0.875rem; max-width: 420px; }
.story-teaser__link { margin-top: 1.75rem; }
.story-teaser__img  { min-height: 280px; max-height: 520px; overflow: hidden; }
.story-teaser__img img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center 80%;
  transition: transform 700ms var(--ease-premium);
}
.story-teaser:hover .story-teaser__img img { transform: scale(1.03); }

@media (max-width: 768px) {
  .story-teaser { grid-template-columns: 1fr; max-height: none; }
  .story-teaser__text { border-right: none; border-bottom: var(--border); }
  .story-teaser__img  { min-height: 220px; max-height: none; }
}

/* ═══════════════════════════════════
   CABIN PAGE (zloty / czarny)
═══════════════════════════════════ */
.cabin-hero {
  display: grid;
  grid-template-columns: 2fr 1fr;
  border-bottom: var(--border);
  min-height: 340px;
}
.cabin-hero__img { overflow: hidden; }
.cabin-hero__img img { width: 100%; height: 100%; object-fit: cover; }
.cabin-hero__info {
  padding: 2rem 1.75rem;
  border-left: var(--border);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.375rem;
}
.cabin-hero__info h1 { font-size: clamp(2rem, 5vw, 3.5rem); margin: 0.375rem 0 1rem; }

.cabin-stats { border-top: var(--border-rule); }
.cabin-stat {
  display: flex;
  justify-content: space-between;
  padding: 0.5rem 0;
  border-bottom: var(--border-dash);
  font-size: 0.82rem;
}
.cabin-stat__key { color: var(--c-smoke); }
.cabin-stat__val { font-weight: 600; }

@media (max-width: 768px) {
  .cabin-hero { grid-template-columns: 1fr; }
  .cabin-hero__img { min-height: 240px; }
  .cabin-hero__info { border-left: none; border-top: var(--border); }
}

/* ─── Cabin gallery row (zloty / czarny – pod hero) ─── */
.cabin-gallery {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-bottom: var(--border);
}
.cabin-gallery__tile {
  position: relative;
  aspect-ratio: 4/3;
  overflow: hidden;
  border-right: var(--border);
  display: block;
}
.cabin-gallery__tile:last-child { border-right: none; }
.cabin-gallery__tile img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 500ms var(--ease-premium);
}
.cabin-gallery__tile:hover img,
.cabin-gallery__tile:focus-visible img { transform: scale(1.05); }
.cabin-gallery__tile:focus-visible { outline: 3px solid var(--c-gold-dk); outline-offset: -3px; }

@media (max-width: 900px) {
  .cabin-gallery { grid-template-columns: 1fr 1fr; }
  .cabin-gallery__tile:nth-child(2) { border-right: none; }
  .cabin-gallery__tile:nth-child(n+3) { border-top: var(--border); }
}
@media (max-width: 480px) {
  .cabin-gallery { grid-template-columns: 1fr; }
  .cabin-gallery__tile { border-right: none; border-bottom: var(--border); }
  .cabin-gallery__tile:last-child { border-bottom: none; }
  .cabin-gallery__tile:nth-child(n+3) { border-top: none; }
}

.cabin-body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-bottom: var(--border);
}
.cabin-body__col { padding: clamp(1.5rem, 4vw, 2.5rem) clamp(1.25rem, 3vw, 2rem); }
.cabin-body__col + .cabin-body__col { border-left: var(--border); }
.cabin-body__col h3 { margin-bottom: 1rem; }

.cabin-feature {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  padding: 0.5rem 0;
  border-bottom: var(--border-dash);
  font-size: 0.82rem;
  color: var(--c-smoke);
}
.cabin-feature__icon {
  width: 1.1rem;
  height: 1.1rem;
  fill: none;
  stroke: var(--c-gold);
  stroke-width: 1.5;
  flex-shrink: 0;
}

/* ═══════════════════════════════════
   SECTION BLOCKS (spa-cennik, generic content rows)
═══════════════════════════════════ */
.section-block {
  border-bottom: var(--border);
  padding: clamp(1.5rem, 4vw, 2.5rem);
}
.section-block--dark {
  background: var(--c-ink);
  color: var(--c-paper);
}
.section-block--dark h2 { color: var(--c-paper); }
.section-block--dark p  { color: var(--c-ash); }

.section-center {
  max-width: 680px;
  margin: 0 auto;
  text-align: center;
}

.section-block__h2 { margin-bottom: 1.25rem; }

.duo-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border: var(--border);
}
.duo-grid__panel { padding: 1.25rem; border-right: var(--border); }
.duo-grid__panel:last-child { border-right: none; }
.duo-grid__img-cover {
  overflow: hidden;
  min-height: 220px;
}
.duo-grid__img-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
@media (max-width: 640px) {
  .duo-grid { grid-template-columns: 1fr; }
  .duo-grid__panel { border-right: none; border-bottom: var(--border); }
  .duo-grid__panel:last-child { border-bottom: none; }
}

.feature-price {
  font-family: var(--f-mono);
  font-size: 2rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
  color: var(--c-gold);
  font-variant-numeric: tabular-nums;
}
.feature-price__unit {
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--c-smoke);
  margin-bottom: 1.25rem;
}
.feature-note {
  margin-top: 1.25rem;
  font-size: 0.78rem;
  color: var(--c-smoke);
  line-height: 1.6;
}

.spa-icon-xl {
  display: block;
  margin: 0 auto 1rem;
  width: 2.5rem;
  height: 2.5rem;
  fill: none;
  stroke: var(--c-gold);
  stroke-width: 1.5;
}

.section-block--dark .label-gold,
.section-block--dark .feature-note { color: var(--c-ash); }

.cta-row {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
  text-align: center;
  padding: clamp(1.5rem, 4vw, 2.5rem);
  border-bottom: var(--border);
}

/* ═══════════════════════════════════
   GALERIA (sekcje header)
═══════════════════════════════════ */
.galeria-section-head {
  padding: 1rem 1.5rem;
  border-bottom: var(--border);
  border-top: var(--border);
}
.galeria-section-head:first-of-type { border-top: none; }
.galeria-hint {
  font-size: 0.85rem;
  color: var(--c-smoke);
  margin-top: 0.25rem;
}

/* ═══════════════════════════════════
   LEGAL DOCS (polityka, regulamin)
═══════════════════════════════════ */
.legal-doc {
  max-width: 760px;
  margin: 0 auto;
  padding: clamp(2rem, 5vw, 4rem) clamp(1.5rem, 4vw, 2.5rem);
}
.legal-doc__h1 {
  margin: 0.5rem 0 2rem;
  font-size: clamp(2rem, 4vw, 3rem);
}
.legal-doc__updated {
  margin-top: 2rem;
  color: var(--c-smoke);
  font-size: 0.8rem;
}

/* ═══════════════════════════════════
   FOOTER credit (subtle wiersz pod stopką)
═══════════════════════════════════ */
.footer__credit-row {
  text-align: center;
  padding: 0.5rem 1.5rem;
  font-size: 0.7rem;
  color: #999;
  border-top: 1px solid #2a2a28;
}
.footer__credit-row a { color: inherit; }
.footer__credit-row a:hover { color: var(--c-paper); }

@media (max-width: 640px) {
  .cabin-body { grid-template-columns: 1fr; }
  .cabin-body__col + .cabin-body__col { border-left: none; border-top: var(--border); }
}

/* ═══════════════════════════════════
   ATTRACTIONS (okolica)
═══════════════════════════════════ */
.attractions-header {
  padding: clamp(1.5rem, 4vw, 2rem) clamp(1.5rem, 4vw, 2.5rem);
  border-bottom: var(--border);
  display: flex;
  align-items: baseline;
  gap: 1.5rem;
  flex-wrap: wrap;
}

.attractions-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-bottom: var(--border);
}
.attraction-card { border-right: var(--border); border-bottom: var(--border); }
.attraction-card:nth-child(3n) { border-right: none; }
.attraction-card:nth-last-child(-n+3) { border-bottom: none; }

.attraction-card__img { height: 240px; overflow: hidden; border-bottom: var(--border); }
.attraction-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--t); }
.attraction-card:hover .attraction-card__img img { transform: scale(1.04); }

.attraction-card__body { padding: 1rem 1.25rem; }
.attraction-card__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 0.25rem;
}
.attraction-card__name { font-family: var(--f-serif); font-size: 1.1rem; font-weight: 600; }
.attraction-card__season {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}
.attraction-card__season svg {
  width: 1rem;
  height: 1rem;
  fill: none;
  stroke: var(--c-gold);
  stroke-width: 1.5;
}
.attraction-card__season svg.season-winter { stroke: #6699aa; }

.okolica-legend {
  display: inline-flex;
  align-items: center;
  gap: 0.15rem;
  flex-wrap: wrap;
}
.okolica-legend .season-icon {
  width: 0.85rem;
  height: 0.85rem;
  fill: none;
  stroke: var(--c-gold);
  stroke-width: 1.5;
  vertical-align: middle;
  margin: 0 0.1rem;
}
.okolica-legend .season-icon--winter { stroke: #6699aa; }
.attraction-card__dist { font-family: var(--f-mono); font-size: 0.58rem; letter-spacing: 0.1em; color: var(--c-gold); margin-bottom: 0.25rem; }
.attraction-card__info { font-size: 0.75rem; color: var(--c-smoke); }

@media (max-width: 768px) {
  .attractions-grid { grid-template-columns: 1fr 1fr; }
  .attraction-card:nth-child(3n) { border-right: var(--border); }
  .attraction-card:nth-child(2n) { border-right: none; }
  .attraction-card:nth-last-child(-n+3) { border-bottom: var(--border); }
  .attraction-card:nth-last-child(-n+2) { border-bottom: none; }
}
@media (max-width: 480px) {
  .attractions-grid { grid-template-columns: 1fr; }
  .attraction-card { border-right: none !important; border-bottom: var(--border) !important; }
  .attraction-card:last-child { border-bottom: none !important; }
}

/* ═══════════════════════════════════
   SPA PAGE
═══════════════════════════════════ */
.spa-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-bottom: var(--border);
}
.spa-hero__text {
  padding: clamp(2rem, 5vw, 3.5rem) clamp(1.5rem, 4vw, 2.5rem);
  border-right: var(--border);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.875rem;
}
.spa-hero__text h1 { font-size: clamp(2rem, 5vw, 3.5rem); margin-bottom: 0.25rem; }
.spa-hero__img { min-height: 360px; overflow: hidden; }
.spa-hero__img img { width: 100%; height: 100%; object-fit: cover; }

@media (max-width: 768px) {
  .spa-hero { grid-template-columns: 1fr; }
  .spa-hero__text { border-right: none; border-bottom: var(--border); }
  .spa-hero__img  { min-height: 220px; }
}

.pricing-section {
  padding: clamp(1.5rem, 4vw, 2.5rem);
  border-bottom: var(--border);
}
.pricing-section h2 { margin-bottom: 1.375rem; font-size: clamp(1.5rem, 3vw, 2.25rem); }

/* ═══════════════════════════════════
   HISTORIA PAGE
═══════════════════════════════════ */
.historia-header {
  padding: clamp(2.5rem, 7vw, 5rem) clamp(1.5rem, 4vw, 2.5rem);
  border-bottom: var(--border);
  max-width: 740px;
}
.historia-header h1 { margin: 0.5rem 0 1.25rem; }
.historia-lead { font-size: clamp(1rem, 2vw, 1.2rem); color: var(--c-smoke); line-height: 1.8; }

/* historia – naprzemienne sekcje */
.historia-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-bottom: var(--border);
  min-height: 480px;
}
.historia-split__text {
  padding: clamp(2rem, 5vw, 3.5rem) clamp(1.5rem, 4vw, 2.5rem);
  border-right: var(--border);
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.historia-split__text p { margin-bottom: 1.25rem; font-size: 0.9rem; line-height: 1.8; }
.historia-split__text p:last-child { margin-bottom: 0; }
.historia-split__img { overflow: hidden; }
.historia-split__img img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* sekcja odwrócona – zdjęcie po lewej, tekst po prawej */
.historia-split--reverse .historia-split__img { border-right: var(--border); order: -1; }
.historia-split--reverse .historia-split__text { border-right: none; }

/* panorama pełna szerokość */
.historia-panorama { height: 380px; overflow: hidden; border-bottom: var(--border); }
.historia-panorama img { width: 100%; height: 100%; object-fit: cover; display: block; }

@media (max-width: 768px) {
  .historia-split { grid-template-columns: 1fr; min-height: auto; }
  .historia-split__text { border-right: none; border-bottom: var(--border); }
  .historia-split__img { min-height: 280px; }
  .historia-split--reverse .historia-split__img { order: 0; border-right: none; border-bottom: var(--border); }
  .historia-panorama { height: 220px; }
}

/* ═══════════════════════════════════
   GALERIA PAGE
═══════════════════════════════════ */
.galeria-header {
  padding: clamp(2rem, 5vw, 3rem) clamp(1.5rem, 4vw, 2.5rem);
  border-bottom: var(--border);
}
.galeria-header h1 { margin: 0.5rem 0 0.25rem; }

.galeria-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}
.galeria-item {
  border-right: var(--border);
  border-bottom: var(--border);
  overflow: hidden;
  aspect-ratio: 4/3;
  cursor: pointer;
}
.galeria-item:nth-child(3n) { border-right: none; }
.galeria-item img { width: 100%; height: 100%; object-fit: cover; transition: transform 300ms ease; }
.galeria-item:hover img { transform: scale(1.04); }

/* Auto-layout: 1 zdjęcie w rzędzie → pełna szerokość */
.galeria-item:last-child:nth-child(3n+1) {
  grid-column: span 3;
  aspect-ratio: 16/5;
  border-right: none;
}
/* Auto-layout: 2 zdjęcia w rzędzie → pierwsze rozciąga się */
.galeria-item:nth-last-child(2):nth-child(3n+1) {
  grid-column: span 2;
  aspect-ratio: 8/3;
}
/* Auto-layout: ostatnie zdjęcie gdy w rzędzie są 2 → brak prawej ramki */
.galeria-item:last-child:nth-child(3n+2) { border-right: none; }

@media (max-width: 640px) {
  .galeria-grid { grid-template-columns: 1fr 1fr; }
  .galeria-item:nth-child(3n) { border-right: var(--border); }
  .galeria-item:nth-child(2n) { border-right: none; }
  .galeria-item:last-child:nth-child(3n+1) { grid-column: span 2; aspect-ratio: 8/3; }
  .galeria-item:nth-last-child(2):nth-child(3n+1) { grid-column: span 2; aspect-ratio: 8/3; }
  .galeria-item:last-child:nth-child(2n+1) { grid-column: span 2; aspect-ratio: 8/3; border-right: none; }
}

/* Lightbox */
.lightbox {
  position: fixed;
  inset: 0;
  background: rgba(17,17,16,0.95);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  opacity: 0;
  pointer-events: none;
  transition: opacity 250ms ease;
}
.lightbox.open { opacity: 1; pointer-events: auto; }
.lightbox__img {
  max-width: 90vw;
  max-height: 90vh;
  object-fit: contain;
  cursor: zoom-in;
  user-select: none;
  touch-action: none;
  transform-origin: center center;
}
.lightbox__img.is-zoomed { cursor: grab; }
.lightbox__img.is-dragging { cursor: grabbing; }
.lightbox__close {
  position: absolute;
  top: 1rem; right: 1.5rem;
  color: var(--c-gold);
  font-size: 2rem;
  line-height: 1;
  transition: color var(--t);
  z-index: 2;
}
.lightbox__close:hover { color: #fff; }
.lightbox__hint {
  position: absolute;
  bottom: 1.25rem;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--f-mono);
  font-size: 0.58rem;
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.35);
  text-transform: uppercase;
  pointer-events: none;
  white-space: nowrap;
}

/* ═══════════════════════════════════
   KONTAKT PAGE
═══════════════════════════════════ */
.kontakt-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  border-bottom: var(--border);
}

.kontakt-form-col {
  padding: clamp(2.5rem, 5vw, 4rem) clamp(2rem, 4vw, 3rem);
  border-right: var(--border);
}

/* nagłówek + taby */
.kontakt-form-col h2 { margin-bottom: 2rem; }
.cabin-tabs          { margin-bottom: 2rem; }
.cabin-prompt        { margin-bottom: 2rem; }
.cal-wrap            { margin-bottom: 2rem; }
.selected-dates-bar  { margin-bottom: 2rem; }

/* pola formularza */
.kontakt-form-col .form-row   { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; margin-bottom: 1.5rem; }
.kontakt-form-col .form-group { margin-bottom: 1.5rem; }

.form-cal-wrap { margin-top: 0.375rem; }
.form-dates-display {
  display: flex;
  gap: 1rem;
  margin-top: 0.75rem;
  font-family: var(--f-mono);
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  color: var(--c-smoke);
}
.form-dates-display span { color: var(--c-gold); }

.kontakt-info-col {
  padding: clamp(2.5rem, 5vw, 4rem) clamp(2rem, 4vw, 3rem);
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
}
.kontakt-info-block h3 { font-size: 1.3rem; margin-bottom: 0.75rem; }
.kontakt-info-item {
  padding: 0.625rem 0;
  border-bottom: var(--border-dash);
  font-size: 0.82rem;
}
.kontakt-info-item:last-child { border-bottom: none; }
.kontakt-info-item__label { font-family: var(--f-mono); font-size: 0.58rem; letter-spacing: 0.15em; color: var(--c-gold); margin-bottom: 0.25rem; }
.kontakt-info-item__val a:hover { color: var(--c-gold); transition: color var(--t); }

.form-success {
  display: none;
  padding: 2rem 1.5rem;
  border: 2px solid var(--c-gold);
  background: var(--c-gold-lt);
  text-align: center;
}
.form-success.visible { display: block; }
.form-success h3 { font-family: var(--f-serif); font-size: 1.75rem; margin-bottom: 0.5rem; }
.form-success p   { font-size: 0.85rem; }

@media (max-width: 900px) {
  .kontakt-grid      { grid-template-columns: 1fr; }
  .kontakt-form-col  { border-right: none; border-bottom: var(--border); }
  .kontakt-form-col .form-row { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════
   REVIEWS
═══════════════════════════════════ */
.reviews-section { border-bottom: var(--border); }
.reviews-section__head {
  padding: clamp(1.5rem, 4vw, 2rem) clamp(1.5rem, 4vw, 2.5rem);
  border-bottom: var(--border);
  display: flex;
  align-items: baseline;
  gap: 1.5rem;
  flex-wrap: wrap;
}
.reviews-section__head .eyebrow { margin: 0; }
.reviews-section__rating {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.reviews-section__stars {
  color: var(--c-gold);
  font-size: 1.1rem;
}
.reviews-section__rating-label {
  font-family: var(--f-mono);
  font-size: 0.6rem;
  letter-spacing: 0.1em;
  color: var(--c-smoke);
}
.reviews-section__more {
  padding: 1.25rem 1.5rem;
  text-align: center;
}

.reviews-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: var(--border);
}
.review-card {
  padding: 2rem clamp(1.25rem, 3vw, 2rem) 1.75rem;
  border-right: var(--border);
  border-bottom: var(--border);
  display: flex;
  flex-direction: column;
  gap: 1rem;
  position: relative;
}
.review-card:nth-child(3n) { border-right: none; }
.review-card::before {
  content: '\201E';
  font-family: var(--f-serif);
  font-size: 4rem;
  line-height: 1;
  color: var(--c-gold);
  opacity: 0.35;
  position: absolute;
  top: 0.75rem;
  left: clamp(1.25rem, 3vw, 2rem);
  pointer-events: none;
}
.review-card__text {
  font-family: var(--f-serif);
  font-size: 0.95rem;
  font-style: italic;
  line-height: 1.8;
  color: var(--c-ink);
  flex: 1;
  padding-top: 2rem;
}
.review-card__author {
  font-family: var(--f-mono);
  font-size: 0.58rem;
  letter-spacing: 0.15em;
  color: var(--c-gold);
  text-transform: uppercase;
}
@media (max-width: 900px) {
  .reviews-grid { grid-template-columns: 1fr 1fr; }
  .review-card:nth-child(3n) { border-right: var(--border); }
  .review-card:nth-child(2n) { border-right: none; }
}
@media (max-width: 540px) {
  .reviews-grid { grid-template-columns: 1fr; }
  .review-card  { border-right: none !important; }
}

/* ═══════════════════════════════════
   COOKIE BANNER
═══════════════════════════════════ */
#cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--c-ink);
  border-top: 2px solid var(--c-gold);
  z-index: 9999;
  padding: 1rem 1.5rem;
}
.cookie-banner__inner {
  max-width: var(--max-w);
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 1.5rem;
  flex-wrap: wrap;
}
.cookie-banner__text {
  flex: 1;
  font-size: 0.78rem;
  color: #aaa;
  line-height: 1.6;
  min-width: 200px;
}
.cookie-banner__text a { color: var(--c-gold); text-decoration: underline; }
.cookie-banner__btns { display: flex; gap: 0.75rem; flex-shrink: 0; flex-wrap: wrap; }
.cookie-banner__btns .btn { padding: 0.5rem 1.25rem; font-size: 0.78rem; }

/* ═══════════════════════════════════
   ADMIN PAGE
═══════════════════════════════════ */
.admin-page { min-height: 100vh; padding: 2rem clamp(1rem, 3vw, 2rem); }
.admin-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 1.25rem;
  border-bottom: var(--border);
  margin-bottom: 2rem;
  flex-wrap: wrap;
  gap: 1rem;
}
.admin-header h1 { font-size: 1.5rem; }
.admin-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2.5rem; }
.admin-cabin h2 { font-size: 1.25rem; margin-bottom: 0.875rem; }
.admin-legend {
  display: flex;
  gap: 1.25rem;
  margin-top: 0.875rem;
  font-family: var(--f-mono);
  font-size: 0.6rem;
  color: var(--c-ash);
}
.admin-taken-list { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 0.875rem; }
.admin-taken-tag {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.25rem 0.625rem;
  background: #fdf2f2;
  border: 1px solid #c0392b;
  font-family: var(--f-mono);
  font-size: 0.6rem;
  color: #c0392b;
}
.admin-taken-tag button { color: #c0392b; font-size: 1.1rem; line-height: 1; opacity: 0.6; transition: opacity var(--t); }
.admin-taken-tag button:hover { opacity: 1; }

.admin-status { padding: 0.75rem 1rem; margin-top: 1rem; font-size: 0.8rem; display: none; border-radius: 1px; }
.admin-status.success { background: #eafaf1; color: #1e8449; border: 1px solid #a9dfbf; display: block; }
.admin-status.error   { background: #fdf2f2; color: #c0392b; border: 1px solid #f5c6cb; display: block; }

.admin-token-box {
  padding: 1.25rem 1.5rem;
  border: var(--border);
  background: var(--c-mist);
  margin-bottom: 2rem;
}
.admin-token-box h3 { font-size: 1rem; margin-bottom: 0.875rem; }
.admin-token-row { display: flex; gap: 0.75rem; margin-top: 0.5rem; }
.admin-token-row input { flex: 1; }

@media (max-width: 720px) {
  .admin-grid { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════
   LANG SWITCH
═══════════════════════════════════ */
.lang-switch {
  display: flex;
  align-items: center;
  gap: 0.2rem;
  margin-left: 0.625rem;
  flex-shrink: 0;
}
.lang-btn {
  background: none;
  border: 1px solid transparent;
  color: var(--c-smoke);
  font-family: var(--f-mono);
  font-size: 0.62rem;
  letter-spacing: 0.06em;
  padding: 0.22rem 0.4rem;
  cursor: pointer;
  transition: color var(--t), border-color var(--t);
  line-height: 1;
}
.lang-btn:hover        { color: var(--c-ink); border-color: var(--c-rule); }
.lang-btn.active       { color: var(--c-gold); border-color: var(--c-gold); }

@media (max-width: 768px) {
  .lang-switch { margin-left: 0; order: -1; }
}

/* ═══════════════════════════════════
   CZYTELNOŚĆ NA KOMPUTERZE / DUŻYCH EKRANACH
   Podbicie mikro-typografii w trybie desktop: treść czytelniejsza,
   etykiety mono nadal w stylu editorial, ale nie miniaturowe.
   Telefon i tablet bez zmian. Blok celowo na końcu main.css,
   żeby wygrał kaskadę z base/components/main bez !important.
   Próg treści = 900px (tam strona przechodzi w tryb desktop).
═══════════════════════════════════ */
@media (min-width: 900px) {
  /* — Tekst treści (to, co się czyta) — */
  .cabin-feature         { font-size: 0.95rem; }
  .specs-row             { font-size: 0.95rem; }
  .cabin-stat            { font-size: 0.95rem; }
  .chip                  { font-size: 0.72rem; }
  .cabin-col__sub        { font-size: 0.9rem; }
  .attraction-card__info { font-size: 0.85rem; }
  .kontakt-info-item     { font-size: 0.92rem; }
  .hero__tagline         { font-size: 0.9rem; }
  .galeria-hint          { font-size: 0.92rem; }
  .prose p,
  .prose li              { font-size: 0.95rem; }

  /* — Etykiety mono (uppercase) — podniesiona podłoga czytelności — */
  .eyebrow,
  .label-gold            { font-size: 0.7rem; }
  .section-head          { font-size: 0.68rem; }
  .specs-row__key        { font-size: 0.68rem; }
  .specs-row__tag        { font-size: 0.66rem; }
  .ticker__item          { font-size: 0.66rem; }

  /* — Cennik — */
  .pricing-item__season  { font-size: 0.68rem; }
  .pricing-item__unit    { font-size: 0.68rem; }
  .pricing-item__dates   { font-size: 0.85rem; }
  .pricing-note          { font-size: 0.7rem; }

  /* — Cytat / autor — */
  .quote-block__attr     { font-size: 0.66rem; }

  /* — Stopka — */
  .footer__col-title     { font-size: 0.66rem; }
  .footer__col a         { font-size: 0.88rem; }
  .footer__tagline       { font-size: 0.86rem; }
  .footer__bottom        { font-size: 0.66rem; }
  .footer__credit-row    { font-size: 0.78rem; }
}

/* Nawigacja: osobny, wyższy próg (≥1024px). W strefie 901–1000px
   poziomy pasek nav jest już ciasny — większy font by go rozpychał. */
@media (min-width: 1024px) {
  .nav__link,
  .nav__cta              { font-size: 0.72rem; letter-spacing: 0.12em; }
  .nav__link             { padding: 0 1.05rem; }
  .nav__cta              { padding: 0 1.75rem; letter-spacing: 0.16em; }
}

/* ═══════════════════════════════════
   DESKTOP POLISH (≥1280px) – druga warstwa podbicia
   Najmniejsze etykiety mono podchodziły do 9–11px (granica
   czytelności). Tu podnosimy bazową podłogę i fixujemy kontrasty
   w stopce. Kolejność po bloku ≥900px, więc wygrywa kaskadą.
═══════════════════════════════════ */
@media (min-width: 1280px) {
  /* — Mikro-etykiety mono (uppercase) — */
  .eyebrow,
  .label-gold                          { font-size: 0.78rem; letter-spacing: 0.22em; }
  .ticker__item                        { font-size: 0.72rem; letter-spacing: 0.22em; }
  .section-head                        { font-size: 0.72rem; }
  .specs-row__key,
  .specs-row__tag                      { font-size: 0.72rem; }
  .pricing-item__season,
  .pricing-item__unit                  { font-size: 0.72rem; }
  .pricing-item__dates                 { font-size: 0.88rem; }
  .pricing-note                        { font-size: 0.74rem; }
  .feature-price__unit                 { font-size: 0.82rem; }
  .feature-note                        { font-size: 0.86rem; line-height: 1.7; }
  .form-label                          { font-size: 0.72rem; letter-spacing: 0.18em; }
  .kontakt-info-item__label            { font-size: 0.72rem; letter-spacing: 0.18em; }
  .kontakt-info-item                   { font-size: 0.95rem; }
  .galeria-hint                        { font-size: 0.95rem; }

  /* — Linki tekstowe (CTA "Sprawdź dostępność →" itp.) — */
  .text-link                           { font-size: 0.78rem; letter-spacing: 0.14em; }

  /* — Amenities strip i atrakcje — */
  .amenities-strip__label              { font-size: 0.78rem; letter-spacing: 0.1em; }
  .amenities-strip__icon               { width: 1.85rem; height: 1.85rem; }
  .attraction-card__name               { font-size: 1.25rem; }
  .attraction-card__dist               { font-size: 0.72rem; }
  .attraction-card__info               { font-size: 0.92rem; line-height: 1.65; }

  /* — Cytat / autor — */
  .quote-block__attr                   { font-size: 0.76rem; letter-spacing: 0.22em; }

  /* — Reviews — */
  .review-card__text                   { font-size: 1.05rem; line-height: 1.85; }
  .review-card__author                 { font-size: 0.72rem; letter-spacing: 0.2em; }
  .reviews-section__rating-label       { font-size: 0.72rem; letter-spacing: 0.14em; }
  .reviews-section__stars              { font-size: 1.25rem; }

  /* — Hero / cabin / story typografia treściowa — */
  .hero__tagline                       { font-size: 1rem; line-height: 1.85; }
  .cabin-col__sub                      { font-size: 0.98rem; line-height: 1.7; }
  .story-teaser__text p                { font-size: 0.98rem; line-height: 1.85; max-width: 460px; }
  .historia-split__text p              { font-size: 1rem; line-height: 1.85; }

  /* — Stopka: większy font + lepszy kontrast na ciemnym tle — */
  .footer__col-title                   { font-size: 0.78rem; letter-spacing: 0.22em; }
  .footer__col a                       { font-size: 0.95rem; }
  .footer__tagline                     { font-size: 0.95rem; color: #8a8a82; }
  .footer__bottom                      { font-size: 0.76rem; letter-spacing: 0.1em; }
  .footer__credit-row                  { font-size: 0.82rem; }
}

/* ═══════════════════════════════════
   KONTRAST – stopka i cookie-banner (niezależnie od breakpointa)
   Stare wartości #555/#999 na #1C1C1A nie spełniały AA dla body text.
═══════════════════════════════════ */
.footer__tagline                       { color: #9a9a92; }     /* #9a9a92 / #1C1C1A ≈ 6.8:1 (AA+) */
.footer__col a                         { color: #b8b8b0; }     /* #b8b8b0 / #1C1C1A ≈ 9.1:1 */
.footer__bottom,
.footer__bottom a                      { color: #b8b8b0; }
.footer__credit-row                    { color: #b8b8b0; }
.cookie-banner__text                   { color: #c8c8c0; }
.footer__social a                      { color: #888; }        /* lepsza widoczność SVG-ikon */
.footer__social a:hover                { color: var(--c-gold); }

/* ═══════════════════════════════════
   VIRTUAL TOUR 360° (index.html)
   Spacer wirtualny aktywowany na klik — Google Street View embed.
   Layout: 2 kolumny (tekst | viewer) na desktopie, stack na mobile.
═══════════════════════════════════ */
.virtual-tour {
  display: grid;
  grid-template-columns: 1fr 1.35fr;
  border-top: var(--border);
  border-bottom: var(--border);
}
.virtual-tour__text {
  padding: clamp(2rem, 5vw, 3.5rem) clamp(1.5rem, 4vw, 2.5rem);
  border-right: var(--border);
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.virtual-tour__text h2 {
  margin: 0.5rem 0 1rem;
  text-wrap: balance;
}
.virtual-tour__lead {
  font-size: 0.92rem;
  line-height: 1.8;
  margin-bottom: 1.25rem;
  max-width: 460px;
}
.virtual-tour__list {
  display: flex;
  flex-direction: column;
  margin-top: 0.25rem;
}
.virtual-tour__list .cabin-feature {
  border-bottom: var(--border-dash);
}
.virtual-tour__list .cabin-feature:last-child { border-bottom: none; }
.virtual-tour__list .cabin-feature::before {
  content: "›";
  color: var(--c-gold);
  font-family: var(--f-serif);
  font-size: 1.25rem;
  line-height: 1;
  margin-right: 0.5rem;
}

.virtual-tour__viewer {
  display: flex;
  flex-direction: column;
}
.vt-frame {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: var(--c-ink);
  border-bottom: var(--border);
  isolation: isolate;
}
.vt-frame__poster {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  z-index: 0;
  transition: transform 700ms var(--ease-premium), filter 300ms ease;
  filter: brightness(0.62);
}
.vt-frame__iframe {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  border: 0;
  z-index: 2;
}
.vt-frame.is-active .vt-frame__poster { display: none; }

.vt-frame__activate {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  background: transparent;
  border: 0;
  color: var(--c-paper);
  cursor: pointer;
  z-index: 1;
  padding: 1.5rem;
  text-align: center;
  font: inherit;
  transition: background 280ms var(--ease-premium);
}
.vt-frame__activate:hover,
.vt-frame__activate:focus-visible {
  background: rgba(28, 28, 26, 0.35);
  outline: none;
}
.vt-frame__activate:hover ~ .vt-frame__poster,
.vt-frame:hover .vt-frame__poster { transform: scale(1.02); filter: brightness(0.55); }
.vt-frame__activate:focus-visible { box-shadow: inset 0 0 0 3px var(--c-gold); }

.vt-frame__play {
  width: 64px;
  height: 64px;
  color: var(--c-gold);
  transition: transform 280ms var(--ease-premium);
  filter: drop-shadow(0 6px 24px rgba(0,0,0,0.45));
}
.vt-frame__activate:hover .vt-frame__play { transform: scale(1.08); }
.vt-frame__activate-label {
  font-family: var(--f-mono);
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
}
.vt-frame__activate-sub {
  font-family: var(--f-mono);
  font-size: 0.62rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  opacity: 0.7;
  max-width: 28ch;
}

.virtual-tour__credit {
  padding: 0.875rem clamp(1.25rem, 3vw, 2rem);
  font-family: var(--f-mono);
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  color: var(--c-smoke);
  line-height: 1.6;
  text-align: center;
}
.virtual-tour .virtual-tour__credit a {
  color: var(--c-gold-dk);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
  transition: color var(--t);
  font-weight: 600;
}
.virtual-tour .virtual-tour__credit a:hover,
.virtual-tour .virtual-tour__credit a:focus-visible { color: var(--c-ink); }

@media (max-width: 900px) {
  .virtual-tour { grid-template-columns: 1fr; }
  .virtual-tour__text { border-right: none; border-bottom: var(--border); }
  .virtual-tour__lead { max-width: none; }
  /* Telefon: spacer pionowo (3:4), wypełnia ekran lepiej niż płaskie 16:9 */
  .vt-frame { aspect-ratio: 3 / 4; }
}

/* Desktop: spacer wypełnia wysokość kolumny (zrównaną z tekstem przez grid stretch),
   bez pustej przestrzeni pod iframem. Mobile zachowuje aspect-ratio 16/9 powyżej. */
@media (min-width: 901px) {
  .virtual-tour__viewer { height: 100%; }
  .vt-frame { aspect-ratio: auto; flex: 1 1 auto; min-height: 360px; }
}

@media (min-width: 1280px) {
  .virtual-tour__lead { font-size: 1rem; line-height: 1.85; }
  .vt-frame__activate-label { font-size: 0.86rem; letter-spacing: 0.2em; }
  .vt-frame__activate-sub { font-size: 0.68rem; }
  .virtual-tour__credit { font-size: 0.82rem; }
}

