/* ============================================================
   Utrata Wagi Bielsko — Bariatria CMR
   Design system & global styles
   ============================================================ */

:root{
  /* Brand palette — dopasowana do logo Szpitala CMR (niebieski + bordo) */
  --brand:        #2b6098;   /* stalowy niebieski z logo */
  --brand-600:    #3a72ad;
  --brand-700:    #1f4e7a;   /* granat */
  --brand-800:    #163a5b;   /* najciemniejszy granat */
  --brand-soft:   #e9f1f9;
  --accent:       #d23a54;   /* bordowa czerwień ze znaku logo */
  --accent-600:   #b82f47;
  --accent-soft:  #fce9ed;

  --ink:          #15212b;
  --ink-2:        #2e3d49;
  --muted:        #5c6b78;
  --muted-2:      #8a98a4;

  --bg:           #ffffff;
  --bg-soft:      #f3f7fb;
  --bg-soft-2:    #eaf1f8;
  --line:         #e2eaf2;
  --line-2:       #d0dcea;

  --white:        #ffffff;
  --shadow-sm:    0 1px 2px rgba(15,33,53,.06), 0 1px 3px rgba(15,33,53,.05);
  --shadow:       0 6px 20px rgba(15,33,53,.08);
  --shadow-lg:    0 18px 48px rgba(15,33,53,.14);

  --radius:       16px;
  --radius-sm:    10px;
  --radius-lg:    26px;

  --maxw:         1180px;
  --gap:          clamp(1rem, 3vw, 2rem);

  --font-head: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0; font-family:var(--font-body); color:var(--ink);
  background:var(--bg); line-height:1.65; font-size:17px;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:var(--brand-700); text-decoration:none; transition:color .15s ease; }
a:hover{ color:var(--accent-600); }
h1,h2,h3,h4{ font-family:var(--font-head); color:var(--ink); line-height:1.18; margin:0 0 .5em; font-weight:700; letter-spacing:-.01em; }
h1{ font-size:clamp(1.95rem,5vw,3.4rem); }
h2{ font-size:clamp(1.7rem,3.6vw,2.5rem); }
h3{ font-size:clamp(1.25rem,2.2vw,1.55rem); }
p{ margin:0 0 1rem; }
ul,ol{ margin:0 0 1rem; padding-left:1.2rem; }
li{ margin:.3rem 0; }
section{ scroll-margin-top:90px; }

/* Layout helpers */
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(1.1rem,4vw,2rem); }
.section{ padding-block:clamp(3.5rem,7vw,6rem); }
.section--soft{ background:var(--bg-soft); }
.section--brand{ background:linear-gradient(160deg,var(--brand-700),var(--brand-800)); color:#eafaf6; }
.section--brand h2,.section--brand h3{ color:#fff; }
.narrow{ max-width:760px; }
.center{ text-align:center; }
.mx-auto{ margin-inline:auto; }
.grid{ display:grid; gap:clamp(1.1rem,2.5vw,1.8rem); }
.cols-2{ grid-template-columns:repeat(2,1fr); }
.cols-3{ grid-template-columns:repeat(3,1fr); }
.cols-4{ grid-template-columns:repeat(4,1fr); }
@media(max-width:900px){ .cols-3,.cols-4{ grid-template-columns:repeat(2,1fr);} }
@media(max-width:640px){ .cols-2,.cols-3,.cols-4{ grid-template-columns:1fr;} }

.eyebrow{
  display:inline-block; font-family:var(--font-head); font-weight:700;
  font-size:.78rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--brand); background:var(--brand-soft); padding:.4rem .85rem;
  border-radius:100px; margin-bottom:1rem;
}
.section--brand .eyebrow{ color:#bff3e8; background:rgba(255,255,255,.1); }
.lead{ font-size:1.18rem; color:var(--muted); }
.section--brand .lead{ color:#cdeee6; }
.muted{ color:var(--muted); }

/* Buttons */
.btn{
  display:inline-flex; align-items:center; gap:.5rem; cursor:pointer;
  font-family:var(--font-head); font-weight:600; font-size:1rem;
  padding:.85rem 1.5rem; border-radius:100px; border:1.5px solid transparent;
  transition:transform .12s ease, box-shadow .15s ease, background .15s ease; white-space:nowrap;
}
.btn:active{ transform:translateY(1px); }
.btn--primary{ background:var(--accent); color:#fff; box-shadow:0 6px 18px rgba(240,112,58,.32); }
.btn--primary:hover{ background:var(--accent-600); color:#fff; box-shadow:0 10px 26px rgba(240,112,58,.4); }
.btn--brand{ background:var(--brand); color:#fff; }
.btn--brand:hover{ background:var(--brand-700); color:#fff; }
.btn--ghost{ background:transparent; color:var(--brand-700); border-color:var(--line-2); }
.btn--ghost:hover{ border-color:var(--brand); color:var(--brand-700); background:var(--brand-soft); }
.btn--light{ background:#fff; color:var(--brand-700); }
.btn--light:hover{ background:#eafaf6; color:var(--brand-800); }
.btn--lg{ padding:1rem 1.9rem; font-size:1.05rem; }
.btn-row{ display:flex; flex-wrap:wrap; gap:.8rem; }

/* ---------- Header ---------- */
.site-header{ position:sticky; top:0; z-index:60; background:rgba(255,255,255,.9);
  backdrop-filter:saturate(140%) blur(12px); border-bottom:1px solid var(--line); }
.topbar{ background:var(--brand-800); color:#d7f1ea; font-size:.86rem; }
.topbar .container{ display:flex; justify-content:space-between; align-items:center; gap:1rem; padding-block:.45rem; flex-wrap:wrap; }
.topbar a{ color:#eafaf6; }
.topbar .tb-links{ display:flex; gap:1.3rem; align-items:center; flex-wrap:wrap; }
.topbar .tb-links span{ display:inline-flex; align-items:center; gap:.4rem; }
.site-header .navbar.container,.site-header > .container{ max-width:1340px; }
.navbar{ display:flex; align-items:center; justify-content:space-between; gap:1rem; padding-block:.7rem; }
.brand{ display:flex; align-items:center; gap:.7rem; font-family:var(--font-head); font-weight:800; font-size:1.15rem; color:var(--ink); letter-spacing:-.02em; flex:none; white-space:nowrap; }
.brand:hover{ color:var(--ink); }
.brand .mark{ width:42px; height:42px; border-radius:12px; background:linear-gradient(150deg,var(--brand),var(--brand-700)); display:grid; place-items:center; color:#fff; flex:none; box-shadow:var(--shadow-sm); }
.brand-logo{ height:46px; width:auto; display:block; }
@media(max-width:520px){ .brand-logo{ height:38px; } }
.footer-logo{ display:inline-block; background:#fff; padding:.5rem .8rem; border-radius:12px; box-shadow:var(--shadow-sm); }
.footer-logo img{ height:42px; width:auto; display:block; }
.brand small{ display:block; font-family:var(--font-body); font-weight:500; font-size:.72rem; color:var(--muted); letter-spacing:.02em; }
.nav-links{ display:flex; align-items:center; gap:.1rem; list-style:none; margin:0; padding:0; }
.nav-links a{ display:block; padding:.55rem .7rem; border-radius:10px; font-family:var(--font-head); font-weight:600; font-size:.95rem; color:var(--ink-2); white-space:nowrap; }
.nav-links a:hover,.nav-links a.active{ background:var(--brand-soft); color:var(--brand-700); }
.nav-actions{ display:flex; align-items:center; gap:.6rem; }
.lang-switch{ display:flex; gap:.15rem; background:var(--bg-soft); border:1px solid var(--line); border-radius:100px; padding:.2rem; }
.lang-switch a{ padding:.28rem .6rem; border-radius:100px; font-weight:700; font-size:.82rem; color:var(--muted); }
.lang-switch a.active{ background:var(--brand); color:#fff; }
.nav-toggle{ display:none; background:none; border:none; cursor:pointer; padding:.4rem; color:var(--ink); }
@media(max-width:1180px){
  .nav-toggle{ display:block; }
  .nav-links{ position:fixed; inset:0 0 0 auto; width:min(80vw,340px); flex-direction:column; align-items:stretch;
    background:#fff; padding:5rem 1.4rem 2rem; gap:.2rem; transform:translateX(100%); transition:transform .25s ease; box-shadow:var(--shadow-lg); }
  .nav-links.open{ transform:translateX(0); }
  .nav-links a{ padding:.85rem 1rem; font-size:1.08rem; }
  .nav-backdrop{ position:fixed; inset:0; background:rgba(8,20,18,.4); opacity:0; visibility:hidden; transition:.25s; z-index:55; }
  .nav-backdrop.open{ opacity:1; visibility:visible; }
}

/* ---------- Hero ---------- */
.hero{ position:relative; color:#fff; overflow:hidden; }
.hero__bg{ position:absolute; inset:0; z-index:0; }
.hero__bg img{ width:100%; height:100%; object-fit:cover; }
.hero__bg::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(105deg,rgba(22,58,91,.92) 0%,rgba(31,78,122,.82) 42%,rgba(22,58,91,.45) 100%); }
.hero__inner{ position:relative; z-index:1; padding-block:clamp(3.5rem,9vw,7rem); }
.hero h1{ color:#fff; max-width:16ch; }
.hero .lead{ color:#d6f0ea; max-width:54ch; font-size:1.22rem; }
.hero__stats{ display:flex; gap:2.4rem; flex-wrap:wrap; margin-top:2.4rem; }
.hero__stats .stat strong{ display:block; font-family:var(--font-head); font-size:2rem; color:#fff; }
.hero__stats .stat span{ color:#bfe8de; font-size:.92rem; }
.hero-badges{ display:flex; gap:.6rem; flex-wrap:wrap; margin-top:1.6rem; }
.hero-badges span{ background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.18); padding:.4rem .85rem; border-radius:100px; font-size:.84rem; }

/* page hero (slim) */
.page-hero{ background:linear-gradient(160deg,var(--brand-700),var(--brand-800)); color:#fff; }
.page-hero .hero__inner{ padding-block:clamp(2.6rem,6vw,4.4rem); }
.page-hero h1{ color:#fff; }
.page-hero .lead{ color:#cdeee6; }
.breadcrumb{ font-size:.85rem; color:#a9ded3; margin-bottom:.7rem; }
.breadcrumb a{ color:#cdeee6; }

/* ---------- Cards ---------- */
.card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:1.6rem; box-shadow:var(--shadow-sm); transition:transform .15s ease, box-shadow .15s ease; }
.card:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.card .ico{ width:52px; height:52px; border-radius:14px; background:var(--brand-soft); color:var(--brand-700); display:grid; place-items:center; margin-bottom:1rem; }
.card h3{ margin-bottom:.4rem; }
.card p{ color:var(--muted); margin-bottom:0; font-size:.97rem; }

.feature-img{ border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); }
.feature-img img{ width:100%; height:100%; object-fit:cover; }
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.5rem,4vw,3.5rem); align-items:center; }
.split--reverse .split__media{ order:2; }
@media(max-width:860px){ .split{ grid-template-columns:1fr; } .split--reverse .split__media{ order:0; } }

/* Procedure / pricing cards */
.proc-card{ display:flex; flex-direction:column; background:#fff; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm); transition:.15s; }
.proc-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.proc-card.popular{ border-color:var(--accent); box-shadow:0 10px 30px rgba(240,112,58,.16); }
.proc-card__head{ padding:1.4rem 1.5rem .6rem; }
.proc-card .tag{ font-size:.72rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--accent-600); }
.proc-card__body{ padding:0 1.5rem 1.5rem; display:flex; flex-direction:column; flex:1; }
.proc-card .price{ font-family:var(--font-head); font-size:1.9rem; font-weight:800; color:var(--brand-700); margin:.3rem 0; }
.proc-card .price small{ font-size:.85rem; font-weight:600; color:var(--muted); }
.proc-card ul{ list-style:none; padding:0; margin:.6rem 0 1.2rem; }
.proc-card ul li{ padding-left:1.6rem; position:relative; color:var(--ink-2); font-size:.95rem; }
.proc-card ul li::before{ content:"✓"; position:absolute; left:0; color:var(--brand); font-weight:800; }
.proc-card .btn{ margin-top:auto; justify-content:center; }

/* Stat band */
.statband{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; text-align:center; }
@media(max-width:740px){ .statband{ grid-template-columns:repeat(2,1fr);} }
.statband .num{ font-family:var(--font-head); font-weight:800; font-size:clamp(2rem,4vw,2.8rem); color:var(--brand-700); line-height:1; }
.section--brand .statband .num{ color:#fff; }
.statband .lbl{ color:var(--muted); font-size:.95rem; margin-top:.4rem; }
.section--brand .statband .lbl{ color:#bfe8de; }

/* Steps */
.steps{ counter-reset:step; display:grid; gap:1.2rem; }
.step{ display:flex; gap:1.1rem; align-items:flex-start; background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:1.3rem 1.5rem; }
.step__n{ counter-increment:step; flex:none; width:44px; height:44px; border-radius:50%; background:var(--brand); color:#fff; display:grid; place-items:center; font-family:var(--font-head); font-weight:800; }
.step__n::before{ content:counter(step); }
.step h3{ margin-bottom:.2rem; font-size:1.15rem; }
.step p{ margin:0; color:var(--muted); font-size:.96rem; }

/* Team */
.doctor{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm); transition:.15s; }
.doctor:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.doctor__photo{ aspect-ratio:1/1; background:var(--bg-soft-2); position:relative; overflow:hidden; }
.doctor__photo img{ width:100%; height:100%; object-fit:cover; }
.doctor__ph{ width:100%; height:100%; display:grid; place-items:center; font-family:var(--font-head); font-weight:800; font-size:2.6rem; color:#fff;
  background:linear-gradient(150deg,var(--brand-600),var(--brand-800)); }
.doctor__body{ padding:1.1rem 1.3rem 1.4rem; }
.doctor__body h3{ margin-bottom:.1rem; font-size:1.18rem; }
.doctor .role{ color:var(--accent-600); font-weight:600; font-size:.9rem; }
.doctor .bio{ color:var(--muted); font-size:.93rem; margin-top:.6rem; }

/* Transformations */
.metamorf{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm); }
.metamorf__imgs{ display:grid; grid-template-columns:1fr 1fr; }
.metamorf__imgs figure{ margin:0; position:relative; aspect-ratio:3/4; background:var(--bg-soft-2); }
.metamorf__imgs figure img{ width:100%; height:100%; object-fit:cover; }
.metamorf__imgs figure figcaption{ position:absolute; top:.6rem; left:.6rem; background:rgba(22,58,91,.85); color:#fff; font-size:.72rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; padding:.25rem .6rem; border-radius:100px; }
.metamorf__imgs figure.after figcaption{ background:var(--accent); }
.metamorf__ph{ width:100%; height:100%; display:grid; place-items:center; background:linear-gradient(170deg,var(--bg-soft) 0%,var(--bg-soft-2) 100%); }
.metamorf__ph svg{ width:58%; height:auto; max-height:80%; }
.metamorf__imgs figure.before .metamorf__ph{ background:linear-gradient(170deg,#eef2f7 0%,#e2e9f1 100%); }
.metamorf__imgs figure.after .metamorf__ph{ background:linear-gradient(170deg,#eaf1f9 0%,#dfeaf6 100%); }
.metamorf__body{ padding:1.1rem 1.3rem 1.4rem; }
.metamorf__stats{ display:flex; gap:1.4rem; margin:.6rem 0; }
.metamorf__stats div strong{ display:block; font-family:var(--font-head); color:var(--brand-700); font-size:1.3rem; }
.metamorf__stats div span{ font-size:.78rem; color:var(--muted); }
.metamorf .quote{ font-style:italic; color:var(--ink-2); font-size:.95rem; }

/* Gallery */
.gallery-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:.7rem; }
@media(max-width:820px){ .gallery-grid{ grid-template-columns:repeat(2,1fr);} }
.gallery-grid a{ display:block; border-radius:12px; overflow:hidden; aspect-ratio:3/2; background:var(--bg-soft-2); }
.gallery-grid img{ width:100%; height:100%; object-fit:cover; transition:transform .35s ease; }
.gallery-grid a:hover img{ transform:scale(1.06); }

/* Lightbox */
.lightbox{ position:fixed; inset:0; z-index:200; background:rgba(6,18,16,.92); display:none; align-items:center; justify-content:center; padding:2rem; }
.lightbox.open{ display:flex; }
.lightbox img{ max-width:92vw; max-height:86vh; border-radius:10px; box-shadow:var(--shadow-lg); }
.lightbox__close,.lightbox__nav{ position:absolute; background:rgba(255,255,255,.12); border:none; color:#fff; cursor:pointer; width:48px; height:48px; border-radius:50%; font-size:1.4rem; display:grid; place-items:center; }
.lightbox__close{ top:1.2rem; right:1.2rem; }
.lightbox__nav{ top:50%; transform:translateY(-50%); }
.lightbox__nav.prev{ left:1.2rem; } .lightbox__nav.next{ right:1.2rem; }
.lightbox button:hover{ background:rgba(255,255,255,.25); }

/* BMI calculator */
.bmi{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); box-shadow:var(--shadow); overflow:hidden; }
.bmi__grid{ display:grid; grid-template-columns:1fr 1fr; }
@media(max-width:760px){ .bmi__grid{ grid-template-columns:1fr; } }
.bmi__form{ padding:clamp(1.5rem,4vw,2.5rem); }
.bmi__result{ padding:clamp(1.5rem,4vw,2.5rem); background:var(--bg-soft); display:flex; flex-direction:column; justify-content:center; }
.field{ margin-bottom:1.2rem; }
.field label{ display:block; font-family:var(--font-head); font-weight:600; font-size:.9rem; margin-bottom:.4rem; color:var(--ink-2); }
.field .input-wrap{ display:flex; align-items:center; border:1.5px solid var(--line-2); border-radius:12px; overflow:hidden; transition:border .15s; }
.field .input-wrap:focus-within{ border-color:var(--brand); }
.field input{ flex:1; border:none; padding:.85rem 1rem; font-size:1.05rem; font-family:var(--font-body); outline:none; width:100%; background:transparent; }
.field .unit{ padding:0 1rem; color:var(--muted); font-weight:600; background:var(--bg-soft); align-self:stretch; display:flex; align-items:center; }
.bmi__value{ font-family:var(--font-head); font-weight:800; font-size:3.6rem; line-height:1; color:var(--brand-700); }
.bmi__cat{ display:inline-block; padding:.4rem 1rem; border-radius:100px; font-weight:700; font-size:.95rem; margin:.8rem 0; }
.bmi__bar{ height:12px; border-radius:100px; margin:1rem 0 .4rem; background:linear-gradient(90deg,#3b9ae1 0%,#33b27b 28%,#33b27b 42%,#f3c63d 55%,#f0892f 72%,#e2502f 100%); position:relative; }
.bmi__bar .pin{ position:absolute; top:50%; width:18px; height:18px; border-radius:50%; background:#fff; border:3px solid var(--ink); transform:translate(-50%,-50%); transition:left .4s ease; box-shadow:var(--shadow-sm); }
.bmi__scale{ display:flex; justify-content:space-between; font-size:.72rem; color:var(--muted); }
.bmi__note{ font-size:.88rem; color:var(--muted); margin-top:1rem; }
.cat-under{ background:#e2effb; color:#2b6cb0; }
.cat-normal{ background:#e3f5ec; color:#1f8a5b; }
.cat-over{ background:#fdf2d8; color:#b7860b; }
.cat-ob1{ background:#fde7d6; color:#c2691f; }
.cat-ob2{ background:#fbdccf; color:#bd4f25; }
.cat-ob3{ background:#f8d2cc; color:#b13322; }
.bmi__cta{ margin-top:1.2rem; padding:1rem; border-radius:12px; background:var(--accent-soft); border:1px solid #f7d3c2; font-size:.92rem; display:none; }
.bmi__cta.show{ display:block; }

/* Blog */
.post-card{ display:flex; flex-direction:column; background:#fff; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm); transition:.15s; height:100%; }
.post-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.post-card__img{ aspect-ratio:16/9; overflow:hidden; background:var(--bg-soft-2); }
.post-card__img img{ width:100%; height:100%; object-fit:cover; transition:transform .3s; }
.post-card:hover .post-card__img img{ transform:scale(1.05); }
.post-card__body{ padding:1.2rem 1.3rem 1.4rem; display:flex; flex-direction:column; flex:1; }
.post-card .meta{ font-size:.8rem; color:var(--muted); margin-bottom:.5rem; display:flex; gap:.6rem; align-items:center; }
.post-card .cat{ color:var(--brand-700); font-weight:700; }
.post-card h3{ font-size:1.18rem; margin-bottom:.4rem; }
.post-card p{ color:var(--muted); font-size:.93rem; flex:1; }
.post-card .more{ font-family:var(--font-head); font-weight:600; font-size:.9rem; margin-top:.6rem; color:var(--accent-600); }

.chips{ display:flex; gap:.5rem; flex-wrap:wrap; }
.chip{ padding:.4rem .9rem; border-radius:100px; border:1px solid var(--line-2); background:#fff; font-size:.85rem; font-weight:600; color:var(--ink-2); cursor:pointer; transition:.15s; }
.chip:hover,.chip.active{ background:var(--brand); border-color:var(--brand); color:#fff; }

/* Article */
.article{ max-width:760px; margin-inline:auto; }
.article p{ font-size:1.08rem; color:var(--ink-2); }
.article h2{ margin-top:2rem; }
.article h3{ margin-top:1.6rem; }
.article img{ border-radius:var(--radius); margin:1.5rem 0; }
.article blockquote{ border-left:4px solid var(--brand); padding:.4rem 0 .4rem 1.4rem; margin:1.5rem 0; font-style:italic; color:var(--ink-2); background:var(--bg-soft); border-radius:0 10px 10px 0; }
.toc{ background:var(--bg-soft); border:1px solid var(--line); border-radius:var(--radius); padding:1.3rem 1.5rem; margin-bottom:2rem; }
.toc strong{ font-family:var(--font-head); display:block; margin-bottom:.5rem; }
.toc ul{ margin:0; }

/* PDF / downloads */
.dl{ display:flex; align-items:center; gap:1.1rem; background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:1.1rem 1.3rem; transition:.15s; }
.dl:hover{ box-shadow:var(--shadow); transform:translateY(-2px); }
.dl__ico{ flex:none; width:50px; height:50px; border-radius:12px; background:var(--accent-soft); color:var(--accent-600); display:grid; place-items:center; }
.dl__meta{ flex:1; }
.dl__meta h3{ font-size:1.05rem; margin:0; }
.dl__meta span{ font-size:.82rem; color:var(--muted); }
.dl .btn{ flex:none; }

/* FAQ */
.faq-item{ border:1px solid var(--line); border-radius:var(--radius); background:#fff; margin-bottom:.8rem; overflow:hidden; }
.faq-q{ width:100%; text-align:left; background:none; border:none; cursor:pointer; padding:1.15rem 1.4rem; font-family:var(--font-head); font-weight:600; font-size:1.05rem; color:var(--ink); display:flex; justify-content:space-between; gap:1rem; align-items:center; }
.faq-q .ic{ flex:none; transition:transform .2s; color:var(--brand); }
.faq-item.open .faq-q .ic{ transform:rotate(45deg); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .3s ease; }
.faq-a div{ padding:0 1.4rem 1.2rem; color:var(--muted); }

/* Contact */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.5rem,4vw,3rem); }
@media(max-width:820px){ .contact-grid{ grid-template-columns:1fr; } }
.info-row{ display:flex; gap:1rem; align-items:flex-start; margin-bottom:1.3rem; }
.info-row .ico{ flex:none; width:46px; height:46px; border-radius:12px; background:var(--brand-soft); color:var(--brand-700); display:grid; place-items:center; }
.info-row h4{ margin:0 0 .15rem; font-size:1rem; }
.info-row p{ margin:0; color:var(--muted); font-size:.95rem; }
.form-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(1.5rem,4vw,2.4rem); box-shadow:var(--shadow); }
.form-card textarea{ resize:vertical; min-height:120px; }
.form-card .field input,.form-card .field textarea,.form-card .field select{ width:100%; border:1.5px solid var(--line-2); border-radius:12px; padding:.8rem 1rem; font-family:var(--font-body); font-size:1rem; outline:none; }
.form-card .field input:focus,.form-card .field textarea:focus,.form-card .field select:focus{ border-color:var(--brand); }
.form-note{ font-size:.82rem; color:var(--muted); }

.map-embed{ border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); height:340px; }
.map-embed iframe{ width:100%; height:100%; border:0; }

/* CTA band */
.cta-band{ background:linear-gradient(150deg,var(--accent),var(--accent-600)); color:#fff; border-radius:var(--radius-lg); padding:clamp(2rem,5vw,3.4rem); text-align:center; box-shadow:var(--shadow-lg); }
.cta-band h2{ color:#fff; } .cta-band p{ color:#ffe9df; }

/* Footer */
.site-footer{ background:var(--brand-800); color:#bfe1da; font-size:.94rem; }
.site-footer a{ color:#dcf2ec; }
.site-footer a:hover{ color:#fff; }
.footer-top{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:2rem; padding-block:clamp(2.5rem,5vw,4rem); }
@media(max-width:860px){ .footer-top{ grid-template-columns:1fr 1fr; } }
@media(max-width:520px){ .footer-top{ grid-template-columns:1fr; } }
.site-footer h4{ color:#fff; font-size:1rem; margin-bottom:1rem; }
.site-footer ul{ list-style:none; padding:0; margin:0; }
.site-footer ul li{ margin:.45rem 0; }
.footer-brand .brand{ color:#fff; margin-bottom:1rem; }
.footer-brand .brand small{ color:#9ccabf; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.12); padding-block:1.2rem; display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; font-size:.84rem; color:#9ccabf; }

/* Utilities */
.hidden{ display:none !important; }
@media(max-width:680px){ .hide-sm{ display:none !important; } }
.mt-0{ margin-top:0; } .mb-0{ margin-bottom:0; }
.tag-pill{ display:inline-block; background:var(--brand-soft); color:var(--brand-700); font-weight:600; font-size:.8rem; padding:.25rem .7rem; border-radius:100px; }
.reveal{ opacity:0; transform:translateY(18px); transition:opacity .6s ease, transform .6s ease; }
.reveal.in{ opacity:1; transform:none; }
.notice{ background:var(--accent-soft); border:1px solid #f6d2c1; border-radius:12px; padding:.8rem 1.1rem; font-size:.9rem; color:#9a4a26; }
@media(prefers-reduced-motion:reduce){ *{ scroll-behavior:auto; } .reveal{ opacity:1; transform:none; transition:none; } }

/* ============================================================
   MOBILE — dopracowanie wersji telefonicznej
   ============================================================ */
.nav-drawer-extra{ display:none; }
@media(max-width:1180px){
  /* drawer: logo + większe linki + CTA + telefon */
  .nav-links{ padding-top:5.5rem; gap:.1rem; overflow-y:auto; }
  .nav-links a{ font-size:1.05rem; border-radius:12px; }
  .nav-links a.active{ background:var(--brand); color:#fff; }
  .nav-drawer-extra{ display:flex; flex-direction:column; gap:.9rem; margin-top:1.4rem; padding-top:1.4rem; border-top:1px solid var(--line); }
  .nav-drawer-extra .btn{ justify-content:center; width:100%; padding-block:.95rem; }
  .drawer-phone{ display:flex; align-items:center; justify-content:center; gap:.5rem; font-family:var(--font-head); font-weight:700; color:var(--brand-700); padding:.6rem; }
  .nav-backdrop{ backdrop-filter:blur(2px); }
}
@media(max-width:760px){
  body{ font-size:16px; }
  .section{ padding-block:clamp(2.6rem,9vw,3.4rem); }
  .hero__inner{ padding-block:clamp(2.8rem,12vw,4rem); }
  .hero .lead{ font-size:1.08rem; }
  .hero__bg::after{ background:linear-gradient(165deg,rgba(22,58,91,.94) 0%,rgba(31,78,122,.86) 55%,rgba(22,58,91,.72) 100%); }
  .hero__stats{ gap:1.4rem 1.8rem; margin-top:1.8rem; }
  .hero__stats .stat strong{ font-size:1.6rem; }
  /* przyciski hero pełnej szerokości — wygodne kciukiem */
  .hero .btn-row{ flex-direction:column; align-items:stretch; }
  .hero .btn-row .btn{ width:100%; justify-content:center; }
  .btn--lg{ padding:.9rem 1.4rem; font-size:1rem; }
  .lead{ font-size:1.05rem; }
  h2{ font-size:clamp(1.5rem,6vw,2rem); }
  .split{ gap:1.6rem; }
  .statband{ gap:1.2rem .8rem; }
  .statband .num{ font-size:2rem; }
  .cta-band{ padding:1.8rem 1.3rem; }
  .cta-band .btn-row{ flex-direction:column; }
  .cta-band .btn{ width:100%; justify-content:center; }
  .gallery-grid{ gap:.5rem; }
  .page-hero .hero__inner{ padding-block:clamp(2rem,9vw,3rem); }
  .article p{ font-size:1.02rem; }
  .footer-bottom{ flex-direction:column; gap:.4rem; }
  .topbar .container{ justify-content:center; }
}
@media(max-width:420px){
  .container{ padding-inline:1.1rem; }
  .brand small{ display:none; }
  .proc-card .price{ font-size:1.7rem; }
  .metamorf__stats{ gap:1rem; }
}
/* większe, wygodniejsze pola formularzy i przyciski dotykowe */
@media(hover:none){
  .btn{ -webkit-tap-highlight-color:transparent; }
  .nav-links a,.faq-q,.chip{ -webkit-tap-highlight-color:transparent; }
}
