:root{
  --cream:#F5F1E6;
  --slate:#4D5F73;
  --ink:#1F2A34;
  --muted:#6E7A86;
  --accent:#9DB8C8;
  --white:#fff;
  --radius:18px;
  --shadow:0 8px 24px rgba(0,0,0,.08);
  --cert-card-h: 320px;     /* wysokość kafla na desktop */
  --cert-area-max: 860px;   /* maks szerokość całego bloku certyfikatów */
  --cert-area-max: 980px;        /* szerokość całego bloku na PC */
  --cert-max-w: 520px;           /* maks szerokość pojedynczego certu */
  --cert-gap: 42px;              /* odstęp między certami */
  --cert-pad: 14px;              /* grubość białej ramki */
  --cert-radius: 18px;           /* zaokrąglenie ramki */
}


/* ==================== BASE ==================== */

*{box-sizing:border-box}

html{scroll-behavior:smooth}

body{
  margin:0;
  background:var(--cream);
  color:var(--ink);
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  line-height:1.65;
  overflow-x:hidden; /* zabezpieczenie przed poziomowym scrollem na mobile */
}

a{
  color:inherit;
  text-decoration:none;
}

img{
  max-width:100%;
  display:block;
}

.container{
  width:min(1100px,92vw);
  margin-inline:auto;
}

/* ==================== HEADER ==================== */

header{
  position:sticky;
  top:0;
  z-index:50;
  background:var(--cream);
  border-bottom:1px solid rgba(0,0,0,.06);
  backdrop-filter:saturate(1.1) blur(6px);
}

.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 0;
}

.brand{
  display:flex;
  align-items:center;
  gap:8px;
  font-weight:700;
  text-decoration:none;
  color:inherit;
}

.brand span{
  font-family:"Playfair Display",serif;
  font-size:1.25rem;
  letter-spacing:.2px;
}

/* logo w nagłówku / stopce – mała ikonka z tłem */
.logo{
  width:auto;
  height:40px;
  border-radius:10px;
  background:linear-gradient(135deg,var(--slate),#71879B);
  box-shadow:var(--shadow);
  object-fit:contain;
  display:block;
}

/* jeśli używasz graficznego logo (plik PNG/JPG) */
.logo-img{
  height:70px;
  width:auto;
  display:block;
}

/* MENU DESKTOP */

.menu{
  display:flex;
  gap:22px;
  align-items:center;
}

.menu a{
  padding:8px 10px;
  border-radius:12px;
  font-weight:500;
  color:var(--ink);
}

.menu a:hover{
  background:rgba(0,0,0,.05);
}

.cta{
  background:var(--slate);
  color:var(--white);
  padding:9px 14px;
  border-radius:12px;
  box-shadow:var(--shadow);
}

/* HAMBURGER / DRAWER */

.hamb{
  display:none;
  background:none;
  border:0;
  padding:8px;
  border-radius:10px;
}

.hamb svg{
  width:24px;
  height:24px;
}

.drawer{
  position:fixed;
  inset:auto 0 auto auto;
  top:56px;
  width:min(92vw,360px);
  background:var(--cream);
  border:1px solid rgba(0,0,0,.06);
  border-right:0;
  border-top-left-radius:14px;
  box-shadow:var(--shadow);
  padding:18px;
  display:none;
}

.drawer a{
  display:block;
  padding:10px 12px;
  border-radius:10px;
}

.drawer a:hover{
  background:rgba(0,0,0,.05);
}

.drawer.show{
  display:block;
}

/* ==================== HERO ==================== */

.hero{
  background:linear-gradient(0deg,var(--slate) 65%,var(--cream) 65%);
  padding:clamp(70px,12vw,140px) 0 70px;
  color:var(--white);
}

.hero-card{
  background:url("img/tlo3.png") center/cover no-repeat;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:clamp(22px,3vw,36px);
  border:none;
  position:relative;
}

.eyebrow{
  letter-spacing:.25em;
  text-transform:uppercase;
  font-size:.8rem;
  display:inline-block;
  background:rgba(77,95,115,.9);
  color:#fff;
  padding:6px 10px;
  border-radius:999px;
  box-shadow:0 2px 8px rgba(0,0,0,.15);
}

h1{
  font-family:"Playfair Display",serif;
  font-weight:700;
  line-height:1.1;
  margin:6px 0 14px;
  font-size:clamp(32px,5vw,54px);
}

.lead{
  font-size:clamp(16px,1.8vw,20px);
  opacity:.95;
}

.actions{
  display:flex;
  gap:12px;
  margin-top:18px;
}

.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:12px 16px;
  border-radius:14px;
  font-weight:600;
  border:1px solid transparent;
  transition:.15s;
}

.btn.primary{
  background:var(--white);
  color:var(--slate);
}

.btn:hover{
  transform:translateY(-1px);
}

/* ==================== SEKCJE OGÓLNE ==================== */

section{
  padding:clamp(48px,7vw,80px) 0;
}

.section-title{
  font-family:"Playfair Display",serif;
  font-size:clamp(26px,3.2vw,36px);
  margin:0 0 14px;
}

.section-desc{
  color:var(--muted);
  margin-bottom:24px;
}

/* ==================== O MNIE – RZĄD 1 ==================== */

.about{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:28px;
  align-items:center;
}

.portrait{
  aspect-ratio:1/1;
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(0,0,0,.06);
}

.portrait img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:50% 35%;
  display:block;
}

.bio-panel{
  background:#e7eff6;
  border:1px solid rgba(0,0,0,.06);
  border-radius:16px;
  box-shadow:var(--shadow);
  padding:20px;
}

.sig{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-top:12px;
  color:var(--muted);
}

.sig .mark{
  width:36px;
  height:18px;
  border-radius:40px;
  background:linear-gradient(135deg,#c6d6e1,#9db8c8);
  box-shadow:var(--shadow);
}

/* ==================== O MNIE / KOMU POMAGAM – RZĄD 2 ==================== */

.about2{
  display:grid;
  grid-template-columns:1.3fr 1fr;
  gap:28px;
  align-items:center;
}

.about2 .about-text{
  background:var(--white);
  border:1px solid rgba(0,0,0,.06);
  border-radius:16px;
  box-shadow:var(--shadow);
  padding:20px;
}

.about2 .about-photo{
  border:1px solid rgba(0,0,0,.06);
  border-radius:16px;
  overflow:hidden;
  height:532px;
  width:100%;
  max-width:402px;
  min-height:300px;
  display:flex;
  background:linear-gradient(145deg,#dfe6ef,#c6d6e1);
  margin-left:auto;
}

.about2 .about-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

/* slider wewnątrz kafla "O mnie" */
.about-photo .slider{
  height:100%;
  width:100%;
  max-width:none;
  aspect-ratio:3 / 4;
  margin:0;
  border-radius:16px;
  overflow:hidden;
}

/* KOMU POMAGAM – wyrównanie kolumn i zamiana miejsc */

#komu-pomagam .about2{
  grid-template-columns:1fr 1fr;
  align-items:center;
  gap:40px;
}

/* kolejność na desktopie: zdjęcie / grafika po lewej, tekst po prawej */
#komu-pomagam .about-photo{
  order:1;
}

#komu-pomagam .about-text{
  order:2;
}

/* ==================== KAFELKI / KARTY ==================== */

.cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}

.card{
  background:var(--white);
  border:1px solid rgba(0,0,0,.06);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:22px;
}

/* flipowane karty */

.card.flip{
  padding:0;
  overflow:hidden;
  position:relative;
  min-height:230px;
  perspective:1000px;
}

.flip-inner{
  height:100%;
  position:relative;
  transform-style:preserve-3d;
  transition:transform .6s;
}

.flip.flipped .flip-inner{
  transform:rotateY(180deg);
}

.card.flip .front,
.card.flip .back,
.front-first,
.front-sec{
  position:absolute;
  inset:0;
  padding:10px;
  background:var(--white);
  -webkit-backface-visibility:hidden;
  backface-visibility:hidden;
  border-radius:var(--radius);
}

.card.flip .front,
.card.flip .back{font-size:14.5px}

.front-first{font-size:14px}
.front-sec{font-size:13.5px}

.card.flip .back{
  transform:rotateY(180deg);
}

.amt{
  font-size:1.4rem;
  font-weight:700;
  color:var(--slate);
}

.back .title{
  font-weight:700;
  margin:0 0 6px;
}

.back .amt{
  font-size:1.8rem;
  font-weight:700;
  color:var(--slate);
  margin:6px 0 8px;
}

.back .desc{
  color:var(--muted);
  margin-bottom:10px;
}

.badges{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.badge{
  padding:6px 10px;
  border-radius:999px;
  background:rgba(0,0,0,.06);
  font-size:.9rem;
}

/* ==================== GALERIA ==================== */

.gallery-wrap{
  background:var(--white);
  border-radius:var(--radius);
  border:1px solid rgba(0,0,0,.06);
  box-shadow:var(--shadow);
  padding:18px;
}

.gallery{
  display:grid;
  grid-template-columns:2fr 1fr;
  gap:18px;
  align-items:start;
}

.slider{
  position:relative;
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(0,0,0,.06);
  aspect-ratio:16 / 9;
}

/* tekst obok galerii */

.gallery-text{
  background:var(--white);
  border:1px solid rgba(0,0,0,.06);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:18px;
}

.gallery-list{
  padding-left:0;
  margin:10px 0 0;
  list-style:none;
}

.gallery-list li{
  margin:8px 0;
  color:var(--ink);
}

/* ==================== DATA-SLIDES SLIDER (JS) ==================== */

.js-data-slider{
  position:relative;
  overflow:hidden;
}

.js-data-slider__img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  opacity:1;
  transition:opacity .6s cubic-bezier(.22,.61,.36,1);
}

.js-data-slider__img.is-fading{
  opacity:0;
}

.js-data-slider__btn{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  border:0;
  background:rgba(0,0,0,.5);
  color:#fff;
  width:40px;
  height:40px;
  border-radius:999px;
  cursor:pointer;
  display:grid;
  place-items:center;
  font-size:18px;
  box-shadow:var(--shadow);
}

.js-data-slider__btn--prev{left:12px}
.js-data-slider__btn--next{right:12px}

.js-data-slider__dots{
  position:absolute;
  left:50%;
  bottom:12px;
  transform:translateX(-50%);
  display:flex;
  gap:8px;
}

.js-data-slider__dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:rgba(0,0,0,.25);
  border:0;
  cursor:pointer;
}

.js-data-slider__dot.is-active{
  background:rgba(0,0,0,.6);
}

/* ==================== FAQ ==================== */

.faq{
  background:var(--white);
  border:1px solid rgba(0,0,0,.06);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}

details{
  border-top:1px solid rgba(0,0,0,.06);
}

details:first-of-type{
  border-top:0;
}

summary{
  list-style:none;
  padding:18px 20px;
  cursor:pointer;
  font-weight:600;
}

summary::-webkit-details-marker{
  display:none;
}

details[open] summary{
  background:rgba(0,0,0,.03);
}

.faq p{
  padding:0 20px 20px;
  margin:0;
  color:var(--muted);
}

/* ==================== KONTAKT ==================== */

.contact{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:24px;
  align-items:start;
}

.contact .box{
  background:var(--white);
  border:1px solid rgba(0,0,0,.06);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:20px;
}

.contact ul{
  padding:0;
  margin:0;
  list-style:none;
}

.contact li{
  margin:8px 0;
}

.map{
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(0,0,0,.06);
}

/* ==================== TEKST POD KAFELKAMI ==================== */

#jak-pomagam .intro{
  margin:6px 0 14px;
  color:var(--ink);
}

.under-cards .psy-short{
  margin-top:-75px;
  padding:0;
  background:none;
  border:0;
  border-radius:0;
  box-shadow:none;
  color:var(--ink);
}

/* ==================== FOOTER ==================== */

footer{
  padding:28px 0 36px;
  color:#fff;
  background:var(--slate);
}

footer .container{
  display:flex;
  align-items:center;
  justify-content:space-between;
}

footer small{
  opacity:.8;
}

/* ==================== ANIMACJE ==================== */

.reveal{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .6s ease, transform .6s ease;
}

.reveal.in{
  opacity:1;
  transform:none;
}

[data-stagger] > *{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .6s ease, transform .6s ease;
}

[data-stagger].in > *{
  opacity:1;
  transform:none;
}

[data-stagger].in > *:nth-child(1){transition-delay:.05s}
[data-stagger].in > *:nth-child(2){transition-delay:.12s}
[data-stagger].in > *:nth-child(3){transition-delay:.18s}

/* ==================== RESPONSYWNOŚĆ ==================== */

@media (max-width:960px){
  .about{grid-template-columns:1fr}
  .about2{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr 1fr}

  /* --- KOMU POMAGAM: mobilnie jak "O mnie" --- */

  /* jedna kolumna tylko w tej sekcji */
  #komu-pomagam .about2{
    grid-template-columns:1fr;
  }

  /* tekst nad grafiką */
  #komu-pomagam .about-text{
    order:1;
  }

  #komu-pomagam .about-photo{
    order:2;
    margin:24px auto 0;
    width:100%;
    max-width:340px;
    height:auto;
    min-height:0;
  }

  #komu-pomagam .about-photo img{
    height:auto;
    object-fit:contain;
  }
}



@media (max-width:768px){
  .about2 .about-photo{
    height:auto;
    max-width:340px;
    margin:0 auto;
  }

    #komu-pomagam .about-text{order:1}
    #komu-pomagam .about-photo{order:2}
}

@media (max-width:680px){
  .menu{display:none}
  .hamb{display:inline-flex}
  .cards{grid-template-columns:1fr}

  #komu-pomagam .about-text{order:1}
  #komu-pomagam .about-photo{order:2}

}

/* Certyfikaty – sekcja O MNIE (rząd 2) */
.about-extended .about-photo{
  height:auto;
  max-width:none;
  min-height:0;
  margin:0;
  background:var(--white);
  display:flex;
  align-items:center;
  justify-content:center;
}

.about-extended .about-photo img{
  width:100%;
  height:auto;
  max-width:520px;
  object-fit:contain;
  border-radius:16px;
  box-shadow:var(--shadow);
}

/* CERTYFIKATY – małe, obok siebie, wyśrodkowane (desktop) */
.about-extended {
  padding-top: 18px; /* mniejszy odstęp od "O mnie" */
}

.container.certificates{
  max-width: var(--cert-area-max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 32px;
}

.cert-card{
  height: var(--cert-card-h);
  padding: 14px;
  background:#fff;
  border:1px solid rgba(0,0,0,.06);
  border-radius:16px;
  box-shadow: var(--shadow);
  display:grid;
  place-items:center;
}

.cert-img{
  width:100%;
  height:100%;
  object-fit:contain;
  border-radius:12px;
}


/* mobile: jedna kolumna */
@media (max-width: 800px) {
  .container.certificates {
    grid-template-columns: 1fr;
    max-width: 520px;
  }

  .cert-card,
  .cert-card--landscape {
    height: auto;
  }

  .cert-img {
    height: auto;
    max-height: 520px;
  }
}


/* ===== CERTYFIKATY: PC layout bez psucia mobile ===== */
@media (min-width: 801px){
  .container.certificates{
    max-width: var(--cert-area-max);
    grid-template-columns: repeat(2, minmax(0, var(--cert-max-w)));
    justify-content: center;
    gap: var(--cert-gap);
    align-items: center;
  }

  .cert-card{
    /* ramka jak na mobile */
    padding: var(--cert-pad);
    border-radius: var(--cert-radius);

    /* klucz: zero sztywnych wysokości */
    height: auto;

    /* spójne proporcje */
    aspect-ratio: 4 / 3; /* bazowo */
  }

  /* jeśli chcesz, aby lewy (poziomy) miał bardziej panoramiczne proporcje */
  .cert-card--landscape{
    aspect-ratio: 16 / 10;
  }

  .cert-img{
    width: 100%;
    height: 100%;
    object-fit: contain;
    border-radius: calc(var(--cert-radius) - 6px);
  }
}


/* ==================== FOOTER ==================== */

footer{
  padding:28px 0 36px;
  color:#fff;
  background:var(--slate);
}

.footer-top{
  display:grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 40px;
  align-items:start;
}

.footer-brand-head{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:10px;
}

/* logo + “kapsułka” jak wcześniej */
.footer-logo{
  height:44px;
  width:auto;
  border-radius:12px;
  background:linear-gradient(135deg,var(--slate),#71879B);
  box-shadow:var(--shadow);
  object-fit:contain;
  display:block;
  padding:6px;
}

.footer-brand-name{
  font-family:"Playfair Display",serif;
  font-size:1.35rem;
  font-weight:700;
  letter-spacing:.2px;
}

.footer-brand-desc{
  opacity:.9;
  margin:0;
  max-width: 46ch;
}

.footer-title{
  font-size:1.05rem;
  margin:0 0 10px;
  font-weight:700;
}

.footer-address{
  margin:0;
  font-style:normal;
  opacity:.9;
  max-width: 70ch;
}

.footer-bottom{
  margin-top:18px;
  padding-top:14px;
  border-top:1px solid rgba(255,255,255,.12);
  display:flex;
  justify-content:flex-start;
}

footer small{opacity:.8}

/* mobile */
@media (max-width: 860px){
  .footer-top{
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .footer-bottom{
    justify-content:flex-start;
  }
}
