/* =========================================================================
   ELIM — Gabinet Dermokosmetyczny
   Design system + layout
   ========================================================================= */

:root{
  /* paleta */
  --cream:    #FBF7F2;
  --cream-2:  #F5EDE3;
  --sand:     #EDE2D4;
  --ink:      #2B2620;
  --ink-2:    #3D362E;
  --ink-soft: #5C5349;
  --muted:    #8A7E70;
  --line:     #E8DCCD;
  --rose:     #C0846F;
  --rose-deep:#A66A55;
  --rose-soft:#F1DDD3;
  --rose-tint:#FAEEE7;
  --gold:     #C2A36B;
  --white:    #ffffff;
  --green:    #6E7A5E;

  /* typografia */
  --serif: "Fraunces", Georgia, "Times New Roman", serif;
  --sans:  "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

  /* kształt / cień */
  --r-sm: 12px;
  --r:    18px;
  --r-lg: 26px;
  --r-xl: 36px;
  --shadow-sm: 0 2px 10px rgba(43,38,32,.06);
  --shadow:    0 18px 50px -22px rgba(43,38,32,.30);
  --shadow-lg: 0 40px 90px -30px rgba(43,38,32,.42);

  --container: 1200px;
  --gutter: clamp(18px, 4vw, 40px);
  --header-h: 76px;
}

/* ---------- reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; border:none; background:none; color:inherit; }
h1,h2,h3,h4{ font-family:var(--serif); font-weight:500; line-height:1.12; letter-spacing:-.01em; color:var(--ink); }
::selection{ background:var(--rose); color:#fff; }

.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--gutter); }

.skip-link{
  position:absolute; left:-9999px; top:0; z-index:200;
  background:var(--ink); color:#fff; padding:10px 16px; border-radius:0 0 10px 0;
}
.skip-link:focus{ left:0; }

:focus-visible{ outline:3px solid var(--rose); outline-offset:3px; border-radius:6px; }

/* =========================================================================
   BUTTONS
   ========================================================================= */
.btn{
  --btn-bg:var(--ink); --btn-fg:#fff;
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  background:var(--btn-bg); color:var(--btn-fg);
  padding:.85em 1.4em; border-radius:999px;
  font-weight:600; font-size:.97rem; letter-spacing:.01em;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease;
  box-shadow:var(--shadow-sm); white-space:nowrap;
}
.btn svg{ width:1.15em; height:1.15em; fill:none; stroke:currentColor; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; flex:none; }
.btn:hover{ transform:translateY(-2px); box-shadow:var(--shadow); }
.btn:active{ transform:translateY(0); }
.btn--primary{ --btn-bg:var(--rose); --btn-fg:#fff; }
.btn--primary:hover{ background:var(--rose-deep); }
.btn--dark{ --btn-bg:var(--ink); --btn-fg:#fff; }
.btn--ghost{ background:transparent; color:var(--ink); border:1.5px solid var(--line); box-shadow:none; }
.btn--ghost:hover{ border-color:var(--ink); background:var(--white); }
.btn--lg{ padding:1.05em 1.7em; font-size:1.03rem; }
.btn--sm{ padding:.6em 1.05em; font-size:.88rem; }
.btn--block{ width:100%; }

/* =========================================================================
   TOPBAR
   ========================================================================= */
.topbar{
  background:var(--ink); color:#E9E0D5; font-size:.82rem;
  position:relative; z-index:60;
}
.topbar__inner{ display:flex; align-items:center; gap:14px; min-height:40px; flex-wrap:wrap; }
.topbar__item{ display:inline-flex; align-items:center; gap:7px; color:#CFC4B7; }
.topbar svg{ width:15px; height:15px; fill:none; stroke:var(--rose); stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
.topbar__sep{ color:#5d5347; }
.topbar__phone{ margin-left:auto; display:inline-flex; align-items:center; gap:7px; font-weight:600; color:#fff; }
.topbar__phone svg{ stroke:var(--rose); }
.topbar__phone:hover{ color:var(--rose-soft); }
@media (max-width:720px){
  .topbar__hours, .topbar__sep{ display:none; }
  .topbar__inner{ justify-content:space-between; }
}

/* =========================================================================
   HEADER
   ========================================================================= */
.header{
  position:sticky; top:0; z-index:50;
  background:rgba(251,247,242,.82);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .3s, box-shadow .3s, background .3s;
}
.header.is-stuck{ border-color:var(--line); box-shadow:0 6px 24px -18px rgba(43,38,32,.5); }
.header__inner{ display:flex; align-items:center; gap:24px; min-height:var(--header-h); }

.brand{ display:inline-flex; align-items:center; gap:12px; }
.brand__mark{
  width:42px; height:42px; border-radius:12px; flex:none;
  display:grid; place-items:center;
  background:linear-gradient(140deg,var(--rose),var(--rose-deep));
  color:#fff; font-family:var(--serif); font-size:1.5rem; font-weight:600;
  box-shadow:0 6px 16px -6px var(--rose-deep);
}
.brand__text{ display:flex; flex-direction:column; line-height:1.05; }
.brand__name{ font-family:var(--serif); font-size:1.32rem; font-weight:600; letter-spacing:.16em; }
.brand__sub{ font-size:.68rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); }

.nav{ display:flex; gap:6px; margin-left:8px; }
.nav a{
  position:relative; padding:.55em .85em; border-radius:10px;
  font-size:.95rem; font-weight:500; color:var(--ink-soft); white-space:nowrap;
  transition:color .2s, background .2s;
}
.nav a::after{
  content:""; position:absolute; left:.85em; right:.85em; bottom:.32em; height:2px;
  background:var(--rose); transform:scaleX(0); transform-origin:left; transition:transform .25s;
}
.nav a:hover{ color:var(--ink); }
.nav a:hover::after, .nav a.is-active::after{ transform:scaleX(1); }
.nav a.is-active{ color:var(--ink); }

.header__actions{ margin-left:auto; display:flex; align-items:center; gap:12px; }
.header__call b{ font-weight:700; }

.burger{ display:none; width:44px; height:44px; border-radius:12px; position:relative; }
.burger span{
  position:absolute; left:11px; right:11px; height:2px; background:var(--ink); border-radius:2px;
  transition:transform .3s, opacity .2s, top .3s;
}
.burger span:nth-child(1){ top:15px; }
.burger span:nth-child(2){ top:21px; }
.burger span:nth-child(3){ top:27px; }
.burger[aria-expanded="true"] span:nth-child(1){ top:21px; transform:rotate(45deg); }
.burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.burger[aria-expanded="true"] span:nth-child(3){ top:21px; transform:rotate(-45deg); }

@media (max-width:980px){
  .header__call span{ display:none; }
  .header__call{ padding:.7em; }
  .header__call svg{ width:1.25em; height:1.25em; }
}
@media (max-width:860px){
  /* backdrop-filter tworzy containing block dla position:fixed —
     na mobile wyłączamy je, by drawer (.nav) pozycjonował się względem viewportu */
  .header{ backdrop-filter:none; -webkit-backdrop-filter:none; background:var(--cream); }
  .nav{
    position:fixed; inset:0 0 0 auto; width:min(82vw,340px); z-index:60;
    flex-direction:column; gap:2px; margin:0; padding:96px 22px 30px;
    background:var(--cream); box-shadow:var(--shadow-lg);
    transform:translateX(100%); transition:transform .35s cubic-bezier(.4,0,.2,1);
    border-left:1px solid var(--line);
  }
  .nav.is-open{ transform:translateX(0); }
  .nav a{ font-size:1.1rem; padding:.7em .6em; border-bottom:1px solid var(--line); border-radius:0; }
  .nav a::after{ display:none; }
  .burger{ display:block; }
  body.nav-open{ overflow:hidden; }
}

/* backdrop for mobile nav */
.nav-backdrop{
  position:fixed; inset:0; background:rgba(43,38,32,.42); z-index:40;
  opacity:0; visibility:hidden; transition:opacity .3s, visibility .3s;
}
.nav-backdrop.is-open{ opacity:1; visibility:visible; }

/* =========================================================================
   HERO
   ========================================================================= */
.hero{ position:relative; overflow:hidden; }
.hero__bg{
  position:absolute; inset:0; z-index:-1;
  background:
    radial-gradient(1100px 520px at 88% -8%, var(--rose-tint), transparent 60%),
    radial-gradient(900px 600px at 0% 100%, var(--cream-2), transparent 55%),
    var(--cream);
}
.hero__inner{
  display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(28px,5vw,68px);
  align-items:center; padding:clamp(46px,7vw,96px) var(--gutter) clamp(60px,8vw,110px);
}
.eyebrow{
  display:inline-flex; align-items:center; gap:9px;
  font-size:.8rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase;
  color:var(--rose-deep); margin-bottom:20px;
}
.eyebrow__dot{ width:7px; height:7px; border-radius:50%; background:var(--rose); box-shadow:0 0 0 4px var(--rose-soft); }
.eyebrow--center{ display:flex; justify-content:center; }
.eyebrow--light{ color:#E7C9BD; }
.eyebrow--light .eyebrow__dot{ background:var(--rose-soft); box-shadow:0 0 0 4px rgba(241,221,211,.25); }

.hero__title{
  font-size:clamp(2.5rem,6vw,4.3rem); line-height:1.04;
}
.hero__title em{ font-style:italic; color:var(--rose-deep); }
.hero__lead{
  margin:24px 0 32px; max-width:33em; font-size:clamp(1.02rem,1.6vw,1.18rem); color:var(--ink-soft);
}
.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; }
.hero__trust{
  list-style:none; display:flex; gap:clamp(18px,3vw,38px); margin-top:40px; flex-wrap:wrap;
  border-top:1px solid var(--line); padding-top:26px;
}
.hero__trust li{ display:flex; flex-direction:column; }
.hero__trust strong{ font-family:var(--serif); font-size:1.6rem; color:var(--ink); font-weight:600; }
.hero__trust span{ font-size:.84rem; color:var(--muted); }

/* hero media */
.hero__media{ position:relative; }
.hero__photo{
  position:relative; border-radius:var(--r-xl); overflow:hidden;
  box-shadow:var(--shadow-lg); aspect-ratio:4/4.6;
  border:7px solid #fff;
}
.hero__photo::after{ content:""; position:absolute; inset:0; box-shadow:inset 0 0 0 1px rgba(43,38,32,.05); border-radius:inherit; }
.hero__photo img{ width:100%; height:100%; object-fit:cover; object-position:center 18%; }
.hero__media::before{
  content:""; position:absolute; right:-26px; top:-26px; width:140px; height:140px; z-index:-1;
  background:radial-gradient(circle at 30% 30%, var(--rose-soft), transparent 70%);
  border-radius:50%;
}
.hero__badge{
  position:absolute; left:-22px; bottom:46px;
  background:#fff; border-radius:var(--r); padding:14px 18px;
  box-shadow:var(--shadow); display:flex; flex-direction:column; gap:2px; max-width:200px;
  border:1px solid var(--line);
}
.hero__badge-stars{ color:var(--gold); letter-spacing:2px; font-size:.95rem; }
.hero__badge-text{ font-size:.8rem; color:var(--ink-soft); line-height:1.35; }
.hero__badge-text b{ color:var(--ink); }
.hero__chip{
  position:absolute; right:-14px; top:30px;
  background:#fff; border:1px solid var(--line); border-radius:999px;
  padding:9px 15px 9px 12px; font-size:.8rem; font-weight:600; color:var(--ink);
  box-shadow:var(--shadow); display:inline-flex; align-items:center; gap:8px;
}
.hero__chip svg{ width:17px; height:17px; fill:none; stroke:var(--green); stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }

@media (max-width:860px){
  .hero__inner{ grid-template-columns:1fr; gap:46px; }
  .hero__media{ max-width:440px; margin-inline:auto; width:100%; }
}
@media (max-width:520px){
  .hero__badge{ left:-6px; padding:11px 14px; }
  .hero__chip{ right:-2px; }
}

/* =========================================================================
   USP STRIP
   ========================================================================= */
.usp{ background:var(--white); border-block:1px solid var(--line); }
.usp__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(20px,3vw,40px); padding:clamp(40px,5vw,64px) var(--gutter); }
.usp__item h3{ font-size:1.12rem; margin-bottom:6px; }
.usp__item p{ font-size:.92rem; color:var(--ink-soft); }
.usp__ico{
  display:grid; place-items:center; width:54px; height:54px; border-radius:15px; margin-bottom:16px;
  background:var(--rose-tint); color:var(--rose-deep);
}
.usp__ico svg{ width:26px; height:26px; fill:none; stroke:currentColor; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; }
@media (max-width:860px){ .usp__grid{ grid-template-columns:1fr 1fr; gap:28px; } }
@media (max-width:480px){ .usp__grid{ grid-template-columns:1fr; } }

/* =========================================================================
   SECTIONS (generic)
   ========================================================================= */
.section{ padding:clamp(64px,9vw,118px) 0; }
.section--tint{ background:linear-gradient(180deg,var(--cream),var(--cream-2)); }
.section__head{ max-width:680px; margin:0 auto clamp(40px,5vw,60px); text-align:center; }
.section__head--left{ margin-inline:0; text-align:left; }
.section__title{ font-size:clamp(2rem,4.2vw,3.1rem); }
.section__title--left{ text-align:left; }
.section__lead{ margin-top:16px; color:var(--ink-soft); font-size:1.06rem; }
.section__lead--left{ margin-inline:0; }

/* =========================================================================
   CARDS (zabiegi)
   ========================================================================= */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.4vw,28px); }
.card{
  background:var(--white); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:clamp(24px,3vw,34px); position:relative; overflow:hidden;
  transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.card::before{
  content:""; position:absolute; inset:0 0 auto 0; height:3px;
  background:linear-gradient(90deg,var(--rose),var(--gold)); transform:scaleX(0); transform-origin:left;
  transition:transform .35s ease;
}
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:transparent; }
.card:hover::before{ transform:scaleX(1); }
.card__ico{
  display:grid; place-items:center; width:58px; height:58px; border-radius:16px; margin-bottom:20px;
  background:var(--rose-tint); color:var(--rose-deep);
}
.card__ico svg{ width:28px; height:28px; fill:none; stroke:currentColor; stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; }
.card h3{ font-size:1.24rem; margin-bottom:9px; }
.card p{ color:var(--ink-soft); font-size:.95rem; margin-bottom:18px; }
.card__link{ display:inline-flex; align-items:center; gap:7px; font-weight:600; color:var(--rose-deep); font-size:.92rem; }
.card__link span{ transition:transform .25s; }
.card__link:hover span{ transform:translateX(4px); }

.cards__note{
  display:flex; align-items:center; justify-content:center; gap:11px; flex-wrap:wrap;
  text-align:center; margin-top:36px; color:var(--ink-soft); font-size:1.02rem;
}
.cards__note svg{ width:20px; height:20px; fill:none; stroke:var(--rose-deep); stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; flex:none; }
.cards__note a{ color:var(--rose-deep); font-weight:600; text-decoration:underline; text-underline-offset:3px; text-decoration-thickness:1.5px; }
.cards__note a:hover{ color:var(--rose); }

@media (max-width:880px){ .cards{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .cards{ grid-template-columns:1fr; } }

/* =========================================================================
   STEPS (jak umówić) — dark band
   ========================================================================= */
.section--steps{
  background:
    linear-gradient(180deg, rgba(43,38,32,.92), rgba(43,38,32,.92)),
    url("../img/treatment-care.jpg") center/cover fixed;
  color:#F4ECE3;
}
.section--steps .section__title{ color:#fff; }
.section--steps .section__lead{ color:#D9CEC1; }
.steps{ list-style:none; display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,3vw,34px); counter-reset:s; max-width:980px; margin-inline:auto; }
.step{
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14);
  border-radius:var(--r-lg); padding:clamp(26px,3vw,36px); position:relative;
  backdrop-filter:blur(2px);
}
.step__num{
  display:grid; place-items:center; width:46px; height:46px; border-radius:50%;
  background:var(--rose); color:#fff; font-family:var(--serif); font-size:1.3rem; font-weight:600;
  margin-bottom:18px; box-shadow:0 8px 20px -8px rgba(0,0,0,.5);
}
.step h3{ color:#fff; font-size:1.3rem; margin-bottom:8px; }
.step p{ color:#D9CEC1; font-size:.96rem; }
.step p a{ color:#fff; font-weight:600; text-decoration:underline; text-underline-offset:3px; }
.step:not(:last-child)::after{
  content:""; position:absolute; right:-18px; top:50%; width:18px; height:2px; background:rgba(255,255,255,.25);
}
.steps__cta{ text-align:center; margin-top:48px; }
@media (max-width:760px){
  .steps{ grid-template-columns:1fr; }
  .step:not(:last-child)::after{ display:none; }
  .section--steps{ background-attachment:scroll; }
}

/* =========================================================================
   ABOUT
   ========================================================================= */
.about{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,5vw,72px); align-items:center; }
.about__media{ position:relative; }
.about__media img{ width:100%; border-radius:var(--r-xl); box-shadow:var(--shadow); aspect-ratio:3/2.1; object-fit:cover; }
.about__media::before{
  content:""; position:absolute; left:-22px; bottom:-22px; width:170px; height:170px; z-index:-1;
  border:2px solid var(--rose-soft); border-radius:var(--r-xl);
}
.about__stat{
  position:absolute; right:-16px; top:30px; background:#fff; border:1px solid var(--line);
  border-radius:var(--r); padding:14px 20px; box-shadow:var(--shadow); text-align:center; max-width:170px;
}
.about__stat strong{ display:block; font-family:var(--serif); font-size:1.7rem; color:var(--rose-deep); }
.about__stat span{ font-size:.78rem; color:var(--ink-soft); }
.about__body > p{ color:var(--ink-soft); margin-bottom:16px; max-width:40em; }
.about__body .section__title{ margin-bottom:20px; }
.about__body .btn{ margin-top:10px; }
.ticks{ list-style:none; margin:6px 0 26px; display:grid; gap:11px; }
.ticks li{ position:relative; padding-left:34px; color:var(--ink-2); }
.ticks li::before{
  content:""; position:absolute; left:0; top:1px; width:22px; height:22px; border-radius:50%;
  background:var(--rose-tint) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23A66A55' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m5 12 4 4 10-10'/%3E%3C/svg%3E") center/13px no-repeat;
}
@media (max-width:840px){
  .about{ grid-template-columns:1fr; }
  .about__media{ max-width:520px; }
  .about__stat{ right:10px; }
}

/* =========================================================================
   GALLERY
   ========================================================================= */
.gallery{
  display:grid; grid-template-columns:repeat(3,1fr); gap:18px;
}
.gallery__item{ overflow:hidden; border-radius:var(--r); position:relative; box-shadow:var(--shadow-sm); aspect-ratio:3/4; }
.gallery__item img{ width:100%; height:100%; object-fit:cover; transition:transform .7s cubic-bezier(.2,.6,.2,1); }
.gallery__item:hover img{ transform:scale(1.05); }
.gallery__item::after{
  content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 55%,rgba(43,38,32,.18));
  opacity:0; transition:opacity .3s;
}
.gallery__item:hover::after{ opacity:1; }
@media (max-width:680px){
  .gallery{ grid-template-columns:1fr 1fr; gap:14px; }
}
@media (max-width:430px){
  .gallery{ grid-template-columns:1fr; max-width:360px; margin-inline:auto; }
}

/* =========================================================================
   QUOTES
   ========================================================================= */
.quotes{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.4vw,26px); }
.quote{
  background:var(--white); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:clamp(26px,3vw,34px); position:relative;
}
.quote::before{
  content:"\201C"; position:absolute; top:6px; right:22px; font-family:var(--serif);
  font-size:5rem; line-height:1; color:var(--rose-soft);
}
.quote__stars{ color:var(--gold); letter-spacing:2px; font-size:1rem; }
.stars-inline{ color:var(--gold); letter-spacing:2px; }
.quote p{ margin:14px 0 20px; color:var(--ink-2); font-size:1.02rem; position:relative; z-index:1; }
.quote footer{ display:flex; align-items:center; gap:11px; font-weight:600; color:var(--ink); font-size:.95rem; }
.quote__avatar{
  width:38px; height:38px; border-radius:50%; display:grid; place-items:center;
  background:linear-gradient(140deg,var(--rose),var(--rose-deep)); color:#fff; font-family:var(--serif); font-weight:600;
}
@media (max-width:860px){ .quotes{ grid-template-columns:1fr; max-width:560px; margin-inline:auto; } }

/* =========================================================================
   FAQ
   ========================================================================= */
.faq{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(34px,5vw,64px); align-items:start; }
.faq .section__head{ position:sticky; top:calc(var(--header-h) + 20px); }
.faq .btn{ margin-top:24px; }
.faq__list{ display:grid; gap:12px; }
.faq__item{
  background:var(--white); border:1px solid var(--line); border-radius:var(--r);
  padding:4px 22px; transition:box-shadow .3s, border-color .3s;
}
.faq__item[open]{ box-shadow:var(--shadow-sm); border-color:var(--rose-soft); }
.faq__item summary{
  list-style:none; cursor:pointer; padding:18px 36px 18px 0; position:relative;
  font-weight:600; font-size:1.05rem; color:var(--ink);
}
.faq__item summary::-webkit-details-marker{ display:none; }
.faq__item summary::after{
  content:""; position:absolute; right:0; top:50%; width:13px; height:13px; margin-top:-6px;
  border-right:2px solid var(--rose-deep); border-bottom:2px solid var(--rose-deep);
  transform:rotate(45deg) translateY(-2px); transition:transform .3s; transform-origin:center;
}
.faq__item[open] summary::after{ transform:rotate(-135deg); }
.faq__a{ padding:0 0 18px; color:var(--ink-soft); }
@media (max-width:840px){
  .faq{ grid-template-columns:1fr; }
  .faq .section__head{ position:static; }
}

/* =========================================================================
   CONTACT
   ========================================================================= */
.section--contact{ background:var(--ink); color:#EDE3D7; position:relative; overflow:hidden; }
.section--contact::before{
  content:""; position:absolute; top:-120px; right:-120px; width:380px; height:380px; border-radius:50%;
  background:radial-gradient(circle, rgba(192,132,111,.30), transparent 65%);
}
.section--contact .section__title{ color:#fff; }
.section--contact .section__lead{ color:#CFC4B7; }
.contact{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,52px); position:relative; z-index:1; }

.contact__phone{
  display:flex; align-items:center; gap:16px; background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14); border-radius:var(--r-lg); padding:20px 24px; margin-bottom:22px;
  transition:transform .25s, background .25s;
}
.contact__phone:hover{ transform:translateY(-2px); background:rgba(255,255,255,.1); }
.contact__phone svg{ width:30px; height:30px; fill:none; stroke:var(--rose-soft); stroke-width:2; stroke-linecap:round; stroke-linejoin:round; flex:none; }
.contact__phone small{ display:block; font-size:.8rem; color:#CFC4B7; letter-spacing:.04em; }
.contact__phone b{ font-family:var(--serif); font-size:1.9rem; color:#fff; font-weight:600; letter-spacing:.02em; }

.contact__list{ list-style:none; display:grid; gap:18px; }
.contact__list li{ display:flex; gap:14px; }
.contact__list svg{ width:22px; height:22px; fill:none; stroke:var(--rose-soft); stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; flex:none; margin-top:3px; }
.contact__list strong{ display:block; color:#fff; font-family:var(--serif); font-weight:500; font-size:1.05rem; margin-bottom:4px; }
.contact__list div{ color:#CFC4B7; font-size:.95rem; }

.hours{ width:100%; max-width:330px; border-collapse:collapse; margin-top:6px; }
.hours th, .hours td{ text-align:left; padding:5px 0; font-size:.9rem; border-bottom:1px solid rgba(255,255,255,.1); }
.hours th{ font-weight:500; color:#CFC4B7; }
.hours td{ text-align:right; color:#fff; font-variant-numeric:tabular-nums; }
.hours--off{ color:#9a8d7e !important; font-style:italic; }

.contact__map{ margin-top:22px; border-radius:var(--r); overflow:hidden; border:1px solid rgba(255,255,255,.14); background:#2f2a23; min-height:120px; }
.contact__map iframe{ width:100%; height:220px; border:0; display:block; filter:grayscale(.2) contrast(1.05); }
.contact__maplink{ display:inline-flex; align-items:center; gap:7px; margin-top:14px; font-size:.9rem; font-weight:600; color:var(--rose-soft); }
.contact__maplink svg{ width:15px; height:15px; fill:none; stroke:currentColor; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.contact__maplink:hover{ color:#fff; }

/* callback form card */
.contact__form-wrap{
  background:var(--cream); color:var(--ink); border-radius:var(--r-xl);
  padding:clamp(26px,3.5vw,40px); box-shadow:var(--shadow-lg);
}
.callback__title{ font-size:1.6rem; }
.callback__sub{ color:var(--ink-soft); margin:8px 0 22px; font-size:.96rem; }
.field{ margin-bottom:16px; }
.field label{ display:block; font-size:.86rem; font-weight:600; margin-bottom:7px; color:var(--ink-2); }
.field__opt{ font-weight:400; color:var(--muted); }
.field input, .field select, .field textarea{
  width:100%; font:inherit; font-size:.97rem; color:var(--ink);
  background:#fff; border:1.5px solid var(--line); border-radius:12px; padding:.78em .95em;
  transition:border-color .2s, box-shadow .2s;
}
.field textarea{ resize:vertical; min-height:84px; }
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--rose); box-shadow:0 0 0 4px var(--rose-soft);
}
.field__err{ display:none; color:#B4452F; font-size:.82rem; margin-top:6px; }
.field.is-invalid input, .field.is-invalid select{ border-color:#CE6A52; }
.field.is-invalid .field__err{ display:block; }
[data-err-for="cb-consent"]{ display:none; color:#B4452F; font-size:.82rem; margin:-6px 0 12px; }
.consent.is-invalid + [data-err-for="cb-consent"]{ display:block; }

.consent{ display:flex; gap:11px; align-items:flex-start; font-size:.88rem; color:var(--ink-soft); margin:4px 0 18px; cursor:pointer; }
.consent input{ width:19px; height:19px; margin-top:2px; accent-color:var(--rose-deep); flex:none; }
.callback__alt{ text-align:center; margin-top:16px; font-size:.92rem; color:var(--ink-soft); }
.callback__alt a{ font-weight:700; color:var(--rose-deep); }
.callback__ok{
  margin-top:18px; padding:14px 16px; border-radius:14px; background:var(--rose-tint);
  color:var(--ink-2); font-size:.92rem; display:flex; gap:10px; align-items:flex-start;
}
.callback__ok[hidden]{ display:none; }
.callback__ok svg{ width:22px; height:22px; fill:none; stroke:var(--green); stroke-width:2; stroke-linecap:round; stroke-linejoin:round; flex:none; }
.callback__ok a{ font-weight:700; color:var(--rose-deep); white-space:nowrap; }

@media (max-width:840px){ .contact{ grid-template-columns:1fr; } }

/* =========================================================================
   FOOTER
   ========================================================================= */
.footer{ background:#211D18; color:#C9BEB0; padding-top:clamp(48px,6vw,72px); }
.footer__inner{ display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:clamp(28px,4vw,48px); padding-bottom:46px; }
.brand--light .brand__sub{ color:#9a8d7e; }
.brand--light .brand__name{ color:#fff; }
.footer__desc{ margin-top:18px; font-size:.92rem; max-width:34ch; color:#A99D8E; }
.footer__col h4{ color:#fff; font-family:var(--sans); font-size:.82rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; margin-bottom:16px; }
.footer__col{ display:flex; flex-direction:column; gap:10px; align-items:flex-start; }
.footer__col a, .footer__col span{ font-size:.93rem; color:#B7AC9D; transition:color .2s; }
.footer__col a:hover{ color:#fff; }
.footer__col .btn{ margin-bottom:6px; }
.footer__bar{ border-top:1px solid rgba(255,255,255,.08); }
.footer__bar-in{ display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; padding-block:20px; font-size:.82rem; color:#8c8071; }
@media (max-width:860px){ .footer__inner{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .footer__inner{ grid-template-columns:1fr; } .footer__bar-in{ justify-content:center; text-align:center; } }

/* =========================================================================
   STICKY MOBILE CALL BAR
   ========================================================================= */
.callbar{
  position:fixed; left:12px; right:12px; bottom:12px; z-index:55;
  display:none; align-items:center; justify-content:center; gap:10px;
  background:var(--rose); color:#fff; padding:15px; border-radius:16px;
  font-weight:600; box-shadow:0 16px 36px -12px rgba(166,106,85,.7);
  animation:callbar-in .4s ease both;
}
.callbar svg{ width:20px; height:20px; fill:none; stroke:currentColor; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.callbar b{ font-weight:800; }
@keyframes callbar-in{ from{ transform:translateY(120%); } to{ transform:translateY(0); } }
@media (max-width:700px){
  .callbar{ display:flex; }
  body{ padding-bottom:78px; }
  .totop{ bottom:84px !important; }
}

/* =========================================================================
   BACK TO TOP
   ========================================================================= */
.totop{
  position:fixed; right:20px; bottom:24px; z-index:54;
  width:48px; height:48px; border-radius:50%; background:var(--ink); color:#fff;
  display:grid; place-items:center; box-shadow:var(--shadow);
  opacity:0; visibility:hidden; transform:translateY(14px); transition:opacity .3s, transform .3s, visibility .3s, background .25s;
}
.totop.is-show{ opacity:1; visibility:visible; transform:translateY(0); }
.totop:hover{ background:var(--rose-deep); }
.totop svg{ width:22px; height:22px; fill:none; stroke:currentColor; stroke-width:2.2; stroke-linecap:round; stroke-linejoin:round; }

/* =========================================================================
   REVEAL ANIMATIONS
   ========================================================================= */
.reveal{ transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1); }
/* treść chowamy TYLKO gdy JS jest aktywny (klasa .js ustawiana inline w <head>);
   bez JS / przy błędzie skryptu wszystko pozostaje widoczne */
.js .reveal{ opacity:0; transform:translateY(26px); }
.js .reveal.is-visible{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1 !important; transform:none !important; transition:none !important; }
  .gallery__item img, .btn, .card{ transition:none !important; }
}
