/* ============================================================
   ANNA KOŁODZIEJCZAK — v2 „KARTKI"
   Logo AK ma między literami cztery kolorowe kartki.
   Ta strona JEST tymi kartkami: pełnokolorowe arkusze
   nakładają się na siebie przy scrollu jak strony książki.
   Kolory = okładki tomów I–IV serii „Kosmetologia” (PZWL).
   ============================================================ */

:root {
  --paper: #FDFCFA;
  --paper-shade: #F5F3EE;
  --ink: #1C2127;
  --ink-soft: #565D66;
  --hairline: rgba(28, 33, 39, .14);

  /* kolory okładek */
  --tom1: #9ED4D9;
  --tom2: #E2AC4D;
  --tom3: #E05C6F;
  --tom4: #A6C92F;

  --tom1-deep: #2E96A3;
  --tom2-deep: #B97F1D;
  --tom3-deep: #C73B50;
  --tom4-deep: #6E8A14;

  --tom1-tint: #EDF7F8;
  --tom2-tint: #FAF3E4;
  --tom3-tint: #FBEDEF;
  --tom4-tint: #F3F7E3;

  --font-display: "STIX Two Text", Georgia, serif;
  --font-body: "Schibsted Grotesk", "Segoe UI", sans-serif;
  --font-mono: "IBM Plex Mono", Consolas, monospace;

  --header-h: 148px;
  --maxw: 1240px;
  --gutter: clamp(20px, 4vw, 52px);
  --radius-sheet: clamp(22px, 3.4vw, 40px);

  --ease-out-strong: cubic-bezier(0.23, 1, 0.32, 1);
  --ease-in-out-strong: cubic-bezier(0.77, 0, 0.175, 1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation: none !important; transition: none !important; }
}

body {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; height: auto; display: block; }
a { color: inherit; }
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible {
  outline: 3px solid var(--tom1-deep); outline-offset: 3px; border-radius: 2px;
}

.wrap { max-width: var(--maxw); margin: 0 auto; padding-inline: var(--gutter); }

.hero-grid > *, .duo > *, .tomy > *, .reviews > *, .products > *,
.newsletter .inner > *, .footer-grid > *, .stats-row > *, .covers-row > *,
.sheet-grid > * { min-width: 0; }
body { overflow-x: clip; }

/* ---------- grzbiety / półka ---------- */
.spines { display: grid; grid-template-columns: repeat(4, 1fr); height: 6px; }
.spines span:nth-child(1) { background: var(--tom1); }
.spines span:nth-child(2) { background: var(--tom2); }
.spines span:nth-child(3) { background: var(--tom3); }
.spines span:nth-child(4) { background: var(--tom4); }

/* ---------- header ---------- */
.site-header { position: sticky; top: 0; z-index: 50; background: var(--paper); border-bottom: 1px solid var(--hairline); }
.site-header .bar { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding-block: 13px; }
.brand { display: flex; align-items: center; gap: 12px; text-decoration: none; }
.brand img { height: 120px; width: auto; }
.brand-name { font-family: var(--font-display); font-size: 19px; line-height: 1.12; font-weight: 600; }
.brand-name small { display: block; font-family: var(--font-mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-soft); font-weight: 400; }

.main-nav ul { display: flex; gap: 4px; list-style: none; align-items: center; }
.main-nav a {
  text-decoration: none; font-size: 15px; font-weight: 500;
  padding: 8px 13px; border-radius: 999px; white-space: nowrap;
  transition: background .18s ease;
}
.main-nav a:hover { background: var(--paper-shade); }
.main-nav a[aria-current="page"] { background: var(--ink); color: var(--paper); }
.main-nav .nav-cta a { background: var(--tom3); color: #fff; font-weight: 600; }
.main-nav .nav-cta a:hover { background: var(--tom3-deep); }
/* Ikony social na dole sidebara (pod „Kontakt") */
.nav-social { display: flex; justify-content: center; gap: 14px; padding-top: 24px; }
.nav-social a { width: 40px; height: 40px; display: grid; place-items: center; border-radius: 50%; border: 1px solid var(--hairline); color: var(--ink-soft); transition: background .2s, color .2s, border-color .2s, transform .2s; }
.nav-social a:hover { background: var(--ink); color: var(--paper); border-color: var(--ink); transform: translateY(-2px); }
.nav-social svg { display: block; }

.has-sub { position: relative; }
.has-sub .sub {
  position: absolute; top: 100%; left: 0; min-width: 280px;
  background: var(--paper); border: 1px solid var(--hairline);
  box-shadow: 0 14px 36px rgba(28,33,39,.10);
  padding: 10px; border-radius: 14px; display: none; z-index: 60;
}
.has-sub:hover .sub, .has-sub:focus-within .sub { display: block; }
/* niewidoczny „mostek", by kursor nie tracił hovera w drodze na listę */
.has-sub::after { content: ""; position: absolute; left: 0; right: 0; top: 100%; height: 12px; display: none; }
.has-sub:hover::after, .has-sub:focus-within::after { display: block; }
.has-sub .sub a { display: block; border-radius: 8px; }
.has-sub .sub .soon { font-family: var(--font-mono); font-size: 10px; letter-spacing: .08em; color: var(--tom2-deep); text-transform: uppercase; display: block; }

.nav-toggle { display: none; background: none; border: 1px solid var(--hairline); border-radius: 10px; padding: 9px 12px; font: 600 14px var(--font-body); cursor: pointer; }

@media (max-width: 1240px) { .brand-name { display: none; } }
@media (max-width: 1080px) {
  .nav-toggle { display: block; }
  .main-nav { display: none; position: absolute; top: 100%; left: 0; right: 0; background: var(--paper); border-bottom: 1px solid var(--hairline); padding: 12px var(--gutter) 20px; z-index: 59; max-height: calc(100dvh - 96px); overflow-y: auto; -webkit-overflow-scrolling: touch; box-shadow: 0 24px 40px rgba(28,33,39,.12); }
  .main-nav.open { display: block; }
  .main-nav ul { flex-direction: column; align-items: stretch; }
  .main-nav a { display: block; padding: 12px 14px; border-radius: 10px; }
  .has-sub .sub { position: static; display: block; box-shadow: none; border: none; padding-left: 18px; }
}

/* ---------- aparat podręcznika ---------- */
.eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-mono); font-size: 12px; font-weight: 500;
  letter-spacing: .16em; text-transform: uppercase; color: var(--ink-soft);
}
.eyebrow::before { content: ""; width: 11px; height: 11px; background: var(--ink); }
.eyebrow.c1::before { background: var(--tom1); }
.eyebrow.c2::before { background: var(--tom2); }
.eyebrow.c3::before { background: var(--tom3); }
.eyebrow.c4::before { background: var(--tom4); }

figure.plate { position: relative; }
figure.plate img { width: 100%; height: auto; object-fit: cover; border-radius: 8px; }
figure.plate figcaption {
  margin-top: 10px; font-family: var(--font-mono); font-size: 12px;
  color: var(--ink-soft); letter-spacing: .02em;
  padding-top: 8px; border-top: 1px solid var(--hairline);
}
figure.plate figcaption b { font-weight: 600; color: var(--ink); }

/* ---------- typografia ---------- */
h1, h2, h3 { font-family: var(--font-display); font-weight: 560; line-height: 1.08; letter-spacing: -0.015em; }
.h-xl { font-size: clamp(40px, 5.6vw, 70px); }
.h-lg { font-size: clamp(30px, 3.9vw, 48px); }
.h-md { font-size: clamp(22px, 2.6vw, 31px); }
.lede { font-size: clamp(17px, 1.6vw, 20px); color: var(--ink-soft); max-width: 56ch; }
em.serif-italic, .hero h1 em { font-style: italic; font-weight: 480; }
.muted { color: var(--ink-soft); }

/* ---------- przyciski ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font: 600 15.5px var(--font-body); text-decoration: none; cursor: pointer;
  padding: 15px 28px; border-radius: 999px; border: none;
  transition: transform 160ms var(--ease-out-strong), background .18s ease, box-shadow .18s ease, color .18s ease;
}
@media (hover: hover) and (pointer: fine) { .btn:hover { transform: translateY(-1px); } }
.btn:active { transform: scale(.97); }
.btn-primary { background: var(--tom3); color: #fff; }
.btn-primary:hover { background: var(--tom3-deep); box-shadow: 0 10px 26px rgba(224,92,111,.32); }
.btn-ink { background: var(--ink); color: var(--paper); }
.btn-ink:hover { background: #000; }
.btn-ghost { background: transparent; color: var(--ink); border: 1.5px solid var(--ink); }
.btn-ghost:hover { background: var(--ink); color: var(--paper); }
.btn-paper { background: var(--paper); color: var(--ink); }
.btn-paper:hover { box-shadow: 0 10px 26px rgba(28,33,39,.22); }
.btn .arr { transition: transform .15s ease; }
.btn:hover .arr { transform: translateX(3px); }

/* ---------- sekcje ---------- */
.section { padding-block: clamp(64px, 9vw, 120px); }
.section.shade { background: var(--paper-shade); }
.section-head { max-width: 760px; margin-bottom: clamp(36px, 5vw, 64px); }
.section-head .eyebrow { margin-bottom: 18px; }
.section-head p { margin-top: 16px; }

/* ---------- HERO v2: gigant „Kosmetologia” na półce ---------- */
.hero { padding-block: clamp(18px, 3vw, 36px) 0; overflow: hidden; }
.hero .top { display: flex; justify-content: space-between; align-items: flex-start; gap: 24px; flex-wrap: wrap; }
.hero .intro-line {
  font-family: var(--font-mono); font-size: 12.5px; letter-spacing: .15em;
  text-transform: uppercase; color: var(--ink-soft);
}

.giant {
  display: block;
  font-family: var(--font-display); font-weight: 600;
  font-size: clamp(32px, 4.4vw, 58px);
  line-height: 1.1; letter-spacing: -0.022em;
}
.giant .g-line { display: block; overflow: hidden; white-space: nowrap; padding-block: 0.04em 0.14em; }
.giant .g-letter { display: inline-block; will-change: transform; }

.shelf { display: grid; grid-template-columns: repeat(4, 1fr); height: 7px; width: min(380px, 72%); margin-block: clamp(14px, 1.6vw, 22px) clamp(18px, 2vw, 26px); }
.shelf i:nth-child(1) { background: var(--tom1); }
.shelf i:nth-child(2) { background: var(--tom2); }
.shelf i:nth-child(3) { background: var(--tom3); }
.shelf i:nth-child(4) { background: var(--tom4); }

.hero-grid {
  display: grid; grid-template-columns: 1.1fr .9fr;
  gap: clamp(28px, 4vw, 60px); align-items: center;
  padding-block: clamp(12px, 1.8vw, 22px) clamp(20px, 2.6vw, 34px);
}
.hero .actions { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 30px; }

.hero-photo { position: relative; }
.hero-photo .stage { position: relative; display: grid; place-items: center; padding: 22px; }
.hero-photo .halo {
  position: absolute; width: min(420px, 88%); aspect-ratio: 1; border-radius: 50%;
  background: conic-gradient(var(--tom1) 0 25%, var(--tom2) 0 50%, var(--tom3) 0 75%, var(--tom4) 0 100%);
  -webkit-mask: radial-gradient(closest-side, transparent calc(100% - 12px), #000 calc(100% - 11px));
  mask: radial-gradient(closest-side, transparent calc(100% - 12px), #000 calc(100% - 11px));
  animation: halo-spin 60s linear infinite;
}
@keyframes halo-spin { to { transform: rotate(360deg); } }
.hero-photo .stage img { width: min(400px, 86%); aspect-ratio: 1; border-radius: 50%; filter: drop-shadow(0 22px 36px rgba(28,33,39,.18)); }
@media (prefers-reduced-motion: reduce) { .hero-photo .halo { animation: none; } }
@media (max-width: 880px) { .hero-grid { grid-template-columns: 1fr; } }

.pill-cta {
  display: inline-flex; align-items: center; gap: 10px;
  font: 600 14px var(--font-body); text-decoration: none;
  padding: 9px 18px; border: 1px solid var(--hairline); border-radius: 999px;
  background: #fff; transition: border-color .18s ease, transform 160ms var(--ease-out-strong);
}
.pill-cta:hover { border-color: var(--tom3); }
.pill-cta:active { transform: scale(.97); }
.pill-cta .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--tom3); animation: pulse 2.2s ease infinite; }
@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(224,92,111,.45); }
  50% { box-shadow: 0 0 0 7px rgba(224,92,111,0); }
}
@media (prefers-reduced-motion: reduce) { .pill-cta .dot { animation: none; } }

/* Tab. 1.1 — liczby */
.stats { border-top: 1px solid var(--ink); padding-bottom: clamp(46px, 6vw, 80px); }
.stats .label { font-family: var(--font-mono); font-size: 12px; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-soft); padding-top: 10px; }
.stats-row { display: grid; grid-template-columns: repeat(5, 1fr); gap: var(--gutter); margin-top: 14px; }
.stat b { font-family: var(--font-display); font-size: clamp(26px, 2.6vw, 40px); font-weight: 560; display: block; line-height: 1; }
.stat span { font-size: 14px; color: var(--ink-soft); display: block; margin-top: 8px; }
.stat:nth-child(1) b { color: var(--tom1-deep); }
.stat:nth-child(2) b { color: var(--tom2-deep); }
.stat:nth-child(3) b { color: var(--tom3-deep); }
.stat:nth-child(4) b { color: var(--tom4-deep); }
.stat:nth-child(5) b { color: var(--tom1-deep); }
.stat:nth-child(6) b { color: var(--tom2-deep); }
@media (max-width: 980px) { .stats-row { grid-template-columns: repeat(3, 1fr); row-gap: 28px; } }
@media (max-width: 560px) { .stats-row { grid-template-columns: repeat(2, 1fr); row-gap: 28px; } }

/* ---------- marquee ---------- */
.marquee { background: var(--ink); overflow: hidden; padding-block: 16px; }
.marquee-track { display: flex; gap: 56px; width: max-content; animation: marquee 30s linear infinite; }
.marquee-track span { font-family: var(--font-mono); font-size: 13px; letter-spacing: .18em; text-transform: uppercase; white-space: nowrap; color: var(--paper); }
.marquee .m1 { color: var(--tom1); }
.marquee .m2 { color: var(--tom2); }
.marquee .m3 { color: var(--tom3); }
.marquee .m4 { color: var(--tom4); }
.marquee .dot { color: rgba(253,252,250,.35); }
@keyframes marquee { to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .marquee-track { animation: none; } }

/* ============================================================
   KARTKI — pełnokolorowe arkusze nakładające się przy scrollu
   ============================================================ */
.sheets { position: relative; }
.sheet {
  position: sticky; top: var(--header-h);
  min-height: calc(100svh - var(--header-h));
  border-radius: var(--radius-sheet) var(--radius-sheet) 0 0;
  padding: clamp(56px, 9vh, 96px) 0 clamp(64px, 10vh, 110px);
  display: flex; align-items: center;
  will-change: transform;
}
.sheet .wrap { width: 100%; }
.sheet.s1 { background: var(--tom1); }
.sheet.s2 { background: var(--tom2); }
.sheet.s3 { background: var(--tom3); color: #fff; }
.sheet.s4 { background: var(--tom4); }

.sheet .folio {
  font-family: var(--font-mono); font-size: 12px; letter-spacing: .2em;
  text-transform: uppercase; display: flex; align-items: center; gap: 14px;
  margin-bottom: clamp(22px, 3.5vh, 40px); opacity: .85;
}
.sheet .folio::after { content: ""; flex: 1; height: 1px; background: currentColor; opacity: .35; }
.sheet h2 { font-size: clamp(32px, 4.6vw, 60px); max-width: 16ch; }
.sheet .sheet-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(30px, 5vw, 72px); align-items: center; }
.sheet p.body { margin-top: 20px; font-size: clamp(16px, 1.5vw, 19px); max-width: 52ch; opacity: .88; }
.sheet ul.ticks { list-style: none; margin-top: 22px; display: grid; gap: 12px; font-size: 16.5px; }
.sheet ul.ticks li { display: flex; gap: 14px; align-items: baseline; }
.sheet ul.ticks b { font-family: var(--font-mono); }
.sheet .actions { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 32px; }
.sheet figure.plate figcaption { border-top-color: currentColor; color: inherit; opacity: .8; }
.sheet figure.plate figcaption b { color: inherit; }
.sheet .big-nr {
  position: absolute; right: var(--gutter); top: clamp(18px, 4vh, 44px);
  font-family: var(--font-display); font-weight: 600;
  font-size: clamp(72px, 11vw, 170px); line-height: 1; opacity: .18; pointer-events: none;
}
@media (max-width: 880px) {
  :root { --header-h: 118px; }            /* realna wysokość mobilnego top-baru */
  .sheet .sheet-grid { grid-template-columns: 1fr; }
  .sheet .big-nr { font-size: 84px; opacity: .14; }
  /* sticky-stack pozostaje WŁĄCZONY też na mobile (efekt nakładania kart) */
}

/* okładki w kartce 3 */
.covers-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(14px, 2vw, 26px); margin-top: clamp(30px, 4.5vh, 52px); }
.cover-tile { text-decoration: none; display: grid; gap: 12px; will-change: transform; }
.cover-tile img { width: 100%; border-radius: 6px; box-shadow: 0 18px 36px rgba(0,0,0,.28); }
.manifesto { max-width: 68ch; }
.manifesto h2 { margin-top: 16px; }
.cv-group { border-top: 1px solid var(--hairline); padding: 6px 0; }
.cv-group > summary { cursor: pointer; list-style: none; padding: 16px 0; font: 600 18px var(--font-body); display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.cv-group > summary::-webkit-details-marker { display: none; }
.cv-group > summary::after { content: "+"; font-family: var(--font-mono); font-size: 22px; color: var(--tom3-deep); line-height: 1; }
.cv-group[open] > summary::after { content: "–"; }
.cv-group ul { list-style: none; margin: 0 0 18px; display: grid; gap: 10px; }
.cv-group ul li { position: relative; padding-left: 22px; color: var(--ink-soft); line-height: 1.5; }
.cv-group ul li::before { content: "→"; position: absolute; left: 0; font-family: var(--font-mono); color: var(--tom3-deep); }
.cover-tile .t { font: 600 15px var(--font-body); line-height: 1.32; }
.cover-tile .t .yr { font-weight: 400; font-family: var(--font-mono); font-size: 12px; opacity: .72; }
.cover-tile .p { font-family: var(--font-mono); font-size: 13px; opacity: .85; }
@media (max-width: 720px) { .covers-row { grid-template-columns: repeat(2, 1fr); } }

/* ---------- opinie: siatka cytatów ---------- */
.t-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(16px, 1.8vw, 26px); margin-top: clamp(28px, 4vh, 46px); }
.t-card { margin: 0; background: #fff; border: 1px solid var(--hairline); border-radius: 16px;
  padding: 30px 28px 26px; display: flex; flex-direction: column; gap: 18px; position: relative; overflow: hidden;
  transition: box-shadow .2s ease, transform .2s ease; }
.t-card::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: var(--tom1); }
.t-card:nth-child(6n+2)::before { background: var(--tom2); }
.t-card:nth-child(6n+3)::before { background: var(--tom3); }
.t-card:nth-child(6n+4)::before { background: var(--tom4); }
.t-card:nth-child(6n+5)::before { background: var(--tom2); }
.t-card:nth-child(6n)::before   { background: var(--tom3); }
.t-card:hover { box-shadow: 0 20px 46px rgba(28,33,39,.10); transform: translateY(-4px); }
.t-card blockquote { margin: 0; font-family: var(--font-display); font-style: italic; font-size: clamp(16px, 1.15vw, 18px); line-height: 1.5; color: var(--ink); }
.t-card blockquote::before { content: "\201D"; display: block; font-family: var(--font-display); font-size: 56px; line-height: .6; color: var(--tom3); margin-bottom: 6px; }
.t-card figcaption { margin-top: auto; font-family: var(--font-mono); font-size: 12px; letter-spacing: .04em; text-transform: uppercase; color: var(--ink-soft); }
.t-card figcaption::before { content: "— "; }
@media (max-width: 900px) { .t-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .t-grid { grid-template-columns: 1fr; } }

/* ---------- układy współdzielone z podstronami ---------- */
.duo { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(36px, 6vw, 80px); align-items: center; }
.duo.rev > :first-child { order: 2; }
@media (max-width: 880px) { .duo { grid-template-columns: 1fr; } .duo.rev > :first-child { order: 0; } }

.pull {
  border-left: 5px solid var(--tom3);
  padding: 10px 0 10px 30px; margin-block: 36px;
  font-family: var(--font-display); font-style: italic; font-weight: 480;
  font-size: clamp(21px, 2.4vw, 27px); line-height: 1.45;
}
.pull cite { display: block; margin-top: 14px; font: 500 12px var(--font-mono); letter-spacing: .14em; text-transform: uppercase; font-style: normal; color: var(--ink-soft); }

.pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.pillar {
  border: 1px solid var(--hairline); border-radius: 16px;
  padding: 30px 28px 32px; background: var(--paper);
  border-top: 6px solid var(--ink);
  transition: transform .18s var(--ease-out-strong), box-shadow .18s ease;
}
.pillar:hover { transform: translateY(-4px); box-shadow: 0 18px 40px rgba(28,33,39,.09); }
.pillar.c1 { border-top-color: var(--tom1); }
.pillar.c2 { border-top-color: var(--tom2); }
.pillar.c3 { border-top-color: var(--tom3); }
.pillar h3 { font-size: 22px; margin: 14px 0 10px; }
.pillar p { font-size: 15.5px; color: var(--ink-soft); }
@media (max-width: 880px) { .pillars { grid-template-columns: 1fr; } }

.tomy { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; perspective: 1100px; }
.tom-card {
  border-radius: 16px; padding: 28px 24px 26px; color: var(--ink);
  display: flex; flex-direction: column; min-height: 380px;
  text-decoration: none; position: relative; overflow: hidden;
  transform-style: preserve-3d; will-change: transform;
  transition: transform .18s var(--ease-out-strong), box-shadow .18s ease;
}
.tom-card:hover { box-shadow: 0 22px 44px rgba(28,33,39,.16); }
.tom-card.c1 { background: var(--tom1); }
.tom-card.c2 { background: var(--tom2); }
.tom-card.c3 { background: var(--tom3); color: #fff; }
.tom-card.c4 { background: var(--tom4); }
.tom-card .nr { font-family: var(--font-display); font-size: 64px; line-height: 1; font-weight: 600; }
.tom-card h3 { font-size: 21px; margin: 14px 0 8px; }
.tom-card .sub { font-family: var(--font-mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; opacity: .75; }
.tom-card p { font-size: 14.5px; line-height: 1.55; margin-top: 10px; opacity: .92; }
.tom-card .buy { margin-top: auto; padding-top: 22px; font-weight: 700; font-size: 15px; display: inline-flex; gap: 8px; align-items: center; }
.tom-card .nr, .tom-card h3 { transform: translateZ(28px); }
.tom-card .sub, .tom-card p, .tom-card .buy { transform: translateZ(14px); }
@media (max-width: 1020px) { .tomy { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .tomy { grid-template-columns: 1fr; } }

.reviews { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; align-items: start; }
.reviews figure.plate img { border: 1px solid var(--hairline); border-radius: 12px; }
@media (max-width: 1020px) { .reviews { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .reviews { grid-template-columns: 1fr; } }

.post-list { border-top: 1px solid var(--ink); }
.post-row {
  display: grid; grid-template-columns: 150px 1fr auto; gap: 28px; align-items: baseline;
  padding-block: 26px; border-bottom: 1px solid var(--hairline);
  text-decoration: none; transition: background .15s ease;
}
.post-row:hover { background: var(--paper-shade); }
.post-row time { font-family: var(--font-mono); font-size: 13px; color: var(--ink-soft); }
.post-row h3 { font-size: clamp(19px, 2vw, 24px); font-weight: 560; }
.post-row:hover h3 { text-decoration: underline; text-decoration-thickness: 1.5px; text-underline-offset: 4px; }
.post-row .cat {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase;
  padding: 5px 12px; border-radius: 999px; white-space: nowrap;
}
.cat.c1 { background: var(--tom1-tint); color: var(--tom1-deep); }
.cat.c2 { background: var(--tom2-tint); color: var(--tom2-deep); }
.cat.c3 { background: var(--tom3-tint); color: var(--tom3-deep); }
.cat.c4 { background: var(--tom4-tint); color: var(--tom4-deep); }
.post-row p { grid-column: 2; font-size: 15px; color: var(--ink-soft); margin-top: 2px; }
@media (max-width: 720px) { .post-row { grid-template-columns: 1fr; gap: 8px; } .post-row p { grid-column: 1; } }

/* w kartce 4 — lista wpisów na limonce */
.sheet .post-list { border-top-color: currentColor; }
.sheet .post-row { border-bottom-color: rgba(28,33,39,.25); }
.sheet .post-row:hover { background: rgba(253,252,250,.35); }
.sheet .post-row time { color: inherit; opacity: .7; }
.sheet .post-row .cat { background: rgba(253,252,250,.7); color: var(--ink); }

.biblio { list-style: none; counter-reset: pub; border-top: 1px solid var(--ink); }
.biblio li {
  counter-increment: pub; display: grid; grid-template-columns: 64px 1fr; gap: 20px;
  padding-block: 16px; border-bottom: 1px solid var(--hairline); font-size: 15px; color: var(--ink-soft);
}
.biblio li::before { content: "[" counter(pub) "]"; font-family: var(--font-mono); font-size: 13px; color: var(--tom1-deep); }

.cta-banner { background: var(--ink); color: var(--paper); border-radius: 22px; padding: clamp(40px, 6vw, 72px); position: relative; overflow: hidden; text-align: center; }
.cta-banner h2 { max-width: 18ch; margin-left: auto; margin-right: auto; }
.cta-banner .lede { margin-left: auto; margin-right: auto; }
.cta-banner .actions { margin-top: 28px; display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; }
.cta-banner .spines { position: absolute; left: 0; right: 0; top: 0; }

.form-grid { display: grid; gap: 18px; max-width: 620px; }
.form-grid label { font: 500 13px var(--font-mono); letter-spacing: .08em; text-transform: uppercase; color: var(--ink-soft); display: block; margin-bottom: 7px; }
.form-grid input, .form-grid textarea {
  width: 100%; padding: 14px 16px; font: 16px var(--font-body);
  border: 1px solid var(--hairline); border-radius: 12px; background: #fff; color: var(--ink);
}
.form-grid input:focus, .form-grid textarea:focus { border-color: var(--tom1-deep); }

.newsletter { background: var(--tom1-tint); }
.newsletter .inner { display: grid; grid-template-columns: 1.2fr 1fr; gap: clamp(28px, 5vw, 64px); align-items: center; }
.newsletter form { display: flex; gap: 10px; }
.newsletter input { flex: 1; padding: 15px 18px; font: 16px var(--font-body); border: 1px solid var(--hairline); border-radius: 999px; background: #fff; }
@media (max-width: 820px) { .newsletter .inner { grid-template-columns: 1fr; } .newsletter form { flex-direction: column; } }

.site-footer { background: var(--ink); color: rgba(253,252,250,.82); padding-block: 56px 36px; font-size: 14.5px; }
.site-footer a { color: inherit; text-decoration: none; }
.site-footer a:hover { color: #fff; text-decoration: underline; }
.footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 32px; margin-bottom: 44px; }
.footer-grid h4 { font: 500 12px var(--font-mono); letter-spacing: .16em; text-transform: uppercase; color: rgba(253,252,250,.55); margin-bottom: 16px; }
.footer-grid ul { list-style: none; display: grid; gap: 9px; }
.footer-bottom { border-top: 1px solid rgba(253,252,250,.18); padding-top: 22px; display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; font-size: 13px; color: rgba(253,252,250,.55); }
@media (max-width: 880px) { .footer-grid { grid-template-columns: 1fr 1fr; } }

/* ---------- nagłówki rozdziałów (podstrony) — kolorowe przekładki ---------- */
.chapter-head { padding-block: clamp(56px, 8vw, 100px) clamp(44px, 6vw, 72px); border-bottom: 1px solid var(--hairline); }
.chapter-head .eyebrow { margin-bottom: 18px; }
.chapter-head h1 { max-width: 20ch; }
.chapter-head .lede { margin-top: 20px; }
.chapter-head.ch-c1 { background: var(--tom1); border-bottom: none; }
.chapter-head.ch-c2 { background: var(--tom2); border-bottom: none; }
.chapter-head.ch-c3 { background: var(--tom3); border-bottom: none; color: #fff; }
.chapter-head.ch-c4 { background: var(--tom4); border-bottom: none; }
.chapter-head.ch-c1 .lede, .chapter-head.ch-c2 .lede, .chapter-head.ch-c4 .lede { color: var(--ink); opacity: .8; }
.chapter-head.ch-c3 .lede { color: #fff; opacity: .85; }
.chapter-head.ch-c1 .eyebrow, .chapter-head.ch-c2 .eyebrow, .chapter-head.ch-c4 .eyebrow { color: var(--ink); }
.chapter-head.ch-c3 .eyebrow { color: #fff; }
.chapter-head.ch-c1 .eyebrow::before, .chapter-head.ch-c2 .eyebrow::before,
.chapter-head.ch-c3 .eyebrow::before, .chapter-head.ch-c4 .eyebrow::before { background: currentColor; }

/* ---------- produkty ---------- */
.products { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.product {
  border: 1px solid var(--hairline); border-radius: 18px; overflow: hidden; background: #fff;
  text-decoration: none; display: flex; flex-direction: column;
  transition: transform .18s var(--ease-out-strong), box-shadow .18s ease;
}
.product:hover { transform: translateY(-5px); box-shadow: 0 20px 42px rgba(28,33,39,.12); }
.product .cover { aspect-ratio: 5/6; display: grid; place-items: center; padding: 26px; }
.product .cover img { max-height: 100%; width: auto; filter: drop-shadow(0 16px 22px rgba(28,33,39,.25)); }
.product .meta { padding: 20px 22px 24px; border-top: 1px solid var(--hairline); }
.product .meta h3 { font-size: 18px; }
.product .meta .price { font-family: var(--font-mono); font-size: 15px; margin-top: 8px; }
.product .meta .buy { margin-top: 14px; font-weight: 700; font-size: 14.5px; }
@media (max-width: 1020px) { .products { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .products { grid-template-columns: 1fr; } }

/* ---------- animacje: stany spoczynkowe ---------- */
.reveal { opacity: 1; }
.line-mask { display: block; overflow: hidden; padding-block: .04em; }
.line-mask > span { display: block; will-change: transform; }

/* ============================================================
   DODATKI MOTYWU WP (poza statycznym prototypem):
   treść wpisu/strony, paginacja, WooCommerce, formularze WP.
   ============================================================ */

/* --- treść wpisu / strony (the_content) --- */
.ak-prose{ max-width:none; }
.ak-prose .wrap, .ak-single .ak-prose{ }
.ak-prose{ font-size:18px; line-height:1.75; color:var(--ink,#20242b); }
.ak-prose > *{ max-width:72ch; }
.ak-prose img, .ak-prose figure, .ak-prose .wp-block-image{ max-width:100%; height:auto; border-radius:14px; }
.ak-prose h2{ font-family:var(--font-display,"STIX Two Text",serif); font-size:clamp(26px,3.2vw,38px); line-height:1.15; margin:42px 0 16px; }
.ak-prose h3{ font-family:var(--font-display,"STIX Two Text",serif); font-size:clamp(21px,2.4vw,27px); margin:32px 0 12px; }
.ak-prose p{ margin:0 0 18px; }
.ak-prose ul, .ak-prose ol{ margin:0 0 20px; padding-left:1.3em; }
.ak-prose li{ margin:6px 0; }
.ak-prose a{ color:var(--tom3-deep,#9a1f4d); text-decoration:underline; text-underline-offset:3px; }
.ak-prose blockquote{ border-left:3px solid var(--hairline,#e7e2da); margin:28px 0; padding:6px 0 6px 24px; font-family:var(--font-display,"STIX Two Text",serif); font-style:italic; font-size:1.15em; }
.ak-prose figure.plate img{ border-radius:16px; }

/* --- paginacja --- */
.ak-pagination, .ak-pagelinks{ margin-top:46px; display:flex; gap:10px; flex-wrap:wrap; align-items:center; font-family:var(--font-mono,monospace); font-size:14px; }
.ak-pagination .page-numbers, .ak-pagelinks a, .ak-pagelinks > span{
  display:inline-flex; align-items:center; justify-content:center; min-width:42px; height:42px; padding:0 14px;
  border:1px solid var(--hairline,#e7e2da); border-radius:10px; text-decoration:none; color:var(--ink,#20242b); background:#fff;
}
.ak-pagination .page-numbers.current{ background:var(--ink,#20242b); color:#fff; border-color:var(--ink,#20242b); }
.ak-pagination .page-numbers:hover{ border-color:var(--ink,#20242b); }

/* --- formularz wyszukiwania --- */
.search-form{ display:flex; gap:10px; }
.search-form .search-field{ flex:1; padding:14px 16px; border:1px solid var(--hairline,#e7e2da); border-radius:12px; font:inherit; }
.search-form .search-submit{ padding:14px 22px; border:0; border-radius:12px; background:var(--ink,#20242b); color:#fff; cursor:pointer; font:inherit; }

/* --- WooCommerce: spójność z motywem --- */
.woocommerce div.product .product_title{ font-family:var(--font-display,"STIX Two Text",serif); font-size:clamp(28px,3.4vw,42px); line-height:1.1; }
.woocommerce div.product p.price, .woocommerce div.product span.price{ color:var(--ink,#20242b); font-family:var(--font-mono,monospace); font-size:22px; }
.woocommerce #respond input#submit,
.woocommerce a.button, .woocommerce button.button, .woocommerce input.button,
.woocommerce .single_add_to_cart_button{
  background:var(--ink,#20242b) !important; color:#fff !important; border-radius:12px !important;
  padding:14px 26px !important; font-family:var(--font-body,'Schibsted Grotesk',sans-serif) !important; font-weight:600 !important;
  border:0 !important; text-transform:none !important; letter-spacing:0 !important;
}
.woocommerce a.button.alt:hover, .woocommerce button.button:hover, .woocommerce .single_add_to_cart_button:hover{ opacity:.9; }
.woocommerce .woocommerce-message, .woocommerce .woocommerce-info{ border-top-color:var(--tom2-deep,#caa12a); }
.woocommerce-breadcrumb{ font-family:var(--font-mono,monospace); font-size:13px; color:#7c7669; margin-bottom:24px; }
.woocommerce ul.products li.product .price{ color:var(--ink,#20242b); font-family:var(--font-mono,monospace); }
.woocommerce nav.woocommerce-pagination ul{ border:0; }
.woocommerce nav.woocommerce-pagination ul li{ border:0; }
.woocommerce nav.woocommerce-pagination ul li a, .woocommerce nav.woocommerce-pagination ul li span{
  border:1px solid var(--hairline,#e7e2da); border-radius:10px; min-width:42px; height:42px; line-height:42px;
}

/* --- karta produktu w bespoke gridzie sklepu: dosuń obraz Woo --- */
.products .product .cover img{ max-width:100%; height:auto; mix-blend-mode:multiply; }

/* --- WooCommerce single product: poprawny layout (flex, nie grid na wszystkim) --- */
.ak-woo-single div.product{ display:flex; flex-wrap:wrap; gap:48px; align-items:flex-start; }
.ak-woo-single div.product .woocommerce-product-gallery,
.ak-woo-single div.product .ak-product-gallery{ flex:1 1 380px; max-width:46%; margin:0; }
.ak-woo-single div.product .summary{ flex:1 1 360px; margin:0; max-width:46%; }
.ak-woo-single div.product .woocommerce-tabs,
.ak-woo-single div.product .related,
.ak-woo-single div.product .up-sells,
.ak-woo-single div.product .woocommerce-product-rating{ flex:1 1 100%; max-width:100%; }
.ak-woo-single .ak-product-gallery{ background:var(--paper-shade,#f5f1ea); border-radius:16px; padding:32px; text-align:center; }
.ak-woo-single .ak-product-cover{ max-width:100%; height:auto; filter:drop-shadow(0 20px 30px rgba(32,36,43,.22)); }
.ak-woo-single .ak-gallery-thumbs{ display:flex; gap:10px; justify-content:center; margin-top:16px; flex-wrap:wrap; }
.ak-woo-single .ak-gallery-thumbs img{ width:64px; height:auto; border-radius:8px; }
@media (max-width:860px){
  .ak-woo-single div.product{ gap:28px; }
  .ak-woo-single div.product .woocommerce-product-gallery,
  .ak-woo-single div.product .ak-product-gallery,
  .ak-woo-single div.product .summary{ max-width:100%; flex-basis:100%; }
}
/* zakładki opisu w stylu motywu */
.ak-woo-single .woocommerce-tabs ul.tabs{ margin:0 0 22px; padding:0; border-bottom:1px solid var(--hairline,#e7e2da); display:flex; gap:8px; list-style:none; }
.ak-woo-single .woocommerce-tabs ul.tabs li{ background:transparent; border:0; margin:0; padding:0; }
.ak-woo-single .woocommerce-tabs ul.tabs li a{ font-family:var(--font-mono,monospace); font-size:13px; text-transform:uppercase; letter-spacing:.06em; padding:12px 4px; color:#7c7669; }
.ak-woo-single .woocommerce-tabs ul.tabs li.active a{ color:var(--ink,#20242b); border-bottom:2px solid var(--tom2,#e7b62c); }

/* --- single product: wymuszenie layoutu obok siebie (nad critical-css essa) --- */
.ak-woo-single div.product{ display:flex !important; flex-direction:row !important; flex-wrap:wrap; gap:48px; align-items:flex-start; }
.ak-woo-single div.product > .woocommerce-product-gallery,
.ak-woo-single div.product > .ak-product-gallery{ flex:0 0 42% !important; max-width:42% !important; width:42% !important; float:none !important; }
.ak-woo-single div.product > .summary{ flex:1 1 50% !important; max-width:52% !important; width:auto !important; float:none !important; }
.ak-woo-single div.product > .woocommerce-tabs,
.ak-woo-single div.product > .related,
.ak-woo-single div.product > .up-sells{ flex:1 1 100% !important; max-width:100% !important; width:100% !important; }
@media (max-width:860px){
  .ak-woo-single div.product > .woocommerce-product-gallery,
  .ak-woo-single div.product > .ak-product-gallery,
  .ak-woo-single div.product > .summary{ flex-basis:100% !important; max-width:100% !important; width:100% !important; }
}

/* Zabezpieczenie: produkty (krytyczna treść) zawsze widoczne.
   Reszta animuje się jak w projekcie (hero, kartki, figury). */
.products .product, .products .product *{ opacity:1 !important; }

/* Hero mieści się na ekranie startowym (obręcz + zdjęcie: patrz blok „OBRĘCZ HERO" niżej) */
.hero .lede{ margin-top: 16px; }
.hero .actions{ margin-top: 22px; }
@media (min-height: 640px) and (max-height: 860px){
  .giant{ font-size: clamp(30px, 4vw, 50px); }
}

/* --- odznaka numeru tomu na stronie produktu --- */
.ak-product-gallery{ position:relative; overflow:hidden; }
.ak-vol-badge{ position:absolute; top:6px; right:22px; font-family:var(--font-display); font-weight:600; font-size:clamp(80px,12vw,150px); line-height:1; opacity:.14; pointer-events:none; }

/* ============================================================
   STRONA PRODUKTU — opis, zakładki, produkty powiązane
   ============================================================ */
.ak-woo-single .woocommerce-tabs{ margin-top: 50px; }
.ak-woo-single .woocommerce-tabs .panel{
  max-width: 80ch; margin: 0 auto; font-size: 17px; line-height: 1.75; color: var(--ink);
}
.ak-woo-single .woocommerce-tabs .panel > h2:first-child{
  font-family: var(--font-display); font-weight:600; font-size: clamp(26px,3.4vw,40px);
  line-height:1.12; margin: 0 0 22px;
}
.ak-woo-single .woocommerce-tabs .panel h2{ font-family:var(--font-display); font-weight:600; font-size:clamp(23px,2.8vw,32px); line-height:1.16; margin:40px 0 14px; }
.ak-woo-single .woocommerce-tabs .panel h3{ font-family:var(--font-display); font-weight:600; font-size:clamp(20px,2.2vw,26px); margin:30px 0 10px; }
.ak-woo-single .woocommerce-tabs .panel h4{ font-size:18px; font-weight:600; margin:24px 0 8px; }
.ak-woo-single .woocommerce-tabs .panel p{ margin:0 0 18px; }
.ak-woo-single .woocommerce-tabs .panel ul,
.ak-woo-single .woocommerce-tabs .panel ol{ margin:0 0 20px; padding-left:1.35em; }
.ak-woo-single .woocommerce-tabs .panel li{ margin:7px 0; padding-left:4px; }
.ak-woo-single .woocommerce-tabs .panel li::marker{ color: var(--tom3-deep); }
.ak-woo-single .woocommerce-tabs .panel strong{ font-weight:600; color:var(--ink); }
.ak-woo-single .woocommerce-tabs .panel img{ border-radius:12px; height:auto; margin:18px 0; }
.ak-woo-single .woocommerce-tabs .panel > *:first-child{ margin-top:0; }
/* tabela atrybutów (Informacje dodatkowe) */
.ak-woo-single .shop_attributes{ width:100%; border-collapse:collapse; max-width:80ch; margin:0 auto; }
.ak-woo-single .shop_attributes th, .ak-woo-single .shop_attributes td{ text-align:left; padding:12px 14px; border-bottom:1px solid var(--hairline); font-size:15.5px; }
.ak-woo-single .shop_attributes th{ font-family:var(--font-mono); font-weight:500; width:34%; color:var(--ink-soft); }

/* produkty powiązane / „Może spodoba się również" */
.ak-woo-single .related, .ak-woo-single .up-sells{ margin-top: 64px; border-top:1px solid var(--hairline); padding-top: 44px; }
.ak-woo-single .related > h2, .ak-woo-single .up-sells > h2{ font-family:var(--font-display); font-weight:600; font-size:clamp(24px,3vw,34px); margin-bottom: 28px; }
.ak-woo-single .related ul.products, .ak-woo-single .up-sells ul.products{
  display:grid; grid-template-columns: repeat(auto-fill, minmax(180px,1fr)); gap: clamp(18px,2.4vw,32px);
  list-style:none; margin:0; padding:0;
}
.ak-woo-single ul.products li.product{ margin:0; width:auto; float:none; text-align:left; }
.ak-woo-single ul.products li.product img{ border-radius:10px; margin-bottom:12px; background:var(--paper-shade); }
.ak-woo-single ul.products li.product .woocommerce-loop-product__title{ font-family:var(--font-display); font-size:16px; font-weight:600; padding:0; margin:0 0 6px; }
.ak-woo-single ul.products li.product .price{ font-family:var(--font-mono); color:var(--ink); font-size:15px; }
.ak-woo-single ul.products li.product .button{ margin-top:10px; font-size:13.5px !important; padding:10px 18px !important; }

/* ============================================================
   STRONA PRODUKTU v2 — bespoke w stylu motywu
   ============================================================ */
.ak-product-gallery{ position:relative; overflow:hidden; border-radius:18px;
  padding:clamp(28px,4vw,56px); display:flex; align-items:center; justify-content:center; min-height:320px; margin:0; }
.ak-product-cover{ width:auto; max-width:min(340px,100%); height:auto; border-radius:4px;
  filter:drop-shadow(0 24px 36px rgba(28,33,39,.24)); }
.ak-vol-badge{ position:absolute; top:8px; right:26px; font-family:var(--font-display); font-weight:600;
  font-size:clamp(90px,13vw,160px); line-height:1; opacity:.16; pointer-events:none; }
.ak-summary{ padding-top:4px; }
.ak-price{ font-family:var(--font-mono); font-size:clamp(26px,3vw,34px); color:var(--ink); margin-bottom:18px; }
.ak-price del{ color:var(--ink-soft); font-size:.7em; margin-right:10px; opacity:.7; }
.ak-price ins{ text-decoration:none; }
.ak-short{ margin-bottom:8px; }
.ak-cart{ margin:28px 0 4px; }
.ak-cart form, .ak-cart .quantity{ display:inline-flex; align-items:center; gap:12px; flex-wrap:wrap; }
.ak-cart a.button, .ak-cart button.button, .ak-cart .single_add_to_cart_button{
  background:var(--tom3) !important; color:#fff !important; border-radius:999px !important;
  padding:16px 32px !important; font-family:var(--font-body) !important; font-weight:600 !important;
  font-size:15.5px !important; border:0 !important; text-transform:none !important; }
.ak-cart a.button:hover, .ak-cart button.button:hover, .ak-cart .single_add_to_cart_button:hover{ background:var(--tom3-deep) !important; }
.ak-woo-single .product_meta{ margin-top:26px; padding-top:20px; border-top:1px solid var(--hairline);
  font-size:14px; color:var(--ink-soft); font-family:var(--font-mono); }
.ak-woo-single .product_meta > span{ display:block; margin-bottom:6px; }
.ak-woo-single .product_meta a{ color:var(--ink); }
.ak-product-desc{ max-width:84ch; }
@media (max-width:880px){
  .ak-product-gallery{ min-height:auto; }
  .ak-product-cover{ max-width:min(260px,70%); }
}

/* Długie tytuły na wąskim mobile nie wystają poza ekran */
@media (max-width:560px){
  .h-xl{ font-size: clamp(28px, 8vw, 38px); }
  .chapter-head h1{ overflow-wrap:break-word; word-break:break-word; hyphens:auto; }
}

/* ============================================================
   TUTOR LMS — autorski wygląd „Podręcznik"
   ============================================================ */
/* Bazowe: kontener, fonty, typografia Tutora w stylu motywu */
.tutor-wrap, .tutor-course-archive-page .tutor-container, .tutor-container{ max-width: var(--maxw) !important; margin-inline:auto; padding-inline: var(--gutter); }
.tutor-wrap, .tutor-wrap *, .tutor-frontend-dashboard *, .tutor-course-single-content-wrapper *{ font-family: var(--font-body); }
.tutor-fs-1, .tutor-fs-2, .tutor-fs-3, .tutor-fs-4, .tutor-fs-5,
.tutor-course-name, .tutor-course-details-title, .tutor-dashboard-title,
.tutor-course-topic-single-header-title{ font-family: var(--font-display) !important; letter-spacing:-.01em; }
.tutor-color-black{ color: var(--ink) !important; }
.tutor-color-muted{ color: var(--ink-soft) !important; }
.tutor-color-secondary{ color: var(--ink-soft) !important; }
.tutor-color-success{ color: var(--tom4-deep) !important; }
.tutor-color-primary, .tutor-text-primary{ color: var(--tom3-deep) !important; }
.tutor-hr, hr.tutor-hr{ border-color: var(--hairline) !important; }

/* sekcja katalogu pod chapter-head */
.tutor-course-archive-page .tutor-wrap{ padding-top: clamp(36px,5vh,64px); padding-bottom: clamp(48px,7vh,90px); }

/* --- przyciski Tutora --- */
.tutor-btn{ border-radius:999px !important; font-family:var(--font-body) !important; font-weight:600 !important; letter-spacing:0 !important; }
.tutor-btn-primary, .tutor-btn.tutor-btn-primary{ background:var(--tom3) !important; border-color:var(--tom3) !important; color:#fff !important; }
.tutor-btn-primary:hover{ background:var(--tom3-deep) !important; border-color:var(--tom3-deep) !important; }
.tutor-btn-outline-primary{ color:var(--ink) !important; border:1.5px solid var(--ink) !important; background:transparent !important; }
.tutor-btn-outline-primary:hover{ background:var(--ink) !important; color:#fff !important; }
.tutor-btn-ghost{ color:var(--ink) !important; background:transparent !important; }
.tutor-btn-ghost:hover{ color:var(--tom3-deep) !important; }
.tutor-btn-link{ color:var(--tom3-deep) !important; padding:0 !important; }
.tutor-iconic-btn{ color:var(--ink-soft) !important; }
.tutor-iconic-btn:hover{ color:var(--tom3-deep) !important; }

/* --- karty kursów (katalog) --- */
.tutor-course-card, .tutor-card{
  border:1px solid var(--hairline) !important; border-radius:16px !important; overflow:hidden;
  box-shadow:0 1px 0 rgba(28,33,39,.02); background:var(--paper) !important; transition:box-shadow .2s ease, transform .2s ease;
}
.tutor-course-card:hover{ box-shadow:0 18px 40px rgba(28,33,39,.10); transform:translateY(-3px); }
.tutor-card-image-top, .tutor-course-thumbnail{ border-radius:0 !important; }
.tutor-card-body{ padding:22px !important; }
.tutor-course-name a, .tutor-course-name{ font-family:var(--font-display) !important; font-weight:600 !important; font-size:19px !important; line-height:1.2 !important; color:var(--ink) !important; }
.tutor-course-name a:hover{ color:var(--tom3-deep) !important; }
.tutor-card-footer{ padding:0 22px 22px !important; border-top:0 !important; }
.tutor-meta, .tutor-meta *{ color:var(--ink-soft) !important; font-family:var(--font-mono) !important; font-size:12.5px !important; }
.tutor-ratio-16x9{ aspect-ratio:16/10; }
.tutor-course-card .tutor-course-thumbnail img{ object-fit:cover; width:100%; height:100%; }
.tutor-ratings-stars i, .tutor-ratings i.tutor-icon-star-bold{ color:var(--tom2) !important; }
.tutor-ratings-average{ font-family:var(--font-mono) !important; font-weight:600; }
/* odznaka cena/free na karcie */
.tutor-course-price, .tutor-card-course-price{ font-family:var(--font-mono) !important; color:var(--ink) !important; font-weight:600 !important; }
.tutor-course-price ins, .tutor-course-price del{ text-decoration:none; }
.tutor-course-price del{ color:var(--ink-soft) !important; opacity:.7; }

/* pasek sortowania / filtry */
.tutor-course-archive-results-meta, .tutor-archive-course-sorting{ margin-bottom: 22px; }
.tutor-form-control, .tutor-form-select{ border-radius:10px !important; border:1px solid var(--hairline) !important; font-family:var(--font-mono) !important; font-size:13px !important; background:var(--paper) !important; }
.tutor-form-control:focus, .tutor-form-select:focus{ border-color:var(--tom1-deep) !important; box-shadow:0 0 0 3px rgba(46,150,163,.18) !important; }
.tutor-course-filter-container, .tutor-courses-filter-form{ border:1px solid var(--hairline) !important; border-radius:16px !important; background:var(--paper) !important; }

/* paginacja */
.tutor-pagination-wrapper .page-numbers, .tutor-pagination .page-numbers{
  font-family:var(--font-mono) !important; border:1px solid var(--hairline) !important; border-radius:10px !important; color:var(--ink) !important; }
.tutor-pagination-wrapper .page-numbers.current, .tutor-pagination .page-numbers.current{
  background:var(--tom3) !important; border-color:var(--tom3) !important; color:#fff !important; }

/* ===== POJEDYNCZY KURS ===== */
.tutor-course-details-page{ padding-block: clamp(28px,4vh,52px) clamp(48px,7vh,90px); }
.tutor-course-details-header{ margin-bottom: clamp(22px,3vw,40px) !important; }
h1.tutor-course-title, .tutor-course-details-title, .tutor-course-header h1{
  font-family:var(--font-display) !important; font-weight:600 !important; font-size:clamp(28px,3.4vw,46px) !important; line-height:1.12 !important; letter-spacing:-.015em;
}
.tutor-course-details-ratings{ font-family:var(--font-mono) !important; }
.tutor-meta.tutor-course-details-info, .tutor-course-details-info{ font-family:var(--font-mono) !important; font-size:13px !important; color:var(--ink-soft) !important; }
.tutor-course-details-page .tutor-course-summary, .tutor-course-content{ font-size:17px; line-height:1.7; }
.tutor-course-details-content, .tutor-course-content{ font-size:16.5px; line-height:1.72; color:var(--ink); }
.tutor-course-details-page h2, .tutor-course-content h2, .tutor-course-details-widget-title{ font-family:var(--font-display) !important; font-weight:600 !important; font-size:clamp(20px,2.4vw,28px) !important; margin:30px 0 12px; }
.tutor-course-content ul li{ margin:6px 0; }
/* widgety: czego się nauczysz / wymagania */
.tutor-course-details-widget{ border:1px solid var(--hairline) !important; border-radius:18px !important; background:var(--paper) !important; padding:clamp(20px,2.4vw,30px) !important; }
.tutor-course-details-widget-list li, .tutor-course-benefits li, .tutor-course-requirements li{ position:relative; }
/* zakładki kursu */
.tutor-course-details-tab.tutor-is-sticky{ background:var(--paper); border-bottom:1px solid var(--hairline); }
.tutor-nav .tutor-nav-link, .tutor-course-details-tab .tutor-nav-link{ font-family:var(--font-mono) !important; font-size:12.5px !important; text-transform:uppercase; letter-spacing:.06em; color:var(--ink-soft) !important; }
.tutor-nav .tutor-nav-link.is-active, .tutor-course-details-tab .tutor-nav-link.is-active{ color:var(--ink) !important; box-shadow: inset 0 -2px 0 var(--tom2) !important; }
/* treść paneli zakładek — wymuś normalną wielkość liter (panel ma klasę .tutor-tab-item) */
.tutor-tab .tutor-tab-item{ text-transform:none !important; }
/* instruktor */
.tutor-instructor-card, .tutor-single-course-instructor{ border:1px solid var(--hairline) !important; border-radius:16px !important; background:var(--paper) !important; }
.tutor-instructor-name, .tutor-instructor-card-title{ font-family:var(--font-display) !important; }

/* tytuły sekcji treści kursu — normalna wielkość liter (Tutor je wersalikuje) */
.tutor-course-content-title, .tutor-course-details-content h2, .tutor-course-details-content h3,
.tutor-course-details-widget-title{ font-family:var(--font-display) !important; font-weight:600 !important; text-transform:none !important; letter-spacing:-.01em; }
.tutor-course-details-content{ font-size:16.5px; line-height:1.72; }
.tutor-course-details-content p{ margin:0 0 12px; }

/* PROGRAM KURSU — akordeon sekcji + lista lekcji (na stronie kursu) */
.tutor-accordion .tutor-accordion-item{ border:1px solid var(--hairline) !important; border-radius:14px !important; margin-bottom:12px; overflow:hidden; background:var(--paper) !important; }
.tutor-accordion .tutor-accordion-item-header{ position:relative; background:var(--paper-shade) !important; text-transform:none !important; font-family:var(--font-display) !important; font-weight:600 !important; font-size:16px !important; color:var(--ink) !important; padding:15px 52px 15px 18px !important; }
/* chevron Tutora (::after) — jedna strzałka, wyśrodkowana pionowo, własny gutter */
.tutor-accordion .tutor-accordion-item-header::after{ position:absolute !important; right:18px; top:50%; transform:translateY(-50%); margin:0 !important; }
.tutor-accordion .tutor-accordion-item-header.is-active::after{ transform:translateY(-50%) rotate(180deg); }
.tutor-accordion .tutor-accordion-item-header.is-active{ box-shadow: inset 3px 0 0 var(--tom3) !important; }
.tutor-accordion .tutor-accordion-item-body{ padding:4px 10px 10px !important; }
.tutor-accordion .tutor-accordion-item-body-content{ padding:0 !important; }
.tutor-course-content-list{ list-style:none !important; margin:0 !important; padding:0 !important; }
.tutor-course-content-list-item{ display:flex !important; align-items:center; justify-content:space-between; gap:12px; padding:11px 12px !important; border-radius:10px; border-top:1px solid var(--hairline) !important; transition:background .15s ease; }
.tutor-course-content-list-item:first-child{ border-top:0 !important; }
.tutor-course-content-list-item:hover{ background:var(--tom3-tint) !important; }
.tutor-course-content-list-item-icon{ color:var(--tom2-deep) !important; }
.tutor-course-content-list-item-title{ font-family:var(--font-body) !important; font-weight:500 !important; font-size:15px !important; margin:0 !important; line-height:1.4; }
.tutor-course-content-list-item-title a{ color:var(--ink) !important; text-decoration:none; }
.tutor-course-content-list-item-title a:hover{ color:var(--tom3-deep) !important; }
.tutor-course-content-list-item-duration{ font-family:var(--font-mono) !important; font-size:11.5px !important; color:var(--ink-soft) !important; }
.tutor-course-content-list-item-status{ color:var(--ink-soft) !important; }

/* sidebar zapisu / cena (entry box) */
.tutor-single-course-sidebar .tutor-card, .tutor-sidebar-card, .tutor-course-single-sidebar, .tutor-course-sidebar-card{
  border:1px solid var(--hairline) !important; border-radius:20px !important; box-shadow:0 16px 44px rgba(28,33,39,.10) !important; overflow:hidden;
}
.tutor-single-course-sidebar .tutor-card-body{ padding:clamp(20px,2.2vw,28px) !important; }
.tutor-course-single-pricing .tutor-fs-4, .tutor-course-single-pricing{ font-family:var(--font-mono) !important; color:var(--ink) !important; }
.tutor-enrolled-info-text, .tutor-enrolled-info-date{ font-family:var(--font-mono) !important; }
.tutor-enroll-course-button{ font-size:15px !important; }

/* ===== ODTWARZACZ LEKCJI / SPOTLIGHT ===== */
.tutor-course-single-content-wrapper{ background:var(--paper); }
.tutor-course-single-sidebar-wrapper{ background:var(--paper-shade); border-right:1px solid var(--hairline); }
.tutor-course-single-sidebar-title{ font-family:var(--font-display) !important; font-weight:600 !important; font-size:18px !important; color:var(--ink) !important; }
/* akordeon programu */
.tutor-accordion-item{ border-bottom:1px solid var(--hairline) !important; background:transparent !important; }
/* WAŻNE: zachowaj prawy gutter (44px) na chevron Tutora (::after right:16px),
   inaczej strzałka nachodzi na licznik „0/2" w sidebarze lekcji. */
.tutor-accordion-item-header{ font-family:var(--font-display) !important; font-weight:600 !important; color:var(--ink) !important; padding:16px 44px 16px 20px !important; }
.tutor-accordion-item-header:hover{ color:var(--tom3-deep) !important; }
/* licznik „0/2" — odsuń od chevronu na wszelki wypadek */
.tutor-course-single-sidebar-wrapper .tutor-course-topic-summary{ margin-right:6px; }
.tutor-accordion-item-body{ background:var(--paper) !important; }
.tutor-course-topic-summary{ font-family:var(--font-mono) !important; font-size:11.5px !important; color:var(--ink-soft) !important; letter-spacing:.03em; }
/* pozycje lekcji w sidebarze */
.tutor-course-topic-item{ border-top:1px solid var(--hairline) !important; transition:background .15s ease; }
.tutor-course-topic-item:hover{ background:var(--tom3-tint) !important; }
.tutor-course-topic-item.is-active{ background:var(--tom3-tint) !important; box-shadow: inset 3px 0 0 var(--tom3) !important; }
.tutor-course-topic-item-title{ font-size:14px !important; color:var(--ink) !important; }
.tutor-course-topic-item-duration{ font-family:var(--font-mono) !important; font-size:11px !important; color:var(--ink-soft) !important; }
.tutor-course-topic-item-icon, .tutor-course-topic-item .tutor-icon-lock-line{ color:var(--ink-soft) !important; }
/* checkbox ukończenia */
.tutor-form-check-circle:checked, .tutor-form-check-input:checked{ background-color:var(--tom4) !important; border-color:var(--tom4) !important; }
/* nawigacja spotlight (zakładki nad treścią lekcji) */
.tutor-course-spotlight-nav{ border-bottom:1px solid var(--hairline) !important; }
.tutor-course-spotlight-nav .tutor-nav-link{ font-family:var(--font-mono) !important; font-size:12.5px !important; text-transform:uppercase; letter-spacing:.06em; color:var(--ink-soft) !important; }
.tutor-course-spotlight-nav .tutor-nav-link.is-active{ color:var(--ink) !important; box-shadow: inset 0 -2px 0 var(--tom2) !important; }
.tutor-course-topic-single-header-title, .tutor-course-topic-single-header h1, .tutor-course-topic-single-header h2{ font-family:var(--font-display) !important; font-weight:600 !important; }
.tutor-course-topic-single-body{ font-size:16.5px; line-height:1.72; }
/* player (Vimeo/YouTube/HTML5) — ramka „Podręcznik" + proporcje 16:9 */
.tutor-video-player-wrapper, .tutor-video-player{ border-radius:18px; overflow:hidden; background:#000;
  box-shadow:0 18px 44px rgba(28,33,39,.16); border:1px solid var(--hairline); }
/* wymuś 16:9 w playerze (globalny override .tutor-ratio-16x9 na 16/10 dotyczy kart, nie wideo) */
.tutor-video-player .tutor-ratio-16x9,
.tutor-video-player .tutor-ratio{ aspect-ratio:16/9 !important; }
.tutor-video-player iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }

/* ===== DASHBOARD UCZNIA ===== */
.tutor-frontend-dashboard{ padding-block: clamp(24px,3.5vh,44px) clamp(48px,7vh,90px); }
.tutor-frontend-dashboard-header{ border:1px solid var(--hairline); border-radius:20px; background:var(--paper); padding:clamp(20px,2.4vw,30px) !important; margin-bottom:clamp(22px,3vw,36px); }
.tutor-dashboard-header-display-name, .tutor-dashboard-header-username{ font-family:var(--font-display) !important; font-weight:600 !important; }
.tutor-dashboard-header-greetings{ font-family:var(--font-mono) !important; color:var(--ink-soft) !important; font-size:12.5px; text-transform:uppercase; letter-spacing:.05em; }
.tutor-dashboard-header-avatar img, .tutor-dashboard-header-avatar .tutor-avatar{ border-radius:50% !important; }
/* lewe menu */
.tutor-dashboard-left-menu{ border:1px solid var(--hairline) !important; border-radius:18px !important; background:var(--paper) !important; overflow:hidden; }
.tutor-dashboard-permalinks{ list-style:none; padding:8px !important; margin:0; }
.tutor-dashboard-permalinks li a, .tutor-dashboard-menu-item-link{ font-family:var(--font-body) !important; font-weight:500 !important; color:var(--ink) !important; border-radius:12px; padding:11px 14px !important; display:flex; align-items:center; gap:10px; }
.tutor-dashboard-permalinks li a:hover{ background:var(--paper-shade) !important; }
.tutor-dashboard-permalinks li.active a, .tutor-dashboard-permalinks li a.active, .tutor-dashboard-menu-item.active a{ background:var(--tom3-tint) !important; color:var(--tom3-deep) !important; }
.tutor-dashboard-menu-divider{ border-top:1px solid var(--hairline) !important; margin:8px 0; }
/* karty zawartości / statystyki */
.tutor-dashboard-content-inner .tutor-card{ border:1px solid var(--hairline) !important; border-radius:16px !important; background:var(--paper) !important; }
.tutor-dashboard-title{ font-family:var(--font-display) !important; font-weight:600 !important; }
.tutor-round-box{ background:var(--tom3-tint) !important; color:var(--tom3-deep) !important; border-radius:50% !important; }
.tutor-course-progress-item{ border:1px solid var(--hairline) !important; border-radius:16px !important; }
.tutor-course-progress-item-title{ font-family:var(--font-display) !important; }
/* tabele */
.tutor-table thead th{ font-family:var(--font-mono) !important; font-size:11.5px !important; text-transform:uppercase; letter-spacing:.05em; color:var(--ink-soft) !important; border-bottom:1px solid var(--hairline) !important; }
.tutor-table td{ border-bottom:1px solid var(--hairline) !important; }
/* mobilny pasek dolny */
.tutor-dashboard-footer-mobile{ background:var(--paper) !important; border-top:1px solid var(--hairline) !important; }

/* pasek postępu — wspólnie */
.tutor-progress-bar{ background:var(--paper-shade) !important; border-radius:999px !important; overflow:hidden; }
.tutor-progress-bar .tutor-progress-value, .tutor-progress-filled, .tutor-progress-value{ background:var(--tom4) !important; }

/* alerty */
.tutor-alert{ border-radius:14px !important; border:1px solid var(--hairline) !important; font-family:var(--font-body) !important; }
.tutor-alert.tutor-warning{ background:var(--tom2-tint) !important; border-color:rgba(185,127,29,.3) !important; }
.tutor-alert.tutor-success{ background:var(--tom4-tint) !important; }
.tutor-alert.tutor-danger{ background:var(--tom3-tint) !important; }

/* ===== LOGIN / REJESTRACJA ===== */
.ak-tutor-auth{ max-width:560px; margin:clamp(28px,6vh,72px) auto clamp(48px,9vh,110px); padding-inline: var(--gutter); }
.ak-tutor-auth .eyebrow{ margin-bottom:10px; }
.ak-tutor-auth h1{ font-family:var(--font-display); font-weight:600; font-size:clamp(26px,3.4vw,40px); line-height:1.12; letter-spacing:-.015em; margin-bottom:8px; }
.ak-tutor-auth .lede{ color:var(--ink-soft); margin-bottom:26px; }
.tutor-login-wrap, .tutor-login-form-wrapper{ width:100%; }
.tutor-login-form-wrapper{ border:1px solid var(--hairline); border-radius:20px; background:var(--paper); box-shadow:0 16px 44px rgba(28,33,39,.08); padding:clamp(24px,3vw,38px) !important; }
.tutor-login-form-wrapper .tutor-fs-5{ font-family:var(--font-display) !important; }
#tutor-login-form .tutor-form-control{ padding:13px 15px !important; }
#tutor-login-form .tutor-btn-block{ width:100% !important; }

/* ===== PUSTY STAN / BRAK DOSTĘPU ===== */
.ak-tutor-state{ max-width:680px; margin:clamp(40px,8vh,100px) auto; padding-inline:var(--gutter); text-align:center; }
.ak-tutor-state .spines-v{ display:flex; gap:7px; justify-content:center; margin:0 auto 26px; }
.ak-tutor-state .spines-v span{ width:9px; height:54px; border-radius:3px; display:block; }
.ak-tutor-state .spines-v span:nth-child(1){ background:var(--tom1); }
.ak-tutor-state .spines-v span:nth-child(2){ background:var(--tom2); }
.ak-tutor-state .spines-v span:nth-child(3){ background:var(--tom3); }
.ak-tutor-state .spines-v span:nth-child(4){ background:var(--tom4); }
.ak-tutor-state h1{ font-family:var(--font-display); font-weight:600; font-size:clamp(26px,3.6vw,40px); line-height:1.12; letter-spacing:-.015em; margin-bottom:12px; }
.ak-tutor-state p{ color:var(--ink-soft); max-width:48ch; margin:0 auto 26px; }
/* wbudowany pusty stan Tutora (np. archiwum bez kursów) */
.tutor-empty-state, .tutor-empty{ text-align:center !important; padding:clamp(36px,6vh,72px) var(--gutter) !important; }
.tutor-empty-state img, .tutor-empty img{ max-width:120px; margin:0 auto 22px; opacity:.85; }
.tutor-empty-state .tutor-fs-5, .tutor-empty-state h3, .tutor-empty h3{ font-family:var(--font-display) !important; font-weight:600 !important; font-size:clamp(22px,2.8vw,30px) !important; color:var(--ink) !important; }
.tutor-empty-state .tutor-color-muted, .tutor-empty .tutor-color-muted{ color:var(--ink-soft) !important; }

/* --- responsywny film (Vimeo/MP4) w stylu motywu --- */
.ak-video{ position:relative; aspect-ratio:16/9; border-radius:18px; overflow:hidden; background:#000;
  box-shadow:0 20px 50px rgba(28,33,39,.16); border:1px solid var(--hairline); }
.ak-video iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
.ak-video video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; background:#000; }

/* ============================================================
   BLOG — lista (karty) + pojedynczy wpis
   ============================================================ */
/* badge kategorii (gdyby brak w bazowym CSS) */
.cat{ display:inline-block; font-family:var(--font-mono); font-size:11px; letter-spacing:.04em; text-transform:uppercase;
  padding:5px 11px; border-radius:999px; background:var(--paper-shade); color:var(--ink); }
.cat.c1{ background:var(--tom1-tint); color:var(--tom1-deep); }
.cat.c2{ background:var(--tom2-tint); color:var(--tom2-deep); }
.cat.c3{ background:var(--tom3-tint); color:var(--tom3-deep); }
.cat.c4{ background:var(--tom4-tint); color:var(--tom4-deep); }

/* --- siatka kart --- */
.ak-blog-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(308px,1fr)); gap:clamp(22px,2.6vw,34px); }
.ak-post-card{ display:flex; flex-direction:column; text-decoration:none; color:inherit;
  border:1px solid var(--hairline); border-radius:18px; overflow:hidden; background:var(--paper);
  transition:box-shadow .22s ease, transform .22s ease; }
.ak-post-card:hover{ box-shadow:0 20px 46px rgba(28,33,39,.12); transform:translateY(-4px); }
.ak-post-thumb{ aspect-ratio:16/10; overflow:hidden; background:var(--paper-shade); }
.ak-post-thumb img{ width:100%; height:100%; object-fit:cover; }
.ak-post-thumb.tint-c1{ background:var(--tom1-tint);} .ak-post-thumb.tint-c2{ background:var(--tom2-tint);}
.ak-post-thumb.tint-c3{ background:var(--tom3-tint);} .ak-post-thumb.tint-c4{ background:var(--tom4-tint);}
.ak-post-card-body{ padding:22px 24px 26px; display:flex; flex-direction:column; gap:11px; flex:1; }
.ak-post-meta{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.ak-post-meta time{ font-family:var(--font-mono); font-size:12px; color:var(--ink-soft); }
.ak-post-card-body h3{ font-family:var(--font-display); font-weight:600; font-size:21px; line-height:1.18; color:var(--ink); }
.ak-post-card:hover h3{ color:var(--tom3-deep); }
.ak-post-card-body p{ color:var(--ink-soft); font-size:15px; line-height:1.6; margin:0; }
.ak-post-more{ margin-top:auto; font-family:var(--font-mono); font-size:13px; color:var(--ink); font-weight:500; padding-top:6px;
  display:inline-flex; align-items:center; gap:8px; }
.ak-post-card:hover .ak-post-more .arr{ transform:translateX(4px); transition:transform .18s ease; }

/* --- pojedynczy wpis --- */
.ak-post-byline{ display:flex; gap:14px; flex-wrap:wrap; align-items:center;
  font-family:var(--font-mono); font-size:13px; color:var(--ink-soft); margin-top:10px; }
.ak-featured-wrap{ padding-top: clamp(26px,3.4vh,44px); }
.ak-featured{ margin:0 auto; width:fit-content; max-width:100%; border-radius:20px; overflow:hidden; box-shadow:0 18px 44px rgba(28,33,39,.12); }
.ak-featured img{ display:block; width:auto; max-width:100%; height:auto; max-height:600px; }

/* Pokaz slajdów 3 zdjęć (auto-crossfade) — sekcja „Doświadczony kosmetolog-praktyk" */
.ak-slideshow{ position:relative; aspect-ratio:1; border-radius:16px; overflow:hidden; box-shadow:0 18px 44px rgba(28,33,39,.14); background:var(--paper-shade); }
/* animujemy bezpośrednie dzieci (img LUB <picture> dodane przez essa-speed) — stąd „> *" zamiast „img" */
.ak-slideshow > *{ position:absolute; inset:0; opacity:0; animation:ak-slidefade 15s infinite; }
.ak-slideshow > *:nth-child(1){ animation-delay:0s; }
.ak-slideshow > *:nth-child(2){ animation-delay:5s; }
.ak-slideshow > *:nth-child(3){ animation-delay:10s; }
.ak-slideshow img{ width:100%; height:100%; object-fit:cover; display:block; }
.ak-slideshow:hover > *{ animation-play-state:paused; }
@keyframes ak-slidefade{ 0%{opacity:0} 6%{opacity:1} 30%{opacity:1} 36%{opacity:0} 100%{opacity:0} }
@media (prefers-reduced-motion: reduce){ .ak-slideshow > *{ animation:none; opacity:0; } .ak-slideshow > *:nth-child(1){ opacity:1; } }

/* Inne publikacje — mały kafelek (Trychomania, mniej eksponowany niż 4 tomy) */
.other-pub-label{ text-align:center; margin-bottom:26px; }
.other-pub-label .eyebrow{ justify-content:center; }
.other-pub-card{ display:grid; grid-template-columns:148px 1fr; gap:30px; align-items:center; max-width:760px; margin:0 auto; padding:28px 32px; border:1px solid var(--hairline); border-radius:18px; background:var(--paper); color:inherit; text-decoration:none; transition:box-shadow .22s, transform .22s, border-color .22s; }
.other-pub-card:hover{ box-shadow:0 18px 44px rgba(28,33,39,.1); transform:translateY(-3px); border-color:var(--tom2); }
.other-pub-card figure{ margin:0; }
.other-pub-card figure img{ width:100%; height:auto; display:block; filter:drop-shadow(0 16px 24px rgba(32,36,43,.24)); }
.other-pub-body .sub{ font-family:var(--font-mono); font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft); }
.other-pub-body h3{ font-size:22px; line-height:1.2; margin:7px 0 9px; }
.other-pub-body p{ color:var(--ink-soft); font-size:15px; line-height:1.55; margin-bottom:16px; }
.other-pub-card .buy{ font-family:var(--font-mono); font-size:13px; letter-spacing:.04em; color:var(--tom2-deep); font-weight:600; }
@media (max-width:560px){ .other-pub-card{ grid-template-columns:1fr; gap:18px; text-align:center; padding:24px; } .other-pub-card figure{ max-width:150px; margin:0 auto; } }
.ak-article-body{ max-width:740px; margin-inline:auto; }
.ak-article-body img{ max-width:100%; width:auto; max-height:600px; height:auto; border-radius:14px; margin:26px auto; display:block; }
.ak-article-body figure{ margin:26px 0; }
.ak-article-body figure img{ margin:0 auto; }
.ak-article-body figcaption{ font-family:var(--font-mono); font-size:12.5px; color:var(--ink-soft); text-align:center; margin-top:10px; }
.ak-article-foot{ max-width:740px; margin:50px auto 0; padding-top:28px; border-top:1px solid var(--hairline);
  display:flex; flex-wrap:wrap; gap:18px; align-items:center; justify-content:space-between; }
.ak-article-foot .ak-tags{ font-family:var(--font-mono); font-size:13px; color:var(--ink-soft); margin:0; }
.ak-prevnext{ display:grid; grid-template-columns:1fr 1fr; gap:20px; }
@media (max-width:680px){ .ak-prevnext{ grid-template-columns:1fr; } }
.ak-pn-card{ display:flex; flex-direction:column; gap:8px; text-decoration:none; color:inherit;
  padding:24px 26px; border:1px solid var(--hairline); border-radius:16px; background:var(--paper);
  transition:box-shadow .2s ease, transform .2s ease; }
.ak-pn-card:hover{ box-shadow:0 14px 34px rgba(28,33,39,.10); transform:translateY(-2px); }
.ak-pn-next{ text-align:right; align-items:flex-end; }
.ak-pn-label{ font-family:var(--font-mono); font-size:12px; color:var(--ink-soft); text-transform:uppercase; letter-spacing:.05em; }
.ak-pn-title{ font-family:var(--font-display); font-weight:600; font-size:18px; line-height:1.2; color:var(--ink); }

/* ============================================================
   STRONY UŻYTKOWE (404, wyszukiwarka, itp.) — styl „maintenance"
   wyśrodkowana karta + pionowe kolorowe kreseczki
   ============================================================ */
.ak-center{ min-height: calc(100svh - var(--header-h) - 2px); display:grid; place-items:center;
  text-align:center; padding: clamp(48px,9vh,110px) var(--gutter); }
.ak-center .inner{ max-width:640px; }
.ak-center .actions{ display:flex; gap:14px; flex-wrap:wrap; justify-content:center; margin-top:32px; }
.ak-center .eyebrow{ justify-content:center; }
.ak-center .lede{ margin:18px auto 0; }
.ak-center .ak-search-wrap{ margin:30px auto 0; max-width:440px; }
.spines-v{ display:flex; gap:8px; justify-content:center; margin-bottom:30px; }
.spines-v span{ width:12px; height:54px; border-radius:4px; }
.spines-v span:nth-child(1){ background:var(--tom1); }
.spines-v span:nth-child(2){ background:var(--tom2); }
.spines-v span:nth-child(3){ background:var(--tom3); }
.spines-v span:nth-child(4){ background:var(--tom4); }
.ak-center .big-404{ font-family:var(--font-display); font-weight:600; font-size:clamp(90px,20vw,200px);
  line-height:.9; letter-spacing:-.03em; opacity:.08; margin-bottom:-.18em; pointer-events:none; }

/* --- baner cookie (essa-cookie-consent) w kolorach motywu --- */
:root{ --ecc-primary:#E05C6F; }
.ecc-banner, .ecc-box{ --ecc-primary:#E05C6F; }
.ecc-btn--primary{ background:#E05C6F !important; border-color:#E05C6F !important; color:#fff !important; }
.ecc-btn--primary:hover{ background:#C73B50 !important; border-color:#C73B50 !important; }
.ecc-title{ font-family:var(--font-display); }
.ecc-box, .ecc-btn{ font-family:var(--font-body); }

/* === OBRĘCZ HERO — finalne, niezawodne (desktop + mobile) =========================
   Sedno: .stage to KWADRAT o rozmiarze obręczy (--hero-ring). Koło (.halo) wypełnia
   stage 1:1 (inset:0), a zdjęcie to STAŁE 86% obręczy i jest wyśrodkowane w gridzie.
   Dzięki temu koło i zdjęcie są na zawsze sprzężone i koncentryczne, a wysokość
   stage zawsze równa się obręczy — koło NIGDY nie wylewa się na podpis ryciny,
   niezależnie od szerokości okna i zoomu. Jeden blok = jedno źródło prawdy. */
.hero-photo{ --hero-ring: clamp(240px, 26vw, 416px); }
.hero-photo .stage{
  position:relative; width:var(--hero-ring); max-width:100%;
  aspect-ratio:1; margin-inline:auto; padding:0;
  display:grid; grid-template-columns:100%; place-items:center;
}
.hero-photo .halo{
  position:absolute !important; inset:0 !important; margin:0 !important;
  width:100% !important; height:100% !important; aspect-ratio:auto !important;
  border-radius:50%;
}
.hero-photo .stage img{
  width:86% !important; max-width:86% !important; height:auto;
  aspect-ratio:1; border-radius:50%;
  justify-self:center !important; margin-inline:auto !important;
}
/* niższe ekrany (np. laptop 13"): mniejsza obręcz, by hero mieścił się w oknie */
@media (min-height:640px) and (max-height:860px){
  .hero-photo{ --hero-ring: clamp(220px, 22vw, 340px); }
}
/* telefon */
@media (max-width:560px){
  .hero-photo{ --hero-ring: min(300px, 78vw); }
}

/* ============================================================
   BIBLIOGRAFIA (page-3064) — publikacje naukowe w stylu „Podręcznik"
   ============================================================ */
.ak-biblio-wrap{ max-width: 920px; }

/* — pasek „Tab. A.1": statystyka publikacji — */
.biblio-meta{ margin: 0 0 clamp(28px,4vw,44px); }
.biblio-tab{
  font: 500 12px/1 var(--font-mono);
  letter-spacing: .08em; text-transform: uppercase;
  color: var(--tom1-deep); margin: 0 0 16px;
}
.biblio-stats{
  display: grid; grid-template-columns: repeat(3, minmax(0,1fr));
  gap: clamp(14px, 2.4vw, 28px);
  border-block: 1px solid var(--hairline);
  padding-block: clamp(18px,2.6vw,26px);
}
.biblio-stat{ display: flex; flex-direction: column; gap: 6px; }
.biblio-stat .num{
  font-family: var(--font-display); font-weight: 600;
  font-size: clamp(30px, 5vw, 48px); line-height: 1;
  color: var(--ink); font-variant-numeric: tabular-nums; letter-spacing: -.01em;
}
.biblio-stat .lab{
  font-size: 13.5px; line-height: 1.4; color: var(--ink-soft); max-width: 22ch;
}
@media (max-width:600px){
  .biblio-stats{ grid-template-columns: 1fr; gap: 16px; }
  .biblio-stat{ flex-direction: row; align-items: baseline; gap: 12px; }
  .biblio-stat .num{ font-size: 30px; min-width: 2.4ch; }
}

/* — wyszukiwarka — */
.biblio-search{ margin: 0 0 clamp(24px,3vw,34px); position: relative; }
.biblio-search input{
  width: 100%; box-sizing: border-box;
  font: 400 16px var(--font-body); color: var(--ink);
  padding: 15px 18px 15px 46px;
  background: var(--paper);
  border: 1.5px solid var(--hairline); border-radius: 14px;
  transition: border-color .18s ease, box-shadow .18s ease;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23565D66' stroke-width='2' stroke-linecap='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: 16px center;
}
.biblio-search input:focus{
  outline: none; border-color: var(--tom1-deep);
  box-shadow: 0 0 0 4px var(--tom1-tint);
}
.biblio-empty{ margin: 18px 2px 0; color: var(--ink-soft); font-size: 15px; }

/* — lista publikacji: numeracja monospace + wcięcie wiszące — */
.biblio-list{ list-style: none; margin: 0; padding: 0; counter-reset: none; }
.biblio-item{
  display: grid; grid-template-columns: 3.2ch 1fr; column-gap: clamp(14px,2vw,22px);
  align-items: start;
  padding: clamp(16px,2.4vw,22px) 0;
  border-top: 1px solid var(--hairline);
}
.biblio-item:last-child{ border-bottom: 1px solid var(--hairline); }
.biblio-item .ref-no{
  font: 500 13px/1.6 var(--font-mono);
  color: var(--tom1-deep); font-variant-numeric: tabular-nums;
  padding-top: 4px;
}
.biblio-item .ref-cite{
  margin: 0; font-size: 16.5px; line-height: 1.6; color: var(--ink);
  text-wrap: pretty;
}
.biblio-item .ref-cite em, .biblio-item .ref-cite i{
  font-family: var(--font-display); font-style: italic; font-weight: 500;
}
.ref-link{
  display: inline-flex; align-items: center; gap: 6px; margin-top: 10px;
  font: 500 12.5px/1 var(--font-mono); letter-spacing: .04em; text-transform: uppercase;
  color: var(--tom1-deep); text-decoration: none;
  padding: 7px 12px; border: 1px solid var(--hairline); border-radius: 999px;
  transition: background .16s ease, border-color .16s ease, color .16s ease, transform .16s var(--ease-out-strong);
}
.ref-link:hover{
  background: var(--tom1-deep); border-color: var(--tom1-deep); color: #fff;
  transform: translateY(-1px);
}
.ref-link .arr{ transition: transform .15s ease; }
.ref-link:hover .arr{ transform: translateX(3px); }

@media (prefers-reduced-motion: reduce){
  .ref-link, .ref-link .arr{ transition: none; }
  .ref-link:hover{ transform: none; }
}

/* ============================================================
   HOME — karty (.sheet) mieszczą się w jednym ekranie
   Karty są sticky-stack: dół kartki wyższej niż viewport chowa się
   pod następną. Dlatego ograniczamy wysokość zdjęć/okładek do ekranu.
   ============================================================ */
.sheet{ padding: clamp(36px,6vh,72px) 0 clamp(40px,7vh,84px); }
/* STIX jest szerszy od Fraunces — nagłówki kart nie mogą zawijać się na 5 linii */
.sheet h2{ font-size: clamp(26px, 3.6vw, 46px); max-width: 22ch; }
.sheet.s3 h2{ max-width: 26ch; }
/* zdjęcie w karcie (np. kartka 1) — STAŁE proporcje 4/5, niezależne od zoomu/okna
   (wcześniej height:56vh powodował zmianę kadru przy powiększeniu strony) */
.sheet .sheet-grid figure.plate img{ aspect-ratio: 4/5; width: 100%; height: auto; object-fit: cover; }
/* okładki w kartce 3 — STAŁE proporcje 5/6 (jak realne okładki), wypełniają kolumnę;
   wcześniej height:31vh ograniczał wysokość → okładki wyglądały „skurczone" z bokami */
.sheet.s3 .covers-row{ margin-top: clamp(16px, 2.2vh, 30px); align-items: end; }
.sheet.s3 .cover-tile{ align-content: start; }
.sheet.s3 .cover-tile img{ width: 100%; height: auto; aspect-ratio: 5/6; object-fit: cover; }
/* bardzo niskie ekrany laptopów — dociśnij, żeby cała kartka była widoczna */
@media (max-height: 820px){
  .sheet{ padding: clamp(24px,4vh,48px) 0; }
}
@media (max-width: 880px){
  /* na mobile karty TEŻ są sticky-stack — zachowujemy dopasowanie zdjęć do ekranu,
     żeby kartki miały ~wysokość ekranu i ładnie się na siebie nasuwały */
  .sheet h2{ max-width: 20ch; }
  /* mobile: te same stałe proporcje 4/5 (bez vh, żeby kadr był zawsze taki sam) */
  .sheet .sheet-grid figure.plate img{ aspect-ratio: 4/5; height: auto; }
}

@media (max-width: 880px){
  .brand img{ height: 86px; }   /* na telefonie logo nieco mniejsze, by header nie był za wysoki */
}

/* ============================================================
   NAGŁÓWKI — siatka bezpieczeństwa zawijania (STIX szerszy niż Fraunces)
   Długie polskie słowa (np. „interdyscyplinarność") muszą się łamać,
   a nie wychodzić poza kontener — szczególnie na mobile.
   ============================================================ */
.h-xl, .h-lg, .h-md,
.chapter-head h1, .section-head h2,
.sheet h2, .ak-prose h2, .ak-prose h3{
  overflow-wrap: break-word;
  hyphens: auto;
}

/* ============================================================
   DESKTOP — CAŁE menu jako pionowy header przy LEWEJ krawędzi.
   (Na końcu pliku, by wygrać kolejnością nad bazowymi regułami nav.)
   Na ≤1080px zostaje górny pasek + hamburger.
   ============================================================ */
@media (min-width: 1081px) {
  :root { --nav-w: 264px; }
  body { padding-left: var(--nav-w); --header-h: 0px; }

  .site-header {
    position: fixed; inset: 0 auto 0 0; width: var(--nav-w);
    background: var(--paper); border-bottom: none; border-right: 1px solid var(--hairline);
    z-index: 60;
  }
  /* pasek 4 kolorów jako pionowa sygnatura na prawej krawędzi panelu (przy treści) */
  .site-header .spines {
    position: absolute; right: 0; left: auto; top: 0; bottom: 0; width: 6px; height: auto;
    grid-template-columns: 1fr; grid-template-rows: repeat(4, 1fr);
  }
  .site-header .bar {
    flex-direction: column; align-items: stretch; justify-content: flex-start;
    height: 100%; gap: 24px; padding: 34px 32px 28px 26px; overflow-y: auto;
  }
  .brand { padding: 0; justify-content: center; }
  .brand img { height: 140px; }

  .main-nav { display: block; width: 100%; }
  .main-nav ul { flex-direction: column; align-items: stretch; gap: 2px; }
  .main-nav a { display: block; padding: 10px 13px; font-size: 15.5px; white-space: normal; line-height: 1.25; }
  /* podmenu rozwinięte na stałe w panelu (brak miejsca na dropdown na hover) */
  .has-sub .sub {
    position: static; display: block; min-width: 0;
    border: none; box-shadow: none; padding: 2px 0 6px 14px; background: transparent;
  }
  .has-sub .sub a { font-size: 13.5px; padding: 6px 12px; color: var(--ink-soft); white-space: normal; line-height: 1.3; }
  .has-sub::after { display: none; }
  .main-nav .nav-cta { margin-top: 12px; }
  .main-nav .nav-cta a { text-align: center; }

  /* Hero na pełny ekran MINUS pasek marquee — żeby przewijany pasek
     („Tom I…IV · Wydawnictwo PZWL") był widoczny na dole pierwszego ekranu. */
  .hero {
    min-height: calc(100svh - 58px);
    display: flex; flex-direction: column; justify-content: center;
    gap: clamp(18px, 2.6vh, 36px);
    padding-block: clamp(20px, 3.4vh, 44px);
  }
}

/* ============================================================
   TUTOR — TRYB KURSU: header na górze + LEKCJA na pełny ekran
   ============================================================ */

/* --- Lekcja/quiz: pełnoekranowy player Tutora — chowamy boczny header motywu --- */
body.ak-lesson{ padding-left: 0 !important; }
body.ak-lesson .site-header{ display: none !important; }
body.ak-lesson main{ margin: 0; }

/* --- Strony kursu (katalog/kurs/dashboard): header z boku → na górę (desktop) --- */
@media (min-width: 1081px) {
  body.ak-course:not(.ak-lesson){ padding-left: 0 !important; --header-h: 66px; }
  body.ak-course:not(.ak-lesson) .site-header{
    position: sticky; inset: auto; top: 0; width: auto;
    border-right: none; border-bottom: 1px solid var(--hairline); z-index: 50;
  }
  body.ak-course:not(.ak-lesson) .site-header .spines{
    position: static; left: 0; right: 0; top: 0; bottom: auto; width: auto; height: 6px;
    grid-template-columns: repeat(4, 1fr); grid-template-rows: auto;
  }
  body.ak-course:not(.ak-lesson) .site-header .bar{
    flex-direction: row; align-items: center; justify-content: space-between;
    height: auto; gap: 24px; padding: 11px var(--gutter); overflow: visible;
  }
  body.ak-course:not(.ak-lesson) .brand img{ height: 50px; }
  body.ak-course:not(.ak-lesson) .main-nav{ display: block; width: auto; }
  body.ak-course:not(.ak-lesson) .main-nav ul{ flex-direction: row; align-items: center; gap: 4px; }
  body.ak-course:not(.ak-lesson) .main-nav a{ display: inline-block; padding: 8px 13px; font-size: 15px; white-space: nowrap; }
  body.ak-course:not(.ak-lesson) .main-nav .has-sub .sub{
    position: absolute; top: 100%; left: 0; min-width: 280px; display: none;
    padding: 10px; background: var(--paper); border: 1px solid var(--hairline);
    box-shadow: 0 14px 36px rgba(28,33,39,.10); border-radius: 14px;
  }
  body.ak-course:not(.ak-lesson) .main-nav .has-sub:hover .sub,
  body.ak-course:not(.ak-lesson) .main-nav .has-sub:focus-within .sub{ display: block; }
  body.ak-course:not(.ak-lesson) .main-nav .has-sub .sub a{ display: block; padding: 6px 12px; font-size: 13.5px; }
}

/* --- LEKCJA: dopracowane środowisko nauki w stylu „Podręcznik" --- */
.tutor-course-single-content-wrapper{ background: var(--paper) !important; }
/* sidebar z programem kursu */
.tutor-course-single-sidebar-wrapper{ background: var(--paper-shade) !important; border-right: 1px solid var(--hairline) !important; }
.tutor-course-single-sidebar-title{ padding: 18px 20px !important; border-bottom: 1px solid var(--hairline); }
.tutor-course-single-sidebar-title span:first-child{ font-family: var(--font-display) !important; font-size: 16px !important; color: var(--ink) !important; font-weight: 600 !important; text-transform: none !important; }
.tutor-course-single-sidebar-wrapper .tutor-accordion-item-header{ background: var(--paper-shade) !important; font-family: var(--font-display) !important; font-weight: 600 !important; color: var(--ink) !important; text-transform: none !important; }
.tutor-course-single-sidebar-wrapper .tutor-accordion-item-header:hover,
.tutor-course-single-sidebar-wrapper .tutor-accordion-item-header.is-active{ color: var(--tom3-deep) !important; }
.tutor-course-single-sidebar-wrapper .tutor-accordion-item-body{ background: var(--paper) !important; }
.tutor-course-single-sidebar-wrapper .tutor-course-topic-item a{ background: var(--paper) !important; }
.tutor-course-single-sidebar-wrapper .tutor-course-topic-item a:hover{ background: var(--tom3-tint) !important; }
.tutor-course-single-sidebar-wrapper .tutor-course-topic-item.is-active a,
.tutor-course-single-sidebar-wrapper .tutor-course-topic-item a.is-active{ background: var(--tom3-tint) !important; box-shadow: inset 3px 0 0 var(--tom3); }
.tutor-course-single-sidebar-wrapper .tutor-course-topic-item-icon{ color: var(--tom2-deep) !important; }
.tutor-course-single-sidebar-wrapper .tutor-course-topic-item-title{ font-size: 14px !important; color: var(--ink) !important; }

/* górny pasek lekcji (tytuł + „Oznacz jako ukończone" + wyjście) */
.tutor-single-page-top-bar, .tutor-course-topic-single-header{
  background: var(--paper) !important; border-bottom: 1px solid var(--hairline) !important;
  padding: 12px 24px !important; box-shadow: 0 1px 0 rgba(28,33,39,.03);
}
.tutor-course-topic-single-header-title{ font-family: var(--font-display) !important; font-weight: 600 !important; font-size: 16px !important; color: var(--ink) !important; }
.tutor-topbar-mark-btn, .tutor-topbar-complete-btn .tutor-btn{ background: var(--tom3) !important; border-color: var(--tom3) !important; color: #fff !important; border-radius: 999px !important; }
.tutor-topbar-mark-btn:hover{ background: var(--tom3-deep) !important; }
.tutor-single-page-top-bar .tutor-iconic-btn, .tutor-course-topics-sidebar-toggler{ color: var(--ink-soft) !important; }
.tutor-single-page-top-bar .tutor-iconic-btn:hover, .tutor-course-topics-sidebar-toggler:hover{ color: var(--tom3-deep) !important; }

/* treść lekcji */
.tutor-course-topic-single-body{ background: var(--paper) !important; }
.tutor-course-topic-single-body .tutor-fs-5, .tutor-course-topic-single-body h1, .tutor-course-topic-single-body h2{ font-family: var(--font-display) !important; }

/* stopka prev/next — rozsuń, by strzałki się nie nachodziły */
.tutor-course-topic-single-footer{ border-top: 1px solid var(--hairline) !important; display: flex !important; align-items: center; justify-content: space-between; gap: 16px; }
.tutor-single-course-content-prev{ margin-right: auto; }
.tutor-single-course-content-next{ margin-left: auto; }
.tutor-course-topic-single-footer .tutor-btn-secondary{ border: 1px solid var(--hairline) !important; background: var(--paper) !important; color: var(--ink) !important; border-radius: 999px !important; }
.tutor-course-topic-single-footer .tutor-btn-secondary:hover{ background: var(--ink) !important; color: #fff !important; border-color: var(--ink) !important; }
.tutor-course-topic-single-footer .tutor-btn-secondary[disabled]{ opacity: .4; }

/* ============================================================
   POPUP — zapis na rabat w przedsprzedaży kursu (#akPromo)
   ============================================================ */
.ak-promo{
  position: fixed; inset: 0; z-index: 100000;
  display: flex; align-items: center; justify-content: center; padding: 20px;
  opacity: 0; visibility: hidden; transition: opacity .26s ease, visibility .26s ease;
}
.ak-promo.is-open{ opacity: 1; visibility: visible; }
.ak-promo-overlay{ position: absolute; inset: 0; background: rgba(28,33,39,.66); }
.ak-promo-card{
  position: relative; z-index: 1;
  display: grid; grid-template-columns: 0.92fr 1.08fr;
  width: 100%; max-width: 880px; max-height: 92vh; overflow: hidden;
  background: var(--paper); border-radius: 24px;
  box-shadow: 0 40px 110px rgba(28,33,39,.4);
  transform: translateY(14px) scale(.96); transition: transform .3s var(--ease-out-strong);
}
.ak-promo.is-open .ak-promo-card{ transform: none; }
.ak-promo-x{
  position: absolute; top: 14px; right: 14px; z-index: 3;
  width: 38px; height: 38px; border-radius: 50%; border: none; cursor: pointer;
  background: rgba(255,255,255,.85); color: var(--ink); font-size: 15px;
  display: grid; place-items: center; transition: background .15s, color .15s;
}
.ak-promo-x:hover{ background: var(--ink); color: #fff; }

/* lewa kolumna: pudełko kursu na 4-kolorowym tle */
.ak-promo-media{
  position: relative; display: grid; place-items: center; padding: 30px 20px;
  background:
    radial-gradient(120% 90% at 50% 0%, var(--tom3-tint), transparent 70%),
    linear-gradient(160deg, var(--tom1-tint), var(--tom2-tint));
}
.ak-promo-media img{ width: 100%; max-width: 300px; height: auto; filter: drop-shadow(0 26px 40px rgba(28,33,39,.34)); }
.ak-promo-badge{
  position: absolute; top: 18px; left: 18px;
  font: 500 11px/1 var(--font-mono); letter-spacing: .14em; text-transform: uppercase;
  background: var(--tom3); color: #fff; padding: 7px 12px; border-radius: 999px;
}

/* prawa kolumna: oferta + formularz */
.ak-promo-body{ padding: clamp(28px,3vw,44px); overflow-y: auto; }
.ak-promo-body h2{
  font-family: var(--font-display); font-weight: 600;
  font-size: clamp(26px,3vw,36px); line-height: 1.12; margin: 14px 0 12px;
}
.ak-promo-lede{ color: var(--ink-soft); font-size: 15.5px; line-height: 1.6; margin: 0 0 22px; }
.ak-promo-body .elf-form{ gap: 14px; }

@media (max-width: 760px){
  .ak-promo{ padding: 12px; }
  .ak-promo-card{ display: flex; flex-direction: column; max-height: 90vh; }
  .ak-promo-media{ padding: 20px; flex: 0 0 auto; }
  .ak-promo-media img{ max-width: 150px; }
  .ak-promo-body{ flex: 1 1 auto; min-height: 0; overflow-y: auto; -webkit-overflow-scrolling: touch; }
  .ak-promo-badge{ top: 14px; left: 14px; }
}
@media (prefers-reduced-motion: reduce){
  .ak-promo, .ak-promo-card{ transition: none; }
}

/* ============================================================
   POJEDYNCZY KURS — HERO „Podręcznik" (tutor/single-course.php)
   Pełnoszerokościowe hero: spines 4 kolorów, eyebrow z pulsującą
   kropką, wielki tytuł STIX, lede, pasek statystyk, medalion autorki.
   ============================================================ */
.ak-course-hero{
  position: relative;
  background:
    radial-gradient(120% 110% at 88% -10%, var(--tom3-tint), transparent 55%),
    linear-gradient(180deg, var(--paper-shade), var(--paper));
  border-bottom: 1px solid var(--hairline);
  overflow: hidden;
}
.ak-hero-spines{ position:absolute; top:0; left:0; right:0; height:6px;
  display:grid; grid-template-columns:repeat(4,1fr); }
.ak-hero-spines i:nth-child(1){ background:var(--tom1); }
.ak-hero-spines i:nth-child(2){ background:var(--tom2); }
.ak-hero-spines i:nth-child(3){ background:var(--tom3); }
.ak-hero-spines i:nth-child(4){ background:var(--tom4); }

.ak-course-hero-inner{
  display:grid; grid-template-columns:1.35fr .9fr; gap:clamp(28px,4vw,64px);
  align-items:center; padding-block:clamp(40px,6vh,84px);
}
.ak-course-hero .eyebrow{ margin-bottom:18px; }
.ak-course-hero .eyebrow::before{ display:none; }
.ak-course-hero .eyebrow .dot{ display:inline-block; width:9px; height:9px; border-radius:50%;
  background:var(--tom3); margin-right:9px; vertical-align:middle; animation:pulse 2.2s ease infinite; }
.ak-course-hero-title{
  font-family:var(--font-display); font-weight:600;
  font-size:clamp(30px,4.2vw,56px); line-height:1.08; letter-spacing:-.015em;
  color:var(--ink); margin:0 0 18px;
}
.ak-course-hero-lede{ font-size:clamp(16px,1.4vw,19px); line-height:1.6; color:var(--ink-soft);
  max-width:52ch; margin:0 0 28px; }

/* pasek statystyk w stylu „Tab." */
.ak-course-stats{ list-style:none; margin:0 0 30px; padding:22px 0;
  display:flex; flex-wrap:wrap; gap:clamp(22px,3.4vw,52px);
  border-block:1px solid var(--hairline); }
.ak-course-stats li{ display:flex; flex-direction:column; gap:5px; }
.ak-course-stats .num{ font-family:var(--font-display); font-weight:600;
  font-size:clamp(26px,3vw,40px); line-height:1; color:var(--ink); font-variant-numeric:tabular-nums; }
.ak-course-stats .num.is-text{ font-size:clamp(16px,1.6vw,21px); line-height:1.1; padding-top:.35em; letter-spacing:-.01em; }
.ak-course-stats .lab{ font-family:var(--font-mono); font-size:11.5px; letter-spacing:.06em;
  text-transform:uppercase; color:var(--ink-soft); }

.ak-course-hero-foot{ display:flex; align-items:center; gap:22px; flex-wrap:wrap; justify-content:space-between; }
.ak-course-author{ display:inline-flex; align-items:center; gap:12px; }
.ak-course-author img, .ak-course-author .tutor-avatar{ width:46px !important; height:46px !important;
  border-radius:50% !important; object-fit:cover; }
.ak-course-author-meta{ display:flex; flex-direction:column; line-height:1.25; }
.ak-course-author-meta .lbl{ font-family:var(--font-mono); font-size:11px; letter-spacing:.06em;
  text-transform:uppercase; color:var(--ink-soft); }
.ak-course-author-meta .nm{ font-family:var(--font-display); font-weight:600; font-size:16px; color:var(--ink); }
.ak-course-hero-actions{ display:inline-flex; align-items:center; gap:8px; flex-wrap:wrap; }
.ak-course-hero-actions .tutor-btn{ padding:8px 14px !important; }

/* obraz hero = zabrandowany box kursu (obrazek wyróżniający), pływający */
.ak-course-hero-media{ position:relative; margin:0; display:grid; place-items:center; }
.ak-course-cover{ position:relative; display:grid; place-items:center; isolation:isolate; }
/* miękka „poświata"/pedestał pod boxem (jak w popupie rabatowym) */
.ak-course-cover::before{
  content:""; position:absolute; z-index:-1; inset:auto 0 6% 0; margin:auto;
  width:78%; height:62%;
  background:radial-gradient(60% 60% at 50% 45%, var(--tom3-tint), transparent 72%);
  filter:blur(6px);
}
.ak-course-cover img{
  display:block; width:clamp(230px,24vw,360px); max-width:86%; height:auto;
  filter:drop-shadow(0 28px 46px rgba(28,33,39,.22));
}

@media (prefers-reduced-motion: reduce){
  .ak-course-hero .eyebrow .dot{ animation:none; }
}
@media (max-width:900px){
  .ak-course-hero-inner{ grid-template-columns:1fr; gap:30px; text-align:left; }
  .ak-course-hero-media{ order:-1; }
  .ak-course-cover img{ width:min(250px,60vw); }
}

/* ciało kursu pod hero: zdejmij nadmiarowy górny padding (hero już oddycha) */
.ak-course-body .tutor-course-details-page{ padding-top: clamp(28px,4vh,48px) !important; }

/* ----- sidebar zapisu (entry-box) — dopracowanie ceny i CTA ----- */
.tutor-course-sidebar-card-pricing .tutor-fs-4,
.tutor-single-course-sidebar .tutor-card-body .tutor-fs-4{
  font-family:var(--font-display) !important; font-size:clamp(28px,3vw,36px) !important;
  font-weight:600 !important; color:var(--ink) !important; }
.tutor-course-price-tax, .tutor-course-single-pricing + div{ font-family:var(--font-mono) !important;
  font-size:12px !important; color:var(--ink-soft) !important; }
.tutor-single-course-sidebar .tutor-btn-lg{ font-size:15.5px !important; padding-top:14px !important; padding-bottom:14px !important; }
.tutor-single-course-sidebar .tutor-btn .tutor-icon-cart-line,
.tutor-single-course-sidebar .tutor-btn .tutor-icon-cart-filled{ margin-right:8px; }
/* komunikat content drip (próba wejścia w zablokowaną lekcję) */
.ak-drip-notice{ max-width:var(--maxw); margin:18px auto 0; padding:14px 18px;
  display:flex; align-items:center; gap:10px;
  background:var(--tom2-tint); border:1px solid rgba(185,127,29,.3); border-radius:14px;
  font-family:var(--font-body); font-size:14.5px; color:var(--ink); }
.ak-drip-notice .tutor-icon-lock-line{ color:var(--tom2-deep); }
/* przycisk certyfikatu */
.ak-cert-btn{ font-size:14.5px !important; }
.ak-cert-btn .tutor-icon-medal{ color:var(--tom2-deep); }

/* dopisek „dostęp po opłaceniu" pod CTA */
.ak-buy-note{ display:flex; align-items:flex-start; gap:8px; margin:14px 2px 0;
  font-family:var(--font-mono); font-size:12px; line-height:1.5; color:var(--ink-soft); text-wrap:pretty; }
.ak-buy-note .tutor-icon-lock-line{ color:var(--tom3-deep); font-size:13px; margin-top:1px; flex:none; }
/* lista cech w stopce karty (poziom/czas/zapisani) */
.tutor-single-course-sidebar .tutor-card-footer ul li span:last-child{ font-family:var(--font-mono) !important; font-size:13px !important; }
.tutor-single-course-sidebar .tutor-card-footer ul li .tutor-color-black[class*="tutor-icon-"]{ color:var(--tom3-deep) !important; }

/* ----- karta kursu w katalogu: trochę więcej charakteru ----- */
.tutor-course-archive-page .tutor-course-listing,
.tutor-course-archive-page [class*="tutor-grid"]{ gap:clamp(22px,2.6vw,34px) !important; }
.tutor-course-card .tutor-course-thumbnail{ background:linear-gradient(160deg,var(--tom1-tint),var(--tom3-tint)); }

/* ===== Strona produktu: mniejszy tytuł + podtytuł tomu (uwagi Ani) ===== */
.chapter-head h1.ak-product-title{ font-size:clamp(30px,3.6vw,46px); max-width:24ch; }
.ak-product-sub{ margin-top:16px; max-width:48ch; font-family:var(--font-display);
  font-style:italic; font-size:clamp(18px,1.9vw,23px); line-height:1.35; opacity:.92; }
.chapter-head.ch-c3 .ak-product-sub{ color:#fff; }

/* ===== Sklep: blok kodu rabatowego ===== */
.ak-promo{ background:var(--tom1-tint); border-radius:18px;
  padding:clamp(28px,4vw,48px); }
.ak-promo .eyebrow{ margin-bottom:14px; }
.ak-promo-h{ font-family:var(--font-display); font-weight:600;
  font-size:clamp(26px,3.2vw,40px); line-height:1.12; margin:0; max-width:22ch; }
.ak-promo-lede{ margin-top:16px; max-width:60ch; font-size:clamp(16px,1.5vw,18px);
  line-height:1.55; color:var(--ink); opacity:.85; }
.ak-code{ display:inline-block; font-family:var(--font-mono); text-transform:uppercase;
  letter-spacing:.04em; background:var(--ink); color:var(--paper);
  padding:.08em .42em; border-radius:8px; }

/* ===== Duże ekrany / ultrawide (34" itp.): poszerzenie kontenera ===== */
/* Bazowo --maxw=1240px (bez zmian dla laptopów/tabletów). Na szerokich */
/* monitorach treść dostaje więcej oddechu, by nie wyglądała jak wąska */
/* kolumna w morzu pustego tła. Akapity i nagłówki mają własne limity */
/* w ch/px, więc długość wierszy pozostaje czytelna. */
@media (min-width: 1600px) { :root { --maxw: 1400px; } }
@media (min-width: 2200px) { :root { --maxw: 1560px; } }
