/* ============================================================
   AI-TEAM · Luxury Editorial Design System
   v2.0 · 2026-05-09
   Fonty: Fraunces (display) + Inter (body) + JetBrains Mono (label)
   Paleta: cream #FBF8F1 + ink #1C1917 + copper #B85C2E
============================================================ */

*,*::before,*::after { margin: 0; padding: 0; box-sizing: border-box; }
:root {
  --cream: #FBF8F1; --cream-deep: #F5EFE3; --cream-soft: #FDFAF3;
  --ink: #1C1917; --ink-soft: rgba(28,25,23,0.65); --ink-mute: rgba(28,25,23,0.42);
  --line: rgba(28,25,23,0.1); --line-soft: rgba(28,25,23,0.06);
  --copper: #B85C2E; --copper-soft: rgba(184,92,46,0.08); --copper-deep: #8B4220;
  --brass: #8B6B3D;
}
html { scroll-behavior: smooth; overflow-x: hidden; }
body { background: var(--cream); color: var(--ink); font-family: 'Inter', system-ui, sans-serif; font-size: 16px; line-height: 1.55; -webkit-font-smoothing: antialiased; overflow-x: hidden; max-width: 100vw; }
body.menu-locked { overflow: hidden; height: 100vh; }
img, svg, .hero-image { max-width: 100%; }
::selection { background: var(--copper); color: var(--cream); }
.container { max-width: 1320px; margin: 0 auto; padding: 0 56px; }
.container-narrow { max-width: 880px; margin: 0 auto; padding: 0 56px; }
.display { font-family: 'Fraunces', 'Georgia', serif; font-weight: 400; letter-spacing: -0.018em; line-height: 0.95; color: var(--ink); }
.display em { font-style: italic; font-weight: 300; }
.label-mono { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--copper); font-weight: 600; }
.copper { color: var(--copper); }
.body-lg { font-size: 18px; line-height: 1.6; color: var(--ink-soft); font-weight: 400; }
.body { font-size: 15px; line-height: 1.6; color: var(--ink-soft); }
.body-sm { font-size: 13px; line-height: 1.5; color: var(--ink-mute); }
a { color: inherit; }
.cta-primary { display: inline-flex; align-items: center; gap: 10px; padding: 16px 32px; background: var(--ink); color: var(--cream); font-size: 14px; font-weight: 600; letter-spacing: 0.04em; border: none; cursor: pointer; transition: all 0.2s; text-decoration: none; }
.cta-primary:hover { background: var(--copper); }
.cta-secondary { display: inline-flex; align-items: center; gap: 8px; color: var(--ink); font-size: 14px; font-weight: 500; text-decoration: none; padding-bottom: 4px; border-bottom: 1px solid var(--copper); transition: all 0.2s; cursor: pointer; }
.cta-secondary:hover { color: var(--copper); }
button { font-family: inherit; }
*:focus-visible { outline: 2px solid var(--copper); outline-offset: 3px; }

/* === NAVIGATION (premium editorial) === */
nav.top-nav { position: sticky; top: 0; z-index: 50; background: rgba(251,248,241,0.96); backdrop-filter: blur(24px) saturate(160%); border-bottom: 1px solid var(--line); }
nav.top-nav .inner { display: flex; align-items: center; justify-content: space-between; padding: 18px 56px; gap: 32px; }
.brand { display: flex; align-items: center; gap: 14px; font-family: 'Fraunces', serif; font-weight: 500; font-size: 22px; color: var(--ink); letter-spacing: 0.01em; text-decoration: none; transition: opacity 0.2s; flex-shrink: 0; }
.brand:hover { opacity: 0.75; }
.brand .logo-mark { flex-shrink: 0; transition: transform 0.4s ease; }
.brand:hover .logo-mark { transform: rotate(15deg); }
.brand .wordmark { line-height: 1; letter-spacing: 0.02em; }
.brand em { font-style: italic; font-weight: 400; color: var(--copper); }
.brand .tagline-mini { display: block; font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink-mute); font-weight: 600; margin-top: 4px; }
.menu { display: flex; align-items: center; gap: 4px; }
.menu a { position: relative; font-family: 'Fraunces', serif; font-size: 17px; font-weight: 400; color: var(--ink-soft); text-decoration: none; transition: color 0.25s ease; padding: 8px 18px; letter-spacing: 0.005em; }
.menu a::before { content: '·'; position: absolute; left: -4px; top: 50%; transform: translateY(-50%); color: var(--copper); opacity: 0; transition: opacity 0.25s ease, left 0.25s ease; font-weight: 700; }
.menu a:first-child::before { display: none; }
.menu a::after { content: ''; position: absolute; left: 18px; right: 18px; bottom: 4px; height: 1px; background: var(--copper); transform: scaleX(0); transform-origin: center; transition: transform 0.3s cubic-bezier(0.65, 0, 0.35, 1); }
.menu a:hover { color: var(--ink); }
.menu a:hover::after { transform: scaleX(1); }
.menu a:hover + a::before, .menu a.active + a::before { opacity: 0; }
.menu a.active { color: var(--copper); font-style: italic; }
.menu a.active::after { transform: scaleX(1); background: var(--copper); }
.nav-cta { display: inline-flex; align-items: center; gap: 10px; font-family: 'JetBrains Mono', monospace; font-size: 11px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; padding: 14px 22px 14px 24px; border: 1px solid var(--ink); background: var(--ink); color: var(--cream); cursor: pointer; transition: all 0.3s ease; text-decoration: none; position: relative; overflow: hidden; flex-shrink: 0; }
.nav-cta::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, var(--copper) 0%, var(--copper-deep) 100%); transform: translateX(-101%); transition: transform 0.4s cubic-bezier(0.65, 0, 0.35, 1); z-index: 0; }
.nav-cta:hover { border-color: var(--copper); }
.nav-cta:hover::before { transform: translateX(0); }
.nav-cta span { position: relative; z-index: 1; }
.nav-cta .arrow { transition: transform 0.3s ease; font-family: 'Fraunces', serif; font-style: italic; font-size: 14px; letter-spacing: 0; }
.nav-cta:hover .arrow { transform: translateX(6px); }
@media (max-width: 1280px) { .menu a { font-size: 15px; padding: 8px 12px; } .menu a::after { left: 12px; right: 12px; } }

/* === HAMBURGER (mobile) === */
.hamburger { display: none; background: transparent; border: none; cursor: pointer; padding: 10px; flex-shrink: 0; position: relative; z-index: 110; }
.hamburger-bar { display: block; width: 24px; height: 2px; background: var(--ink); margin: 5px 0; transition: transform 0.3s ease, opacity 0.2s ease; transform-origin: center; }
.hamburger.is-active .hamburger-bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.is-active .hamburger-bar:nth-child(2) { opacity: 0; }
.hamburger.is-active .hamburger-bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 900px) {
  nav.top-nav .inner { padding: 14px 24px; gap: 12px; }
  .brand { font-size: 18px; gap: 10px; }
  .brand .tagline-mini { display: none; }
  .brand .logo-mark { width: 36px; height: 36px; }
  .menu { display: none; flex-direction: column; align-items: stretch; gap: 0; position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: var(--cream); padding: 96px 32px 48px; z-index: 90; overflow-y: auto; }
  .menu.is-open { display: flex; }
  .menu a { font-family: 'Fraunces', serif; font-size: 28px; padding: 18px 0; border-bottom: 1px solid var(--line); }
  .menu a::before, .menu a::after { display: none; }
  .menu a:hover { color: var(--copper); }
  .nav-cta { display: none; }
  .menu.is-open::after { content: 'AI · Team · 2026'; display: block; font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.22em; color: var(--ink-mute); text-align: center; margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--line); }
  .hamburger { display: block; }
}

/* === BREADCRUMBS (subpage) === */
.breadcrumbs { padding: 24px 0; border-bottom: 1px solid var(--line-soft); font-size: 12px; }
.breadcrumbs .container { display: flex; align-items: center; gap: 12px; color: var(--ink-mute); letter-spacing: 0.02em; }
.breadcrumbs a { color: var(--ink-soft); text-decoration: none; transition: color 0.2s; }
.breadcrumbs a:hover { color: var(--copper); }
.breadcrumbs .sep { color: var(--ink-mute); }

/* === HERO (homepage editorial split) === */
section.hero { padding: 60px 0 100px; border-bottom: 1px solid var(--line); }
.hero-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.hero-left h1 { font-size: clamp(56px, 7vw, 96px); margin-bottom: 28px; }
.hero-left .body-lg { margin-bottom: 36px; max-width: 480px; }
.hero-cta-row { display: flex; gap: 28px; align-items: center; flex-wrap: wrap; }
.hero-image { aspect-ratio: 4/5; position: relative; overflow: hidden; }
.hero-image img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }
.hero-image::before { content: ''; position: absolute; inset: 16px; border: 1px solid rgba(255,255,255,0.5); pointer-events: none; z-index: 2; }
.hero-image .photo-label { position: absolute; bottom: 32px; left: 32px; color: rgba(255,255,255,0.85); z-index: 3; mix-blend-mode: difference; }
.hero-trust { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 48px; padding-top: 28px; border-top: 1px solid var(--line); }
.hero-trust .item { display: flex; align-items: baseline; gap: 10px; min-width: 0; }
.hero-trust .num { font-family: 'Fraunces', serif; font-size: 28px; font-weight: 400; color: var(--copper); letter-spacing: -0.02em; line-height: 1; flex-shrink: 0; }
.hero-trust .label { font-size: 11px; color: var(--ink-mute); letter-spacing: 0.04em; line-height: 1.3; }
@media (max-width: 1280px) { .hero-trust { gap: 14px; } .hero-trust .num { font-size: 22px; } .hero-trust .label { font-size: 10px; } }
@media (max-width: 700px) { .hero-trust { grid-template-columns: 1fr; gap: 12px; } }

/* === HERO DAY TRACK (scrollujące karty asystentów AI) === */
.hero-day { background: transparent; overflow: visible; position: relative; aspect-ratio: 4/5; }
.hero-day::before { display: none; }

.day-track { position: relative; height: 100%; overflow: hidden; padding: 16px 4px 4px; }
.day-track-head {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; font-weight: 700; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--cream);
  background: var(--ink);
  padding: 10px 16px;
  border-radius: 999px;
  margin-bottom: 18px;
  box-shadow: 0 6px 20px rgba(28,25,23,0.18);
  position: relative;
  z-index: 6;
}
.day-track-head .day-pulse { background: #4ADE80; box-shadow: 0 0 12px #4ADE80, 0 0 4px #4ADE80; }
.day-track-title { line-height: 1.3; }
.day-pulse {
  width: 8px; height: 8px; border-radius: 50%; background: #2D7A2D;
  box-shadow: 0 0 12px #2D7A2D, 0 0 4px #2D7A2D;
  animation: dayPulse 1.6s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes dayPulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.45; transform: scale(0.8); }
}

.day-track::before, .day-track::after {
  content: ''; position: absolute; left: 0; right: 0; height: 80px; z-index: 5; pointer-events: none;
}
.day-track::before {
  top: 50px;
  background: linear-gradient(180deg, var(--cream) 0%, transparent 100%);
}
.day-track::after {
  bottom: 0;
  background: linear-gradient(0deg, var(--cream) 0%, transparent 100%);
}

.day-scroll {
  display: flex; flex-direction: column; gap: 10px;
  animation: dayScrollAnim 36s linear infinite;
  will-change: transform;
}
.day-scroll:hover { animation-play-state: paused; }
@keyframes dayScrollAnim {
  0% { transform: translateY(0); }
  100% { transform: translateY(-50%); }
}

.day-card {
  background: rgba(184,92,46,0.04);
  border: 1px solid rgba(28,25,23,0.08);
  padding: 14px 16px;
  position: relative;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.day-card:hover {
  background: rgba(184,92,46,0.07);
  border-color: rgba(184,92,46,0.25);
  transform: translateX(-3px);
}

.day-card-head {
  display: flex; align-items: center; gap: 12px; margin-bottom: 8px;
}
.day-card-time {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px; font-weight: 600;
  color: var(--ink); letter-spacing: 0.04em;
  flex-shrink: 0;
}
.day-card-tag {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 3px 8px;
  border: 1px solid currentColor;
}
.tag-copper { color: #B85C2E; background: rgba(184,92,46,0.06); }
.tag-ink { color: #1C1917; background: rgba(28,25,23,0.06); }
.tag-olive { color: #6F7B3F; background: rgba(111,123,63,0.08); }
.tag-rust { color: #A14728; background: rgba(161,71,40,0.08); }
.tag-slate { color: #4B5563; background: rgba(75,85,99,0.06); }
.tag-burgundy { color: #8B2A3A; background: rgba(139,42,58,0.06); }

.day-card-title {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 13px; line-height: 1.45; color: var(--ink);
  margin-bottom: 8px;
}
.day-card-status {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; font-weight: 600;
  letter-spacing: 0.12em; color: var(--ink-mute);
  text-transform: uppercase;
}

/* Active card: live processing */
.day-card.active {
  background: rgba(184,92,46,0.08);
  border-color: rgba(184,92,46,0.3);
  box-shadow: 0 4px 24px rgba(184,92,46,0.1);
}
.day-card.active .day-card-status { color: var(--copper); }
.day-progress {
  height: 2px; background: rgba(184,92,46,0.15);
  margin-top: 10px; overflow: hidden;
}
.day-progress .fill {
  width: 60%; height: 100%; background: var(--copper);
  animation: progressPulse 3s ease-in-out infinite;
}
@keyframes progressPulse {
  0%, 100% { width: 30%; opacity: 0.6; }
  50% { width: 80%; opacity: 1; }
}

@media (prefers-reduced-motion: reduce) {
  .day-scroll, .day-pulse, .day-progress .fill { animation: none; }
}

/* === HERO TYPOGRAPHY (legacy, zachowane dla zgodności) === */
.hero-typo { background: transparent; overflow: visible; position: relative; }
.hero-typo::before { display: none; }
.hero-typo .hero-svg { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 2; }

/* Orbiting text rings */
.hero-typo-orbit-cw { transform-origin: 200px 250px; transform-box: fill-box; animation: heroOrbitCW 70s linear infinite; }
.hero-typo-orbit-ccw { transform-origin: 200px 250px; transform-box: fill-box; animation: heroOrbitCCW 45s linear infinite; }

@keyframes heroOrbitCW { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
@keyframes heroOrbitCCW { from { transform: rotate(0deg); } to { transform: rotate(-360deg); } }

/* Pulse waves expanding from core */
.hero-typo-wave { transform-origin: 200px 250px; transform-box: fill-box; opacity: 0; animation: heroWavePulse 4s cubic-bezier(0.4, 0, 0.2, 1) infinite; }
.hero-typo-wave.w1 { animation-delay: 0s; }
.hero-typo-wave.w2 { animation-delay: 1.4s; }
.hero-typo-wave.w3 { animation-delay: 2.8s; }
@keyframes heroWavePulse {
  0% { transform: scale(0.6); opacity: 0; stroke-width: 2; }
  20% { opacity: 0.55; }
  60% { opacity: 0.15; stroke-width: 0.6; }
  100% { transform: scale(2.6); opacity: 0; stroke-width: 0; }
}

/* Core slowly breathes */
.hero-typo-core { transform-origin: 200px 250px; transform-box: fill-box; animation: heroBreathe 6s ease-in-out infinite alternate; }
@keyframes heroBreathe {
  from { transform: scale(1); }
  to { transform: scale(1.025); }
}

/* Live indicator blink */
.hero-typo-blink { animation: heroBlink 1.6s ease-in-out infinite; filter: drop-shadow(0 0 6px #2D7A2D); }
@keyframes heroBlink {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.35; }
}

/* Decorative brackets fade subtly */
.hero-typo-bracket { animation: heroFadeBracket 5s ease-in-out infinite alternate; }
@keyframes heroFadeBracket {
  from { opacity: 0.35; }
  to { opacity: 0.7; }
}

@media (prefers-reduced-motion: reduce) {
  .hero-typo-orbit-cw, .hero-typo-orbit-ccw, .hero-typo-wave, .hero-typo-core, .hero-typo-blink, .hero-typo-bracket { animation: none; }
}

/* Rotating layers — origin at center 200,250 */
.hero-mandala .mandala-rotate-cw-slow { transform-origin: 200px 250px; transform-box: fill-box; animation: mandalaRotateCW 80s linear infinite; }
.hero-mandala .mandala-rotate-cw { transform-origin: 200px 250px; transform-box: fill-box; animation: mandalaRotateCW 50s linear infinite; }
.hero-mandala .mandala-rotate-cw-fast { transform-origin: 200px 250px; transform-box: fill-box; animation: mandalaRotateCW 30s linear infinite; }
.hero-mandala .mandala-rotate-ccw { transform-origin: 200px 250px; transform-box: fill-box; animation: mandalaRotateCCW 40s linear infinite; }
.hero-mandala .mandala-rotate-ccw-slow { transform-origin: 200px 250px; transform-box: fill-box; animation: mandalaRotateCCW 90s linear infinite; }

/* 12 dots breathing */
.hero-mandala .mandala-12-dots circle { transform-origin: center; transform-box: fill-box; animation: mandalaDotBreathe 3s ease-in-out infinite; filter: drop-shadow(0 0 4px rgba(184,92,46,0.6)); }
.hero-mandala .mandala-12-dots circle:nth-child(2n) { animation-delay: 0.3s; }
.hero-mandala .mandala-12-dots circle:nth-child(3n) { animation-delay: 0.6s; }
.hero-mandala .mandala-12-dots circle:nth-child(4n) { animation-delay: 0.9s; }

/* Role nodes — labels stay readable (counter-rotate inside rotating group) */
.hero-mandala .mandala-role-node circle { animation: mandalaNodePulse 3s ease-in-out infinite; transform-origin: center; transform-box: fill-box; filter: drop-shadow(0 0 8px rgba(184,92,46,0.5)); }
.hero-mandala .mandala-role-node:nth-child(2n) circle { animation-delay: 0.5s; }
.hero-mandala .mandala-role-node:nth-child(3n) circle { animation-delay: 1s; }

/* Pulse waves */
.hero-mandala .mandala-pulse-waves circle { transform-origin: 200px 250px; transform-box: fill-box; opacity: 0; }
.hero-mandala .m-wave-1 { animation: mandalaWaveExpand 5s ease-out infinite; }
.hero-mandala .m-wave-2 { animation: mandalaWaveExpand 5s ease-out infinite; animation-delay: 1.7s; }
.hero-mandala .m-wave-3 { animation: mandalaWaveExpand 5s ease-out infinite; animation-delay: 3.3s; }

/* Central core */
.hero-mandala .mandala-core circle:nth-child(2) { transform-origin: 200px 250px; transform-box: fill-box; animation: mandalaCorePulse 4s ease-in-out infinite; }
.hero-mandala .mandala-core circle:nth-child(3) { transform-origin: 200px 250px; transform-box: fill-box; animation: mandalaCoreRing 4s ease-in-out infinite; }
.hero-mandala .mandala-core circle:nth-child(4) { transform-origin: 200px 250px; transform-box: fill-box; animation: mandalaCoreSpin 30s linear infinite; }
.hero-mandala .mandala-core text:first-of-type { transform-origin: 200px 250px; transform-box: fill-box; animation: mandalaCoreBreathe 4s ease-in-out infinite; }

/* Hexagram outer */
.hero-mandala .mandala-hex polygon { animation: mandalaHexBreathe 6s ease-in-out infinite; transform-origin: 200px 250px; transform-box: fill-box; }
.hero-mandala .mandala-hex polygon:nth-child(2) { animation-delay: 1s; }

@keyframes mandalaRotateCW { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
@keyframes mandalaRotateCCW { from { transform: rotate(0deg); } to { transform: rotate(-360deg); } }
@keyframes mandalaDotBreathe { 0%, 100% { opacity: 0.8; transform: scale(1); } 50% { opacity: 1; transform: scale(1.6); } }
@keyframes mandalaNodePulse { 0%, 100% { opacity: 0.9; transform: scale(1); } 50% { opacity: 1; transform: scale(1.12); } }
@keyframes mandalaWaveExpand { 0% { r: 35; opacity: 0.7; stroke-width: 2; } 100% { r: 230; opacity: 0; stroke-width: 0.4; } }
@keyframes mandalaCorePulse { 0%, 100% { opacity: 0.55; transform: scale(0.95); } 50% { opacity: 1; transform: scale(1.1); } }
@keyframes mandalaCoreRing { 0%, 100% { opacity: 0.7; transform: scale(1); } 50% { opacity: 1; transform: scale(1.18); } }
@keyframes mandalaCoreSpin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
@keyframes mandalaCoreBreathe { 0%, 100% { opacity: 0.95; } 50% { opacity: 1; } }
@keyframes mandalaHexBreathe { 0%, 100% { opacity: 0.4; } 50% { opacity: 0.85; } }
@keyframes mandalaMesh { 0% { transform: translate(-3%, -2%) rotate(0deg) scale(1); } 100% { transform: translate(5%, 4%) rotate(30deg) scale(1.2); } }
@keyframes mandalaPing { 0%, 100% { opacity: 1; transform: scale(1); } 50% { opacity: 0.5; transform: scale(1.6); } }

@media (prefers-reduced-motion: reduce) {
  .hero-mandala .hero-mesh, .hero-mandala [class*="mandala-rotate"], .hero-mandala .mandala-12-dots circle, .hero-mandala .mandala-role-node circle, .hero-mandala .mandala-pulse-waves circle, .hero-mandala .mandala-core circle, .hero-mandala .mandala-core text, .hero-mandala .mandala-hex polygon, .hero-mandala .hero-corner-mark::before, .hero-mandala .mandala-particles circle { animation: none !important; }
}

/* === HERO PULSE (legacy — zachowane dla compat) === */
.hero-pulse { background: linear-gradient(140deg, #FBF8F1 0%, #F5EFE3 55%, #E8DDC9 100%); }
.hero-pulse::before { display: none; }
.hero-pulse .hero-mesh { position: absolute; inset: -20%; z-index: 1; opacity: 1; background: radial-gradient(ellipse 50% 40% at 50% 50%, rgba(184,92,46,0.4) 0%, transparent 60%), radial-gradient(ellipse 40% 35% at 25% 30%, rgba(212,184,150,0.45) 0%, transparent 55%); animation: heroPulseMesh 16s ease-in-out infinite alternate; filter: blur(12px); }
.hero-pulse .hero-svg { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 2; }
.hero-pulse .pulse-waves circle { transform-origin: 200px 250px; transform-box: fill-box; }
.hero-pulse .pulse-wave-1 { animation: heroPulseExpand 4.5s ease-out infinite; }
.hero-pulse .pulse-wave-2 { animation: heroPulseExpand 4.5s ease-out infinite; animation-delay: 1.1s; }
.hero-pulse .pulse-wave-3 { animation: heroPulseExpand 4.5s ease-out infinite; animation-delay: 2.2s; }
.hero-pulse .pulse-wave-4 { animation: heroPulseExpand 4.5s ease-out infinite; animation-delay: 3.3s; }
.hero-pulse .pulse-rays line { animation: heroRayFlow 6s linear infinite; }
.hero-pulse .pulse-nodes .pulse-node circle { transform-origin: center; transform-box: fill-box; animation: heroNodePulse 3s ease-in-out infinite; filter: drop-shadow(0 0 6px rgba(184,92,46,0.65)); }
.hero-pulse .pulse-nodes .pulse-node:nth-child(2n) circle { animation-delay: 0.4s; }
.hero-pulse .pulse-nodes .pulse-node:nth-child(3n) circle { animation-delay: 0.9s; }
.hero-pulse .pulse-nodes .pulse-node:nth-child(5n) circle { animation-delay: 1.4s; }
.hero-pulse .pulse-nodes .pulse-node text { paint-order: stroke; stroke: #FBF8F1; stroke-width: 4px; stroke-linejoin: round; animation: heroLabelFade 4s ease-in-out infinite; }
.hero-pulse .pulse-nodes .pulse-node:nth-child(2n) text { animation-delay: 1s; }
.hero-pulse .pulse-nodes .pulse-node:nth-child(3n) text { animation-delay: 2s; }
.hero-pulse .pulse-center circle:nth-child(2) { transform-origin: 200px 250px; transform-box: fill-box; animation: heroCenterPulse 3s ease-in-out infinite; }
.hero-pulse .pulse-center circle:nth-child(3) { transform-origin: 200px 250px; transform-box: fill-box; animation: heroCenterRing 3s ease-in-out infinite; }
.hero-pulse .pulse-center text:first-of-type { animation: heroCenterTextBreathe 4s ease-in-out infinite; transform-origin: 200px 250px; transform-box: fill-box; }
.hero-pulse .hero-corner-mark { position: absolute; bottom: 24px; left: 24px; z-index: 4; display: flex; align-items: center; gap: 8px; }
.hero-pulse .hero-corner-mark::before { content: ''; width: 8px; height: 8px; border-radius: 50%; background: #2D7A2D; box-shadow: 0 0 12px #2D7A2D, 0 0 4px #2D7A2D; animation: heroPing 1.4s ease-in-out infinite; }

@keyframes heroPulseExpand { 0% { r: 30; opacity: 0.9; stroke-width: 2.5; } 100% { r: 220; opacity: 0; stroke-width: 0.5; } }
@keyframes heroPulseMesh { 0% { transform: translate(-3%, -2%) scale(1); } 50% { transform: translate(5%, 4%) scale(1.15); } 100% { transform: translate(-2%, 6%) scale(1.05); } }
@keyframes heroRayFlow { 0% { stroke-dashoffset: 0; } 100% { stroke-dashoffset: -36; } }
@keyframes heroNodePulse { 0%, 100% { opacity: 0.85; transform: scale(1); } 50% { opacity: 1; transform: scale(1.5); } }
@keyframes heroLabelFade { 0%, 100% { opacity: 0.7; } 50% { opacity: 1; } }
@keyframes heroCenterPulse { 0%, 100% { opacity: 0.5; transform: scale(0.95); } 50% { opacity: 1; transform: scale(1.1); } }
@keyframes heroCenterRing { 0%, 100% { opacity: 0.7; transform: scale(1); } 50% { opacity: 1; transform: scale(1.15); } }
@keyframes heroCenterTextBreathe { 0%, 100% { opacity: 0.95; } 50% { opacity: 1; } }
@keyframes heroPing { 0%, 100% { opacity: 1; transform: scale(1); } 50% { opacity: 0.5; transform: scale(1.6); } }

@media (prefers-reduced-motion: reduce) {
  .hero-pulse .hero-mesh, .hero-pulse .pulse-waves circle, .hero-pulse .pulse-rays line, .hero-pulse .pulse-particles circle, .hero-pulse .pulse-nodes circle, .hero-pulse .pulse-nodes text, .hero-pulse .pulse-center circle, .hero-pulse .pulse-center text, .hero-pulse .hero-corner-mark::before { animation: none !important; }
}

/* Stara wersja constellation (zachowana dla compatibility) */
.hero-network { background: linear-gradient(140deg, #FBF8F1 0%, #F5EFE3 50%, #E8DDC9 100%); }
.hero-network::before { display: none; }
.hero-network .hero-mesh { position: absolute; inset: -20%; z-index: 1; opacity: 1; background: radial-gradient(ellipse 50% 40% at 25% 30%, rgba(184,92,46,0.45) 0%, transparent 55%), radial-gradient(ellipse 45% 50% at 75% 70%, rgba(139,107,61,0.4) 0%, transparent 55%), radial-gradient(ellipse 30% 30% at 60% 25%, rgba(212,184,150,0.5) 0%, transparent 55%); animation: heroMeshDrift 14s ease-in-out infinite alternate; filter: blur(10px); }
.hero-network .hero-svg { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 2; }
.hero-network .hero-svg .lines line { stroke-dasharray: 8 6; animation: heroLineFlow 4s linear infinite; }
.hero-network .hero-svg .halos circle { animation: heroHaloPulse 3s ease-in-out infinite; transform-origin: center; transform-box: fill-box; }
.hero-network .hero-svg .halos circle:nth-child(1) { animation-delay: 0s; }
.hero-network .hero-svg .halos circle:nth-child(2) { animation-delay: 0.6s; }
.hero-network .hero-svg .halos circle:nth-child(3) { animation-delay: 1.2s; }
.hero-network .hero-svg .halos circle:nth-child(4) { animation-delay: 1.8s; }
.hero-network .hero-svg .halos circle:nth-child(5) { animation-delay: 2.4s; }
.hero-network .hero-svg .dots circle { transform-origin: center; transform-box: fill-box; animation: heroDotPulse 2.4s ease-in-out infinite; filter: drop-shadow(0 0 6px rgba(184,92,46,0.6)); }
.hero-network .hero-svg .dots circle:nth-child(1) { animation: heroDotDrift1 6s ease-in-out infinite, heroDotPulse 2.4s ease-in-out infinite; }
.hero-network .hero-svg .dots circle:nth-child(2) { animation: heroDotDrift2 7s ease-in-out infinite, heroDotPulse 2.4s ease-in-out infinite; animation-delay: 0.5s; }
.hero-network .hero-svg .dots circle:nth-child(3) { animation: heroDotDrift1 8s ease-in-out infinite reverse, heroDotPulse 2.4s ease-in-out infinite; animation-delay: 1s; }
.hero-network .hero-svg .dots circle:nth-child(4) { animation: heroDotDrift2 6.5s ease-in-out infinite reverse, heroDotPulse 2.4s ease-in-out infinite; animation-delay: 1.5s; }
.hero-network .hero-svg .dots circle:nth-child(5) { animation: heroDotPulseStrong 3s ease-in-out infinite; animation-delay: 0.3s; }
.hero-network .hero-svg .dots circle:nth-child(6) { animation: heroDotDrift1 7.5s ease-in-out infinite, heroDotPulse 2.4s ease-in-out infinite; animation-delay: 0.8s; }
.hero-network .hero-svg .dots circle:nth-child(7) { animation: heroDotDrift2 9s ease-in-out infinite, heroDotPulse 2.4s ease-in-out infinite; animation-delay: 1.3s; }
.hero-network .hero-svg .dots circle:nth-child(8) { animation: heroDotDrift1 6.8s ease-in-out infinite reverse, heroDotPulse 2.4s ease-in-out infinite; animation-delay: 1.8s; }
.hero-network .hero-svg .dots circle:nth-child(9) { animation: heroDotDrift2 8.5s ease-in-out infinite reverse, heroDotPulse 2.4s ease-in-out infinite; animation-delay: 0.6s; }
.hero-network .hero-svg .labels text { animation: heroLabelFade 4s ease-in-out infinite; paint-order: stroke; stroke: #FBF8F1; stroke-width: 4px; stroke-linejoin: round; }
.hero-network .hero-svg .labels text:nth-child(2n) { animation-delay: 1s; }
.hero-network .hero-svg .labels text:nth-child(3n) { animation-delay: 2s; }
.hero-network .hero-svg .packets circle { fill: #B85C2E; filter: drop-shadow(0 0 8px #B85C2E); }
.hero-network .hero-corner-mark { position: absolute; bottom: 24px; left: 24px; z-index: 4; display: flex; align-items: center; gap: 8px; }
.hero-network .hero-corner-mark::before { content: ''; width: 8px; height: 8px; border-radius: 50%; background: #2D7A2D; box-shadow: 0 0 12px #2D7A2D, 0 0 4px #2D7A2D; animation: heroPing 1.4s ease-in-out infinite; }

@keyframes heroMeshDrift {
  0% { transform: translate(-5%, -3%) rotate(0deg) scale(1); }
  50% { transform: translate(8%, 6%) rotate(20deg) scale(1.15); }
  100% { transform: translate(-3%, 8%) rotate(-10deg) scale(1.05); }
}
@keyframes heroLineFlow { 0% { stroke-dashoffset: 0; } 100% { stroke-dashoffset: -56; } }
@keyframes heroHaloPulse { 0%, 100% { opacity: 0.3; transform: scale(0.7); } 50% { opacity: 1; transform: scale(1.5); } }
@keyframes heroDotPulse { 0%, 100% { opacity: 0.85; transform: scale(1); } 50% { opacity: 1; transform: scale(1.6); } }
@keyframes heroDotPulseStrong { 0%, 100% { opacity: 0.9; transform: scale(1); } 50% { opacity: 1; transform: scale(1.8); } }
@keyframes heroDotDrift1 { 0%, 100% { translate: 0 0; } 50% { translate: 8px -6px; } }
@keyframes heroDotDrift2 { 0%, 100% { translate: 0 0; } 50% { translate: -6px 8px; } }
@keyframes heroLabelFade { 0%, 100% { opacity: 0.7; } 50% { opacity: 1; } }
@keyframes heroPing { 0%, 100% { opacity: 1; transform: scale(1); } 50% { opacity: 0.5; transform: scale(1.6); } }

@media (prefers-reduced-motion: reduce) {
  .hero-network .hero-mesh, .hero-network .hero-svg .lines line, .hero-network .hero-svg .halos circle, .hero-network .hero-svg .dots circle, .hero-network .hero-svg .labels text, .hero-network .hero-svg .packets circle, .hero-network .hero-corner-mark::before { animation: none !important; }
}

/* === CASE STUDY MOCKUP CRM === */
.case-mockup { background: linear-gradient(135deg, #1C1917 0%, #3A2814 100%); padding: 32px; display: flex; align-items: center; justify-content: center; }
.case-mockup::before { display: none; }
.case-image-tag { position: absolute; bottom: 16px; left: 24px; z-index: 5; color: rgba(251,248,241,0.6); }
.crm-window { width: 100%; height: 100%; background: #FBF8F1; border-radius: 8px; box-shadow: 0 24px 60px rgba(0,0,0,0.4), 0 8px 16px rgba(0,0,0,0.2); overflow: hidden; display: flex; flex-direction: column; }
.crm-titlebar { display: flex; align-items: center; gap: 8px; padding: 10px 14px; background: #F5EFE3; border-bottom: 1px solid rgba(28,25,23,0.08); }
.crm-dot { width: 10px; height: 10px; border-radius: 50%; }
.crm-url { margin-left: 16px; font-family: 'JetBrains Mono', monospace; font-size: 10px; color: rgba(28,25,23,0.5); letter-spacing: 0.04em; }
.crm-app { display: grid; grid-template-columns: 130px 1fr; flex: 1; min-height: 0; }
.crm-sidebar { background: #1C1917; color: #FBF8F1; padding: 18px 14px; display: flex; flex-direction: column; }
.crm-brand { font-family: 'Fraunces', serif; font-size: 16px; font-weight: 500; margin-bottom: 24px; letter-spacing: 0.02em; }
.crm-brand em { font-style: italic; font-weight: 300; color: #B85C2E; font-size: 11px; margin-left: 4px; }
.crm-nav { display: flex; flex-direction: column; gap: 4px; flex: 1; }
.crm-nav a { font-size: 11px; padding: 7px 10px; color: rgba(251,248,241,0.6); border-radius: 4px; text-decoration: none; letter-spacing: 0.01em; transition: all 0.2s; cursor: pointer; }
.crm-nav a:hover { color: #FBF8F1; background: rgba(184,92,46,0.15); }
.crm-nav a.crm-active { color: #FBF8F1; background: rgba(184,92,46,0.25); border-left: 2px solid #B85C2E; padding-left: 8px; }
.crm-side-foot { padding-top: 12px; border-top: 1px solid rgba(251,248,241,0.1); }
.crm-side-foot .label-mono { font-size: 8px; letter-spacing: 0.18em; color: rgba(184,92,46,0.8); }
.crm-main { padding: 18px; background: #FBF8F1; overflow: hidden; display: flex; flex-direction: column; gap: 14px; }
.crm-stats { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }
.crm-stat { background: #F5EFE3; padding: 10px 12px; border-radius: 4px; display: flex; flex-direction: column; gap: 4px; }
.crm-stat-num { font-family: 'Fraunces', serif; font-size: 22px; font-weight: 400; color: #B85C2E; line-height: 1; }
.crm-stat-label { font-size: 9px; color: rgba(28,25,23,0.5); letter-spacing: 0.04em; text-transform: uppercase; }
.crm-table { background: #fff; border: 1px solid rgba(28,25,23,0.06); border-radius: 4px; overflow: hidden; flex: 1; min-height: 0; }
.crm-tr { display: grid; grid-template-columns: 1.4fr 1.2fr 1fr 1fr; gap: 8px; padding: 9px 12px; border-bottom: 1px solid rgba(28,25,23,0.05); align-items: center; }
.crm-tr:last-child { border-bottom: none; }
.crm-th { background: #F5EFE3; font-size: 9px; color: rgba(28,25,23,0.5); letter-spacing: 0.06em; text-transform: uppercase; font-weight: 600; padding: 8px 12px; }
.crm-pill { height: 14px; background: rgba(184,92,46,0.12); border-radius: 999px; }
.crm-bar { height: 8px; background: rgba(28,25,23,0.08); border-radius: 4px; }
.crm-bar.w-30 { width: 30%; }
.crm-bar.w-40 { width: 40%; }
.crm-bar.w-50 { width: 50%; }
.crm-bar.w-60 { width: 60%; }
.crm-bar.w-70 { width: 70%; }
.crm-bar.w-80 { width: 80%; }
.crm-foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding-top: 4px; }
.crm-foot .crm-bar { flex: 1; max-width: 120px; }
.crm-action { font-size: 10px; padding: 7px 14px; background: #1C1917; color: #FBF8F1; border-radius: 4px; letter-spacing: 0.04em; font-weight: 600; }

/* === HERO PAGE (subpage centered) === */
section.hero-page { padding: 80px 0 100px; border-bottom: 1px solid var(--line); text-align: center; }
.hero-page .label-mono { display: block; margin-bottom: 28px; }
.hero-page h1 { font-family: 'Fraunces', serif; font-weight: 400; font-size: clamp(48px, 6vw, 96px); line-height: 0.98; letter-spacing: -0.018em; max-width: 980px; margin: 0 auto 32px; }
.hero-page h1 em { font-style: italic; font-weight: 300; color: var(--copper); }
.hero-page .body-lg { max-width: 680px; margin: 0 auto 40px; }
.hero-page .hero-cta-row { justify-content: center; }

/* === MANIFEST === */
section.manifest { padding: 120px 0; text-align: center; background: var(--cream-deep); border-bottom: 1px solid var(--line); }
.manifest .label-mono { margin-bottom: 32px; display: block; }
.manifest h2 { font-family: 'Fraunces', serif; font-weight: 400; font-size: clamp(32px, 4.5vw, 56px); line-height: 1.18; letter-spacing: -0.01em; max-width: 920px; margin: 0 auto; }
.manifest h2 em { font-style: italic; font-weight: 300; color: var(--copper); }

/* === ENGINE: ChatGPT vs Asystent === */
section.engine { padding: 120px 0; border-bottom: 1px solid var(--line); }
.engine-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; max-width: 1200px; margin: 0 auto; }
.engine-text .label-mono { display: block; margin-bottom: 24px; }
.engine-text h2 { font-family: 'Fraunces', serif; font-weight: 400; font-size: clamp(32px, 3.6vw, 48px); line-height: 1.1; letter-spacing: -0.018em; margin-bottom: 32px; }
.engine-text h2 em { font-style: italic; font-weight: 300; color: var(--copper); }
.engine-text .body-lg { margin-bottom: 20px; line-height: 1.6; }
.engine-text .body-lg strong { color: var(--ink); font-weight: 600; }
.engine-compare { display: flex; flex-direction: column; gap: 16px; }
.engine-card { padding: 28px 32px; border: 1px solid var(--line); }
.engine-card.cold { background: rgba(28,25,23,0.02); }
.engine-card.warm { background: rgba(184,92,46,0.05); border-color: rgba(184,92,46,0.3); }
.engine-card .label-mono { display: block; margin-bottom: 12px; font-size: 10px; }
.engine-card.cold .label-mono { color: var(--ink-mute); }
.engine-card.warm .label-mono { color: var(--copper); }
.engine-card h4 { font-family: 'Fraunces', serif; font-weight: 500; font-size: 22px; margin-bottom: 16px; line-height: 1.2; }
.engine-card.cold h4 { color: var(--ink-mute); }
.engine-card.warm h4 { color: var(--ink); }
.engine-card ul { list-style: none; padding: 0; margin: 0; }
.engine-card li { font-size: 14px; line-height: 1.6; padding-left: 18px; position: relative; margin-bottom: 6px; }
.engine-card.cold li { color: var(--ink-mute); }
.engine-card.cold li::before { content: '·'; position: absolute; left: 4px; color: var(--ink-mute); }
.engine-card.warm li::before { content: '✓'; position: absolute; left: 0; color: var(--copper); font-weight: 600; }
@media (max-width: 900px) {
  .engine-grid { grid-template-columns: 1fr; gap: 48px; }
  section.engine { padding: 80px 0; }
}

/* === SECTION HEAD (universal) === */
.section-head { text-align: center; margin-bottom: 80px; }
.section-head .label-mono { display: block; margin-bottom: 18px; }
.section-head h2 { font-family: 'Fraunces', serif; font-weight: 400; font-size: clamp(40px, 5vw, 68px); letter-spacing: -0.018em; line-height: 1.05; max-width: 760px; margin: 0 auto 16px; }
.section-head h2 em { font-style: italic; font-weight: 300; color: var(--copper); }
.section-head .body-lg { max-width: 620px; margin: 0 auto; }

/* === QUIZ === */
section.quiz { padding: 140px 0; border-bottom: 1px solid var(--line); }
.quiz-card { background: var(--ink); color: var(--cream); padding: 80px 64px; max-width: 980px; margin: 0 auto; position: relative; overflow: hidden; }
.quiz-card::before { content: ''; position: absolute; inset: 16px; border: 1px solid rgba(251,248,241,0.15); pointer-events: none; }
.quiz-card .label-mono { color: var(--copper); margin-bottom: 24px; display: block; }
.quiz-card h3 { font-family: 'Fraunces', serif; font-size: 36px; font-weight: 400; line-height: 1.15; margin-bottom: 16px; letter-spacing: -0.01em; }
.quiz-card p { color: rgba(251,248,241,0.7); margin-bottom: 32px; max-width: 560px; }
.quiz-questions { display: grid; grid-template-columns: repeat(5, 1fr); gap: 0; margin: 48px 0; padding: 24px 0; border-top: 1px solid rgba(251,248,241,0.1); border-bottom: 1px solid rgba(251,248,241,0.1); }
.quiz-q { padding: 16px 8px; border-right: 1px solid rgba(251,248,241,0.1); text-align: center; }
.quiz-q:last-child { border-right: none; }
.quiz-q .num { font-family: 'Fraunces', serif; font-style: italic; font-size: 14px; color: var(--copper); margin-bottom: 8px; display: block; }
.quiz-q .text { font-size: 12px; line-height: 1.4; color: rgba(251,248,241,0.85); }
.quiz-card .cta-primary { background: var(--cream); color: var(--ink); }
.quiz-card .cta-primary:hover { background: var(--copper); color: var(--cream); }

/* === QUIZ WIZARD (interaktywny) === */
.quiz-progress { margin-bottom: 56px; position: relative; z-index: 2; }
.quiz-progress-bar { height: 2px; background: var(--copper); transition: width 0.5s cubic-bezier(0.4, 0, 0.2, 1); border-radius: 2px; }
.quiz-progress-label { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.18em; color: rgba(251,248,241,0.5); text-transform: uppercase; margin-top: 12px; }

.quiz-step { display: none; animation: quizStepIn 0.5s cubic-bezier(0.4, 0, 0.2, 1); position: relative; z-index: 2; }
.quiz-step.is-active { display: block; }
@keyframes quizStepIn {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

.quiz-options { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 36px; }
.quiz-options.grid-2 { grid-template-columns: 1fr 1fr; }
.quiz-opt {
  background: rgba(251,248,241,0.04);
  border: 1px solid rgba(251,248,241,0.15);
  color: var(--cream);
  padding: 22px 24px;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 16px;
  font-weight: 500;
  text-align: left;
  cursor: pointer;
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  border-radius: 0;
}
.quiz-opt:hover { background: rgba(184,92,46,0.12); border-color: var(--copper); transform: translateX(4px); }
.quiz-opt.is-selected { background: var(--copper); border-color: var(--copper); color: var(--cream); transform: translateX(4px); }
@media (max-width: 700px) {
  .quiz-options, .quiz-options.grid-2 { grid-template-columns: 1fr; }
  .quiz-opt:hover, .quiz-opt.is-selected { transform: none; }
}

.quiz-slider-wrap { margin-top: 36px; padding: 32px; background: rgba(251,248,241,0.04); border: 1px solid rgba(251,248,241,0.1); }
.quiz-slider-value { font-family: 'Fraunces', serif; font-size: 56px; font-weight: 400; color: var(--copper); margin-bottom: 24px; line-height: 1; letter-spacing: -0.02em; }
.quiz-slider-value .unit { font-size: 18px; color: rgba(251,248,241,0.6); margin-left: 8px; font-style: italic; font-family: 'Fraunces', serif; }
.quiz-slider {
  -webkit-appearance: none; appearance: none;
  width: 100%; height: 4px;
  background: rgba(251,248,241,0.12);
  outline: none;
  cursor: pointer;
}
.quiz-slider::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 24px; height: 24px;
  background: var(--copper);
  border-radius: 50%;
  cursor: pointer;
  box-shadow: 0 0 0 6px rgba(184,92,46,0.2);
  transition: box-shadow 0.2s;
}
.quiz-slider::-webkit-slider-thumb:hover { box-shadow: 0 0 0 10px rgba(184,92,46,0.3); }
.quiz-slider::-moz-range-thumb {
  width: 24px; height: 24px;
  background: var(--copper);
  border-radius: 50%; border: none;
  cursor: pointer;
  box-shadow: 0 0 0 6px rgba(184,92,46,0.2);
}
.quiz-slider-scale { display: flex; justify-content: space-between; margin-top: 16px; font-family: 'JetBrains Mono', monospace; font-size: 11px; color: rgba(251,248,241,0.4); letter-spacing: 0.1em; }

.quiz-nav { display: flex; justify-content: space-between; align-items: center; margin-top: 56px; padding-top: 32px; border-top: 1px solid rgba(251,248,241,0.1); position: relative; z-index: 2; }
.quiz-back, .quiz-restart {
  background: transparent; color: rgba(251,248,241,0.5); border: none;
  font-family: 'JetBrains Mono', monospace; font-size: 12px; letter-spacing: 0.12em;
  text-transform: uppercase; cursor: pointer; padding: 12px 0;
  transition: color 0.2s;
}
.quiz-back:hover:not(:disabled), .quiz-restart:hover { color: var(--cream); }
.quiz-back:disabled { opacity: 0.3; cursor: not-allowed; }
.quiz-next { padding: 18px 36px; font-size: 14px; }

/* WYNIK */
.quiz-result h3 { font-size: 44px; line-height: 1.1; margin-bottom: 24px; }
.quiz-result .quiz-money { color: var(--copper); font-style: italic; }
.quiz-result-yearly { font-size: 18px; line-height: 1.5; max-width: 600px; }
.quiz-result-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin: 48px 0; padding: 32px 0; border-top: 1px solid rgba(251,248,241,0.1); border-bottom: 1px solid rgba(251,248,241,0.1); }
.quiz-result-stat { text-align: center; }
.quiz-result-stat .num { font-family: 'Fraunces', serif; font-size: 64px; font-weight: 400; color: var(--copper); display: block; line-height: 1; letter-spacing: -0.02em; margin-bottom: 8px; }
.quiz-result-stat .label { font-size: 13px; color: rgba(251,248,241,0.6); line-height: 1.4; }

.quiz-recommend { background: rgba(184,92,46,0.08); border: 1px solid rgba(184,92,46,0.3); padding: 32px; margin-top: 48px; }
.quiz-recommend .label-mono { color: var(--copper); margin-bottom: 16px; }
.quiz-recommend h4 { font-family: 'Fraunces', serif; font-size: 28px; font-weight: 400; line-height: 1.2; margin-bottom: 12px; }
.quiz-recommend p { font-size: 15px; line-height: 1.6; max-width: none; margin-bottom: 24px; }
.quiz-recommend-meta { display: flex; gap: 24px; align-items: baseline; flex-wrap: wrap; margin-bottom: 24px; }
.quiz-recommend-price { font-family: 'Fraunces', serif; font-size: 36px; font-style: italic; color: var(--copper); }
.quiz-recommend-roi { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(251,248,241,0.6); }
.quiz-restart { margin: 32px auto 0; display: block; }

@media (max-width: 700px) {
  .quiz-card { padding: 48px 24px; }
  .quiz-card h3 { font-size: 26px; }
  .quiz-slider-value { font-size: 40px; }
  .quiz-result h3 { font-size: 30px; }
  .quiz-result-grid { grid-template-columns: 1fr; gap: 16px; }
  .quiz-result-stat .num { font-size: 48px; }
  .quiz-recommend-price { font-size: 28px; }
  .quiz-nav { flex-direction: column-reverse; gap: 16px; align-items: stretch; }
  .quiz-next { width: 100%; }
}

/* === PROBLEMS (Brzmi znajomo) === */
section.problems { padding: 140px 0; background: var(--cream-deep); border-bottom: 1px solid var(--line); }
.problems-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 32px; max-width: 1100px; margin: 0 auto; }
.problem-card { padding: 40px; background: var(--cream); border: 1px solid var(--line); position: relative; transition: all 0.2s; }
.problem-card:hover { border-color: var(--copper); }
.problem-card .quote { font-family: 'Fraunces', serif; font-size: 26px; font-weight: 400; line-height: 1.25; letter-spacing: -0.01em; margin-bottom: 18px; color: var(--ink); position: relative; padding-left: 8px; }
.problem-card .reply { font-size: 14px; color: var(--ink-soft); padding-top: 20px; border-top: 1px solid var(--line); }
.problem-card .reply strong { color: var(--copper); font-weight: 600; }

/* === PATHS (3 ścieżki) === */
section.paths { padding: 140px 0; border-bottom: 1px solid var(--line); }
.paths-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.path-card { border: 1px solid var(--line); padding: 56px 40px; transition: all 0.3s; cursor: pointer; text-decoration: none; color: inherit; display: flex; flex-direction: column; background: var(--cream-soft); }
.path-card:hover { border-color: var(--copper); transform: translateY(-4px); box-shadow: 0 24px 48px rgba(0,0,0,0.06); }
.path-card .num { font-family: 'Fraunces', serif; font-weight: 300; font-style: italic; font-size: 64px; color: var(--copper); margin-bottom: 32px; line-height: 1; }
.path-card h3 { font-family: 'Fraunces', serif; font-weight: 400; font-size: 32px; margin-bottom: 18px; letter-spacing: -0.01em; }
.path-card .body { margin-bottom: 32px; flex: 1; }
.path-card ul { list-style: none; margin-bottom: 32px; }
.path-card ul li { font-size: 13px; color: var(--ink-soft); padding: 6px 0 6px 20px; position: relative; line-height: 1.4; }
.path-card ul li::before { content: '→'; position: absolute; left: 0; color: var(--copper); font-weight: 400; }
.path-card .arrow { font-size: 13px; color: var(--copper); font-weight: 600; letter-spacing: 0.04em; }

/* === FULL OFFER (cennik z 21 produktów) === */
section.full-offer { padding: 140px 0; background: var(--cream-deep); border-bottom: 1px solid var(--line); }
.offer-group { margin-bottom: 80px; }
.offer-group:last-child { margin-bottom: 0; }
.offer-group-head { display: flex; align-items: baseline; justify-content: space-between; padding: 24px 0; margin-bottom: 32px; border-bottom: 1px solid var(--copper); flex-wrap: wrap; gap: 16px; }
.offer-group-head h3 { font-family: 'Fraunces', serif; font-weight: 400; font-size: 36px; letter-spacing: -0.012em; line-height: 1.1; }
.offer-group-head h3 em { font-style: italic; font-weight: 300; color: var(--copper); }
.offer-group-head .meta { font-size: 13px; color: var(--ink-mute); letter-spacing: 0.04em; }
.offer-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.offer-grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.offer-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.offer-item { background: var(--cream); padding: 36px 28px; border: 1px solid var(--line); display: flex; flex-direction: column; transition: all 0.2s; position: relative; text-decoration: none; color: inherit; }
.offer-item:hover { border-color: var(--copper); }
.offer-item .price { font-family: 'Fraunces', serif; font-weight: 400; font-size: 32px; line-height: 1; letter-spacing: -0.02em; margin-bottom: 4px; color: var(--ink); }
.offer-item .price .unit { font-size: 14px; color: var(--copper); margin-left: 4px; font-weight: 500; }
.offer-item .price-meta { font-size: 12px; color: var(--ink-mute); margin-bottom: 24px; letter-spacing: 0.02em; text-transform: uppercase; }
.offer-item h4 { font-family: 'Fraunces', serif; font-weight: 400; font-size: 22px; margin-bottom: 12px; letter-spacing: -0.005em; line-height: 1.2; }
.offer-item .body-sm { margin-bottom: 24px; flex: 1; }
.offer-item .item-cta { font-size: 12px; color: var(--copper); font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; padding-top: 16px; border-top: 1px solid var(--line); }
.offer-item .contact-note { margin-top: 8px; font-size: 13px; color: var(--ink-mute); font-weight: 500; }
.offer-item.featured { border-color: var(--ink); }
.offer-item.featured::before { content: '★'; position: absolute; top: -10px; right: 16px; background: var(--copper); color: var(--cream); width: 28px; height: 28px; display: flex; align-items: center; justify-content: center; font-size: 14px; }
.offer-status { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; padding: 4px 10px; background: var(--copper-soft); color: var(--copper); display: inline-block; margin-bottom: 16px; font-weight: 600; }
.offer-status.live { background: rgba(34,139,34,0.08); color: #2D7A2D; }
.offer-status.soon { background: rgba(184,92,46,0.08); color: var(--copper); }
.offer-status.free { background: rgba(28,25,23,0.05); color: var(--ink-soft); }

/* === CASE STUDY === */
section.case-study { padding: 140px 0; border-bottom: 1px solid var(--line); }
.case-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.case-image { aspect-ratio: 4/3; position: relative; overflow: hidden; background: var(--cream-deep); }
.case-image img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }
.case-image::before { content: ''; position: absolute; inset: 16px; border: 1px solid rgba(255,255,255,0.5); z-index: 2; pointer-events: none; }
.case-text .label-mono { margin-bottom: 24px; display: block; }
.case-text h2 { font-family: 'Fraunces', serif; font-weight: 400; font-size: clamp(36px, 4vw, 56px); line-height: 1.05; letter-spacing: -0.018em; margin-bottom: 28px; }
.case-text h2 em { font-style: italic; font-weight: 300; }
.case-stats { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 32px; margin-top: 40px; padding-top: 32px; border-top: 1px solid var(--line); }
.case-stat .num { font-family: 'Fraunces', serif; font-weight: 400; font-size: 48px; color: var(--copper); line-height: 1; margin-bottom: 8px; letter-spacing: -0.02em; }
.case-stat .label { font-size: 12px; color: var(--ink-mute); line-height: 1.4; letter-spacing: 0.02em; text-transform: uppercase; }

/* === TESTIMONIALS === */
section.testimonials { padding: 140px 0; background: var(--cream-deep); border-bottom: 1px solid var(--line); }
.testimonials-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.testimonial { padding: 40px; background: var(--cream); border: 1px solid var(--line); display: flex; flex-direction: column; }
.testimonial .stars { color: var(--copper); font-size: 18px; letter-spacing: 4px; margin-bottom: 24px; font-family: 'Fraunces', serif; }
.testimonial blockquote { font-family: 'Fraunces', serif; font-weight: 400; font-size: 20px; line-height: 1.4; letter-spacing: -0.005em; margin-bottom: 32px; flex: 1; }
.testimonial .author { padding-top: 24px; border-top: 1px solid var(--line); }
.testimonial .author-name { font-weight: 600; font-size: 14px; color: var(--ink); }
.testimonial .author-role { font-size: 12px; color: var(--ink-mute); margin-top: 2px; letter-spacing: 0.02em; }

/* === PROCESS (4 kroki) === */
section.process { padding: 140px 0; border-bottom: 1px solid var(--line); }
.process-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; margin-top: 64px; }
.step { padding: 40px 32px 0 0; position: relative; border-right: 1px solid var(--line); }
.step:last-child { border-right: none; padding-right: 0; }
.step:not(:first-child) { padding-left: 32px; }
.step .num { font-family: 'Fraunces', serif; font-weight: 300; font-style: italic; font-size: 14px; color: var(--copper); letter-spacing: 0.06em; margin-bottom: 16px; display: block; }
.step h4 { font-family: 'Fraunces', serif; font-weight: 400; font-size: 24px; margin-bottom: 14px; letter-spacing: -0.005em; line-height: 1.15; }
.step .body { font-size: 14px; }

/* === ACADEMY (dark teaser) === */
section.academy { padding: 140px 0; background: var(--ink); color: var(--cream); border-bottom: 1px solid rgba(251,248,241,0.1); }
.academy-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 80px; align-items: center; }
.academy-text .label-mono { display: block; margin-bottom: 24px; color: var(--copper); }
.academy-text h2 { font-family: 'Fraunces', serif; font-weight: 400; font-size: clamp(40px, 5vw, 68px); line-height: 1.05; letter-spacing: -0.018em; color: var(--cream); margin-bottom: 32px; }
.academy-text h2 em { font-style: italic; font-weight: 300; color: var(--copper); }
.academy-text p { color: rgba(251,248,241,0.7); margin-bottom: 24px; max-width: 520px; line-height: 1.7; font-size: 17px; }
.academy-text .cta-primary { background: var(--cream); color: var(--ink); margin-top: 16px; }
.academy-text .cta-primary:hover { background: var(--copper); color: var(--cream); }
.academy-image { aspect-ratio: 4/5; position: relative; overflow: hidden; background: linear-gradient(180deg,#FBF8F1 0%,#F5EFE3 100%); }
.academy-image img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: contain; padding: 32px; display: block; }
.academy-image::before { content: ''; position: absolute; inset: 16px; border: 1px solid rgba(255,255,255,0.2); z-index: 2; pointer-events: none; }
.academy-image .label-mono { position: absolute; bottom: 32px; left: 32px; color: rgba(251,248,241,0.6); z-index: 3; }

/* === ACADEMY ORBIT (animated 13 nodes) === */
.academy-orbit { background: linear-gradient(140deg, #14110F 0%, #1C1917 50%, #2A1F18 100%); }
.academy-orbit::before { border-color: rgba(184,92,46,0.2); }
.academy-orbit .orbit-svg { position: absolute; inset: 0; width: 100%; height: 100%; padding: 24px; z-index: 1; }
.academy-orbit .orbit-tag { position: absolute; bottom: 24px; left: 24px; color: var(--copper); z-index: 4; }
.academy-orbit .orbit-rings { animation: orbitRingsBreathe 8s ease-in-out infinite; }
.academy-orbit .orbit-outer { transform-origin: 200px 250px; transform-box: fill-box; animation: orbitRotateCW 60s linear infinite; }
.academy-orbit .orbit-inner { transform-origin: 200px 250px; transform-box: fill-box; animation: orbitRotateCCW 40s linear infinite; }
.academy-orbit .orbit-outer .orbit-node text, .academy-orbit .orbit-outer .orbit-node circle { animation: orbitCounterRotate 60s linear infinite; transform-origin: center; transform-box: fill-box; }
.academy-orbit .orbit-outer .orbit-node circle { animation: orbitNodePulse 3s ease-in-out infinite, orbitCounterRotate 60s linear infinite; filter: drop-shadow(0 0 4px rgba(184,92,46,0.6)); }
.academy-orbit .orbit-outer .orbit-node:nth-child(2n) circle { animation-delay: 0.6s, 0s; }
.academy-orbit .orbit-outer .orbit-node:nth-child(3n) circle { animation-delay: 1.2s, 0s; }
.academy-orbit .orbit-inner .orbit-node-sm circle { animation: orbitNodePulse 2.4s ease-in-out infinite, orbitCounterRotateInner 40s linear infinite; transform-origin: center; transform-box: fill-box; filter: drop-shadow(0 0 3px rgba(184,92,46,0.6)); }
.academy-orbit .orbit-inner .orbit-node-sm:nth-child(odd) circle { animation-delay: 0.8s, 0s; }
.academy-orbit .orbit-center circle:nth-child(2) { transform-origin: 200px 250px; transform-box: fill-box; animation: orbitCenterPulse 4s ease-in-out infinite; }
.academy-orbit .orbit-center text { animation: orbitLabelFade 5s ease-in-out infinite; }
.academy-orbit .orbit-halos circle { transform-origin: center; transform-box: fill-box; animation: orbitHaloPulse 3s ease-in-out infinite; }
.academy-orbit .orbit-halos circle:nth-child(2) { animation-delay: 0.7s; }
.academy-orbit .orbit-halos circle:nth-child(3) { animation-delay: 1.4s; }
.academy-orbit .orbit-halos circle:nth-child(4) { animation-delay: 2.1s; }

@keyframes orbitRotateCW { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
@keyframes orbitRotateCCW { from { transform: rotate(0deg); } to { transform: rotate(-360deg); } }
@keyframes orbitCounterRotate { from { transform: rotate(0deg); } to { transform: rotate(-360deg); } }
@keyframes orbitCounterRotateInner { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
@keyframes orbitNodePulse { 0%, 100% { opacity: 0.85; } 50% { opacity: 1; } }
@keyframes orbitCenterPulse { 0%, 100% { opacity: 0.6; transform: scale(1); } 50% { opacity: 1; transform: scale(1.08); } }
@keyframes orbitLabelFade { 0%, 100% { opacity: 0.85; } 50% { opacity: 1; } }
@keyframes orbitHaloPulse { 0%, 100% { opacity: 0.4; transform: scale(0.7); } 50% { opacity: 1; transform: scale(1.4); } }
@keyframes orbitRingsBreathe { 0%, 100% { opacity: 0.2; } 50% { opacity: 0.4; } }

@media (prefers-reduced-motion: reduce) {
  .academy-orbit .orbit-rings, .academy-orbit .orbit-outer, .academy-orbit .orbit-inner, .academy-orbit .orbit-outer .orbit-node circle, .academy-orbit .orbit-inner .orbit-node-sm circle, .academy-orbit .orbit-center circle, .academy-orbit .orbit-center text, .academy-orbit .orbit-halos circle { animation: none !important; }
}
@media (max-width: 700px) {
  .academy-orbit { aspect-ratio: 1/1; }
}

/* === ABOUT === */
section.about { padding: 140px 0; border-bottom: 1px solid var(--line); }
.about-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; align-items: center; }
.about-image { aspect-ratio: 4/5; position: relative; overflow: hidden; background: var(--cream-deep); }
.about-image img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }
.about-image::before { content: ''; position: absolute; inset: 16px; border: 1px solid rgba(255,255,255,0.5); z-index: 2; pointer-events: none; }
.about-text .label-mono { margin-bottom: 28px; display: block; }
.about-text h2 { font-family: 'Fraunces', serif; font-weight: 400; font-size: clamp(36px, 4.5vw, 64px); line-height: 1.05; letter-spacing: -0.018em; margin-bottom: 32px; }
.about-text h2 em { font-style: italic; font-weight: 300; }
.about-text .body-lg { margin-bottom: 24px; max-width: 540px; }
.about-meta { display: flex; gap: 48px; margin-top: 40px; padding-top: 32px; border-top: 1px solid var(--line); flex-wrap: wrap; }
.about-meta .item { min-width: 120px; }
.about-meta .item .label-mono { display: block; margin-bottom: 6px; }
.about-meta .item .val { font-family: 'Fraunces', serif; font-size: 18px; color: var(--ink); }

/* === FAQ === */
section.faq { padding: 140px 0; background: var(--cream-deep); border-bottom: 1px solid var(--line); }
.faq-grid { display: grid; grid-template-columns: 1fr 2fr; gap: 80px; align-items: start; }
.faq-list { display: flex; flex-direction: column; }
.faq-item { border-bottom: 1px solid var(--line); padding: 28px 0; }
.faq-item summary { font-family: 'Fraunces', serif; font-weight: 400; font-size: 22px; cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; letter-spacing: -0.005em; line-height: 1.3; gap: 24px; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: '+'; font-family: 'Inter'; font-weight: 300; font-size: 32px; color: var(--copper); transition: transform 0.2s; line-height: 1; flex-shrink: 0; }
.faq-item[open] summary::after { transform: rotate(45deg); }
.faq-item .answer { padding-top: 16px; max-width: 720px; font-size: 15px; line-height: 1.6; color: var(--ink-soft); }

/* === CTA FINAL === */
section.cta-final { padding: 160px 0; background: var(--ink); color: var(--cream); text-align: center; position: relative; overflow: hidden; }
.cta-final h2 { font-family: 'Fraunces', serif; font-weight: 400; font-size: clamp(48px, 6vw, 88px); line-height: 1; letter-spacing: -0.02em; color: var(--cream); margin-bottom: 32px; }
.cta-final h2 em { font-style: italic; font-weight: 300; color: var(--copper); }
.cta-final p { color: rgba(251,248,241,0.7); max-width: 540px; margin: 0 auto 48px; font-size: 18px; line-height: 1.6; }
.cta-final .cta-primary { background: var(--cream); color: var(--ink); }
.cta-final .cta-primary:hover { background: var(--copper); color: var(--cream); }
.cta-final .cta-secondary { color: var(--cream); border-bottom-color: var(--copper); }
.cta-final .cta-secondary:hover { color: var(--copper); }
.cta-final .cta-row { display: flex; gap: 32px; justify-content: center; align-items: center; flex-wrap: wrap; }

/* === CONTENT (uniwersalna sekcja content na podstronach) === */
section.content { padding: 100px 0; border-bottom: 1px solid var(--line); }
section.content.dark { background: var(--cream-deep); }
.content h2 { font-family: 'Fraunces', serif; font-weight: 400; font-size: clamp(32px, 4vw, 52px); line-height: 1.05; letter-spacing: -0.018em; margin-bottom: 24px; max-width: 820px; }
.content h2 em { font-style: italic; font-weight: 300; color: var(--copper); }
.content h3 { font-family: 'Fraunces', serif; font-weight: 400; font-size: 28px; margin: 40px 0 16px; letter-spacing: -0.005em; }
.content p { margin-bottom: 18px; max-width: 740px; }
.content ul, .content ol { margin: 16px 0 24px 24px; max-width: 740px; }
.content li { margin-bottom: 8px; line-height: 1.6; color: var(--ink-soft); }
.content .label-mono { display: block; margin-bottom: 18px; }

/* === FORM === */
.form-card { background: var(--cream); border: 1px solid var(--line); padding: 48px 40px; max-width: 620px; margin: 0 auto; }
.form-card.dark { background: var(--ink); color: var(--cream); }
.form-card.dark::before { content: ''; position: absolute; inset: 16px; border: 1px solid rgba(251,248,241,0.15); pointer-events: none; }
.form-row { margin-bottom: 24px; }
.form-row label { display: block; font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-mute); font-weight: 600; margin-bottom: 8px; }
.form-row input, .form-row textarea, .form-row select { width: 100%; padding: 14px 16px; background: var(--cream-soft); border: 1px solid var(--line); font-family: inherit; font-size: 15px; color: var(--ink); transition: border-color 0.2s; }
.form-row input:focus, .form-row textarea:focus, .form-row select:focus { border-color: var(--copper); outline: none; }
.form-row textarea { min-height: 120px; resize: vertical; }

/* === FOOTER === */
footer { padding: 80px 0 40px; background: var(--cream-deep); border-top: 1px solid var(--line); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 64px; margin-bottom: 64px; }
.footer-brand .brand { font-size: 28px; margin-bottom: 16px; display: flex; }
.footer-brand .body-sm { max-width: 320px; }
.footer-col h5 { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--copper); font-weight: 600; margin-bottom: 18px; }
.footer-col a { display: block; font-size: 14px; color: var(--ink-soft); text-decoration: none; padding: 4px 0; transition: color 0.2s; }
.footer-col a:hover { color: var(--copper); }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; padding-top: 32px; border-top: 1px solid var(--line); font-size: 12px; color: var(--ink-mute); flex-wrap: wrap; gap: 16px; }

/* === RESPONSIVE === */
@media (max-width: 1100px) {
  .hero-grid, .case-grid, .about-grid, .academy-grid, .faq-grid { grid-template-columns: 1fr; gap: 48px; }
  .paths-grid, .testimonials-grid, .offer-grid-3 { grid-template-columns: 1fr; }
  .offer-grid-4, .offer-grid-2 { grid-template-columns: repeat(2, 1fr); }
  .process-grid { grid-template-columns: 1fr 1fr; }
  .quiz-questions { grid-template-columns: 1fr 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 40px; }
  .quiz-card { padding: 56px 32px; }
  section.hero, section.hero-page, section.manifest, section.quiz, section.problems, section.paths, section.full-offer, section.case-study, section.testimonials, section.process, section.academy, section.about, section.faq, section.cta-final, section.content { padding: 100px 0; }
}
@media (max-width: 900px) {
  .hero-network, .hero-image { display: none; }
  .hero-grid { grid-template-columns: 1fr; }
  section.hero { padding: 40px 0 60px; }
}
@media (max-width: 700px) {
  .container, .container-narrow { padding: 0 20px; }
  .offer-grid-4, .offer-grid-2 { grid-template-columns: 1fr; }
  .case-stats { grid-template-columns: 1fr; }
  .process-grid { grid-template-columns: 1fr; }
  .quiz-questions { grid-template-columns: 1fr; }
  .step { border-right: none; border-bottom: 1px solid var(--line); padding: 32px 0; }
  .step:not(:first-child) { padding-left: 0; }
  .form-card { padding: 32px 24px; }
  .hero-left h1 { font-size: clamp(40px, 11vw, 64px); }
  .hero-cta-row { flex-direction: column; align-items: stretch; }
  .hero-cta-row .cta-primary { justify-content: center; text-align: center; }
  .quiz-card { padding: 40px 22px; }
  .quiz-card h3 { font-size: 24px; }
  .crm-app { grid-template-columns: 1fr; }
  .crm-sidebar { display: none; }
  .case-mockup { padding: 16px; }
  .academy-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; gap: 32px; }
  .breadcrumbs .container { padding: 0 20px; }
  .offer-group-head { flex-direction: column; align-items: flex-start; gap: 8px; }
}

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