/* ==========================================================================
   Medical Park Polska — Design System
   Czysty CSS, bez build-stepu. Paleta: czerwień Medical Park + granat (tekst) + złoto.
   ========================================================================== */

:root{
  /* Kolory marki — premium: głęboka czerwień/burgund + ciepłe neutrale + złoto */
  --red:#BE1622;         /* czerwień akcentowa (głębsza, mniej neonu) */
  --red-700:#8E1522;
  --red-900:#5A0E18;     /* burgund */
  --red-soft:#F7ECEC;
  --navy:#2A1E20;        /* ciepła grafitowa czerń — nagłówki/tekst */
  --navy-900:#1A1113;    /* prawie czarny — topbar/stopka */
  --navy-700:#46363A;
  --blue:#BE1622;        /* alias historyczny → czerwień */
  --blue-600:#8E1522;
  --gold:#C0A053;        /* złoto — akcent premium */
  --gold-soft:#E3CD96;
  --teal:#BE1622;        /* dawny turkus → czerwień (spójność) */
  --teal-600:#8E1522;
  --mint:#F7ECEC;

  /* Neutralne — ciepłe (kość słoniowa / krem) */
  --bg:#FBF9F7;
  --bg-alt:#F5EFEC;
  --white:#ffffff;
  --ink:#322629;
  --muted:#837074;
  --line:#ECE3E0;
  --line-2:#DFD3CE;

  /* Gradienty */
  --grad-navy:linear-gradient(135deg,#BE1622 0%,#8E1522 100%);
  --grad-hero:linear-gradient(135deg,#2E0910 0%,#520E1A 48%,#7C1524 100%);
  --grad-gold:linear-gradient(135deg,#A9853A 0%,#C0A053 45%,#E3CD96 100%);
  --grad-teal:linear-gradient(135deg,#8E1522 0%,#BE1622 100%);

  /* Cienie */
  --shadow-sm:0 1px 3px rgba(58,26,30,.06),0 1px 2px rgba(58,26,30,.04);
  --shadow:0 12px 30px rgba(58,26,30,.10),0 3px 10px rgba(58,26,30,.06);
  --shadow-lg:0 30px 60px rgba(58,26,30,.16),0 10px 24px rgba(58,26,30,.08);
  --shadow-gold:0 14px 30px rgba(201,162,75,.32);

  /* Promienie */
  --r-sm:10px; --r:16px; --r-lg:22px; --r-xl:30px; --r-pill:999px;

  /* Typografia */
  --font-head:'Playfair Display',Georgia,'Times New Roman',serif;
  --font-body:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;

  --maxw:1200px;

  /* Akcent kontekstowy (zmieniany per sekcja/strona) */
  --accent:var(--red);
  --accent-2:var(--gold);
  --grad-accent:var(--grad-navy);
}

/* Motyw estetyczny (podstrona + sekcje) */
.theme-aesthetic{
  --accent:var(--teal);
  --accent-2:var(--gold);
  --grad-accent:var(--grad-teal);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.65;
  font-size:17px;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}

/* Typografia */
h1,h2,h3,h4{font-family:var(--font-head);color:var(--navy);line-height:1.12;font-weight:700;letter-spacing:-.01em}
h1{font-size:clamp(2.3rem,5.2vw,4rem)}
h2{font-size:clamp(1.9rem,3.6vw,2.9rem)}
h3{font-size:clamp(1.2rem,2vw,1.5rem)}
p{color:var(--muted)}
.serif{font-family:var(--font-head)}

/* Layout */
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:96px 0;position:relative}
.section--tight{padding:64px 0}
.section--alt{background:
  radial-gradient(1200px 500px at 80% -10%,rgba(190,22,34,.06),transparent 60%),
  var(--bg-alt)}
.section--dark{background:var(--grad-hero);color:#f0e4e5}
.section--dark h2,.section--dark h3{color:#fff}
.section--dark p{color:#ecd8da}

.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.78rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--accent);margin-bottom:16px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--accent-2);border-radius:2px}
.section-head{max-width:680px;margin:0 auto 56px;text-align:center}
.section-head.left{margin-left:0;text-align:left}
.section-head p{margin-top:16px;font-size:1.08rem}
.lead{font-size:1.15rem;color:var(--muted)}

/* Przyciski */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:15px 28px;border-radius:var(--r-pill);font-weight:600;font-size:.98rem;
  transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s,background .25s,color .25s;
  white-space:nowrap;line-height:1;
}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--grad-navy);color:#fff;box-shadow:var(--shadow)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.btn-gold{background:var(--grad-gold);color:#3a2c08;box-shadow:var(--shadow-gold);font-weight:700}
.btn-gold:hover{transform:translateY(-3px)}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border:1.5px solid rgba(255,255,255,.35);backdrop-filter:blur(6px)}
.btn-ghost:hover{background:rgba(255,255,255,.16);transform:translateY(-3px)}
.btn-outline{background:#fff;color:var(--navy);border:1.5px solid var(--line-2);box-shadow:var(--shadow-sm)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-3px)}
.btn-block{width:100%}
.btn-lg{padding:18px 34px;font-size:1.05rem}

.link-arrow{display:inline-flex;align-items:center;gap:8px;color:var(--accent);font-weight:600;font-size:.95rem}
.link-arrow svg{width:16px;height:16px;transition:transform .25s}
.link-arrow:hover svg{transform:translateX(5px)}

/* Pills / badge */
.pill{display:inline-flex;align-items:center;gap:8px;padding:7px 16px;border-radius:var(--r-pill);
  background:rgba(190,22,34,.08);color:var(--blue-600);font-size:.82rem;font-weight:600}
.pill svg{width:15px;height:15px}

/* ===== Top bar ===== */
.topbar{background:var(--navy-900);color:#e7d6d8;font-size:.84rem}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:16px;height:42px}
.topbar a{display:inline-flex;align-items:center;gap:7px;color:#e7d6d8;transition:color .2s}
.topbar a:hover{color:#fff}
.topbar svg{width:14px;height:14px;color:var(--gold-soft)}
.topbar-left{display:flex;gap:22px}
.topbar-right{display:flex;gap:18px;align-items:center}
.lang-switch{display:flex;gap:4px}
.lang-switch button{color:#bda9ac;font-size:.8rem;font-weight:600;padding:3px 7px;border-radius:6px}
.lang-switch button.is-active{background:rgba(255,255,255,.12);color:#fff}

/* ===== Nav ===== */
.nav{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.82);backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line);transition:box-shadow .3s,background .3s}
.nav.is-scrolled{box-shadow:var(--shadow);background:rgba(255,255,255,.95)}
.nav .container{display:flex;align-items:center;justify-content:space-between;height:74px;gap:20px}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{width:42px;height:42px;border-radius:12px;background:var(--grad-navy);display:grid;place-items:center;box-shadow:var(--shadow-sm);flex:none}
.brand-mark svg{width:24px;height:24px;color:#fff}
.brand-name{font-family:var(--font-head);font-weight:700;font-size:1.16rem;color:var(--navy);line-height:1.05}
.brand-name span{display:block;font-family:var(--font-body);font-size:.66rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--gold)}
/* Logo Medical Park (obraz) */
.brand-logo{height:30px;width:auto;display:block;flex:none}
.brand-sub{font-family:var(--font-body);font-size:.6rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);padding-left:11px;margin-left:1px;border-left:1px solid var(--line-2);line-height:1.25;max-width:130px}
.footer .brand-logo{height:26px}
.footer .brand-sub{color:var(--gold-soft);border-color:rgba(255,255,255,.2)}
@media(max-width:600px){.brand-sub{display:none}}
.nav-menu{display:flex;align-items:center;gap:6px}
.nav-menu a{padding:10px 14px;border-radius:10px;font-weight:500;font-size:.95rem;color:var(--ink);transition:color .2s,background .2s}
.nav-menu a:hover{color:var(--accent);background:rgba(190,22,34,.06)}
.nav-cta{display:flex;align-items:center;gap:10px}
.nav-toggle{display:none;width:46px;height:46px;border-radius:12px;border:1px solid var(--line-2);background:#fff}
.nav-toggle span{display:block;width:20px;height:2px;background:var(--navy);margin:4px auto;border-radius:2px;transition:.3s}
.nav-toggle.is-open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav-toggle.is-open span:nth-child(2){opacity:0}
.nav-toggle.is-open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* ===== Hero ===== */
.hero{position:relative;background:var(--grad-hero);color:#fff;overflow:hidden;padding:84px 0 96px}
.hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(700px 380px at 85% 12%,rgba(190,22,34,.22),transparent 60%),
  radial-gradient(600px 400px at 10% 95%,rgba(201,162,75,.14),transparent 60%);}
.hero::after{content:"";position:absolute;inset:0;opacity:.5;
  background-image:radial-gradient(rgba(255,255,255,.10) 1px,transparent 1px);background-size:26px 26px;
  -webkit-mask-image:linear-gradient(180deg,transparent,#000 30%,#000 70%,transparent);
          mask-image:linear-gradient(180deg,transparent,#000 30%,#000 70%,transparent);}
.hero .container{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;gap:54px;align-items:center}
.hero-badge{display:inline-flex;align-items:center;gap:9px;padding:8px 16px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);font-size:.82rem;font-weight:600;color:#f6ece d;margin-bottom:24px}
.hero-badge .dot{width:8px;height:8px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 4px rgba(190,22,34,.3)}
.hero h1{color:#fff;margin-bottom:22px}
.hero h1 em{font-style:normal;color:var(--gold-soft);position:relative;white-space:nowrap}
.hero h1 em::after{content:"";position:absolute;left:0;bottom:6px;width:100%;height:10px;background:rgba(201,162,75,.25);z-index:-1;border-radius:4px}
.hero-sub{font-size:1.16rem;color:#e7d6d8;max-width:560px;margin-bottom:32px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:34px}
.hero-trust{display:flex;flex-wrap:wrap;gap:14px 26px;align-items:center}
.hero-trust .t{display:flex;align-items:center;gap:9px;font-size:.9rem;color:#f0e4e5}
.hero-trust .t svg{width:20px;height:20px;color:var(--gold-soft);flex:none}
.hero-trust b{color:#fff;font-weight:700}

/* Hero karta wizualna */
.hero-card{position:relative}
.hero-glass{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);border-radius:var(--r-xl);
  padding:26px;backdrop-filter:blur(12px);box-shadow:var(--shadow-lg)}
.hero-glass h4{color:#fff;font-family:var(--font-body);font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:#ecd8da;margin-bottom:18px;font-weight:700}
.hero-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.hero-stat{background:rgba(255,255,255,.07);border-radius:var(--r);padding:18px 16px;border:1px solid rgba(255,255,255,.1)}
.hero-stat .n{font-family:var(--font-head);font-size:1.9rem;font-weight:700;color:#fff;line-height:1}
.hero-stat .l{font-size:.8rem;color:#ecd8da;margin-top:6px}
.hero-jci{display:flex;align-items:center;gap:12px;margin-top:16px;padding:14px 16px;background:rgba(190,22,34,.14);border:1px solid rgba(190,22,34,.3);border-radius:var(--r)}
.hero-jci svg{width:30px;height:30px;color:var(--teal);flex:none}
.hero-jci span{font-size:.86rem;color:#f6ece d}
.hero-jci b{color:#fff}

/* Marquee zaufania */
.logos{background:var(--white);border-bottom:1px solid var(--line)}
.logos .container{display:flex;align-items:center;gap:30px;flex-wrap:wrap;justify-content:center;padding-top:26px;padding-bottom:26px}
.logos .lbl{font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.logos .badge{display:flex;align-items:center;gap:9px;color:var(--navy);font-weight:700;opacity:.78;font-size:.95rem}
.logos .badge svg{width:22px;height:22px;color:var(--blue-600)}

/* ===== Split medyczne/estetyczne ===== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.split-card{position:relative;overflow:hidden;border-radius:var(--r-xl);padding:44px 38px;min-height:340px;
  display:flex;flex-direction:column;justify-content:flex-end;color:#fff;box-shadow:var(--shadow);
  transition:transform .4s cubic-bezier(.2,.8,.2,1),box-shadow .4s}
.split-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.split-card.medical{background:var(--grad-hero)}
.split-card.aesthetic{background:linear-gradient(135deg,#5A0E18 0%,#8E1522 55%,#BE1622 100%)}
.split-card::before{content:"";position:absolute;inset:0;opacity:.5;
  background:radial-gradient(380px 280px at 80% 10%,rgba(255,255,255,.16),transparent 60%)}
.split-card .sc-icon{position:relative;width:60px;height:60px;border-radius:18px;background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.25);display:grid;place-items:center;margin-bottom:auto}
.split-card .sc-icon svg{width:32px;height:32px;color:#fff}
.split-card .sc-tag{position:relative;font-size:.8rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.8);margin-top:26px}
.split-card h3{position:relative;color:#fff;font-size:1.9rem;margin:8px 0 10px}
.split-card p{position:relative;color:rgba(255,255,255,.9);margin-bottom:22px;max-width:90%}
.split-card .sc-list{position:relative;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.split-card .sc-list span{font-size:.82rem;padding:6px 12px;background:rgba(255,255,255,.14);border-radius:var(--r-pill)}
.split-card .sc-cta{position:relative;display:inline-flex;align-items:center;gap:10px;font-weight:700;
  background:#fff;color:var(--navy);padding:13px 22px;border-radius:var(--r-pill);align-self:flex-start;transition:gap .25s}
.split-card.aesthetic .sc-cta{color:var(--teal-600)}
.split-card .sc-cta:hover{gap:16px}
.split-card .sc-cta svg{width:17px;height:17px}

/* ===== Statystyki ===== */
.stats{display:grid;grid-template-columns:repeat(5,1fr);gap:20px;text-align:center}
.stat{padding:18px 8px}
.stat .n{font-family:var(--font-head);font-size:clamp(2rem,3.4vw,2.8rem);font-weight:700;color:var(--navy);line-height:1}
.stat .n .suf{color:var(--gold)}
.stat .l{font-size:.9rem;color:var(--muted);margin-top:8px}
.stat+.stat{border-left:1px solid var(--line)}

/* ===== Karty (dlaczego my) ===== */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:30px;transition:transform .3s,box-shadow .3s,border-color .3s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.card .ic{width:56px;height:56px;border-radius:16px;display:grid;place-items:center;margin-bottom:20px;
  background:linear-gradient(135deg,rgba(190,22,34,.12),rgba(190,22,34,.12))}
.card .ic svg{width:28px;height:28px;color:var(--accent)}
.card h3{font-size:1.22rem;margin-bottom:10px}
.card p{font-size:.96rem}
.card.gold .ic{background:linear-gradient(135deg,rgba(201,162,75,.18),rgba(227,205,150,.18))}
.card.gold .ic svg{color:var(--gold)}

/* ===== Taby zabiegów ===== */
.tabs-head{display:flex;justify-content:center;gap:10px;margin-bottom:40px;flex-wrap:wrap}
.tab-btn{padding:13px 26px;border-radius:var(--r-pill);font-weight:600;color:var(--muted);
  background:#fff;border:1.5px solid var(--line-2);transition:.25s;display:inline-flex;gap:9px;align-items:center}
.tab-btn svg{width:18px;height:18px}
.tab-btn.is-active{color:#fff;background:var(--grad-navy);border-color:transparent;box-shadow:var(--shadow)}
.tab-btn[data-tab="est"].is-active{background:var(--grad-teal)}
.tab-panel{display:none;animation:fade .5s ease}
.tab-panel.is-active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.proc{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;transition:.3s;position:relative;overflow:hidden}
.proc::after{content:"";position:absolute;left:0;top:0;height:4px;width:100%;background:var(--grad-accent);transform:scaleX(0);transform-origin:left;transition:transform .35s}
.proc:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.proc:hover::after{transform:scaleX(1)}
.proc .ic{width:50px;height:50px;border-radius:14px;background:var(--bg-alt);display:grid;place-items:center;margin-bottom:16px}
.proc .ic svg{width:26px;height:26px;color:var(--accent)}
.proc h4{font-family:var(--font-body);font-weight:700;font-size:1.05rem;color:var(--navy);margin-bottom:6px}
.proc p{font-size:.88rem;margin-bottom:14px}
.proc .foot{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--line);padding-top:12px}
.proc .price{font-size:.84rem;color:var(--muted)}
.proc .price b{color:var(--navy);font-size:1rem;font-family:var(--font-head)}
.proc .ask{font-size:.82rem;font-weight:700;color:var(--accent)}

/* ===== Pełna opieka (concierge) ===== */
.care-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.care{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-lg);padding:26px;transition:.3s}
.care:hover{background:rgba(255,255,255,.1);transform:translateY(-5px)}
.care .ic{width:52px;height:52px;border-radius:14px;background:rgba(201,162,75,.16);border:1px solid rgba(201,162,75,.3);display:grid;place-items:center;margin-bottom:16px}
.care .ic svg{width:26px;height:26px;color:var(--gold-soft)}
.care h4{color:#fff;font-family:var(--font-body);font-size:1.05rem;font-weight:700;margin-bottom:8px}
.care p{color:#ecd8da;font-size:.9rem}
.care-banner{display:flex;align-items:center;gap:20px;flex-wrap:wrap;justify-content:space-between;
  margin-top:44px;padding:26px 32px;border-radius:var(--r-lg);
  background:linear-gradient(120deg,rgba(201,162,75,.18),rgba(190,22,34,.14));border:1px solid rgba(255,255,255,.16)}
.care-banner p{color:#f6ece d;font-size:1.05rem;max-width:640px}
.care-banner b{color:#fff}

/* ===== Oś czasu (jak to działa) ===== */
.timeline{position:relative;display:grid;grid-template-columns:repeat(6,1fr);gap:18px;counter-reset:step}
.timeline::before{content:"";position:absolute;top:28px;left:6%;right:6%;height:2px;background:linear-gradient(90deg,var(--blue),var(--teal),var(--gold))}
.tstep{position:relative;text-align:center}
.tstep .num{counter-increment:step;width:56px;height:56px;border-radius:50%;background:#fff;border:2px solid var(--line-2);
  display:grid;place-items:center;margin:0 auto 16px;position:relative;z-index:2;font-family:var(--font-head);font-weight:700;color:var(--accent);font-size:1.3rem;box-shadow:var(--shadow-sm)}
.tstep .num::after{content:counter(step)}
.tstep h4{font-family:var(--font-body);font-size:1rem;color:var(--navy);margin-bottom:6px}
.tstep p{font-size:.85rem}

/* ===== Asystent AI — sekcja ===== */
.ai-feature{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.ai-points{margin-top:26px;display:flex;flex-direction:column;gap:16px}
.ai-point{display:flex;gap:14px;align-items:flex-start}
.ai-point .ic{width:42px;height:42px;border-radius:12px;flex:none;background:linear-gradient(135deg,rgba(190,22,34,.14),rgba(190,22,34,.14));display:grid;place-items:center}
.ai-point .ic svg{width:22px;height:22px;color:var(--accent)}
.ai-point h4{font-family:var(--font-body);font-size:1.02rem;margin-bottom:3px}
.ai-point p{font-size:.92rem}

/* Podgląd okna czatu (statyczny w sekcji) */
.ai-mock{background:#fff;border-radius:var(--r-xl);box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid var(--line)}
.ai-mock .head{background:var(--grad-navy);color:#fff;padding:18px 20px;display:flex;align-items:center;gap:12px}
.ai-mock .head .av{width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.16);display:grid;place-items:center}
.ai-mock .head .av svg{width:24px;height:24px;color:#fff}
.ai-mock .head .nm{font-weight:700;font-size:1rem}
.ai-mock .head .st{font-size:.78rem;color:#ecd8da;display:flex;align-items:center;gap:6px}
.ai-mock .head .st::before{content:"";width:7px;height:7px;border-radius:50%;background:#56e0a0}
.ai-mock .body{padding:22px 20px;background:var(--bg);display:flex;flex-direction:column;gap:12px;min-height:230px}
.bubble{max-width:82%;padding:12px 16px;border-radius:16px;font-size:.92rem;line-height:1.5}
.bubble.bot{background:#fff;border:1px solid var(--line);color:var(--ink);border-bottom-left-radius:5px;align-self:flex-start;box-shadow:var(--shadow-sm)}
.bubble.user{background:var(--grad-navy);color:#fff;border-bottom-right-radius:5px;align-self:flex-end}
.ai-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.ai-chips button,.chip{font-size:.82rem;padding:8px 14px;border-radius:var(--r-pill);background:#fff;border:1.5px solid var(--accent);color:var(--accent);font-weight:600;transition:.2s}
.ai-chips button:hover,.chip:hover{background:var(--accent);color:#fff}

/* ===== Opinie ===== */
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.tcard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:30px;position:relative}
.tcard .quote{position:absolute;top:18px;right:24px;font-family:var(--font-head);font-size:3.4rem;color:var(--line-2);line-height:1}
.tstars{display:flex;gap:3px;margin-bottom:14px}
.tstars svg{width:18px;height:18px;color:var(--gold)}
.tcard p{color:var(--ink);font-size:1rem;margin-bottom:20px}
.tperson{display:flex;align-items:center;gap:12px;border-top:1px solid var(--line);padding-top:16px}
.tperson .av{width:46px;height:46px;border-radius:50%;background:var(--grad-navy);color:#fff;display:grid;place-items:center;font-weight:700;font-family:var(--font-head)}
.tperson .nm{font-weight:700;color:var(--navy);font-size:.96rem}
.tperson .meta{font-size:.82rem;color:var(--muted)}

/* ===== Before / after ===== */
.ba-wrap{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.ba-slider{position:relative;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/3;user-select:none;background:#2A1E20}
.ba-img{position:absolute;inset:0;display:grid;place-items:center;color:#fff;text-align:center;font-weight:700;letter-spacing:.04em}
.ba-before{background:linear-gradient(135deg,#3a4a5a,#5a6b7b)}
.ba-after{background:linear-gradient(135deg,#0E6BA8,#BE1622);clip-path:inset(0 0 0 50%)}
.ba-label{position:absolute;bottom:16px;padding:6px 14px;border-radius:var(--r-pill);font-size:.78rem;background:rgba(0,0,0,.45);color:#fff;backdrop-filter:blur(4px)}
.ba-label.l{left:16px}.ba-label.r{right:16px}
.ba-line{position:absolute;top:0;bottom:0;left:50%;width:3px;background:#fff;transform:translateX(-50%);box-shadow:0 0 10px rgba(0,0,0,.3)}
.ba-handle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;background:#fff;display:grid;place-items:center;box-shadow:var(--shadow);color:var(--navy)}
.ba-handle svg{width:24px;height:24px}
.ba-range{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:ew-resize;margin:0}

/* ===== Akredytacje ===== */
.acc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.acc{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;text-align:center;transition:.3s}
.acc:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.acc .ic{width:60px;height:60px;border-radius:50%;margin:0 auto 14px;display:grid;place-items:center;background:var(--bg-alt)}
.acc .ic svg{width:30px;height:30px;color:var(--blue-600)}
.acc h4{font-family:var(--font-body);font-size:1.02rem;margin-bottom:6px}
.acc p{font-size:.84rem}

/* ===== Cennik teaser ===== */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.pcard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;transition:.3s}
.pcard:hover{box-shadow:var(--shadow-lg);transform:translateY(-5px)}
.pcard .cat{font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}
.pcard h4{font-family:var(--font-body);font-size:1.18rem;margin:8px 0 4px}
.pcard .from{font-size:.85rem;color:var(--muted)}
.pcard .amt{font-family:var(--font-head);font-size:2rem;color:var(--navy);font-weight:700;margin:8px 0 14px}
.pcard ul{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.pcard li{display:flex;gap:9px;align-items:flex-start;font-size:.9rem;color:var(--ink)}
.pcard li svg{width:17px;height:17px;color:var(--teal-600);flex:none;margin-top:3px}
.price-note{text-align:center;margin-top:24px;font-size:.86rem;color:var(--muted)}

/* ===== FAQ ===== */
.faq{max-width:820px;margin:0 auto}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:var(--r);margin-bottom:14px;overflow:hidden;transition:box-shadow .3s}
.faq-item.is-open{box-shadow:var(--shadow)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:22px 24px;text-align:left;font-weight:600;font-size:1.05rem;color:var(--navy)}
.faq-q .ico{width:30px;height:30px;border-radius:50%;background:var(--bg-alt);display:grid;place-items:center;flex:none;transition:.3s}
.faq-q .ico svg{width:18px;height:18px;color:var(--accent);transition:transform .3s}
.faq-item.is-open .ico{background:var(--accent)}
.faq-item.is-open .ico svg{color:#fff;transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-a .inner{padding:0 24px 22px;color:var(--muted);font-size:.97rem}

/* ===== Formularz (multi-step) ===== */
.lead-wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:0;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-lg);background:#fff;border:1px solid var(--line)}
.lead-side{background:var(--grad-hero);color:#fff;padding:46px 40px;position:relative;overflow:hidden}
.lead-side::after{content:"";position:absolute;right:-60px;bottom:-60px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(190,22,34,.3),transparent 70%)}
.lead-side h3{color:#fff;font-size:1.7rem;margin-bottom:14px}
.lead-side p{color:#e7d6d8;margin-bottom:24px}
.lead-side .lpoint{display:flex;gap:12px;align-items:center;margin-bottom:14px;font-size:.95rem;color:#f6ece d}
.lead-side .lpoint svg{width:22px;height:22px;color:var(--gold-soft);flex:none}
.lead-form{padding:42px 40px}
.lead-steps{display:flex;gap:8px;margin-bottom:26px}
.lstep-dot{flex:1;height:6px;border-radius:3px;background:var(--line-2);transition:.3s}
.lstep-dot.is-active{background:var(--grad-navy)}
.fstep{display:none}
.fstep.is-active{display:block;animation:fade .4s ease}
.fstep h4{font-family:var(--font-body);font-size:1.15rem;margin-bottom:6px}
.fstep>p{font-size:.9rem;margin-bottom:20px}
.opt-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}
.opt{border:1.5px solid var(--line-2);border-radius:var(--r);padding:18px;cursor:pointer;transition:.2s;display:flex;gap:12px;align-items:center}
.opt:hover{border-color:var(--accent)}
.opt.is-sel{border-color:var(--accent);background:rgba(190,22,34,.05);box-shadow:var(--shadow-sm)}
.opt .ic{width:40px;height:40px;border-radius:10px;background:var(--bg-alt);display:grid;place-items:center;flex:none}
.opt .ic svg{width:22px;height:22px;color:var(--accent)}
.opt .t b{display:block;color:var(--navy);font-size:.98rem}
.opt .t span{font-size:.8rem;color:var(--muted)}
.field{margin-bottom:16px}
.field label{display:block;font-size:.85rem;font-weight:600;color:var(--navy);margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;padding:13px 15px;border:1.5px solid var(--line-2);border-radius:12px;font-family:inherit;font-size:.96rem;color:var(--ink);background:#fff;transition:.2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px rgba(190,22,34,.1)}
.form-actions{display:flex;gap:12px;justify-content:space-between;margin-top:8px}
.form-note{font-size:.78rem;color:var(--muted);margin-top:16px;display:flex;gap:8px;align-items:flex-start}
.form-note svg{width:15px;height:15px;flex:none;margin-top:2px;color:var(--teal-600)}
.form-success{text-align:center;padding:20px 0}
.form-success .ok{width:72px;height:72px;border-radius:50%;background:var(--grad-teal);display:grid;place-items:center;margin:0 auto 18px}
.form-success .ok svg{width:38px;height:38px;color:#fff}

/* ===== Stopka ===== */
.footer{background:var(--navy-900);color:#cdbbbe;padding:70px 0 0}
.footer .container{position:relative;z-index:1}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer .brand-name{color:#fff}
.footer p{color:#bda9ac;font-size:.92rem;margin-top:16px}
.footer h5{color:#fff;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:18px;font-weight:700}
.footer ul li{margin-bottom:11px}
.footer ul a{color:#bda9ac;font-size:.92rem;transition:color .2s}
.footer ul a:hover{color:var(--gold-soft)}
.foot-contact div{display:flex;gap:10px;align-items:flex-start;margin-bottom:14px;font-size:.92rem;color:#e7d6d8}
.foot-contact svg{width:18px;height:18px;color:var(--gold-soft);flex:none;margin-top:3px}
.foot-disclaimer{font-size:.78rem;color:#7e96ad;padding:22px 0;line-height:1.7}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;padding:20px 0;border-top:1px solid rgba(255,255,255,.08);font-size:.84rem;color:#7e96ad}

/* ===== Floating: AI + WhatsApp + sticky CTA ===== */
.fab-stack{position:fixed;right:22px;bottom:22px;z-index:80;display:flex;flex-direction:column;gap:12px;align-items:flex-end}
.fab{width:60px;height:60px;border-radius:50%;display:grid;place-items:center;box-shadow:var(--shadow-lg);transition:transform .25s;position:relative}
.fab:hover{transform:scale(1.08)}
.fab svg{width:28px;height:28px;color:#fff}
.fab-ai{background:var(--grad-navy)}
.fab-wa{background:#25D366}
.fab-pulse::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid currentColor;color:var(--blue);animation:pulse 2s infinite;opacity:0}
@keyframes pulse{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.5);opacity:0}}
.fab-tip{position:absolute;right:72px;top:50%;transform:translateY(-50%);background:var(--navy);color:#fff;font-size:.82rem;padding:8px 14px;border-radius:10px;white-space:nowrap;box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:.25s}
.fab:hover .fab-tip{opacity:1;right:76px}
.fab-tip::after{content:"";position:absolute;right:-5px;top:50%;transform:translateY(-50%) rotate(45deg);width:10px;height:10px;background:var(--navy)}

/* Panel czatu AI (interaktywny) */
.ai-panel{position:fixed;right:22px;bottom:22px;z-index:90;width:380px;max-width:calc(100vw - 28px);
  height:560px;max-height:calc(100vh - 40px);background:#fff;border-radius:var(--r-xl);box-shadow:var(--shadow-lg);
  display:flex;flex-direction:column;overflow:hidden;transform:translateY(30px) scale(.96);opacity:0;pointer-events:none;
  transition:transform .3s cubic-bezier(.2,.8,.2,1),opacity .3s;border:1px solid var(--line)}
.ai-panel.is-open{transform:none;opacity:1;pointer-events:auto}
.ai-panel .ap-head{background:var(--grad-navy);color:#fff;padding:18px 20px;display:flex;align-items:center;gap:12px}
.ai-panel .ap-head .av{width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.16);display:grid;place-items:center;flex:none}
.ai-panel .ap-head .av svg{width:24px;height:24px}
.ai-panel .ap-head .nm{font-weight:700;font-size:1rem;line-height:1.2}
.ai-panel .ap-head .st{font-size:.76rem;color:#ecd8da;display:flex;align-items:center;gap:6px}
.ai-panel .ap-head .st::before{content:"";width:7px;height:7px;border-radius:50%;background:#56e0a0}
.ai-panel .ap-close{margin-left:auto;width:34px;height:34px;border-radius:9px;background:rgba(255,255,255,.12);display:grid;place-items:center;color:#fff}
.ai-panel .ap-close svg{width:18px;height:18px}
.ai-panel .ap-body{flex:1;overflow-y:auto;padding:20px;background:var(--bg);display:flex;flex-direction:column;gap:12px}
.ai-panel .ap-foot{padding:14px 16px;border-top:1px solid var(--line);background:#fff}
.ai-panel .ap-quick{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.ai-panel .ap-input{display:flex;gap:8px}
.ai-panel .ap-input input{flex:1;padding:12px 14px;border:1.5px solid var(--line-2);border-radius:var(--r-pill);font-family:inherit;font-size:.92rem}
.ai-panel .ap-input input:focus{outline:none;border-color:var(--accent)}
.ai-panel .ap-input button{width:46px;height:46px;border-radius:50%;background:var(--grad-navy);color:#fff;display:grid;place-items:center;flex:none}
.ai-panel .ap-input button svg{width:20px;height:20px}
.ai-disc{font-size:.7rem;color:var(--muted);text-align:center;margin-top:8px}
.typing{display:flex;gap:4px;padding:14px 16px;background:#fff;border:1px solid var(--line);border-radius:16px;border-bottom-left-radius:5px;align-self:flex-start;width:fit-content}
.typing span{width:8px;height:8px;border-radius:50%;background:var(--line-2);animation:blink 1.2s infinite}
.typing span:nth-child(2){animation-delay:.2s}.typing span:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}

/* Sticky CTA mobile */
.sticky-cta{display:none;position:fixed;left:0;right:0;bottom:0;z-index:70;background:rgba(255,255,255,.96);
  backdrop-filter:blur(10px);border-top:1px solid var(--line);padding:12px 16px;gap:10px;box-shadow:0 -6px 20px rgba(58,26,30,.08)}
.sticky-cta .btn{flex:1;padding:14px}

/* Placeholder „zdjęcie" */
.ph{position:relative;border-radius:var(--r-lg);background:linear-gradient(135deg,#e8eef5,#dce7f1);display:grid;place-items:center;color:#8aa0b6;overflow:hidden;min-height:200px}
.ph::after{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(58,26,30,.05) 1px,transparent 1px);background-size:18px 18px}
.ph .ph-in{position:relative;text-align:center;font-size:.82rem;font-weight:600;letter-spacing:.02em}
.ph .ph-in svg{width:34px;height:34px;margin:0 auto 8px;color:#a9bccd;display:block}

/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.8,.2,1)}
.reveal.is-visible{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* Pasek info górny (banner) */
.notice{display:flex;align-items:center;justify-content:center;gap:10px;background:var(--gold);color:#3a2c08;
  font-size:.84rem;font-weight:600;padding:9px 16px;text-align:center}
.notice svg{width:16px;height:16px}

/* ===== Responsywność ===== */
@media (max-width:1024px){
  .hero .container{grid-template-columns:1fr;gap:40px}
  .hero-card{max-width:480px}
  .grid-4,.proc-grid,.care-grid,.acc-grid{grid-template-columns:repeat(2,1fr)}
  .timeline{grid-template-columns:repeat(3,1fr);row-gap:34px}
  .timeline::before{display:none}
  .stats{grid-template-columns:repeat(3,1fr);row-gap:24px}
  .stat:nth-child(4){border-left:none}
  .ai-feature{grid-template-columns:1fr;gap:34px}
  .lead-wrap{grid-template-columns:1fr}
  .lead-side{display:none}
}
@media (max-width:720px){
  body{font-size:16px}
  .section{padding:64px 0}
  .topbar{display:none}
  .nav-menu{position:fixed;inset:74px 0 auto 0;flex-direction:column;background:#fff;padding:18px;
    box-shadow:var(--shadow-lg);transform:translateY(-130%);transition:transform .35s;align-items:stretch;gap:4px;border-bottom:1px solid var(--line)}
  .nav-menu.is-open{transform:none}
  .nav-menu a{padding:14px}
  .nav .nav-cta .btn:not(.nav-toggle){display:none}
  .nav-toggle{display:block}
  .split,.grid-3,.grid-4,.grid-2,.proc-grid,.care-grid,.tgrid,.acc-grid,.price-grid,.ba-wrap{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .stat{border-left:none!important}
  .timeline{grid-template-columns:1fr;gap:14px}
  .care-banner{flex-direction:column;text-align:center;align-items:center}
  .fab-stack{right:14px;bottom:84px}
  .sticky-cta{display:flex}
  .hero{padding:54px 0 64px}
  .section-head{margin-bottom:40px}
  .opt-grid{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* ==========================================================================
   Galeria metamorfoz (przed/po — brandowane materiały Medical Park)
   ========================================================================== */
.meta-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:28px}
.meta-gallery figure{margin:0;border-radius:var(--r-lg);overflow:hidden;background:#fff;
  box-shadow:var(--shadow);border:1px solid var(--line);transition:transform .25s,box-shadow .25s}
.meta-gallery figure:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.meta-gallery img{display:block;width:100%;height:100%;object-fit:cover;aspect-ratio:3/2}
@media (max-width:900px){.meta-gallery{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.meta-gallery{grid-template-columns:1fr}}

/* ==========================================================================
   Hero / subhero ze zdjęciem w tle (estetyka)
   ========================================================================== */
.hero--photo{position:relative;isolation:isolate;background:var(--grad-hero)}
.hero--photo .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  z-index:0;opacity:.9}
/* Ciemnoczerwony overlay: ciemniej u dołu (.72), lżej u góry (.55) — biały tekst czytelny */
.hero--photo::before{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(74,8,12,.55) 0%,rgba(90,9,16,.62) 45%,rgba(122,10,17,.78) 100%)}
.hero--photo::after{content:"";position:absolute;inset:0;z-index:1;opacity:.5;
  background-image:radial-gradient(rgba(255,255,255,.10) 1px,transparent 1px);background-size:26px 26px;
  -webkit-mask-image:linear-gradient(180deg,transparent,#000 30%,#000 70%,transparent);
          mask-image:linear-gradient(180deg,transparent,#000 30%,#000 70%,transparent)}
.hero--photo .container{position:relative;z-index:2}

/* Subhero podstrony zabiegu (wariant wyśrodkowany na tle-zdjęciu) */
.subhero{position:relative;isolation:isolate;color:#fff;overflow:hidden;
  padding:78px 0 84px;background:var(--grad-hero)}
.subhero .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.85}
.subhero::before{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(74,8,12,.58) 0%,rgba(90,9,16,.66) 45%,rgba(122,10,17,.80) 100%)}
.subhero .container{position:relative;z-index:2;max-width:880px;text-align:center}
.subhero .crumbs{font-size:.86rem;color:#f2d2d4;margin-bottom:18px}
.subhero .crumbs a{color:#f2d2d4}
.subhero .crumbs a:hover{color:#fff}
.subhero h1{color:#fff;margin-bottom:16px}
.subhero .lead{color:#f3e0e1;font-size:1.16rem;max-width:640px;margin:0 auto 30px}
.subhero .hero-actions{justify-content:center}
.subhero .hero-trust{justify-content:center;margin-top:30px}

/* ==========================================================================
   Siatka kafelków zabiegów (treat-grid → treat-card)
   ========================================================================== */
.treat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.treat-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);
  border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .3s cubic-bezier(.2,.8,.2,1),box-shadow .3s,border-color .3s}
.treat-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.treat-card .tc-media{position:relative;aspect-ratio:16/11;overflow:hidden;background:var(--bg-alt)}
.treat-card .tc-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.treat-card:hover .tc-media img{transform:scale(1.05)}
.treat-card .tc-media .tc-ic{position:absolute;left:16px;bottom:-22px;width:52px;height:52px;border-radius:15px;
  background:var(--grad-navy);display:grid;place-items:center;box-shadow:var(--shadow);border:2px solid #fff}
.treat-card .tc-ic svg{width:26px;height:26px;color:#fff}
.treat-card .tc-body{padding:32px 24px 26px;display:flex;flex-direction:column;flex:1}
.treat-card h3{font-size:1.22rem;margin-bottom:8px}
.treat-card p{font-size:.94rem;margin-bottom:18px;flex:1}
.treat-card .tc-more{display:inline-flex;align-items:center;gap:8px;color:var(--accent);
  font-weight:700;font-size:.92rem;transition:gap .25s}
.treat-card .tc-more svg{width:16px;height:16px;transition:transform .25s}
.treat-card:hover .tc-more{gap:12px}
.treat-card:hover .tc-more svg{transform:translateX(4px)}

/* ==========================================================================
   Podstrona zabiegu — treść (treat-section / treat-steps / treat-faq)
   ========================================================================== */
.treat-section .lead{font-size:1.12rem;margin-bottom:24px;max-width:760px}
.treat-lead-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:44px;align-items:center}
.treat-lead-grid .treat-figure{border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-lg);border:1px solid var(--line)}
.treat-lead-grid .treat-figure img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.treat-points{display:flex;flex-direction:column;gap:14px;margin-top:22px}
.treat-points li{display:flex;gap:12px;align-items:flex-start;font-size:1rem;color:var(--ink)}
.treat-points li svg{width:22px;height:22px;color:var(--accent);flex:none;margin-top:2px}

/* Proces w krokach (pionowa oś na podstronie) */
.treat-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;counter-reset:tstep}
.treat-steps .tstep{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  padding:26px 22px;position:relative;transition:transform .3s,box-shadow .3s}
.treat-steps .tstep:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.treat-steps .tstep .num{counter-increment:tstep;width:48px;height:48px;border-radius:14px;
  background:linear-gradient(135deg,rgba(190,22,34,.12),rgba(201,162,75,.14));display:grid;place-items:center;
  font-family:var(--font-head);font-weight:700;color:var(--accent);font-size:1.25rem;margin-bottom:16px}
.treat-steps .tstep .num::after{content:counter(tstep)}
.treat-steps .tstep h4{font-family:var(--font-body);font-size:1.04rem;color:var(--navy);margin-bottom:6px}
.treat-steps .tstep p{font-size:.9rem}

/* Cennik — pojedyncza karta na podstronie */
.treat-price{max-width:640px;margin:0 auto;text-align:center;background:#fff;border:1px solid var(--line);
  border-radius:var(--r-xl);padding:38px 32px;box-shadow:var(--shadow)}
.treat-price .amt{font-family:var(--font-head);font-size:1.9rem;color:var(--navy);font-weight:700;margin:6px 0 12px}
.treat-price p{font-size:.96rem;margin-bottom:22px}

/* treat-faq: reuse .faq */
.treat-note{font-size:.84rem;color:var(--muted);margin-top:18px;text-align:center}

/* Wybór zabiegu w formularzu (3 opcje jedna pod drugą) */
.opt-grid--treat{grid-template-columns:1fr}

@media (max-width:1024px){
  .treat-grid{grid-template-columns:repeat(2,1fr)}
  .treat-lead-grid{grid-template-columns:1fr;gap:30px}
  .treat-steps{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:720px){
  .treat-grid,.treat-steps{grid-template-columns:1fr}
  .subhero{padding:54px 0 60px}
}
