/* =========================================================================
   LAYOUT / KOMPONENTY  —  szkielet. Kolory/fonty wyłącznie przez var() z
   tokens.css. Zmiana stylistyki = edycja tokens.css.
   ========================================================================= */

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
html, body { overflow-x: clip; max-width: 100%; }

body {
  margin: 0;
  background-color: var(--canvas);
  background-image: var(--texture);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 17px; font-weight: 400; line-height: 1.62; letter-spacing: 0;
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
}

/* PANEL — spłaszczony: treść siedzi wprost na płótnie z siatką (v5) */
.panel {
  background: transparent;
  border-radius: 0;
  box-shadow: none;
  padding: 0;
}
/* edytorialna linia działowa nad sekcją jasną (poza hero) */
section:not(.hero) > .wrap > .panel {
  border-top: 1px solid var(--line);
  padding-top: clamp(2rem, 4vw, 3.4rem);
}
img { max-width: 100%; display: block; }
a { color: inherit; }
::selection { background: var(--ink); color: var(--paper); }

.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: clamp(1.25rem, 5vw, 4rem); }
.narrow { max-width: var(--maxw-narrow); margin-inline: auto; }

section { padding-block: var(--section-pad); position: relative; }

/* ---- SIATKA KOLUMN W TLE (Stripe-style guide lines) ---------------------- */
/* Treść (main/footer/nav) renderuje się NAD siatką dzięki z-index. */
main, .footer { position: relative; z-index: 1; }

.grid-lines { position: fixed; inset: 0; z-index: 0; pointer-events: none; }
.grid-lines .wrap { height: 100%; }
/* JEDNOLITE pionowe linie (border = ta sama grubość co wewnętrzne) +
   krzyżyki ✕ na przecięciach (motyw skrzyżowania z logo „WOLNIEJ"). */
.grid-lines__field {
  height: 100%;
  border-inline: 1px solid var(--grid);
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 132'%3E%3Cpath d='M-4 62 4 70 M4 62 -4 70' stroke='rgba(25,22,19,0.14)' stroke-width='1'/%3E%3C/svg%3E"),
    repeating-linear-gradient(to right, var(--grid) 0 1px, transparent 1px calc(100% / var(--cols)));
  background-repeat: repeat, repeat;
  background-size: calc(100% / var(--cols)) var(--grid-row), auto;
  background-position: 0 0, 0 0;
}
/* wariant na ciemnym pasie: absolutny w obrębie sekcji, jasne linie */
.grid-lines--band { position: absolute; z-index: 0; }
.grid-lines--band .grid-lines__field {
  border-color: var(--grid-dark);
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 132'%3E%3Cpath d='M-4 62 4 70 M4 62 -4 70' stroke='rgba(255,255,255,0.20)' stroke-width='1'/%3E%3C/svg%3E"),
    repeating-linear-gradient(to right, var(--grid-dark) 0 1px, transparent 1px calc(100% / var(--cols)));
  background-repeat: repeat, repeat;
  background-size: calc(100% / var(--cols)) var(--grid-row), auto;
  background-position: 0 0, 0 0;
}
/* mniej kolumn na węższych ekranach, ukryj na telefonie */
@media (max-width: 900px) { :root { --cols: 6; } }
@media (max-width: 560px) { .grid-lines { display: none; } }

/* ---- Typografia ---------------------------------------------------------- */
.eyebrow {
  font-family: var(--font-body); font-weight: 500; text-transform: uppercase;
  font-size: .72rem; color: var(--accent); margin: 0 0 1.2rem; letter-spacing: var(--tracking-eyebrow);
  display: inline-flex; align-items: center; gap: .55rem;
}
.eyebrow::before {
  content: ""; width: .72rem; height: .72rem; flex: none;
  background: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 10'%3E%3Cpath d='M1.5 1.5 8.5 8.5 M8.5 1.5 1.5 8.5' stroke='black' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E") center / contain no-repeat;
          mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 10'%3E%3Cpath d='M1.5 1.5 8.5 8.5 M8.5 1.5 1.5 8.5' stroke='black' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E") center / contain no-repeat;
}
h1, h2, h3, h4 { font-family: var(--font-display); font-weight: 500; letter-spacing: var(--tracking-head); line-height: 1.04; margin: 0; font-optical-sizing: auto; }
h1, h2 { font-variation-settings: "opsz" 144, "SOFT" 0, "WONK" 0; }
h1 { font-size: clamp(2.7rem, 6.4vw, 5.2rem); font-weight: 540; }
h2 { font-size: clamp(2rem, 4.4vw, 3.4rem); }
h3 { font-size: clamp(1.5rem, 2.4vw, 2rem); }
h4 { font-size: 1.25rem; }
em, .it { font-style: italic; color: var(--green); }
.dark em, .dark .it { color: var(--dark-paper); }
.h-dim { color: var(--sage); font-style: normal; }
p  { margin: 0 0 1.15rem; }
.muted { color: var(--muted); }
.lead  { font-size: clamp(1.08rem, 1.7vw, 1.3rem); color: var(--muted); font-weight: 300; line-height: 1.6; }
.measure { max-width: 56ch; }

/* nagłówek sekcji — edytorialnie do lewej; szerokość h2 i lead osobno */
.s-head { text-align: left; max-width: none; margin: 0 0 clamp(2.4rem, 5vw, 4rem); }
.s-head h2 { max-width: 30ch; }
.s-head .lead { margin: 1.3rem 0 0; max-width: 54ch; }

/* ---- Przyciski ----------------------------------------------------------- */
.btn {
  display: inline-flex; align-items: center; gap: .55rem;
  font-family: var(--font-body); font-size: .85rem; font-weight: 500; letter-spacing: .01em;
  text-decoration: none; padding: .82rem 1.55rem; border-radius: 999px;
  border: 1px solid var(--ink);
  background: var(--ink); color: #ffffff;
  box-shadow: none;
  transition: transform .25s var(--ease), background .25s, color .25s, border-color .25s, box-shadow .25s;
  cursor: pointer;
}
.btn:hover { transform: translateY(-2px); background: var(--green); border-color: var(--green); color: #ffffff; }
.btn-ghost { background: var(--paper-2); color: var(--ink); border-color: color-mix(in srgb, var(--ink) 22%, transparent); }
.btn-ghost:hover { background: var(--paper-2); border-color: var(--green); color: var(--green); }
.btn .arr { transition: transform .25s var(--ease); }
.btn:hover .arr { transform: translateX(3px); }
/* warianty na ciemnym (zielonym) tle */
.dark .btn { background: var(--green-ink); color: var(--green-deep); border-color: var(--green-ink); }
.dark .btn:hover { background: transparent; color: var(--green-ink); border-color: var(--green-ink); }
.dark .btn-ghost { background: rgba(255,255,255,.07); color: var(--dark-paper); border-color: color-mix(in srgb, var(--dark-paper) 32%, transparent); }
.dark .btn-ghost:hover { background: var(--dark-paper); color: var(--dark); border-color: var(--dark-paper); }

/* link tekstowy z podkreśleniem */
.link { color: var(--ink); text-decoration: none; border-bottom: 1px solid color-mix(in srgb, var(--ink) 30%, transparent); padding-bottom: 1px; transition: border-color .2s, color .2s; }
.link:hover { color: var(--accent); border-color: var(--accent); }

/* ---- Nawigacja (scroll-spy) ---------------------------------------------- */
.nav { position: sticky; top: 0; z-index: 50; background: color-mix(in srgb, var(--canvas) 58%, transparent); backdrop-filter: blur(10px); border-bottom: 1px solid transparent; transition: border-color .3s, background .3s; }
.nav.is-scrolled { border-color: var(--line); }
.nav .wrap { display: flex; align-items: center; justify-content: space-between; padding-block: 1.05rem; gap: 1.5rem; }
.nav__logo { display: block; line-height: 0; }
.nav__logo img { height: 22px; width: auto; }
.nav__links { display: flex; gap: 1.7rem; align-items: center; }
.nav__links a { position: relative; text-decoration: none; font-size: .82rem; font-weight: 400; letter-spacing: .06em; color: var(--muted); transition: color .25s; }
.nav__links a::after { content: ""; position: absolute; left: 0; bottom: -5px; width: 100%; height: 1px; background: var(--accent); transform: scaleX(0); transform-origin: left; transition: transform .3s var(--ease); }
.nav__links a:hover { color: var(--ink); }
.nav__links a.active { color: var(--ink); }
.nav__links a.active::after { transform: scaleX(1); }
.nav__cta { /* identyczny rozmiar/styl jak baton w Hero (.btn) */ }
@media (max-width: 880px) { .nav__links a:not(.nav__cta) { display: none; } }

/* ---- Hero (jeden ekran, bez „peek" pod foldem) --------------------------- */
.hero { min-height: calc(100svh - 56px); display: grid; place-items: center; text-align: center; padding-block: 3rem; }
.hero__inner { max-width: 26ch; }
.hero .eyebrow { color: var(--accent); }
.hero h1 { margin-bottom: 1.6rem; }
.hero .lead { max-width: 44ch; margin-inline: auto; }
.hero__cta { display: flex; gap: .9rem; justify-content: center; flex-wrap: wrap; margin-top: 2.4rem; }
.hero__scroll { position: absolute; bottom: 1.8rem; left: 50%; transform: translateX(-50%); font-size: .72rem; letter-spacing: .22em; text-transform: uppercase; color: var(--muted); display: flex; flex-direction: column; align-items: center; gap: .5rem; }
.hero__scroll span { width: 1px; height: 26px; background: var(--muted); opacity: .5; animation: scrollpulse 2.4s var(--ease) infinite; }
@keyframes scrollpulse { 0%,100% { transform: scaleY(.4); opacity: .25 } 50% { transform: scaleY(1); opacity: .6 } }

/* ---- Sekcja ciemna (pełnoekranowy pas z własną jasną siatką) ------------- */
.dark { background: var(--dark); color: var(--dark-paper); }
.dark > .wrap { position: relative; z-index: 1; }
.dark .muted, .dark .lead { color: var(--dark-muted); }
.dark .eyebrow { color: var(--dark-paper); opacity: .75; }
.dark .row { border-color: var(--dark-line); }
.dark .card { background: color-mix(in srgb, var(--dark-paper) 6%, transparent); border-color: var(--dark-line); }
.dark .card h4 { color: var(--dark-paper); }
.dark .card p { color: var(--dark-muted); }

/* ---- Listy hairline (jak „Programs") ------------------------------------- */
.rows { margin: 0; padding: 0; list-style: none; }
.row { display: grid; grid-template-columns: 1fr 1.3fr auto; gap: 1.5rem; align-items: baseline; padding: 1.5rem 0; border-top: 1px solid var(--line); transition: padding-left .35s var(--ease); }
.row:last-child { border-bottom: 1px solid var(--line); }
.row:hover { padding-left: .6rem; }
.row__title { font-family: var(--font-display); font-size: clamp(1.3rem, 2.2vw, 1.8rem); }
.row__desc { color: var(--muted); font-size: .98rem; }
.row__meta { color: var(--muted); font-size: .82rem; letter-spacing: .04em; white-space: nowrap; }
@media (max-width: 720px) { .row { grid-template-columns: 1fr; gap: .4rem; } .row__meta { display: none; } }

/* ---- Festiwal (wyśrodkowane oświadczenie - inny rytm niż reszta) --------- */
.festival { text-align: center; max-width: 62ch; margin-inline: auto; }
.festival .eyebrow { justify-content: center; }
.festival h2 { max-width: none; margin-inline: auto; font-size: clamp(2.4rem, 5.4vw, 4.2rem); }
.festival .lead { max-width: 58ch; margin: 1.5rem auto 0; }

/* ---- Split tekst / wizual ------------------------------------------------ */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 6vw, 5.5rem); align-items: center; }
.split--rev > :first-child { order: 2; }
@media (max-width: 860px) { .split { grid-template-columns: 1fr; gap: 2.5rem; } .split--rev > :first-child { order: 0; } }

/* ---- Obraz w ramce ------------------------------------------------------- */
.framed { background: var(--paper-2); padding: .55rem .55rem 2.1rem; border-radius: var(--radius-img); box-shadow: var(--shadow); border: 1px solid var(--line); }
.framed img { border-radius: 2px; width: 100%; object-fit: cover; aspect-ratio: 4/5; }
.framed figcaption { font-family: var(--font-display); font-style: italic; font-size: 1.15rem; text-align: center; margin-top: 1rem; }

/* ---- Slot na zdjęcie (placeholder, gdy brak pliku) ----------------------- */
.photo-slot { aspect-ratio: 4/5; border-radius: var(--radius-img); border: 1px dashed color-mix(in srgb, var(--muted) 45%, transparent); display: grid; place-content: center; text-align: center; color: var(--muted); font-size: .82rem; letter-spacing: .04em; background: var(--paper-2); }

/* ---- Karty --------------------------------------------------------------- */
.grid { display: grid; gap: 1.1rem; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); }
.card { background: var(--paper-2); border: 1px solid var(--line); border-radius: var(--radius-img); padding: 2rem 1.8rem; box-shadow: none; transition: border-color .25s, transform .25s var(--ease); }
.card:hover { border-color: color-mix(in srgb, var(--accent) 55%, var(--line)); transform: translateY(-3px); }
.dark .card:hover { border-color: var(--dark-line); }
.card__chip { width: 2.6rem; height: 2.6rem; border-radius: 12px; background: color-mix(in srgb, var(--green) 12%, var(--paper-2)); color: var(--green); display: grid; place-content: center; margin-bottom: 1.1rem; }
.card__chip svg { width: 1.3rem; height: 1.3rem; fill: none; stroke: currentColor; stroke-width: 1.6; }
.dark .card__chip { background: rgba(255,255,255,.08); color: var(--dark-paper); }
.card h4 { margin-bottom: .5rem; font-size: 1.4rem; }
.card p { font-size: .96rem; color: var(--muted); margin-bottom: 0; }

/* ---- Pasek credentiali (jak band liczb w referencji) --------------------- */
.creds { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: clamp(1.5rem, 4vw, 3rem); }
.creds__item { text-align: center; }
.creds__item .big { display: block; font-family: var(--font-display); font-size: clamp(1.9rem, 3.6vw, 2.8rem); color: var(--green); line-height: 1.05; }
.creds__item p { color: var(--muted); font-size: .9rem; margin: .5rem 0 0; }

/* ---- Portfolio (nazwiska) ------------------------------------------------ */
.names { display: flex; flex-wrap: wrap; justify-content: center; gap: .8rem 2.4rem; align-items: baseline; }
.names span { font-family: var(--font-display); font-size: clamp(1.6rem, 3.4vw, 2.6rem); }
.names small { display: block; text-align: center; font-family: var(--font-body); font-size: .76rem; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); margin-top: .2rem; }

/* ---- Streaming pills ----------------------------------------------------- */
.streams { display: flex; flex-wrap: wrap; gap: .6rem; justify-content: center; }
.streams a { display: inline-flex; align-items: center; font-size: .82rem; letter-spacing: .03em; text-decoration: none; padding: .6rem 1.2rem; border-radius: 999px; border: 1px solid var(--line); background: var(--paper-2); color: var(--ink); transition: border-color .25s, color .25s, transform .25s var(--ease); }
.streams a:hover { border-color: var(--accent); color: var(--accent); transform: translateY(-2px); }
.dark .streams a { background: transparent; border-color: var(--dark-line); color: var(--dark-paper); }
.dark .streams a:hover { border-color: var(--dark-paper); color: var(--dark-paper); }

/* ---- Blok promujący płytę (CTA główne) ----------------------------------- */
.album-cta { display: grid; grid-template-columns: .9fr 1.1fr; gap: clamp(2rem, 6vw, 5rem); align-items: center; }
@media (max-width: 860px) { .album-cta { grid-template-columns: 1fr; } }
.cover { aspect-ratio: 1/1; border-radius: var(--radius-img); border: 1px solid var(--line); box-shadow: var(--shadow); display: grid; place-content: center; text-align: center; background: linear-gradient(150deg, var(--sky), var(--blush)); overflow: hidden; }
.cover b { font-family: var(--font-display); font-style: italic; font-size: clamp(2.6rem, 6vw, 4.2rem); color: var(--ink); font-weight: 500; }
.album-cta .badge { margin-bottom: 1rem; }
.price { font-family: var(--font-display); font-size: 2.4rem; }
.price small { font-family: var(--font-body); font-size: 1rem; color: var(--dark-muted); }

/* ---- Badge --------------------------------------------------------------- */
.badge { display: inline-block; font-family: var(--font-body); font-size: .68rem; letter-spacing: .2em; text-transform: uppercase; color: var(--accent); border: 1px solid currentColor; border-radius: 999px; padding: .32rem .9rem; }
.dark .badge { color: var(--dark-paper); opacity: .8; }

/* ---- Kroki (aplikacja) --------------------------------------------------- */
.steps { list-style: none; padding: 0; margin: 1.6rem 0 0; display: grid; gap: 1.3rem; }
.steps li { display: grid; grid-template-columns: auto 1fr; gap: 1.1rem; align-items: start; }
.steps .n { font-family: var(--font-display); font-style: italic; font-size: 1.6rem; color: var(--accent); line-height: 1; }
.steps b { display: block; font-weight: 500; font-family: var(--font-display); font-size: 1.25rem; }
.steps span { color: var(--muted); font-size: .95rem; }

/* ---- Kontakt / stopka ---------------------------------------------------- */
.social { display: flex; gap: 1.6rem; justify-content: center; margin-top: 2.2rem; flex-wrap: wrap; }
.social a { color: var(--dark-muted); text-decoration: none; font-size: .8rem; letter-spacing: .1em; text-transform: uppercase; transition: color .25s; }
.social a:hover { color: var(--dark-paper); }
.footer { background: var(--canvas); color: var(--muted); border-top: 1px solid var(--line); padding-block: 2.2rem; }
.footer .wrap { display: flex; align-items: center; justify-content: space-between; gap: 1.2rem 2rem; flex-wrap: wrap; }
.footer__logo { height: 20px; }
.footer__links { display: flex; gap: 1.4rem; flex-wrap: wrap; }
.footer__links a { color: var(--muted); text-decoration: none; font-size: .8rem; letter-spacing: .06em; transition: color .2s; }
.footer__links a:hover { color: var(--ink); }
.footer__meta { color: var(--muted); font-size: .75rem; letter-spacing: .04em; margin: 0; }

/* ---- Animacje wejścia ---------------------------------------------------- */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.is-in { opacity: 1; transform: none; }
.reveal[data-d="1"] { transition-delay: .08s; }
.reveal[data-d="2"] { transition-delay: .16s; }
.reveal[data-d="3"] { transition-delay: .24s; }
.reveal[data-d="4"] { transition-delay: .32s; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  .hero__scroll span { animation: none; }
  html { scroll-behavior: auto; }
}

/* ---- Hero: portret + środek (fix) ---------------------------------------- */
.hero { text-align: center; padding-block: clamp(3rem, 7vw, 6rem) 0; min-height: 0; display: block; }
.hero__inner { max-width: 900px; margin-inline: auto; }
.hero__inner h1 { max-width: 18ch; margin-inline: auto; }
.hero__inner .lead { max-width: 52ch; margin-inline: auto; }
.hero__portrait { max-width: 300px; margin: clamp(2.5rem, 5vw, 4rem) auto 0; transform: rotate(-1.2deg); }

/* ---- Marquee social-proof (przelatujące nazwiska) ------------------------ */
.marquee { margin-top: clamp(3rem, 6vw, 5rem); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding-block: 1.4rem; overflow: hidden; -webkit-mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent); mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent); }
.marquee__label { text-align: center; font-family: var(--font-display); font-style: italic; color: var(--accent); font-size: 1rem; margin: 0 0 1rem; }
.marquee__track { display: flex; width: max-content; animation: marquee 32s linear infinite; }
.marquee:hover .marquee__track { animation-play-state: paused; }
.marquee__group { display: flex; align-items: center; gap: 1.8rem; padding-right: 1.8rem; flex: 0 0 auto; }
.marquee__item { font-family: var(--font-display); font-size: clamp(1.5rem, 3vw, 2.3rem); color: var(--ink); white-space: nowrap; }
.marquee .dot { color: var(--accent); font-family: var(--font-display); font-size: clamp(1.5rem, 3vw, 2.3rem); }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .marquee__track { animation: none; flex-wrap: wrap; } }

/* ---- Hero: klaster zdjęć (film-style) ------------------------------------ */
.hero__photos { display: flex; justify-content: center; align-items: center; margin-top: clamp(2.5rem, 5vw, 4rem); }
.hero__photos .framed { width: clamp(110px, 19vw, 180px); margin-inline: -10px; box-shadow: var(--shadow); padding-bottom: 1.4rem; }
.hero__photos .framed:nth-child(1) { transform: rotate(-6deg); }
.hero__photos .framed:nth-child(2) { transform: rotate(1.5deg); width: clamp(150px, 24vw, 230px); z-index: 2; }
.hero__photos .framed:nth-child(3) { transform: rotate(6deg); }
.hero__photos .framed figcaption { font-size: .95rem; margin-top: .6rem; }

/* ---- Nagłówek sekcji wyrównany do lewej (szeroki) ------------------------ */
.s-head--left { text-align: left; max-width: none; margin-left: 0; margin-right: 0; }
.s-head--left .lead { margin-left: 0; margin-right: 0; max-width: 54ch; }

/* ---- Ikony platform (inline SVG sprite → pewny render + currentColor) ----- */
.ic { width: 1.05em; height: 1.05em; fill: currentColor; vertical-align: -2px; margin-right: .5rem; flex: none; }

/* ---- Karty twórczości (singiel + płyta — wspólny vibe) ------------------- */
.releases { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.2rem, 3vw, 2rem); }
@media (max-width: 760px) { .releases { grid-template-columns: 1fr; } }
.release-card { background: var(--paper-2); border: 1px solid var(--line); border-radius: var(--radius-img); overflow: hidden; box-shadow: var(--shadow-soft); display: flex; flex-direction: column; transition: transform .35s var(--ease), box-shadow .35s var(--ease); }
.release-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
/* pastelowe tła zamiast czystej bieli */
.release-card--blush { background: var(--blush); border-color: color-mix(in srgb, var(--blush) 70%, var(--line)); }
.release-card--sky   { background: var(--sky);   border-color: color-mix(in srgb, var(--sky) 70%, var(--line)); }
.release-card--blush .streams a, .release-card--sky .streams a { background: rgba(255,255,255,.6); }
.release-card__cover { aspect-ratio: 1/1; display: grid; place-content: center; text-align: center; }
.release-card__cover img { width: 100%; height: 100%; object-fit: cover; }
.cover--single { background: linear-gradient(150deg, var(--blush), var(--sand)); }
.cover--album  { background: linear-gradient(150deg, var(--sky), var(--sage-soft)); }
.release-card__cover b { font-family: var(--font-display); font-style: italic; font-size: clamp(2rem, 4vw, 3rem); color: var(--ink); font-weight: 500; padding: 1rem; }
.release-card__body { padding: 1.7rem 1.6rem 1.9rem; display: flex; flex-direction: column; flex: 1; }
.release-card__kicker { font-family: var(--font-display); font-style: italic; color: var(--accent); font-size: .98rem; margin: 0 0 .3rem; }
.release-card__title { font-family: var(--font-display); font-size: clamp(1.5rem, 2.4vw, 2rem); margin: 0 0 .3rem; }
.release-card__meta { color: var(--muted); font-size: .9rem; margin: 0 0 1.2rem; }
.release-card__foot { margin-top: auto; }
.release-card .price { font-size: 1.7rem; }

/* ---- Kontakt slim -------------------------------------------------------- */
.contact-slim { padding-block: clamp(3rem, 6vw, 5rem); text-align: center; }
.contact-slim h3 { font-size: clamp(1.6rem, 3vw, 2.2rem); }

/* ---- Dummy checkout: siatka + potwierdzenie ------------------------------ */
.checkout-grid { display: grid; grid-template-columns: .82fr 1fr; gap: clamp(1.5rem, 4vw, 3rem); align-items: start; }
@media (max-width: 760px) { .checkout-grid { grid-template-columns: 1fr; } .checkout-grid aside { order: 2; } }
.check { width: 76px; height: 76px; margin: 0 auto; border-radius: 999px; background: var(--ink); color: var(--paper); display: grid; place-content: center; font-size: 2.2rem; animation: pop .5s var(--ease); }
@keyframes pop { 0% { transform: scale(.5); opacity: 0 } 60% { transform: scale(1.08) } 100% { transform: scale(1); opacity: 1 } }

/* ---- Subpage płyty: tracklist + checkout ---------------------------------*/
/* nowoczesny układ płyty: sticky okładka + tracklista obok */
.album-layout { display: grid; grid-template-columns: minmax(260px, 360px) 1fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: start; }
@media (max-width: 820px) { .album-layout { grid-template-columns: 1fr; } .album-sticky { position: static !important; } }
.album-sticky { position: sticky; top: 92px; }
.album-cover-img { width: 100%; aspect-ratio: 1/1; object-fit: cover; border-radius: var(--radius-img); box-shadow: var(--shadow); display: block; }
.album-buy { margin-top: 1.5rem; display: grid; gap: .7rem; }
.album-buy .btn { width: 100%; justify-content: center; }

.tracklist { list-style: none; margin: 0; padding: 0; }
.track--link { text-decoration: none; color: inherit; }
.track__title { transition: color .2s; }
.track--link:hover .track__title { color: var(--accent); }
.track__sub { display: block; color: var(--muted); font-size: .8rem; }
.dark .track--link:hover .track__title { color: var(--dark-paper); }
.track { display: grid; grid-template-columns: auto 1fr auto; gap: 1.2rem; align-items: center; padding: 1.05rem 0; border-top: 1px solid var(--line); transition: padding-left .3s var(--ease); }
.track:last-child { border-bottom: 1px solid var(--line); }
.track:hover { padding-left: .5rem; }
.track__n { font-family: var(--font-display); font-style: italic; color: var(--muted); width: 2ch; }
.track__title { font-family: var(--font-display); font-size: 1.35rem; }
.track__len { color: var(--muted); font-size: .85rem; font-variant-numeric: tabular-nums; }

.checkout { background: var(--paper-2); border: 1px solid var(--line); border-radius: var(--radius-img); padding: clamp(1.6rem, 4vw, 2.6rem); box-shadow: var(--shadow-soft); }
.field { display: block; margin-bottom: 1.1rem; }
.field label { display: block; font-size: .78rem; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); margin-bottom: .45rem; }
.field input, .field textarea { width: 100%; font: inherit; font-size: 1rem; padding: .85rem 1rem; border: 1px solid var(--line); border-radius: var(--radius); background: var(--paper); color: var(--ink); transition: border-color .2s; }
.field input:focus, .field textarea:focus { outline: none; border-color: var(--accent); }
.qty { display: inline-flex; align-items: center; border: 1px solid var(--line); border-radius: 999px; overflow: hidden; }
.qty button { width: 2.6rem; height: 2.6rem; border: 0; background: var(--paper); font-size: 1.2rem; cursor: pointer; color: var(--ink); }
.qty button:hover { background: var(--line); }
.qty input { width: 3rem; text-align: center; border: 0; font: inherit; font-size: 1rem; background: transparent; }
.summary { display: flex; justify-content: space-between; align-items: baseline; padding: 1.2rem 0; border-top: 1px solid var(--line); margin-top: .6rem; }
.summary .total { font-family: var(--font-display); font-size: 2rem; }
.checkout .btn { width: 100%; justify-content: center; margin-top: .4rem; }
.checkout__note { font-size: .82rem; color: var(--muted); margin: 1rem 0 0; text-align: center; }
.back-link { display: inline-flex; align-items: center; gap: .5rem; font-size: .85rem; color: var(--muted); text-decoration: none; letter-spacing: .04em; }
.back-link:hover { color: var(--ink); }
