/* ════════════════════════════════════════
   HERO
════════════════════════════════════════ */
.hero{
  position:relative;overflow:hidden;
  display:grid;grid-template-columns:1fr 1fr;
  min-height:calc(100svh - var(--nav-h) - var(--top-h));
  background-color:var(--white);
  background-repeat:no-repeat;
  background-position:right center;
  background-size:cover;
}
/* Białe gradient fade po lewej stronie żeby tło PNG nie zaśmiecało tekstu */
.hero::before{
  content:""; position:absolute; inset:0; z-index:0;
  background:linear-gradient(90deg, var(--white) 0%, rgba(255,255,255,.95) 30%, rgba(255,255,255,.65) 45%, transparent 60%);
  pointer-events:none;
}

.hero-bg{display:none}
/* Responsywne hero-bg — mobile używa mniejszej wersji JPG (~23KB) */
@media (max-width: 768px) {
  .hero {
    background-image: url('../hero/hero-bg-mobile.jpg') !important;
  }
}
@keyframes bfloat{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(14px,-16px) scale(1.04)}}

.hero-txt{
  position:relative;z-index:2;
  display:flex;flex-direction:column;justify-content:center;
  padding:clamp(40px,5vw,80px) clamp(20px,4vw,60px) clamp(40px,5vw,80px) var(--px);
}

/* pill tag — outline różowy z bardzo jasnym mag-w bg */
.hero-pill-tag{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(253,240,250,.6);
  border:1px solid rgba(223,59,163,.3);
  color:var(--mag);font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  padding:8px 18px;border-radius:var(--r-pill);
  margin-bottom:28px;width:fit-content;
  animation:fadeUp .5s .05s both;
}
.hero-pill-tag svg{flex-shrink:0}
.hero-h1{
  font-family:var(--f-serif);font-weight:400;
  font-size:clamp(38px,4.5vw,58px);line-height:1.05;
  color:var(--ink);
  margin-bottom:20px;
  animation:fadeUp .5s .12s both;
}
.hero-h1 em,.hero-h1 .hl{font-style:italic;color:var(--mag);font-weight:400}
.hero-sub{
  font-family:var(--f-ui);
  font-size:clamp(15px,1.3vw,17px);line-height:1.65;
  color:var(--ink);max-width:480px;font-weight:400;
  margin-bottom:38px;
  animation:fadeUp .5s .19s both;
}
.hero-btns{
  display:flex;gap:14px;flex-wrap:wrap;
  margin-bottom:44px;
  animation:fadeUp .5s .26s both;
}
.hero-btns .btn-p,.hero-btns .btn-s{padding:13px 28px;font-size:15px}

.hero-stats{
  display:flex;gap:clamp(20px,3.5vw,44px);flex-wrap:wrap;
  padding-top:26px;border-top:.5px solid rgba(0,0,0,.08);
  animation:fadeUp .5s .33s both;
}
.hs-n{font-family:var(--f-serif);font-weight:400;font-size:clamp(28px,2.8vw,40px);line-height:1;color:var(--mag)}
.hs-l{font-size:12px;color:var(--gray);margin-top:4px;line-height:1.4}

@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}

/* hero visual side — przezroczyste, tło jest na całym .hero */
.hero-vis{
  position:relative;z-index:1;
  display:flex;align-items:center;justify-content:center;
  background:transparent;
  overflow:visible;
  min-height:560px;
}

/* floating stats badge — kompaktowa karta, ikona po lewej, tekst w dwóch liniach */
.hbadge{
  position:absolute;z-index:10;
  background:var(--white);border-radius:16px;
  padding:16px 24px 16px 18px;
  box-shadow:0 12px 32px rgba(27,16,32,.08);
  display:flex;align-items:center;gap:14px;
}
.hbadge.b1{
  bottom:clamp(40px,7vw,80px);
  left:clamp(20px,3vw,40px);
  right:auto;
  animation:anim-float 3.5s ease-in-out infinite;
}
.hbadge::before{
  content:""; width:48px;height:48px;border-radius:50%;
  background:var(--mag-w);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23DF3BA3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M16 21v-2a4 4 0 0 0-4-4H6a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='9' cy='7' r='4'/%3E%3Cpath d='M22 21v-2a4 4 0 0 0-3-3.87'/%3E%3Cpath d='M16 3.13a4 4 0 0 1 0 7.75'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;background-size:26px;
  flex-shrink:0;
}
@keyframes anim-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.hbn{font-family:var(--f-serif);font-size:34px;line-height:1;color:var(--mag);font-weight:400}
.hbl{font-family:var(--f-ui);font-size:13px;color:var(--slate);margin-top:4px;line-height:1.3;font-weight:500}

/* ════════════════════════════════════════
   TRUST BAR
════════════════════════════════════════ */
.trust{
  background:#fafafa;
  padding:clamp(20px,2.5vw,36px) clamp(20px,3vw,48px);
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:clamp(14px,1.5vw,22px);
  width:100%;
}
.ti{
  display:flex;align-items:center;gap:clamp(14px,1.3vw,20px);
  padding:clamp(22px,2.4vw,30px) clamp(22px,2.4vw,30px);
  background:var(--white);
  border:none;
  border-radius:14px;
  box-shadow:0 4px 16px rgba(27,16,32,.04);
  cursor:default;
  transition:box-shadow var(--tn) var(--eo),transform var(--tn) var(--eo);
}
.ti:hover{
  box-shadow:0 12px 32px rgba(223,59,163,.10);
  transform:translateY(-2px);
}
.ti-ico{
  width:clamp(52px,4.5vw,64px); height:clamp(52px,4.5vw,64px);
  flex-shrink:0;
  border-radius:50%;
  background:var(--mag-w);
  display:flex;align-items:center;justify-content:center;
  transition:transform var(--tn) var(--spring),box-shadow var(--tn) var(--eo);
}
.ti-ico svg{
  width:58%;height:58%;display:block;
  shape-rendering:geometricPrecision;
}
.ti:hover .ti-ico{
  transform:scale(1.08);
  box-shadow:0 8px 20px rgba(223,59,163,.22);
}

/* Animacje ikon trust — pulsuj zamiast obracać */
.ti-ico.anim-pulse{
  animation:trust-pulse 2.2s ease-in-out infinite;
}
.ti-ico.anim-bounce{
  animation:trust-bounce 3s ease-in-out infinite;
}
.ti-ico.anim-shake{
  animation:trust-shake 4s ease-in-out infinite;
}
@keyframes trust-pulse{
  0%,100%{ transform:scale(1); box-shadow:0 0 0 0 rgba(223,59,163,.22); }
  50%{ transform:scale(1.06); box-shadow:0 0 0 10px rgba(223,59,163,0); }
}
@keyframes trust-bounce{
  0%,100%{ transform:translateY(0); }
  50%{ transform:translateY(-4px); }
}
@keyframes trust-shake{
  0%,90%,100%{ transform:rotate(0); }
  92%{ transform:rotate(-6deg); }
  94%{ transform:rotate(6deg); }
  96%{ transform:rotate(-4deg); }
  98%{ transform:rotate(4deg); }
}
.ti-txt{display:flex;flex-direction:column;gap:6px;padding-top:4px;min-width:0;flex:1}
.ti-txt strong{
  font-family:var(--f-ui);
  font-size:clamp(16px,1.4vw,19px);
  font-weight:700; letter-spacing:-.01em;
  color:var(--ink); line-height:1.3;
}
.ti-txt span{
  font-family:var(--f-ui);
  font-size:clamp(13.5px,1vw,15px);
  color:var(--slate); line-height:1.5; font-weight:400;
}

/* ════════════════════════════════════════
   SHARED SEC STYLES
════════════════════════════════════════ */
.sec{padding:clamp(48px,6vw,80px) var(--px)}
.slbl{display:block;font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--mag);margin-bottom:12px}
.stitle{font-family:var(--f-serif);font-weight:400;font-size:clamp(26px,2.8vw,40px);line-height:1.1;color:var(--ink)}
.stitle em{font-style:italic}
.stitle .hl{color:var(--mag)}
.ssub{font-size:clamp(14px,1.4vw,17px);line-height:1.72;color:var(--gray);max-width:600px;margin-top:14px}
.sec-head{margin-bottom:clamp(32px,4vw,52px);max-width: var(--max); margin-inline: auto;}
.sec-head.ctr{text-align:center}
.sec-head.ctr .ssub{margin:14px auto 0}
.sec-content{max-width: var(--max); margin: 0 auto;}

/* ════════════════════════════════════════
   SERVICES
════════════════════════════════════════ */
.services{background:var(--bg, #fafafa)}
.svc-g{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch}

/* Karta usługi — link na całej karcie + równe wysokości */
.svc{
  display:flex;flex-direction:column;
  background:var(--white);
  border:1px solid rgba(0,0,0,0.06);
  border-radius:var(--r-card);
  padding:clamp(22px,2.5vw,30px);
  position:relative;overflow:hidden;
  text-decoration:none;color:inherit;
  height:100%;
  transition:box-shadow .35s var(--eo),transform .35s var(--eo),border-color .25s,background .35s var(--eo);
}
/* Gradient hover-overlay (rosnie z lewego dolnego rogu) */
.svc::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,218,237,0.55) 0%,rgba(247,224,241,0.65) 50%,rgba(224,247,247,0.55) 100%);
  opacity:0;
  transition:opacity .35s var(--eo);
  pointer-events:none;z-index:0;
}
/* Pasek na dole — pojawia się przy hover */
.svc::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--mag),var(--teal));
  transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--eo);
  z-index:1;
}
.svc:hover{
  box-shadow:0 18px 50px rgba(223,59,163,0.14);
  transform:translateY(-6px);
  border-color:rgba(223,59,163,0.22);
}
.svc:hover::before{opacity:1}
.svc:hover::after{transform:scaleX(1)}

/* Cała zawartość karty nad gradient overlay */
.svc > *{position:relative;z-index:1}

.svc-ico{
  width:56px;height:56px;border-radius:var(--r-btn);
  background:var(--blush, #FFDAED);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;overflow:hidden;flex-shrink:0;
  transition:transform var(--tn) var(--spring),background var(--tn) var(--eo);
}
.svc:hover .svc-ico{transform:scale(1.08) rotate(-6deg)}
.svc-ico img{width:38px;height:38px;object-fit:contain}
.svc-ico i{font-size:24px;color:var(--mag)}
/* Color variants — bg w jasnym odcieniu, ikona w nasyconym (czytelny kontrast) */
.svc-ico.mag{background:var(--mag-w)}
.svc-ico.mag i{color:var(--mag)}
.svc-ico.blush{background:var(--blush)}
.svc-ico.blush i{color:var(--mag-d)}
.svc-ico.teal{background:var(--teal-g)}
.svc-ico.teal i{color:var(--teal)}
.svc-ico.green{background:var(--green-g)}
.svc-ico.green i{color:#2d8a3a}

.svc-title{font-size:18px;font-weight:600;color:var(--ink);margin-bottom:10px;line-height:1.3}
.svc-desc{font-size:14px;color:var(--gray);line-height:1.65;margin-bottom:16px}
.svc-ul{list-style:none;display:flex;flex-direction:column;gap:7px;margin-bottom:20px;padding:0}
.svc-ul li{font-size:13.5px;color:var(--gray);display:flex;align-items:center;gap:10px}
.svc-ul li::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--mag);flex-shrink:0}

/* CTA na dole — auto margin top żeby zawsze przylegał do dolu */
.svc-cta{
  margin-top:auto;
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 18px;
  background:transparent;
  border:1px solid rgba(223,59,163,.4);
  color:var(--mag);
  font-size:13.5px;font-weight:600;
  border-radius:var(--r-btn);
  align-self:flex-start;
  transition:background .25s var(--eo),color .25s var(--eo),border-color .25s var(--eo),transform .25s var(--eo);
}
.svc-cta i{transition:transform .25s var(--eo)}
.svc:hover .svc-cta{
  background:var(--mag);
  color:var(--white);
  border-color:var(--mag);
}
.svc:hover .svc-cta i{transform:translateX(4px)}

@media(max-width:1024px){.svc-g{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.svc-g{grid-template-columns:1fr}}

/* ════════════════════════════════════════
   WHY US (v2 — z 4 ikonami u góry + teal box)
════════════════════════════════════════ */
.why.why-v2{background:var(--white);padding:clamp(48px,6vw,80px) var(--px)}
.why-v2 .why-inner{max-width:var(--max);margin:0 auto}

.why-v2 .sec-head{margin-bottom:clamp(36px,4vw,52px);max-width:1024px;margin-inline:auto;text-align:center}
.why-v2 .sec-head .slbl{text-align:center}
.why-v2 .sec-head .stitle{font-size:clamp(28px,3vw,42px)}
.why-v2 .sec-head .stitle em{font-style:italic;color:var(--mag);font-weight:400}

/* Top: 4 icon pills row */
.why-icons-row{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  text-align:center;margin-bottom:clamp(40px,5vw,56px);
}
.why-icon-item{
  display:flex;flex-direction:column;align-items:center;gap:14px;
  padding:0 14px;position:relative;
}
.why-icon-item:not(:last-child)::after{
  content:'';position:absolute;top:24px;right:0;
  width:1px;height:28px;background:rgba(223,59,163,.15);
}
.wii-ico{
  width:54px;height:54px;border-radius:50%;
  background:var(--white);border:1px solid rgba(0,0,0,.07);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;color:var(--mag);
  box-shadow:0 2px 12px rgba(0,0,0,.05);
  transition:transform var(--tn) var(--spring),background var(--tn);
}
.why-icon-item:hover .wii-ico{
  background:var(--mag-w);
  transform:scale(1.08) rotate(-5deg);
}
.wii-title{font-size:14px;font-weight:600;color:var(--ink);margin-top:2px}
.wii-desc{font-size:12.5px;color:var(--gray);line-height:1.5;max-width:220px;margin-inline:auto}

/* Teal box section */
.why-teal{
  background:#ECF8F7;
  border-radius:var(--r-card);
  overflow:hidden;
  display:grid;grid-template-columns:1fr 1fr;
  min-height:340px;
}
.why-teal-img{
  background:#DFF1F0;
  display:flex;align-items:flex-end;justify-content:center;
  padding:30px;overflow:hidden;position:relative;
}
.why-teal-img svg{margin-bottom:-10px}
.why-teal-text{
  padding:clamp(24px,3vw,44px);
  display:flex;flex-direction:column;justify-content:center;
}
.why-quote{
  font-size:16px;color:var(--slate, #4a5568);line-height:1.72;
  margin-bottom:24px;
  border-left:3px solid rgba(155,212,207,.6);
  padding-left:16px;
}
.why-teal-title{
  font-family:var(--f-serif);font-weight:400;
  font-size:clamp(22px,2.2vw,30px);line-height:1.15;
  color:var(--ink);margin-bottom:10px;
}
.why-teal-title em{font-style:italic;color:var(--mag);font-weight:400}
.why-teal-sub{
  font-size:14.5px;color:var(--gray);line-height:1.65;
  margin-bottom:22px;
}

/* Punkty w teal-box */
.why-teal .why-pts{display:flex;flex-direction:column;gap:14px;margin:0 0 24px}
.why-teal .wpt{
  display:flex;gap:14px;align-items:flex-start;
  padding:10px;border-radius:var(--r-btn);
  transition:background var(--tn) var(--eo);cursor:default;
}
.why-teal .wpt:hover{background:rgba(155,212,207,.18)}
.why-teal .wpt-ico{
  width:40px;height:40px;flex-shrink:0;border-radius:10px;
  background:rgba(155,212,207,.32);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;color:var(--teal);
  transition:background var(--tn),color var(--tn),transform var(--tn) var(--spring);
}
.why-teal .wpt:hover .wpt-ico{
  background:var(--mag);color:var(--white);
  transform:scale(1.1) rotate(-8deg);
}
.why-teal .wpt-t{font-size:14.5px;font-weight:600;color:var(--ink);margin-bottom:2px}
.why-teal .wpt-d{font-size:13px;color:var(--gray);line-height:1.55;margin:0}

.why-cta{display:flex;gap:12px;flex-wrap:wrap}
.why-cta .btn-p{padding:12px 24px;font-size:14px}

/* ════════════════════════════════════════
   STATS & PROCESS
════════════════════════════════════════ */
.stats{background:var(--white)}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);border:.5px solid rgba(0,0,0,.08);border-radius:var(--r-card);overflow:hidden;max-width: var(--max); margin: 0 auto;}
.st{padding:clamp(24px,4vw,44px) clamp(16px,3vw,36px);text-align:center;border-right:.5px solid rgba(0,0,0,.08);transition:background var(--tn) var(--eo)}
.st:last-child{border-right:none}
.st:hover{background:var(--mag-w)}
.st-n{font-family:var(--f-serif);font-size:clamp(34px,3.5vw,50px);line-height:1;color:var(--mag);margin-bottom:8px}
.st-l{font-size:14px;color:var(--gray);line-height:1.5}

/* PROCESS v2 — pill + okręgi z numerami + dashed connector */
.process.process-v2{
  background:var(--mag-w, #fef4fa);
  padding:clamp(56px,7vw,96px) var(--px);
  position:relative; overflow:hidden;
}
.process-v2 .process-inner{max-width:var(--max);margin:0 auto;position:relative;z-index:2}

/* Floral dekoracje po bokach sekcji */
.process-floral{
  position:absolute; z-index:1;
  width:clamp(200px,22vw,320px); height:auto;
  pointer-events:none;
  opacity:.55;
}
.process-floral-l{ left:-40px; bottom:-40px; }
.process-floral-r{ right:-40px; top:-40px; }
@media(max-width:1024px){
  .process-floral{ display:none; }
}

/* Pill label */
.pill-lbl{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--white);border:1px solid rgba(223,59,163,.3);
  color:var(--mag);font-size:11px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;
  padding:7px 16px;border-radius:var(--r-pill);
  margin:0 auto 18px;
}
.process-v2 .sec-head{margin-bottom:clamp(40px,5vw,64px);text-align:center}
.process-v2 .sec-head .stitle{font-size:clamp(30px,3.5vw,48px)}
.process-v2 .sec-head .stitle em{font-style:italic;color:var(--mag);font-weight:400}

/* Grid 4 kroków — karty z numerem + SVG + tytuł + opis */
.proc-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:clamp(16px,1.8vw,28px);
  position:relative;
  margin-top:clamp(32px,4vw,52px);
}
/* Dotted connector — linia między kartami (poziom numeru) */
.proc-grid::before{
  content:'';position:absolute;
  top:48px;
  left:calc(12.5% + 36px);right:calc(12.5% + 36px);
  height:0;
  border-top:2px dotted rgba(223,59,163,.35);
  pointer-events:none;
  z-index:0;
}

.pstep{
  position:relative;z-index:1;
  text-align:center;
  background:var(--white);
  border:1px solid rgba(223,59,163,.10);
  border-radius:20px;
  padding:clamp(20px,2.2vw,32px) clamp(16px,1.8vw,24px) clamp(20px,2.2vw,28px);
  cursor:default;
  transition:transform var(--tn) var(--spring),box-shadow var(--tn) var(--eo),border-color var(--tn);
}
.pstep:hover{
  transform:translateY(-4px);
  box-shadow:0 16px 40px rgba(223,59,163,.12);
  border-color:rgba(223,59,163,.25);
}
.pstep-num{
  width:48px;height:48px;border-radius:50%;
  border:2px solid var(--mag);
  background:var(--white);
  color:var(--mag);
  font-family:var(--f-serif);font-size:20px;font-weight:400;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 18px;
  position:relative;z-index:2;
  transition:background var(--tn) var(--eo),color var(--tn) var(--eo);
  box-shadow:0 4px 14px rgba(223,59,163,.12);
}
.pstep:hover .pstep-num{ background:var(--mag); color:var(--white); }

/* PNG ikona pod numerem (z paczki designerskiej) */
.pstep-ico{
  width:clamp(88px,8.5vw,116px); height:clamp(88px,8.5vw,116px);
  margin:0 auto 16px;
  display:flex;align-items:center;justify-content:center;
  transition:transform var(--tn) var(--spring);
}
.pstep-ico img,
.pstep-ico svg{
  width:100%;height:100%;display:block;
  object-fit:contain;
  image-rendering:auto;
}
.pstep:hover .pstep-ico{ transform:scale(1.05); }

.pstep-title{
  font-family:var(--f-ui);
  font-size:clamp(16px,1.4vw,19px);font-weight:600;letter-spacing:-.01em;
  color:var(--ink);
  margin-bottom:10px;line-height:1.3;
}
.pstep-desc{
  font-family:var(--f-ui);
  font-size:clamp(14px,1.1vw,15.5px);
  color:var(--slate);line-height:1.55;font-weight:400;
  margin:0;
}

/* Cascade reveal on first scroll into view */
.process-v2.in .pstep{
  animation: pstepFadeIn .55s var(--eo) backwards;
}
.process-v2.in .pstep:nth-child(1){animation-delay:.05s}
.process-v2.in .pstep:nth-child(2){animation-delay:.18s}
.process-v2.in .pstep:nth-child(3){animation-delay:.32s}
.process-v2.in .pstep:nth-child(4){animation-delay:.46s}
@keyframes pstepFadeIn{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}

@media(max-width:1024px){
  .proc-grid{grid-template-columns:repeat(2,1fr);gap:18px}
  .proc-grid::before{display:none}
}
@media(max-width:480px){
  .proc-grid{grid-template-columns:1fr}
}

/* ════════════════════════════════════════
   DOCTORS
════════════════════════════════════════ */
.doctors{background:var(--bg)}

/* ── Doctors head (mirror struktur usług DCG) ── */
.doc-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:clamp(20px,2.5vw,32px);flex-wrap:wrap}
.doc-head-left{flex:1;min-width:0}
.doc-head-left .slbl{display:inline-block;margin-bottom:8px}
.doc-head-left .stitle{margin:0 0 8px}
.doc-head-left .ssub{margin:0;max-width:640px}
.doc-head-right{display:flex;align-items:center;gap:16px;flex-shrink:0}

/* Mobile/tablet ≤900px: tekst na całą szerokość, nav + link pod spodem; większy ssub */
@media (max-width:1024px){
  .doc-head{flex-direction:column;align-items:stretch;gap:18px}
  .doc-head-left{width:100%}
  .doc-head-left .ssub{max-width:none;font-size:17px;line-height:1.55}
  .doc-head-right{width:100%;justify-content:space-between}
  .doc-head-right .svc-dcg-all{font-size:15px}
}
.doc-carousel-nav{display:flex;gap:8px}
.doc-carousel-nav .svc-nav-btn{
  width:42px;height:42px;border-radius:50%;border:1.5px solid rgba(0,0,0,.1);
  background:var(--white);color:var(--ink);cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;font-size:18px;
  transition:all var(--tf);
}
.doc-carousel-nav .svc-nav-btn:hover:not(:disabled){background:var(--mag);color:var(--white);border-color:var(--mag)}
.doc-carousel-nav .svc-nav-btn:disabled{opacity:.35;cursor:not-allowed}

/* ── Karuzela ── */
.doc-carousel-wrap{width:100%;position:relative}
.doc-carousel{
  display:flex;gap:clamp(14px,1.5vw,22px);
  overflow-x:auto;overflow-y:visible;
  scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
  touch-action:pan-x;
  padding:4px 4px 20px;cursor:grab;user-select:none;
  overscroll-behavior-x:contain;
}
.doc-carousel.is-dragging{cursor:grabbing;scroll-behavior:auto}
.doc-carousel::-webkit-scrollbar{display:none}

/* Karta: 5.5 widocznych desktop (5 + peek 6-tej) → 4 → 3 → 2 → 1.2 (peek mobile) */
.doc-carousel .doc{
  flex:0 0 calc((100% - 5 * clamp(14px,1.5vw,22px)) / 5.5);
  min-width:0;scroll-snap-align:start;
}
@media(max-width:1280px){.doc-carousel .doc{flex-basis:calc((100% - 4 * clamp(14px,1.5vw,22px)) / 4.5)}}
@media(max-width:1024px){.doc-carousel .doc{flex-basis:calc((100% - 3 * clamp(14px,1.5vw,22px)) / 3.4)}}
@media(max-width:768px){.doc-carousel .doc{flex-basis:calc((100% - 2 * clamp(14px,1.5vw,22px)) / 2.3)}}
@media(max-width:640px){.doc-carousel .doc{flex-basis:82%;max-width:none}.doc-carousel{gap:12px}}
.doc{
  background:var(--white);
  border:1px solid rgba(0,0,0,.06);
  border-radius:var(--r-card);
  overflow:hidden;
  text-decoration:none;color:inherit;
  display:flex;flex-direction:column;
  transition:box-shadow .35s var(--eo),transform .35s var(--eo),border-color .25s;
}
.doc:hover{
  box-shadow:0 14px 40px rgba(223,59,163,.12);
  transform:translateY(-5px);
  border-color:rgba(223,59,163,.18);
}

.doc-ph{
  aspect-ratio:1/1.05;
  background:linear-gradient(140deg,var(--blush, #FFDAED) 0%,var(--mag-w, #fef4fa) 100%);
  position:relative;overflow:hidden;
}
.doc-ph img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 18%;
  transition:transform .5s var(--eo),filter .35s var(--eo);
  image-rendering:auto;
  filter:saturate(1.02);
}
.doc:hover .doc-ph img{transform:scale(1.05);filter:saturate(1.08)}
.doc-ini{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--f-serif);font-size:56px;
  color:rgba(223,59,163,.22);
}

/* Badge specjalizacji — domyślnie magenta */
.doc-bdg{
  position:absolute;bottom:14px;left:14px;
  background:var(--mag);color:var(--white);
  font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:6px 13px;border-radius:var(--r-pill);
  box-shadow:0 2px 10px rgba(0,0,0,.18);
  backdrop-filter:saturate(1.4);
}
/* Kolory wg specjalizacji */
.doc-bdg.doc-bdg-founder { background:linear-gradient(135deg,#c98e2a,#d4a045); }    /* Założyciel — gold */
.doc-bdg.doc-bdg-gin     { background:var(--mag); }                                 /* Ginekolog — magenta */
.doc-bdg.doc-bdg-peri    { background:#0CB8B6; }                                    /* Perinatolog — teal */
.doc-bdg.doc-bdg-psy     { background:#7c4dff; }                                    /* Psycholog — violet */
.doc-bdg.doc-bdg-endo    { background:#f59e0b; }                                    /* Endokrynolog — amber */
.doc-bdg.doc-bdg-cardio  { background:#e74c3c; }                                    /* Kardiolog — red */
.doc-bdg.doc-bdg-diet    { background:#43a047; }                                    /* Dietetyk — green */
.doc-bdg.doc-bdg-fizjo   { background:#26a69a; }                                    /* Fizjoterapeuta — teal-2 */
.doc-bdg.doc-bdg-pol     { background:#ec4899; }                                    /* Położna — pink-2 */

.doc-bdy{
  padding:clamp(16px,1.5vw,20px);
  display:flex;flex-direction:column;flex:1;
}
.doc-name{
  font-size:18px;font-weight:700;color:var(--ink);
  margin-bottom:6px;line-height:1.3;letter-spacing:-.01em;
}
.doc-spec{
  font-size:14.5px;color:var(--mag);font-weight:500;
  margin-bottom:18px;line-height:1.45;
}
.doc-btn{
  display:block;text-align:center;
  padding:12px 14px;
  border:1.5px solid rgba(223,59,163,.22);
  border-radius:var(--r-btn);
  font-size:14.5px;font-weight:600;color:var(--mag);
  margin-top:auto;
  transition:all var(--tf) var(--eo);
}
.doc:hover .doc-btn{
  background:var(--mag);color:var(--white);border-color:var(--mag);
}

/* .doc-g zastąpione przez .doc-carousel (karuzela) — media queries niżej w sekcji karuzeli */

/* ════════════════════════════════════════
   KLINIKA & ESTETICA
════════════════════════════════════════ */
.clinic{background:var(--white)}
.clinic-g{
  display:grid;
  grid-template-columns: 1.2fr 1fr;
  gap: clamp(12px, 1.5vw, 20px);
  margin-top: clamp(24px,3vw,36px);
  align-items: stretch;
}
.cg-team{
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  min-height: clamp(360px, 42vw, 540px);
  box-shadow: 0 12px 36px rgba(26,21,35,.1);
}
.cg-team img{
  width:100%; height:100%;
  object-fit:cover; object-position: center top;
  display: block;
  transition: transform .5s var(--eo);
}
.cg-team:hover img{ transform: scale(1.04); }
.cg-team-overlay{
  position:absolute; bottom:0; left:0; right:0;
  padding: clamp(24px, 3vw, 36px);
  background: linear-gradient(to top, rgba(0,0,0,.78) 0%, rgba(0,0,0,.55) 50%, transparent 100%);
  color: var(--white);
  display: flex; flex-direction: column; gap: 6px;
}
.cg-team-label{
  font-size: 12.5px; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  color: rgba(255,255,255,.78);
}
.cg-team-title{
  font-family: var(--f-serif);
  font-size: clamp(22px, 2.4vw, 30px);
  font-weight: 400;
  line-height: 1.2;
  color: var(--white);
}

.cg-tiles{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(12px, 1.5vw, 20px);
}
.cg-tile{
  border-radius: 16px;
  overflow: hidden;
  position: relative;
  background: var(--mag-w);
  aspect-ratio: 4/3;
  box-shadow: 0 6px 20px rgba(26,21,35,.06);
}
.cg-tile img{
  width:100%; height:100%;
  object-fit:cover; object-position:center;
  display: block;
  transition: transform .5s var(--eo);
}
.cg-tile:hover img{ transform: scale(1.06); }
/* Legacy fallback compat */
.cg-main{display:none}
.cg-s{overflow:hidden;border-radius:var(--r-card)}
.clinic-g img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--eo)}
.clinic-g img:hover{transform:scale(1.04)}

.estetica{background:var(--teal-g);display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,72px);align-items:center;padding:clamp(48px,6vw,80px) clamp(28px,4vw,56px); max-width: var(--max); margin:clamp(40px,5vw,72px) auto; border-radius:var(--r-card,20px); overflow:hidden;}
.est-img{border-radius:var(--r-card);overflow:hidden;height:clamp(280px,32vw,450px)}
.est-img img{width:100%;height:100%;object-fit:cover}
.estetica .ssub{color:var(--slate)}
.est-ul{list-style:none;display:flex;flex-direction:column;gap:16px;margin-top:22px}
.est-li{display:flex;align-items:flex-start;gap:14px;font-size:14px;color:var(--slate);padding:12px;border-radius:var(--r-card);transition:background var(--tn) var(--eo)}
.est-li:hover{background:rgba(12,184,182,.08)}
.est-ico{width:36px;height:36px;flex-shrink:0;border-radius:var(--r-btn);background:var(--teal);display:flex;align-items:center;justify-content:center;font-size:17px;color:var(--white);transition:background var(--tn),transform var(--tn) var(--spring)}
.est-li:hover .est-ico{background:var(--mag);transform:scale(1.15) rotate(-8deg)}
.est-t{font-weight:500;color:var(--ink);margin-bottom:2px;font-size:15px}

/* ════════════════════════════════════════
   PROFILAKTYKA & OPINIE
════════════════════════════════════════ */
.prfl{background:var(--green-g)}
.prfl .ssub{color:var(--slate)}
.prfl-g{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:clamp(24px,3vw,40px)}
.prfl-c{background:var(--white);border-radius:var(--r-card);padding:clamp(20px,2.5vw,28px);border:.5px solid rgba(97,206,112,.15);transition:box-shadow var(--tn),transform var(--tn) var(--eo)}
.prfl-c:hover{box-shadow:0 8px 28px rgba(97,206,112,.15);transform:translateY(-3px)}
.prfl-ico{width:48px;height:48px;border-radius:var(--r-btn);background:var(--green-g);display:flex;align-items:center;justify-content:center;font-size:22px;color:#2d8a3a;margin-bottom:14px;transition:transform var(--tn) var(--spring),background var(--tn) var(--eo)}
.prfl-c:hover .prfl-ico{transform:scale(1.12) rotate(-6deg);background:#2d8a3a;color:var(--white)}
.prfl-bdg{display:inline-flex;align-items:center;gap:6px;background:var(--green-g);color:#2d8a3a;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:4px 12px;border-radius:var(--r-pill);margin-bottom:14px}
.prfl-bdg i{font-size:12px}
.prfl-t{font-size:17px;font-weight:500;color:var(--ink);margin-bottom:10px}
.prfl-d{font-size:14px;color:var(--slate);line-height:1.65}

.testi{background:var(--blush)}
.testi-trustmate{min-height:240px}
.testi-tm-placeholder{
  background:rgba(255,255,255,.7);
  border:2px dashed rgba(223,59,163,.25);
  border-radius:var(--r-card);
  padding:48px 32px;
  text-align:center;
  color:var(--slate);
  max-width:560px;
  margin:0 auto;
}
.testi-tm-placeholder i{font-size:40px;color:var(--mag);margin-bottom:12px;display:block}
.testi-tm-placeholder p{font-size:15px;line-height:1.6;margin-bottom:8px}
.testi-tm-placeholder a{color:var(--mag);font-weight:600;text-decoration:underline}
.testi-g{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.tcard{background:var(--white);border-radius:var(--r-card);padding:clamp(20px,2.5vw,28px);position:relative;transition:transform var(--tn),box-shadow var(--tn);border:.5px solid rgba(0,0,0,.06)}
.tcard:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(223,59,163,.08)}
.tq{font-family:var(--f-serif);font-size:70px;line-height:.55;color:var(--blush);position:absolute;top:14px;left:18px;user-select:none}
.tstars{display:flex;gap:3px;color:#F59E0B;font-size:14px;margin-bottom:14px}
.ttxt{font-size:14px;color:var(--slate);line-height:1.72;font-style:italic;position:relative;z-index:1}
.tauth{margin-top:18px;display:flex;align-items:center;gap:12px}
.tav{width:38px;height:38px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--blush),var(--mag));display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--white);font-weight:600}
.tname{font-size:13px;font-weight:600;color:var(--ink)}
.tsrc{font-size:11px;color:var(--gray)}

/* ════════════════════════════════════════
   CTA BANNER & BLOG & LOCATIONS
════════════════════════════════════════ */
.cta-ban{background:linear-gradient(135deg,var(--ink) 0%,#1a0e2e 50%,#2d1040 100%);padding:clamp(48px,6vw,80px) clamp(32px,5vw,72px);display:grid;grid-template-columns:1fr auto;gap:40px;align-items:center;position:relative;overflow:hidden; max-width: var(--max); margin:clamp(40px,5vw,72px) auto; border-radius:var(--r-card,24px);}
.cta-ban::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 8% 50%,rgba(223,59,163,.18) 0%,transparent 55%),radial-gradient(ellipse at 92% 20%,rgba(12,184,182,.10) 0%,transparent 50%);pointer-events:none}
.cta-ban::after{content:'';position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;border-radius:var(--r-card,24px);padding:2px;background:linear-gradient(135deg,rgba(223,59,163,.25),transparent 40%,transparent 60%,rgba(12,184,182,.18));-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.cta-title{font-family:var(--f-serif);font-weight:400;font-size:clamp(28px,3.4vw,44px);line-height:1.1;color:var(--white);margin-bottom:16px;position:relative;z-index:1;letter-spacing:-.005em}
.cta-title em{font-style:italic;color:var(--mag);font-weight:400;display:inline-block}
.cta-sub{font-size:clamp(14px,1.1vw,16px);color:rgba(255,255,255,.66);line-height:1.7;position:relative;z-index:1;max-width:560px}
.cta-contacts{display:flex;gap:24px;margin-top:22px;flex-wrap:wrap;position:relative;z-index:1}
.cci{display:flex;align-items:center;gap:10px;font-size:14px;color:rgba(255,255,255,.7)}
.cci i{font-size:16px;color:var(--mag);flex-shrink:0;width:32px;height:32px;border-radius:50%;background:rgba(223,59,163,.14);display:inline-flex;align-items:center;justify-content:center}
.cci a{color:rgba(255,255,255,.92);font-weight:500;transition:color var(--tn)}
.cci a:hover{color:var(--mag)}
.cta-btns{display:flex;flex-direction:column;gap:12px;min-width:220px;position:relative;z-index:1}
.btn-w{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 26px;background:var(--white);color:var(--mag);font-family:var(--f-ui);font-weight:600;font-size:15px;border-radius:var(--r-btn);transition:background var(--tf) var(--eo),transform var(--tn);box-shadow:0 4px 16px rgba(0,0,0,.18)}
.btn-w:hover{background:var(--blush);transform:translateY(-2px)}
.btn-ow{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 24px;background:rgba(255,255,255,.04);color:rgba(255,255,255,.92);font-family:var(--f-ui);font-weight:500;font-size:15px;border:1.5px solid rgba(255,255,255,.22);border-radius:var(--r-btn);transition:border-color var(--tf),background var(--tf),color var(--tf)}
.btn-ow:hover{border-color:rgba(255,255,255,.6);background:rgba(255,255,255,.1);color:var(--white)}

.blog{background:var(--bg)}
.blog-g{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.bcard{background:var(--white);border-radius:var(--r-card);overflow:hidden;border:.5px solid rgba(0,0,0,.08);transition:box-shadow var(--tn),transform var(--tn)}
.bcard:hover{box-shadow:0 10px 32px rgba(223,59,163,.1);transform:translateY(-3px)}
.bthumb{height:190px;background:var(--blush);position:relative;overflow:hidden}
.bthumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--eo)}
.bcard:hover .bthumb img{transform:scale(1.04)}
.bcat{position:absolute;top:14px;left:14px;background:var(--mag);color:var(--white);font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:4px 11px;border-radius:var(--r-pill)}
.bbody{padding:clamp(16px,2vw,22px)}
.bdate{font-size:11px;color:var(--gray);margin-bottom:8px}
.btit{font-weight:500;font-size:16px;color:var(--ink);line-height:1.35;margin-bottom:10px}
.bexc{font-size:14px;color:var(--gray);line-height:1.65}

.locations{background:var(--white)}
.loc-g{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.lcard{background:var(--bg);border-radius:var(--r-card);padding:clamp(20px,3vw,28px);border:.5px solid rgba(0,0,0,.08);display:flex;gap:18px}
.lcard.acc{background:var(--blush);border-color:rgba(223,59,163,.15)}
.lico{width:48px;height:48px;flex-shrink:0;border-radius:var(--r-btn);background:var(--white);display:flex;align-items:center;justify-content:center;font-size:21px;color:var(--mag);box-shadow:0 2px 8px rgba(0,0,0,.07)}
.lname{font-size:17px;font-weight:500;color:var(--ink);margin-bottom:8px}
.laddr{font-size:14px;color:var(--slate);line-height:1.72;margin-bottom:10px}
.lhours{font-size:14px;color:var(--slate);line-height:1.8}
.lhours strong{color:var(--ink);font-weight:500}

/* Footer / scroll-top: globalnie z global.css — nie duplikujemy. */

/* ════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════ */

@media(max-width:1280px){
  .c-table-wrap { overflow-x: auto; }
  /* Blog 4 w 1 linii utrzymane na średnich ekranach — łamie się dopiero <900px */
}

/* TABLET 769-1024px — siatki 2-kolumnowe, hero 1-col, sidebar ukryty */
@media (max-width: 1024px) {
  .nav-list, .nav-cta { display: none }
  .topbar { display: none }

  .hero { grid-template-columns: 1fr; min-height: auto; background-image: none !important }
  .hero::before { display: none }
  .hero-txt { padding: clamp(36px, 5vw, 64px) var(--px) }
  .hero-vis, .hbadge { display: none !important }

  .svc-g, .blog-g, .testi-g { grid-template-columns: repeat(2, 1fr) }
  .why-teal { grid-template-columns: 1fr }
  .why-teal-img { min-height: 200px }
  .why-icons-row { grid-template-columns: repeat(2, 1fr); gap: 32px 0 }
  .why-icon-item:nth-child(2)::after { display: none }
  .estetica { grid-template-columns: 1fr }
  .est-img { height: 280px }
  .stats-row { grid-template-columns: repeat(2, 1fr) }
  .st:nth-child(2) { border-right: none }
  .st:nth-child(3) { border-top: .5px solid rgba(0,0,0,.08) }
  .st:nth-child(4) { border-top: .5px solid rgba(0,0,0,.08); border-right: none }
  .trust { grid-template-columns: repeat(2, 1fr) }
  .proc-row { grid-template-columns: repeat(2, 1fr) }
  .proc-row::before { display: none }
  .cta-ban { grid-template-columns: 1fr }
  .loc-g { grid-template-columns: 1fr }
  .clinic-g { grid-template-columns: 1fr; gap: 14px }
  .cg-team { min-height: 280px }
  .cg-tiles { grid-template-columns: repeat(2, 1fr) }
  .cg-s { height: 150px }
  .footer-top { grid-template-columns: 1fr 1fr; gap: 28px }
}

/* MOBILE ≤768px — wszystko 1-kolumna, zwarte */
@media (max-width: 768px) {
  .svc-g, .blog-g, .prfl-g, .testi-g { grid-template-columns: 1fr }
  .trust { grid-template-columns: 1fr; gap: 10px }
  .hero-stats { gap: 16px }
  .stats-row { grid-template-columns: 1fr 1fr }
  .proc-row { grid-template-columns: 1fr; gap: 20px }
  .cg-tiles { grid-template-columns: 1fr 1fr; gap: 10px }
  .cg-team { min-height: 240px }
  .footer-top { grid-template-columns: 1fr }
  .ft-bottom { flex-direction: column; align-items: flex-start; gap: 6px }
  .c-cell { padding: 12px 16px; }
  .c-head { padding: 16px; }
}



/* ════ CTA STRIP ════ */
/* ════ CTA DARK BANNER (gradient navy/violet z gradient deco) ════ */
.cta-dark{
  position:relative;overflow:hidden;
  background:linear-gradient(135deg,#1A0A2E 0%,#2d0a3e 40%,#3d0050 100%);
  padding:clamp(48px,6vw,80px) var(--px);
}
.cta-dark-inner{
  max-width: var(--max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 40px;
  align-items: center;
  position: relative;
  z-index: 1;
}
.cta-dark::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 10% 50%,rgba(223,59,163,.18) 0%,transparent 50%),
    radial-gradient(ellipse at 90% 30%,rgba(155,212,207,.08) 0%,transparent 40%);
  pointer-events:none;
}
.cta-dark-deco{
  position:absolute;right:0;top:0;bottom:0;width:280px;
  background:radial-gradient(ellipse at 80% 50%,rgba(223,59,163,.14),transparent 70%);
  pointer-events:none;
}
.cta-dark-text{position:relative;z-index:1;max-width:768px}
.cta-dark-title{
  font-family:var(--f-serif);font-weight:400;
  font-size:clamp(30px,3.6vw,52px);line-height:1.1;
  color:var(--white);margin-bottom:18px;
  letter-spacing:-0.01em;
}
.cta-dark-title em{font-style:italic;color:#ff6ec7;font-weight:400}
.cta-dark-sub{
  font-size:clamp(16px,1.5vw,19px);line-height:1.65;
  color:rgba(255,255,255,.88);
  font-weight:400;
}
.cta-dark-sub i{
  font-size:15px;color:rgba(255,255,255,.72);
  margin:0 4px 0 8px;vertical-align:middle;
}

/* Buttons stack po prawej */
.cta-dark-btns{
  position:relative;z-index:1;
  display:flex;flex-direction:column;gap:12px;
  align-items:stretch;flex-shrink:0;
  min-width:240px;
}
.cta-dark-btn-primary{
  font-size:15px !important;
  padding:13px 26px !important;
  font-weight:700 !important;
  background:var(--mag);
  border:0;
  box-shadow:0 6px 18px rgba(223,59,163,.32);
}
.cta-dark-btn-primary:hover{background:var(--mag-d);transform:translateY(-2px)}

/* Telefon "Zadzwoń do nas" — outline button + status dot */
.cta-dark-tel{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:12px 26px;
  background:transparent;
  border:1.5px solid rgba(255,255,255,.35);
  color:var(--white) !important;
  font-family:var(--f-ui);font-weight:600;font-size:15px;
  border-radius:var(--r-pill);
  text-decoration:none;
  white-space:nowrap;
  transition:background var(--tf),border-color var(--tf),transform var(--tf);
}
.cta-dark-tel:hover{
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.45);
  transform:translateY(-2px);
}
.cta-dark-tel .phone-dot-wrap{margin-right:2px}
.cta-dark-tel.is-closed{border-color:rgba(231,76,60,.35)}
.cta-dark-tel.is-closed:hover{border-color:rgba(231,76,60,.6);background:rgba(231,76,60,.08)}

@media(max-width:1024px){
  .cta-dark-inner{grid-template-columns:1fr;gap:28px}
  .cta-dark-btns{flex-direction:row;flex-wrap:wrap;min-width:0}
  .cta-dark-btn-primary,.cta-dark-tel{flex:1;min-width:200px}
}
@media(max-width:480px){
  .cta-dark-btns{flex-direction:column}
  .hero-h1{font-size:clamp(26px,7vw,34px)}
  .hero-btns{flex-direction:column}
  .hero-btns .btn-p,.hero-btns .btn-s{display:flex;justify-content:center}
  .stats-row{grid-template-columns:1fr}
  .st{border-right:none!important;border-top:.5px solid rgba(0,0,0,.08)!important}
  .st:first-child{border-top:none!important}
  .hero-pill-tag{margin-bottom:18px}
  .tab-btn { padding: 8px 12px; font-size: 13px; }
}


/* ═══════════════════════════════════════════════════════════════════════
   USŁUGI V2 — 6 grup po kategoriach, kafelki klikalne, większe fonty
═══════════════════════════════════════════════════════════════════════ */
.services-v2 {
  padding: clamp(56px, 7vw, 96px) var(--px);
}
.services-v2 .sec-head {
  max-width: 780px;
  margin: 0 auto clamp(40px, 5vw, 64px);
}
.services-v2 .slbl {
  display: inline-block;
  font-size: 13px; font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase;
  color: var(--mag);
  margin-bottom: 14px;
}
.services-v2 .stitle {
  font-family: var(--f-serif);
  font-size: clamp(32px, 4.5vw, 52px);
  line-height: 1.1;
  color: var(--ink);
  margin-bottom: 16px;
  letter-spacing: -0.01em;
}
.services-v2 .stitle .hl { color: var(--mag); font-style: normal; }
.services-v2 .ssub {
  font-size: clamp(16px, 1.5vw, 19px);
  color: var(--slate);
  line-height: 1.6;
  max-width: 640px;
  margin: 0 auto;
}

.svc-groups {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(20px, 2vw, 28px);
  max-width: calc(var(--max) + 2 * var(--px));
  margin: 0 auto;
}

.svc-group {
  background: var(--white);
  border-radius: 20px;
  padding: clamp(22px, 2.5vw, 32px);
  border: 1px solid rgba(26,21,35,.05);
  box-shadow: 0 8px 28px rgba(26,21,35,.045);
  display: flex; flex-direction: column;
  transition: box-shadow .25s var(--eo), transform .25s var(--eo);
}
.svc-group:hover {
  box-shadow: 0 14px 36px rgba(26,21,35,.08);
  transform: translateY(-2px);
}

.svc-group-head {
  display: flex; align-items: center; gap: 18px;
  margin-bottom: 24px;
  padding-bottom: 22px;
  border-bottom: 1px solid rgba(0,0,0,.05);
}
.svc-group-ico {
  width: 68px; height: 68px;
  border-radius: 18px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  font-size: 32px;
}
.svc-group-ico.mag   { background: var(--mag-w);   color: var(--mag); }
.svc-group-ico.blush { background: var(--blush);   color: var(--mag-d); }
.svc-group-ico.teal  { background: var(--teal-g);  color: var(--teal); }
.svc-group-ico.green { background: var(--green-g); color: #2d8a3a; }

.svc-group-txt { flex: 1; min-width: 0; }
.svc-group-title {
  font-family: var(--f-serif);
  font-size: clamp(24px, 2.8vw, 32px);
  line-height: 1.2;
  color: var(--ink);
  margin: 0 0 6px;
  display: flex; align-items: center; flex-wrap: wrap; gap: 12px;
}
.svc-group-count {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 32px; height: 26px; padding: 0 10px;
  background: var(--mag-w);
  color: var(--mag);
  font-family: var(--f-ui);
  font-size: 13px; font-weight: 700;
  border-radius: 100px;
  letter-spacing: 0;
}
.svc-group-desc {
  font-size: clamp(15px, 1.3vw, 17px);
  color: var(--slate);
  line-height: 1.55;
  margin: 0;
}

.svc-tiles {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  margin-bottom: 20px;
  flex: 1;
}

.svc-tile {
  display: flex; align-items: center; gap: 12px;
  padding: 16px 18px;
  background: var(--bg);
  border: 1.5px solid rgba(26,21,35,.05);
  border-radius: 14px;
  text-decoration: none;
  color: var(--ink);
  transition: all .2s var(--eo);
  position: relative;
  min-height: 68px;
}
.svc-tile:hover {
  border-color: var(--mag);
  background: var(--white);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(223,59,163,.12);
}

.svc-tile-ico {
  width: 40px; height: 40px;
  border-radius: 10px;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  font-size: 20px;
  transition: transform .25s var(--eo);
}
.svc-tile-ico.mag   { background: var(--mag-w);   color: var(--mag); }
.svc-tile-ico.blush { background: var(--blush);   color: var(--mag-d); }
.svc-tile-ico.teal  { background: var(--teal-g);  color: var(--teal); }
.svc-tile-ico.green { background: var(--green-g); color: #2d8a3a; }
.svc-tile:hover .svc-tile-ico { transform: scale(1.08) rotate(-4deg); }

.svc-tile-name {
  flex: 1; min-width: 0;
  font-size: 15.5px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.3;
}

.svc-tile-arrow {
  font-size: 20px;
  color: var(--gray);
  flex-shrink: 0;
  transition: transform .2s, color .2s;
}
.svc-tile:hover .svc-tile-arrow {
  color: var(--mag);
  transform: translateX(4px);
}

/* Akcje pod grupą — "Zobacz wszystkie" + "Umów wizytę" */
.svc-group-actions {
  display: flex; align-items: center; gap: 10px;
  padding-top: 16px;
  border-top: 1px solid rgba(0,0,0,.05);
  flex-wrap: wrap;
}
.svc-group-more {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 12px 18px;
  background: var(--bg);
  border: 1.5px solid rgba(0,0,0,.06);
  color: var(--ink) !important;
  font-size: 15px; font-weight: 600;
  border-radius: 10px;
  text-decoration: none;
  transition: all .2s;
  flex: 1; justify-content: center;
  min-width: 160px;
}
.svc-group-more:hover {
  border-color: var(--mag);
  color: var(--mag) !important;
  background: var(--mag-w);
}
.svc-group-more i { font-size: 18px; transition: transform .2s; }
.svc-group-more:hover i { transform: translateX(3px); }

.svc-group-cta {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 12px 22px;
  background: var(--mag);
  color: var(--white) !important;
  font-family: var(--f-ui);
  font-size: 15px; font-weight: 700;
  border: none;
  border-radius: 10px;
  cursor: pointer;
  transition: background .2s, transform .15s, box-shadow .2s;
  flex: 1; justify-content: center;
  min-width: 160px;
}
.svc-group-cta:hover {
  background: var(--mag-d);
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(223,59,163,.28);
}
.svc-group-cta i { font-size: 18px; }

/* RESPONSIVE */
@media (max-width: 1024px) {
  .svc-groups { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .svc-tiles { grid-template-columns: 1fr; gap: 10px; }
  .svc-tile { padding: 14px 16px; min-height: 60px; }
  .svc-tile-name { font-size: 15px; }
  .svc-group-head { gap: 14px; }
  .svc-group-ico { width: 56px; height: 56px; border-radius: 14px; font-size: 26px; }
  .svc-group-title { font-size: 22px; }
  .svc-group-desc { font-size: 14.5px; }
  .svc-group-actions { flex-direction: column; }
  .svc-group-more, .svc-group-cta { width: 100%; }
}

/* ═══════════════════════════════════════════════════════════════════════
   USŁUGI DCG — karty ze zdjęciami, 4 kolumny
═══════════════════════════════════════════════════════════════════════ */
.services-dcg {
  background: var(--bg);
  padding: clamp(48px, 6vw, 84px) var(--px);
}

.svc-dcg-head {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 16px;
  margin-bottom: clamp(28px, 3.5vw, 44px);
  max-width: var(--max);
  margin-left: auto; margin-right: auto;
}

.svc-dcg-title {
  font-family: var(--f-ui);
  font-weight: 700;
  font-size: clamp(24px, 2.6vw, 34px);
  color: var(--ink);
  margin: 0;
  line-height: 1.2;
  letter-spacing: -0.01em;
}

.svc-dcg-all {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 15.5px;
  font-weight: 600;
  color: var(--slate);
  text-decoration: none;
  transition: color .2s;
}
.svc-dcg-all i {
  font-size: 20px;
  transition: transform .2s;
}
.svc-dcg-all:hover {
  color: var(--mag);
}
.svc-dcg-all:hover i {
  transform: translateX(4px);
}

/* Carousel — wszystkie karty w 1 linii, scroll horizontal */
.svc-dcg-head-right {
  display: flex; align-items: center; gap: 18px;
}
.svc-carousel-nav {
  display: flex; gap: 8px;
}
.svc-nav-btn {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--white);
  border: 1.5px solid rgba(0,0,0,.08);
  color: var(--ink);
  font-size: 22px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all .2s;
}
.svc-nav-btn:hover:not(:disabled) {
  background: var(--mag);
  border-color: var(--mag);
  color: var(--white);
  transform: scale(1.05);
}
.svc-nav-btn:disabled {
  opacity: .35;
  cursor: not-allowed;
}

.svc-carousel-wrap {
  /* Wyrównany do siatki strony — bez negative margin */
  width: 100%;
  position: relative;
}
.svc-carousel {
  display: flex;
  gap: clamp(14px, 1.5vw, 22px);
  overflow-x: auto;
  overflow-y: visible;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  touch-action: pan-x;
  overscroll-behavior-x: contain;
  /* Pad: 4px top, 4px right żeby ostatnia karta miała oddech, 20px bottom dla shadow */
  padding: 4px 4px 20px;
  cursor: grab;
  user-select: none;
}
.svc-carousel.is-dragging {
  cursor: grabbing;
  scroll-behavior: auto;
}
.svc-carousel::-webkit-scrollbar { display: none; }

/* Karta: dokładnie 4 widoczne na desktop, równe szerokości */
.svc-dcg-card {
  flex: 0 0 calc((100% - 3 * clamp(14px, 1.5vw, 22px)) / 4);
  min-width: 0; /* pozwól flexbox kurczyć */
  scroll-snap-align: start;
}

/* RESPONSIVE: 4 → 3 → 2 → 1.2 karta widoczna */
@media (max-width: 1024px) {
  .svc-dcg-card {
    flex-basis: calc((100% - 2 * clamp(14px, 1.5vw, 22px)) / 3);
  }
}
@media (max-width: 768px) {
  .svc-dcg-card {
    flex-basis: calc((100% - clamp(14px, 1.5vw, 22px)) / 2);
  }
}
@media (max-width: 640px) {
  .svc-dcg-card {
    /* 1.2 karty widoczne — peek next w karuzeli */
    flex-basis: 82%;
    max-width: none;
  }
  .svc-carousel {
    gap: 12px;
    padding: 4px 4px 20px;
  }
}

.svc-dcg-card {
  background: var(--white);
  border-radius: 20px;
  overflow: hidden;
  display: flex; flex-direction: column;
  border: 1px solid rgba(26,21,35,.05);
  box-shadow: 0 1px 2px rgba(26,21,35,.02), 0 4px 12px -2px rgba(26,21,35,.04);
  transition: transform .3s var(--eo), box-shadow .3s var(--eo), border-color .3s var(--eo);
}
.svc-dcg-card:hover {
  transform: translateY(-3px);
  border-color: rgba(223,59,163,.12);
  box-shadow:
    0 1px 2px rgba(26,21,35,.02),
    0 12px 28px -6px rgba(26,21,35,.08),
    0 24px 48px -16px rgba(223,59,163,.10);
}

.svc-dcg-img {
  display: block;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: linear-gradient(135deg, #fefafc 0%, #ffffff 100%);
  position: relative;
  border-bottom: 1px solid rgba(26,21,35,.04);
}
.svc-dcg-img > img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  display: block;
  transition: transform .5s var(--eo);
}
.svc-dcg-card:hover .svc-dcg-img > img {
  transform: scale(1.05);
}

/* Fallback: inline SVG (magenta line icon) wycentrowany, czytelny */
.svc-dcg-img-fallback {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  padding: 32px;
  position: relative;
  overflow: hidden;
}
/* subtelny radial spot za ikoną — tworzy "presence" zamiast pustki */
.svc-dcg-img-fallback::before {
  content: '';
  position: absolute;
  width: 58%;
  aspect-ratio: 1/1;
  border-radius: 50%;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle at 50% 50%, rgba(255,255,255,.9) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}

/* Inline SVG ikona — magenta line, statyczna */
.svc-dcg-img-fallback svg.usluga-icon-svg,
.svc-dcg-img-fallback .usluga-icon-svg {
  width: 40%;
  height: 40%;
  color: var(--mag, #DF3BA3);
  stroke: currentColor;
  position: relative;
  z-index: 1;
  stroke-width: 16 !important;
}
/* Fallback dla starych <img> lub <i> */
.svc-dcg-img-fallback img.svc-dcg-icon {
  width: 44%; height: 44%;
  object-fit: contain;
  position: relative; z-index: 2;
}
.svc-dcg-img-fallback i {
  font-size: 72px;
  color: var(--mag, #DF3BA3);
  position: relative; z-index: 2;
}

/* Pastelowe tła kategorii — saturowane, każdy odcień charakter */
.svc-dcg-img-fallback.mag   { background: linear-gradient(140deg, #fce4f1 0%, #fdf2f9 60%, #ffffff 100%); }
.svc-dcg-img-fallback.blush { background: linear-gradient(140deg, #fbdce8 0%, #fef0f6 60%, #ffffff 100%); }
.svc-dcg-img-fallback.teal  { background: linear-gradient(140deg, #d4eeed 0%, #e8f5f4 60%, #ffffff 100%); }
.svc-dcg-img-fallback.green { background: linear-gradient(140deg, #def0d6 0%, #ecf6e6 60%, #ffffff 100%); }

.svc-dcg-body {
  padding: 24px 24px 24px;
  display: flex; flex-direction: column;
  flex: 1;
  gap: 14px;
}

.svc-dcg-name {
  font-family: var(--f-ui);
  font-size: 18px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.35;
  letter-spacing: -0.005em;
  margin: 0;
  flex: 1;
}
.svc-dcg-name a {
  color: inherit;
  text-decoration: none;
  transition: color .2s;
}
.svc-dcg-name a:hover { color: var(--mag); }

.svc-dcg-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 0;
  background: transparent;
  border: 0;
  color: var(--mag) !important;
  font-size: 13.5px;
  font-weight: 600;
  letter-spacing: .01em;
  text-decoration: none;
  transition: gap .2s var(--eo), color .2s;
  margin-top: auto;
  position: relative;
  width: fit-content;
}
.svc-dcg-btn::after {
  content: '';
  position: absolute;
  left: 0; bottom: -2px;
  width: 0; height: 1px;
  background: currentColor;
  transition: width .3s var(--eo);
}
.svc-dcg-btn:hover {
  gap: 12px;
  color: #C1268A !important;
}
.svc-dcg-btn:hover::after { width: calc(100% - 22px); }
.svc-dcg-btn i {
  font-size: 16px;
  transition: transform .25s var(--eo);
}
.svc-dcg-btn:hover i {
  transform: translateX(2px);
}

/* RESPONSIVE body */
@media (max-width: 768px) {
  .svc-dcg-body { padding: 18px; gap: 12px; }
  .svc-dcg-name { font-size: 16.5px; }
}
@media (max-width: 640px) {
  .svc-dcg-head { flex-direction: column; align-items: flex-start; }
  .svc-dcg-head-right { width: 100%; justify-content: space-between; }
  .svc-dcg-all { font-size: 14.5px; }
}

/* Blog cards — 4-col grid: większe niż 6-col, ale wciąż kompaktowe */
.blog-g .bthumb { height: 170px; }
.blog-g .bbody { padding: 18px 18px 20px; }
.blog-g .bdate { font-size: 11px; margin-bottom: 8px; letter-spacing: 0.02em; }
.blog-g .btit { font-size: 15px; line-height: 1.35; margin-bottom: 8px; font-weight: 500;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; min-height: 2.7em; }
.blog-g .bexc { font-size: 13px; line-height: 1.55;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.blog-g .bcat { font-size: 10px; padding: 4px 9px; letter-spacing: 0.06em; }
.blog-g .bmore { font-size: 13px; margin-top: 10px; display: inline-flex; align-items: center; gap: 6px; font-weight: 500; }
.blog-g .bmore i { transition: transform .2s; }
.blog-g .bcard:hover .bmore i { transform: translateX(3px); }
