/* ============================================
   SPARX × Blumil Go / Blumil Sport — Custom Styles
   ============================================ */

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

:root {
  --red: #f32730;
  --red-dark: #c21f26;
  --black: #0d0d0d;
  --dark: #191919;
  --dark2: #222;
  --white: #fff;
  --offwhite: #f9f9f9;
  --gray-light: #f2f2f2;
  --gray-mid: #d8d8d8;
  --gray-text: #5a5a5a;
  --gold: #c9a84c;
}

body {
  font-family: "Open Sans", sans-serif;
  color: var(--black);
  background: var(--white);
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5 { font-family: "Montserrat", sans-serif; }

/* ---- Navbar ---- */
.navbar2_component .navbar2_link,
.navbar2_component .w-nav-link,
.navbar2_component .locales-wrapper,
.navbar2_component .locales-wrapper div { color: rgba(255,255,255,.75) !important; }
.navbar2_component .navbar2_link:hover,
.navbar2_component .w-nav-link:hover { color: #fff !important; }

/* ---- Buttons ---- */
.btn-red { display: inline-block; background: var(--red); color: #fff; font-family: Montserrat; font-weight: 700; font-size: .85rem; letter-spacing: .05em; text-transform: uppercase; padding: 1rem 2.4rem; border-radius: .4rem; text-decoration: none; transition: background .2s; }
.btn-red:hover { background: var(--red-dark); }
.btn-outline-white { display: inline-block; border: 1px solid rgba(255,255,255,.25); color: rgba(255,255,255,.85); font-family: Montserrat; font-weight: 600; font-size: .85rem; padding: 1rem 2.4rem; border-radius: .4rem; text-decoration: none; transition: border-color .2s, color .2s; }
.btn-outline-white:hover { border-color: rgba(255,255,255,.6); color: #fff; }
.btn-outline-dark { display: inline-block; border: 2px solid var(--black); color: var(--black); font-family: Montserrat; font-weight: 700; font-size: .85rem; padding: 1rem 2.4rem; border-radius: .4rem; text-decoration: none; transition: background .2s, color .2s; }
.btn-outline-dark:hover { background: var(--black); color: #fff; }
.btn-black { display: inline-block; background: var(--black); color: #fff; font-family: Montserrat; font-weight: 700; font-size: .85rem; letter-spacing: .05em; text-transform: uppercase; padding: 1.1rem 2.6rem; border-radius: .4rem; text-decoration: none; transition: background .2s; }
.btn-black:hover { background: #333; }

/* ---- Section atoms ---- */
.section-tag { font-family: Montserrat; font-size: .68rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; color: var(--red); margin-bottom: .8rem; display: block; }
.section-tag-line { display: flex; align-items: center; gap: .8rem; font-family: Montserrat; font-size: .68rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; color: var(--red); margin-bottom: 1.5rem; }
.section-tag-line::after { content: ""; flex: 1; height: 1px; background: var(--gray-mid); max-width: 80px; }
.section-title { font-size: clamp(1.8rem, 3vw, 2.6rem); font-weight: 700; line-height: 1.15; margin-bottom: .8rem; }
.section-sub { color: var(--gray-text); line-height: 1.8; font-size: .95rem; max-width: 540px; margin-bottom: 3rem; }

/* ---- Footer ---- */
.sparx-footer { background: var(--black); padding: 2.5rem 6%; display: flex; align-items: center; justify-content: space-between; border-top: 1px solid rgba(255,255,255,.06); flex-wrap: wrap; gap: 1rem; }
.sparx-footer img { height: 24px; }
.sparx-footer p { font-size: .75rem; color: rgba(255,255,255,.25); }

/* ---- HERO (białe tło) ---- */
.hero { background: #fff; min-height: 100vh; display: flex; flex-direction: column; position: relative; overflow: hidden; }
.hero-bg-text { position: absolute; bottom: -2rem; right: -1rem; font-family: Montserrat; font-size: 20vw; font-weight: 900; color: rgba(0,0,0,.025); line-height: 1; pointer-events: none; user-select: none; letter-spacing: -.02em; }
.hero-top { flex: 1; display: flex; align-items: center; justify-content: center; padding: 8rem 6% 4rem; position: relative; z-index: 2; }
.hero-center { text-align: center; max-width: 820px; }
.hero-badge { display: inline-flex; align-items: center; gap: 1rem; background: rgba(0,0,0,.04); border: 1px solid rgba(0,0,0,.1); border-radius: 2rem; padding: .55rem 1.4rem; margin-bottom: 2.5rem; font-family: Montserrat; font-size: .7rem; font-weight: 700; letter-spacing: .12em; color: rgba(0,0,0,.6); text-transform: uppercase; }
.hero-badge-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--red); }
.hero h1 { font-size: clamp(2.4rem, 5.5vw, 4.8rem); font-weight: 700; color: #020101; line-height: 1.1; letter-spacing: -.025em; margin-bottom: 1.5rem; text-transform: none; }
.hero h1 em { font-style: normal; color: var(--red); }
.hero-sub { color: #020101; font-size: 1.05rem; line-height: 1.8; max-width: 540px; margin: 0 auto 3rem; }
.hero-actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
.hero-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: rgba(0,0,0,.08); border-top: 1px solid rgba(0,0,0,.08); position: relative; z-index: 2; }
.hero-stat { padding: 2.2rem 1.5rem; background: #0d0d0d; }
.hero-stat-num { font-family: Montserrat; font-size: 2.5rem; font-weight: 800; color: #f32730; line-height: 1; margin-bottom: .4rem; }
.hero-stat-num span { color: #f32730; }
.hero-stat-label { font-size: .9rem; color: #fff; letter-spacing: .03em; line-height: 1.4; }

/* ---- INTRO (offwhite, 2-col) ---- */
.intro-section { padding: 5rem 5%; background: var(--offwhite); }
.intro-inner { max-width: 90rem; margin: 0 auto; display: grid; grid-template-columns: 1fr .75fr; gap: 5rem; align-items: center; }
.intro-content h2 { font-size: clamp(1.8rem, 3vw, 2.4rem); font-weight: 700; line-height: 1.15; margin-bottom: 1.2rem; }
.intro-content p { font-size: .95rem; color: #020101; line-height: 1.8; margin-bottom: 1rem; }
.intro-content .actions { margin-top: 2rem; display: flex; gap: 1rem; flex-wrap: wrap; }
.intro-visual img { width: 100%; border-radius: 1rem; display: block; }

/* ---- FEATURES (dark, 4 cards) ---- */
.features-section { padding: 5rem 5%; background: var(--black); }
.features-header { max-width: 90rem; margin: 0 auto 4rem; }
.features-header .section-tag { color: var(--red); }
.features-header .section-title { color: var(--white); margin-bottom: .5rem; font-weight: 700; }
.features-header .section-sub { color: #fff; margin-bottom: 0; }
.features-grid { max-width: 90rem; margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
.feature-card { background: #fff; border-radius: 1rem; overflow: hidden; border: 1px solid #f32730; transition: border-color .25s; }
.feature-card:hover { border-color: #c21f26; }
.feature-card-img { width: 100%; aspect-ratio: 1/1; object-fit: cover; display: block; background: #f5f5f5; }
.feature-card-body { padding: 1.2rem 1.4rem 1.6rem; }
.feature-card-num { font-family: Montserrat; font-size: .65rem; font-weight: 700; letter-spacing: .12em; color: var(--red); margin-bottom: .6rem; }
.feature-card h4 { font-size: .95rem; font-weight: 700; color: #020101; margin-bottom: .5rem; line-height: 1.3; }
.feature-card p { font-size: .8rem; color: #4c4c4c; line-height: 1.6; }

/* ---- LIFESTYLE BAND (full-width photo overlay) ---- */
.lifestyle-band { position: relative; height: 520px; overflow: hidden; }
.lifestyle-band img { width: 100%; height: 100%; object-fit: cover; object-position: center 40%; display: block; }
.lifestyle-band-overlay { position: absolute; inset: 0; background: linear-gradient(to right, rgba(0,0,0,.75) 0%, rgba(0,0,0,.2) 60%, transparent 100%); display: flex; align-items: center; padding: 0 8%; }
.lifestyle-band-text { max-width: 440px; }
.lifestyle-band-text h2 { font-size: clamp(1.6rem, 3vw, 2.4rem); font-weight: 700; color: var(--white); line-height: 1.2; margin-bottom: 1rem; }
.lifestyle-band-text p { color: rgba(255,255,255,.7); font-size: .95rem; line-height: 1.75; margin-bottom: 2rem; }

/* ---- STEPS (dark, 3-col) ---- */
.steps-section { padding: 5rem 5%; background: var(--black); }
.steps-header { max-width: 90rem; margin: 0 auto 5rem; text-align: center; }
.steps-header .section-tag { color: var(--red); }
.steps-header h2 { font-size: clamp(2rem, 4vw, 3.2rem); font-weight: 700; color: var(--white); line-height: 1.1; letter-spacing: -.02em; }
.steps-track { max-width: 90rem; margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 3rem; position: relative; }
.steps-track::before { content: ""; position: absolute; top: 28px; left: calc(16.6% + 28px); right: calc(16.6% + 28px); height: 1px; background: rgba(255,255,255,.08); }
.step { text-align: center; position: relative; z-index: 1; }
.step-circle { width: 56px; height: 56px; border-radius: 50%; background: transparent; border: 1px solid rgba(243,39,48,.3); display: flex; align-items: center; justify-content: center; font-family: Montserrat; font-weight: 800; font-size: .9rem; color: #f32730; margin: 0 auto 1.5rem; transition: background .3s, border-color .3s; }
.step:hover .step-circle { background: transparent; border-color: #f32730; }
.step h4 { font-size: 1.05rem; font-weight: 700; color: #f32730; margin-bottom: .5rem; }
.step p { font-size: .95rem; color: #fff; line-height: 1.7; }

/* ---- ZESTAW SPLIT ---- */
.zestaw-split { display: grid; grid-template-columns: 1fr 1fr; }
.zestaw-split-visual { position: relative; overflow: hidden; }
.zestaw-split-visual img { width: 100%; height: 100%; min-height: 500px; object-fit: cover; display: block; }
.zestaw-split-content { background: var(--black); padding: 6rem 7%; display: flex; flex-direction: column; justify-content: center; }
.zestaw-split-content .section-tag { color: var(--red); }
.zestaw-split-content h2 { font-size: clamp(2.2rem, 3vw, 3.2rem); font-weight: 700; color: var(--white); line-height: 1.15; margin-bottom: 1.2rem; }
.zestaw-split-content h2 em { font-style: normal; color: var(--red); }
.zestaw-split-content p { font-size: 1rem; color: #fff; line-height: 1.8; margin-bottom: 1rem; }
.zestaw-checklist { list-style: none; margin: 1.5rem 0 2.5rem; display: flex; flex-direction: column; gap: .75rem; }
.zestaw-checklist li { display: flex; gap: .75rem; font-size: .95rem; color: #fff; align-items: flex-start; }
.zestaw-checklist li::before { content: "✓"; font-family: Montserrat; font-weight: 800; color: var(--red); flex-shrink: 0; }
.zestaw-split-actions { display: flex; gap: 1rem; flex-wrap: wrap; }

/* ---- DOF — tekst + zdjęcie ---- */
.dof-clean { padding: 5rem 5%; background: var(--white); }
.dof-clean-inner { max-width: 90rem; margin: 0 auto; }
.dof-text-photo { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; }
.dof-text h2 { font-size: clamp(1.8rem, 3vw, 2.6rem); font-weight: 700; line-height: 1.15; margin-bottom: 1rem; }
.dof-text h2 span { color: var(--red); }
.dof-text p { font-size: .9rem; color: #020101; line-height: 1.8; margin-bottom: 1.5rem; }
.dof-photo img { width: 100%; border-radius: .75rem; display: block; }

/* ---- KALKULATOR — 2 kolumny ---- */
.dof-calc-section { padding: 5rem 5%; background: #f9f9f9; }
.dof-calc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; margin-bottom: 1.5rem; }
.calc-card { background: #0d0d0d; border-radius: 1.25rem; padding: 2.5rem; }
.calc-card-total { display: flex; justify-content: space-between; align-items: flex-end; margin-top: 1.5rem; padding-top: 1.5rem; border-top: 2px solid rgba(255,255,255,.1); }
.calc-summary-bar { background: #0d0d0d; border-radius: 1rem; padding: 1.5rem 2.5rem; display: flex; justify-content: space-between; align-items: center; margin-bottom: 1rem; }
.calc-summary-saving { font-family: Montserrat; font-size: .85rem; font-weight: 700; color: #f32730; letter-spacing: .02em; }
.calc-summary-total { text-align: right; }
.calc-footnote { font-size: .68rem; color: rgba(0,0,0,.35); line-height: 1.5; }
.calc-box-title { font-family: Montserrat; font-size: .7rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--red); margin-bottom: 2rem; display: block; }
.calc-row { display: flex; justify-content: space-between; align-items: center; padding: .8rem 0; border-bottom: 1px solid rgba(255,255,255,.06); font-size: .9rem; }
.calc-row:last-child { border-bottom: none; }
.calc-row-label { color: rgba(255,255,255,.5); }
.calc-row-val { font-family: Montserrat; font-weight: 700; color: var(--white); }
.calc-row-val.red { color: var(--red); }
.calc-row.highlight { background: rgba(255,255,255,.04); margin: .5rem -2.5rem; padding: 1rem 2.5rem; }
.calc-total-label { font-family: Montserrat; font-size: .7rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: rgba(255,255,255,.35); }
.calc-grand-val { font-family: Montserrat; font-size: 1.6rem; font-weight: 900; color: var(--red); line-height: 1; }

/* ---- CTA white final ---- */
.cta-white-final { padding: 8rem 6%; background: var(--white); text-align: center; }
.cta-white-final h2 { font-size: clamp(2.2rem, 5vw, 4rem); font-weight: 700; line-height: 1.1; letter-spacing: -.02em; margin-bottom: 1.2rem; color: var(--black); }
.cta-white-final h2 span { color: var(--red); }
.cta-white-final p { color: var(--gray-text); font-size: 1rem; line-height: 1.75; max-width: 480px; margin: 0 auto 3rem; }
.cta-white-final-btns { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

/* ---- CTA variants ---- */
.cta-white { padding: 8rem 6%; background: var(--white); text-align: center; }
.cta-white h2 { font-size: clamp(2.2rem, 5vw, 4rem); font-weight: 700; line-height: 1.1; letter-spacing: -.02em; margin-bottom: 1.2rem; }
.cta-white h2 span { color: var(--red); }
.cta-white p { color: var(--gray-text); font-size: 1rem; line-height: 1.75; max-width: 480px; margin: 0 auto 3rem; }
.cta-white-btns { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
.cta-dark { background: var(--black); padding: 8rem 6%; text-align: center; }
.cta-dark h2 { font-size: clamp(2.2rem, 5vw, 4rem); font-weight: 700; color: var(--white); line-height: 1.1; letter-spacing: -.02em; margin-bottom: 1.2rem; }
.cta-dark h2 span { color: var(--red); }
.cta-dark p { color: rgba(255,255,255,.45); font-size: 1rem; line-height: 1.75; max-width: 480px; margin: 0 auto 3rem; }
.cta-dark-btns { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

/* ---- Blumil banner ---- */
.blumil-banner { position: relative; height: 420px; overflow: hidden; }
.blumil-banner img { width: 100%; height: 100%; object-fit: cover; object-position: center 30%; display: block; }
.blumil-banner-overlay { position: absolute; inset: 0; background: linear-gradient(to right, rgba(0,0,0,.8) 0%, rgba(0,0,0,.4) 55%, rgba(0,0,0,.15) 100%); display: flex; align-items: center; padding: 0 8%; }
.blumil-banner-content { max-width: 560px; }
.blumil-banner-eyebrow { font-family: Montserrat; font-size: .65rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: rgba(255,255,255,.45); margin-bottom: 1rem; display: block; }
.blumil-banner-content h2 { font-size: clamp(1.6rem, 3vw, 2.6rem); font-weight: 700; color: var(--white); line-height: 1.2; letter-spacing: -.02em; margin-bottom: 2rem; }
@media (max-width: 600px) { .blumil-banner { height: 340px; } }

/* ---- Responsive ---- */
@media (max-width: 960px) {
  .hero-stats { grid-template-columns: repeat(2, 1fr); }
  .intro-inner { grid-template-columns: 1fr; gap: 3rem; }
  .features-grid { grid-template-columns: repeat(2, 1fr); }
  .steps-track { grid-template-columns: 1fr; }
  .steps-track::before { display: none; }
  .zestaw-split { grid-template-columns: 1fr; }
  .zestaw-split-visual img { min-height: 300px; }
  .dof-text-photo { grid-template-columns: 1fr; gap: 3rem; }
  .dof-calc-grid { grid-template-columns: 1fr; }
  .calc-summary-bar { flex-direction: column; gap: 1rem; text-align: center; }
  .calc-summary-total { text-align: center; }
}
@media (max-width: 600px) {
  .features-grid { grid-template-columns: 1fr 1fr; }
  .lifestyle-band { height: 380px; }
}
