/* ░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░
   Dania 2026 — wyprawa ślubna po krainie wikingów
   Nordycko-królewski motyw: fiord navy + mosiężne złoto + papier
   ░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░ */

:root {
  --ink:    #0a1a24;   /* głęboki fiord */
  --ink-2:  #102b38;
  --sea:    #2c727b;   /* morska zieleń */
  --gold:   #c9a24b;
  --gold-2: #e7c982;
  --red:    #c1121f;   /* Dannebrog */
  --paper:  #fbf6ec;
  --paper-2:#f1e7d4;
  --cream:  #f6efe1;
  --text:   #243039;
  --muted:  #6a6256;
  --line:   rgba(201,162,75,.30);
  --shadow: 0 18px 50px -20px rgba(10,26,36,.45);
  --radius: 18px;
  --font-display: 'Cinzel', 'Iowan Old Style', Georgia, serif;
  --font-body: 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-hand: 'Caveat', cursive;
  --wrap: 1140px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-body);
  color: var(--text);
  background: var(--paper);
  line-height: 1.65;
  overflow-x: hidden;
}
img { display: block; max-width: 100%; }
a { color: inherit; }

.wrap { width: 100%; max-width: var(--wrap); margin-inline: auto; padding-inline: 22px; }

/* ── typografia sekcji ── */
.eyebrow {
  font-family: var(--font-display);
  letter-spacing: .28em;
  text-transform: uppercase;
  font-size: .72rem;
  font-weight: 700;
  color: var(--gold);
  margin-bottom: .6rem;
}
.eyebrow--center { text-align: center; }
.eyebrow--light { color: var(--gold-2); }
h2 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(1.8rem, 4.4vw, 2.9rem);
  line-height: 1.08;
  color: var(--ink);
  letter-spacing: -.01em;
}
.h2--center { text-align: center; }
.h2--light { color: var(--paper); }
h3 { font-family: var(--font-display); }
h4 { font-family: var(--font-display); font-weight: 700; }

/* ── przyciski ── */
.btn {
  display: inline-flex; align-items: center; gap: .4em;
  font-weight: 600; font-size: .95rem;
  padding: .8em 1.5em; border-radius: 999px;
  text-decoration: none; cursor: pointer;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
  white-space: nowrap;
}
.btn--sm { padding: .58em 1.05em; font-size: .85rem; }
.btn--gold {
  background: linear-gradient(135deg, var(--gold-2), var(--gold));
  color: #3a2c08;
  box-shadow: 0 10px 24px -10px rgba(201,162,75,.8);
}
.btn--gold:hover { transform: translateY(-2px); box-shadow: 0 16px 30px -10px rgba(201,162,75,.9); }
.btn--ghost { border: 1.5px solid currentColor; color: var(--ink); }
.btn--ghost:hover { background: var(--ink); color: var(--paper); transform: translateY(-2px); }

/* ░░░ HERO ░░░ */
.hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  color: var(--paper);
  isolation: isolate;
  overflow: hidden;
}
.hero__bg {
  position: absolute; inset: 0; z-index: -2;
  background: url('/img/p/frederiksborg.jpg?v=bb8c2583') center 30% / cover no-repeat;
  transform: scale(1.05);
  filter: saturate(.9);
}
.hero__scrim {
  position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(120% 90% at 18% 12%, rgba(44,114,123,.45), transparent 60%),
    linear-gradient(180deg, rgba(10,26,36,.78) 0%, rgba(10,26,36,.62) 38%, rgba(10,26,36,.92) 100%);
}
.hero__nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: 22px clamp(22px, 5vw, 60px);
}
.brand {
  font-family: var(--font-display); font-weight: 900;
  letter-spacing: .18em; font-size: 1.05rem;
}
.brand span { color: var(--gold-2); }
.hero__links { display: flex; gap: clamp(14px, 3vw, 34px); }
.hero__links a {
  text-decoration: none; font-weight: 500; font-size: .92rem;
  letter-spacing: .04em; opacity: .85; position: relative; padding: 4px 0;
}
.hero__links a::after {
  content: ''; position: absolute; left: 0; bottom: -2px; height: 2px; width: 0;
  background: var(--gold-2); transition: width .25s ease;
}
.hero__links a:hover { opacity: 1; }
.hero__links a:hover::after { width: 100%; }

.hero__inner {
  flex: 1;
  display: flex; flex-direction: column; justify-content: center;
  max-width: var(--wrap); width: 100%;
  margin-inline: auto; padding: 4vh clamp(22px, 5vw, 60px);
}
.kicker {
  font-family: var(--font-display);
  letter-spacing: .26em; text-transform: uppercase;
  font-size: clamp(.66rem,1.6vw,.82rem); font-weight: 700;
  color: var(--gold-2); margin-bottom: 1.1rem;
}
.hero__title {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(2.9rem, 9vw, 6.4rem);
  line-height: .98; letter-spacing: -.015em;
  text-shadow: 0 6px 40px rgba(0,0,0,.4);
}
.hero__title em {
  font-style: normal;
  background: linear-gradient(135deg, var(--gold-2), var(--gold));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.hero__lead {
  margin-top: 1.4rem; max-width: 38ch;
  font-size: clamp(1rem, 2.3vw, 1.22rem); opacity: .92;
}
.hero__badge {
  margin-top: 2rem; display: inline-flex; align-items: center; gap: 14px;
  background: rgba(251,246,236,.1); backdrop-filter: blur(6px);
  border: 1px solid rgba(231,201,130,.4);
  padding: 14px 20px; border-radius: 14px; width: fit-content;
}
.hero__badge-ico { font-size: 1.7rem; }
.hero__badge strong { display: block; font-family: var(--font-display); font-size: 1.02rem; }
.hero__badge span { font-size: .86rem; opacity: .8; }
.hero__poem {
  margin-top: 2rem;
  font-family: var(--font-hand);
  font-size: clamp(1.4rem, 3.6vw, 2rem);
  color: var(--gold-2); line-height: 1.2;
  transform: rotate(-2deg); transform-origin: left;
}
.hero__scroll {
  align-self: center; text-decoration: none; color: var(--paper);
  font-size: 1.6rem; padding-bottom: 18px; opacity: .7;
  animation: bob 1.8s ease-in-out infinite;
}
@keyframes bob { 0%,100%{transform:translateY(0)} 50%{transform:translateY(7px)} }

/* ── złoty pasek-dzielnik ── */
.invite, .route, .plan, .stays { position: relative; }
.invite { background: var(--cream); padding: clamp(60px,9vw,110px) 0; }

.invite__grid {
  display: grid; grid-template-columns: 1.5fr 1fr;
  gap: clamp(30px, 5vw, 70px); align-items: center;
}
.invite__text h2 { margin-bottom: 1.1rem; }
.invite__text p { margin-bottom: 1rem; font-size: 1.04rem; color: #3a4148; }
.invite__note {
  border-left: 3px solid var(--gold);
  padding-left: 16px; font-style: italic; color: var(--muted);
}
.invite__cta { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 1.6rem; }

.invite__facts {
  list-style: none; display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
}
.invite__facts li {
  background: var(--paper); border: 1px solid var(--line);
  border-radius: 14px; padding: 22px 18px; text-align: center;
  box-shadow: 0 10px 26px -22px rgba(10,26,36,.7);
}
.invite__facts .num {
  display: block; font-family: var(--font-display); font-weight: 900;
  font-size: 1.9rem; color: var(--sea); line-height: 1;
}
.invite__facts .lbl { font-size: .82rem; color: var(--muted); letter-spacing: .02em; }

/* ░░░ TRASA ░░░ */
.route { background: var(--paper); padding: clamp(60px,9vw,110px) 0; }
.route__sub {
  text-align: center; max-width: 60ch; margin: .8rem auto 0; color: var(--muted);
}
.route__sub--light { color: rgba(246,239,225,.72); }
.route__maps {
  margin-top: 3rem; display: grid; grid-template-columns: 1fr 1fr; gap: 26px;
}
.route__maps figure {
  background: #fff; border: 1px solid var(--line); border-radius: var(--radius);
  overflow: hidden; box-shadow: var(--shadow);
}
.route__maps img { width: 100%; height: 100%; object-fit: cover; }
.route__maps figcaption {
  font-family: var(--font-display); font-weight: 700; font-size: .92rem;
  padding: 14px 18px; color: var(--ink); border-top: 1px solid var(--line);
}
.route__maps figcaption span { color: var(--gold); font-weight: 500; }

/* ░░░ PLAN / TIMELINE ░░░ */
.plan { background: var(--cream); padding: clamp(60px,9vw,110px) 0; }
.timeline { list-style: none; margin: 3rem auto 0; max-width: 760px; position: relative; }
.timeline::before {
  content: ''; position: absolute; left: 82px; top: 14px; bottom: 14px; width: 2px;
  background: linear-gradient(180deg, var(--gold), rgba(201,162,75,.2));
}
.tl { position: relative; display: grid; grid-template-columns: 58px 1fr; gap: 48px; padding-bottom: 34px; }
.tl__date { text-align: right; padding-top: 9px; }
/* znacznik na osi — wyśrodkowany na pionowej linii (82px), nie nachodzi na daty */
.tl::after {
  content: ''; position: absolute; left: 82px; top: 14px;
  transform: translateX(-50%);
  width: 14px; height: 14px; border-radius: 50%;
  background: var(--paper); border: 3px solid var(--gold); z-index: 1;
}
.tl--star::after {
  background: var(--red); border-color: var(--gold-2);
  box-shadow: 0 0 0 4px rgba(193,18,31,.18);
}
.tl__d { display: block; font-family: var(--font-display); font-weight: 700; font-size: 1.04rem; color: var(--ink); }
.tl__w { font-size: .76rem; color: var(--muted); text-transform: uppercase; letter-spacing: .08em; }
.tl__body {
  background: var(--paper); border: 1px solid var(--line);
  border-radius: 14px; padding: 20px 22px;
  box-shadow: 0 12px 30px -26px rgba(10,26,36,.8);
}
.tl--star .tl__body { border-color: var(--gold); background: linear-gradient(180deg,#fff,var(--paper)); }
.tl__body h3 { font-size: 1.18rem; color: var(--ink); margin-bottom: .4rem; }
.tl__body p { font-size: .98rem; color: #3a4148; }
.tl__sleep { margin-top: .7rem; font-size: .9rem !important; color: var(--sea) !important; }
.tl__pics { display: flex; gap: 10px; margin: .9rem 0 .2rem; }
.tl__pics img {
  width: 50%; aspect-ratio: 4/3; object-fit: cover; border-radius: 10px;
  border: 1px solid var(--line);
}

/* ░░░ NOCLEGI ░░░ */
.stays { background: var(--paper); padding: clamp(60px,9vw,110px) 0; }

/* pasek trasy: skąd dokąd */
.route-strip {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 6px 12px;
  margin: 2.2rem auto 0; max-width: 820px;
  background: #fff; border: 1px solid var(--line); border-radius: 999px;
  padding: 13px 26px; box-shadow: 0 12px 30px -24px rgba(10,26,36,.8);
}
.route-strip a {
  text-decoration: none; font-family: var(--font-display); font-weight: 700;
  font-size: .94rem; color: var(--ink); transition: color .15s ease;
}
.route-strip a:hover { color: var(--sea); }
.route-strip__arr { color: var(--gold); font-weight: 700; }

.stops { display: flex; flex-direction: column; gap: clamp(2.2rem, 4vw, 3.2rem); margin-top: 2.8rem; }
.stop { scroll-margin-top: 24px; }

/* jednolity nagłówek miasta dla wszystkich przystanków */
.city-head {
  display: flex; align-items: center; gap: 16px;
  border-bottom: 1px solid var(--line); padding-bottom: .8rem; margin-bottom: 1.3rem;
}
.city-head__num {
  flex: none; width: 40px; height: 40px; border-radius: 50%;
  display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 700; font-size: 1.15rem; color: #3a2c08;
  background: linear-gradient(135deg, var(--gold-2), var(--gold));
  box-shadow: 0 8px 18px -8px rgba(201,162,75,.95);
}
.city-head__title { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; flex: 1; }
.city-head__title h3 { font-size: 1.5rem; color: var(--ink); letter-spacing: -.01em; }
.city-head__date { font-family: var(--font-body); font-weight: 500; font-size: .9rem; color: var(--muted); }
.city-head__badge { font-size: .74rem; font-weight: 700; color: var(--red); letter-spacing: .06em; text-transform: uppercase; white-space: nowrap; }
.city-head__leg { font-family: var(--font-display); font-size: .82rem; color: var(--sea); letter-spacing: .03em; white-space: nowrap; }

.stays__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 26px; }

/* szeroka pozioma karta dla pojedynczych miast */
.stay--wide { flex-direction: row; align-items: stretch; }
.stay--wide .stay__media { aspect-ratio: 4/3; width: 38%; flex: none; }
.stay--wide .stay__body { flex: 1; justify-content: center; gap: .45rem; padding: 24px 30px; }
.stay--wide .stay__foot { margin-top: .9rem; }

/* przycisk w kolorach Booking.com */
.btn--booking {
  background: #006ce4; color: #fff;
  box-shadow: 0 10px 24px -12px rgba(0,108,228,.85);
}
.btn--booking:hover { background: #00509e; transform: translateY(-2px); box-shadow: 0 16px 30px -12px rgba(0,108,228,.95); }

/* ── serpentyna noclegów: droga wijąca się lewo↔prawo, tekst na zdjęciu ── */
.snake { display: flex; flex-direction: column; align-items: stretch; margin-top: 2.6rem; }
.scard {
  position: relative; width: min(560px, 90%); aspect-ratio: 16/10;
  border-radius: var(--radius); overflow: hidden; isolation: isolate;
  box-shadow: var(--shadow); color: #fff; scroll-margin-top: 24px;
  transition: transform .2s ease, box-shadow .2s ease;
}
.scard--left  { align-self: flex-start; }
.scard--right { align-self: flex-end; }
.scard:hover { transform: translateY(-4px); box-shadow: 0 28px 60px -24px rgba(10,26,36,.55); }
.scard__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: -2; transition: transform .5s ease; }
.scard:hover .scard__img { transform: scale(1.06); }
.scard::after {
  content: ''; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(180deg, rgba(8,20,28,0) 26%, rgba(8,20,28,.5) 56%, rgba(8,20,28,.94) 100%);
}
.scard__content { position: absolute; inset: auto 0 0 0; padding: 20px 22px; display: flex; flex-direction: column; gap: 5px; }
.scard__head {
  display: flex; align-items: center; gap: 9px;
  font-family: var(--font-display); font-weight: 700; font-size: 1rem; color: var(--gold-2);
  text-shadow: 0 2px 10px rgba(0,0,0,.55);
}
.scard__num {
  flex: none; width: 26px; height: 26px; border-radius: 50%;
  display: grid; place-items: center; font-size: .82rem; color: #3a2c08;
  background: linear-gradient(135deg, var(--gold-2), var(--gold));
}
.scard__date { font-family: var(--font-body); font-weight: 500; font-size: .78rem; color: rgba(255,255,255,.82); }
.scard__title { font-size: 1.3rem; line-height: 1.2; color: #fff; text-shadow: 0 2px 14px rgba(0,0,0,.65); }
.scard__foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 7px; flex-wrap: wrap; }
.scard__price { font-family: var(--font-display); font-weight: 700; font-size: 1.12rem; color: #fff; text-shadow: 0 2px 10px rgba(0,0,0,.5); }
.scard__price small { display: block; font-family: var(--font-body); font-weight: 500; font-size: .72rem; color: rgba(255,255,255,.8); }

/* Kopenhaga — JEDNA szersza karta przecięta po skosie na 2 opcje */
.scard--choice { align-self: center; width: min(880px, 100%); aspect-ratio: 21/9; }
.splitcard {
  position: relative; align-self: center; width: min(880px, 100%); aspect-ratio: 21/9;
  border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow);
  color: #fff; scroll-margin-top: 24px; isolation: isolate;
}
.splitcard__head {
  position: absolute; inset: 0 0 auto 0; z-index: 5;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  padding: 13px 16px; font-family: var(--font-display); font-weight: 700; font-size: .94rem;
  background: linear-gradient(180deg, rgba(8,20,28,.82), rgba(8,20,28,0));
  text-shadow: 0 2px 8px rgba(0,0,0,.6);
}
.splitcard__head .scard__num { position: static; }
.splitcard__head em { font-style: normal; font-family: var(--font-body); font-weight: 500; color: var(--gold-2); }
.half { position: absolute; inset: 0; }
.half--a { clip-path: polygon(0 0, 53% 0, 47% 100%, 0 100%); }
.half--b { clip-path: polygon(53% 0, 100% 0, 100% 100%, 47% 100%); }
.half__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: -2; }
.half::after { content: ''; position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg, rgba(8,20,28,.18) 28%, rgba(8,20,28,.92) 100%); }
.half__body { position: absolute; bottom: 0; width: 46%; padding: 18px 20px; display: flex; flex-direction: column; gap: 5px; }
.half--a .half__body { left: 0; align-items: flex-start; }
.half--b .half__body { right: 0; align-items: flex-start; }
.opt__tag { width: 26px; height: 26px; border-radius: 50%; display: grid; place-items: center; font-family: var(--font-display); font-weight: 700; font-size: .82rem; color: #fff; background: rgba(28,90,99,.95); }
.opt__tag--b { background: rgba(193,18,31,.92); }
.opt__name { font-family: var(--font-display); font-weight: 700; font-size: 1.05rem; line-height: 1.18; text-shadow: 0 2px 10px rgba(0,0,0,.65); }
.opt__price { font-family: var(--font-display); font-weight: 700; font-size: 1rem; }
.opt__price small { display: block; font-family: var(--font-body); font-weight: 500; font-size: .7rem; color: rgba(255,255,255,.82); }
.half__body .btn { margin-top: 8px; align-self: flex-start; }
.split__seam {
  position: absolute; top: -8%; left: 50%; width: 4px; height: 116%;
  transform: translateX(-50%) rotate(8deg); transform-origin: center;
  background: linear-gradient(var(--gold-2), var(--gold)); box-shadow: 0 0 14px rgba(201,162,75,.6);
  z-index: 4;
}
.scard__opt {
  position: absolute; top: 14px; left: 14px; z-index: 1;
  font-size: .7rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
  padding: 5px 12px; border-radius: 999px; color: #fff;
  box-shadow: 0 6px 16px -8px rgba(0,0,0,.6);
}
.scard__opt--a { background: rgba(28,90,99,.92); }
.scard__opt--b { background: rgba(193,18,31,.9); }

/* zakręty drogi między przystankami */
.snake__turn { align-self: center; font-size: 2.2rem; line-height: 1; color: var(--gold); opacity: .85; margin: 8px 0; }
.snake__turn--rl { transform: translateX(22%); }
.snake__turn--lr { transform: translateX(-22%); }

.stay {
  background: #fff; border: 1px solid var(--line); border-radius: var(--radius);
  overflow: hidden; box-shadow: var(--shadow);
  display: flex; flex-direction: column;
  transition: transform .2s ease, box-shadow .2s ease;
}
.stay:hover { transform: translateY(-4px); box-shadow: 0 26px 56px -24px rgba(10,26,36,.5); }
.stay__media { aspect-ratio: 16/10; overflow: hidden; }
.stay__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.stay:hover .stay__media img { transform: scale(1.05); }
.stay__media--duo { display: grid; grid-template-columns: 1fr 1fr; gap: 2px; aspect-ratio: 16/8; }
.stay__media--duo img { transition: none; }

.stay__body { padding: 18px 20px 20px; display: flex; flex-direction: column; flex: 1; }
.stay__tag {
  align-self: flex-start; font-size: .72rem; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; padding: 3px 10px; border-radius: 999px; margin-bottom: .5rem;
}
.stay__tag--a { background: rgba(44,114,123,.14); color: var(--sea); }
.stay__tag--b { background: rgba(193,18,31,.12); color: var(--red); }
.stay__city { font-family: var(--font-display); font-weight: 700; color: var(--sea); font-size: .92rem; }
.stay__dates { font-size: .78rem; color: var(--muted); margin-bottom: .3rem; }
.stay__body h4 { font-size: 1.08rem; color: var(--ink); line-height: 1.25; margin: .25rem 0 .4rem; }
.stay__meta { font-size: .85rem; color: var(--muted); margin-bottom: 1rem; }
.stay__foot { margin-top: auto; display: flex; align-items: center; justify-content: space-between; gap: 10px; flex-wrap: wrap; }
.stay__price { font-family: var(--font-display); font-weight: 700; font-size: 1.18rem; color: var(--ink); }
.stay__price small { font-family: var(--font-body); font-weight: 500; font-size: .72rem; color: var(--muted); }
.stay__price-sub { display: block; font-style: normal; font-family: var(--font-body); font-size: .72rem; font-weight: 500; color: var(--sea); }

/* ░░░ KOSZTY ░░░ */
.costs {
  background: linear-gradient(170deg, var(--ink), var(--ink-2));
  color: var(--paper); padding: clamp(60px,9vw,110px) 0;
  position: relative;
}
.costs__grid {
  margin-top: 3rem; display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px;
}
.cost {
  background: rgba(251,246,236,.05); border: 1px solid rgba(231,201,130,.22);
  border-radius: 16px; padding: 26px 22px;
}
.cost__ico { font-size: 1.8rem; }
.cost h4 { font-size: 1.05rem; color: var(--gold-2); margin: .6rem 0 .3rem; letter-spacing: .02em; }
.cost__big { font-family: var(--font-display); font-weight: 900; font-size: 1.7rem; color: #fff; margin-bottom: .5rem; }
.cost__desc { font-size: .88rem; color: rgba(246,239,225,.72); line-height: 1.55; }

.nights { list-style: none; max-width: 720px; margin: 2.8rem auto 0; display: flex; flex-direction: column; gap: 10px; }
.night {
  display: grid; grid-template-columns: 1.4fr 1fr auto; align-items: center; gap: 16px;
  background: rgba(251,246,236,.05); border: 1px solid rgba(231,201,130,.2);
  border-radius: 12px; padding: 14px 20px;
}
.night__city { font-family: var(--font-display); font-weight: 700; color: #fff; font-size: 1.02rem; }
.night__city em { font-family: var(--font-body); font-weight: 500; font-style: normal; color: rgba(246,239,225,.55); font-size: .82rem; }
.night__grp { font-size: .9rem; color: rgba(246,239,225,.7); }
.night__pp { font-family: var(--font-display); font-weight: 700; color: var(--gold-2); font-size: 1.08rem; justify-self: end; white-space: nowrap; }
.night__pp::after { content: ' / os'; font-family: var(--font-body); font-weight: 500; font-size: .72rem; color: rgba(246,239,225,.5); }

.costs__summary {
  margin-top: 2.4rem; display: flex; align-items: center; justify-content: space-between;
  gap: 24px; flex-wrap: wrap;
  background: rgba(201,162,75,.12); border: 1px solid rgba(231,201,130,.35);
  border-radius: 18px; padding: 26px 30px;
}
.costs__summary-lbl { font-size: .82rem; letter-spacing: .14em; text-transform: uppercase; color: var(--gold-2); }
.costs__summary-val { font-family: var(--font-display); font-weight: 900; font-size: clamp(2rem,5vw,2.8rem); color: #fff; line-height: 1; }
.costs__summary-val span { font-size: 1rem; font-family: var(--font-body); color: rgba(246,239,225,.7); }
.costs__compare { max-width: 44ch; font-size: .92rem; color: rgba(246,239,225,.82); }

/* ░░░ STOPKA ░░░ */
.foot {
  background: var(--ink); color: var(--paper); text-align: center;
  padding: clamp(54px,8vw,90px) 0 60px;
  border-top: 3px solid var(--gold);
}
.foot__big { font-family: var(--font-display); font-weight: 900; font-size: clamp(1.8rem,5vw,2.8rem); color: var(--gold-2); }
.foot__sub { margin-top: .6rem; font-size: 1.05rem; opacity: .9; }
.foot__dates { margin-top: 1.4rem; font-family: var(--font-display); letter-spacing: .12em; font-size: .82rem; color: rgba(246,239,225,.55); }

/* ░░░ scroll-reveal (progresywne wzmocnienie) ░░░ */
@supports (animation-timeline: view()) {
  @media (prefers-reduced-motion: no-preference) {
    .reveal {
      animation: reveal-in linear both;
      animation-timeline: view();
      animation-range: entry 0% entry 42%;
    }
    @keyframes reveal-in {
      from { opacity: 0; transform: translateY(34px); }
      to   { opacity: 1; transform: translateY(0); }
    }
  }
}

/* ░░░ responsywność ░░░ */
@media (max-width: 920px) {
  .hero__links { display: none; }
  .invite__grid { grid-template-columns: 1fr; }
  .route__maps { grid-template-columns: 1fr; }
  .stays__grid--3 { grid-template-columns: 1fr 1fr; }
  .costs__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .stays__grid { grid-template-columns: 1fr; }
  .stay--wide { flex-direction: column; }
  .stay--wide .stay__media { width: 100%; aspect-ratio: 16/10; }
  .stay--wide .stay__body { padding: 18px 20px 20px; }
  .route-strip { padding: 11px 16px; gap: 4px 8px; }
  .route-strip a { font-size: .84rem; }
  .city-head__leg { display: none; }
  .scard { width: 100%; aspect-ratio: 16/12; }
  /* telefon: bez ukosu — pasek nagłówka u góry + dwie pełne karty jedna pod drugą */
  .splitcard { aspect-ratio: auto; background: var(--ink); }
  .splitcard__head { position: static; justify-content: flex-start; flex-wrap: wrap; background: none; padding: 15px 18px 12px; }
  .half { position: relative; inset: auto; width: 100%; aspect-ratio: 16/10; }
  .half--a, .half--b { clip-path: none; }
  .half__body { position: absolute; left: 0; right: 0; top: auto; bottom: 0; width: 100%; }
  .split__seam { display: none; }
  .snake__turn { font-size: 1.8rem; }
  .snake__turn--rl, .snake__turn--lr { transform: none; }
  .costs__grid { grid-template-columns: 1fr; }
  .invite__facts { grid-template-columns: 1fr 1fr; }
  .timeline::before { left: 64px; }
  .tl { grid-template-columns: 48px 1fr; gap: 34px; }
  .tl::after { left: 64px; }
  .stay__media--duo { aspect-ratio: 16/9; }
  .night { grid-template-columns: 1fr auto; row-gap: 2px; }
  .night__grp { grid-column: 1; font-size: .82rem; }
  .night__pp { grid-column: 2; grid-row: 1 / 3; align-self: center; }
}
