/* =====================================================
   Salon Fryzjerski DORIS — Zduńska Wola
   Paleta wzięta wprost z fotela: espresso, miedź, kość
   ===================================================== */

:root{
  --paper:      #FBF6EE;   /* kość słoniowa, ciepła      */
  --sand:       #F0E4D4;   /* piaskowy podkład           */
  --espresso:   #2C1E16;   /* ciemny brąz — włosy/espresso */
  --espresso-2: #3B2A1E;
  --copper:     #B36A2E;   /* miedź — kolor z koloryzacji */
  --copper-deep:#8F4F1F;
  --blush:      #E9C9BD;   /* róż fotela                  */
  --star:       #E2A23B;
  --ink:        #2C1E16;
  --line:       rgba(44,30,22,.16);
  --line-light: rgba(251,246,238,.22);

  --font-display:"Fraunces", Georgia, serif;
  --font-body:"Instrument Sans", system-ui, sans-serif;
  --font-script:"Caveat", cursive;

  --radius-arch: 999px 999px 18px 18px;
  --shadow-soft: 0 18px 50px -18px rgba(44,30,22,.35);
  --header-h: 76px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:calc(var(--header-h) + 12px)}
body{
  font-family:var(--font-body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  font-size:17px;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit}
:focus-visible{outline:3px solid var(--copper);outline-offset:3px;border-radius:4px}

.container{max-width:1180px;margin:0 auto;padding:0 24px}
.section{padding:96px 0}
.center{text-align:center}

/* ---------- typografia ---------- */
h1,h2,h3{font-family:var(--font-display);font-weight:520;line-height:1.08;letter-spacing:-.01em}
h1{font-size:clamp(2.6rem,6vw,4.4rem)}
h2{font-size:clamp(2rem,4.4vw,3.1rem);margin-bottom:.5em}
h3{font-size:1.5rem;margin-bottom:.4em}
h1 em,h2 em{font-style:italic;color:var(--copper)}
.eyebrow{
  font-size:.8rem;text-transform:uppercase;letter-spacing:.22em;
  color:var(--copper-deep);font-weight:600;margin-bottom:14px;
}
.eyebrow.light{color:var(--blush)}
.script-note{
  font-family:var(--font-script);font-size:1.45rem;color:var(--copper-deep);
  margin-top:18px;transform:rotate(-1.2deg);
}

/* ---------- przyciski ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55em;
  padding:.78em 1.5em;border-radius:999px;text-decoration:none;
  font-weight:600;font-size:.98rem;border:2px solid transparent;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
}
.btn-lg{padding:.95em 1.8em;font-size:1.05rem}
.btn-copper{background:var(--copper);color:#fff;box-shadow:0 10px 26px -12px rgba(143,79,31,.8)}
.btn-copper:hover{background:var(--copper-deep);transform:translateY(-2px)}
.btn-ghost{border-color:var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper);transform:translateY(-2px)}
.section-dark .btn-ghost{border-color:var(--paper);color:var(--paper)}
.section-dark .btn-ghost:hover{background:var(--paper);color:var(--ink)}
.ic{width:1.15em;height:1.15em;fill:currentColor;flex:none}
.text-link{
  font-weight:600;color:var(--copper-deep);text-decoration:none;
  border-bottom:2px solid transparent;transition:border-color .2s;
}
.text-link:hover{border-color:var(--copper-deep)}

/* =====================================================
   NAGŁÓWEK + LOGO
   ===================================================== */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(251,246,238,.86);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
  transition:box-shadow .25s ease;
}
.site-header.scrolled{box-shadow:0 8px 30px -18px rgba(44,30,22,.45)}
.header-inner{
  max-width:1180px;margin:0 auto;padding:0 24px;height:var(--header-h);
  display:flex;align-items:center;gap:28px;
}
.logo{display:flex;align-items:center}
.logo-svg{height:62px;width:auto;display:block}
:root{--logo-ink:var(--ink)}
.dm-text{font-family:"Bodoni Moda",Georgia,serif;font-weight:700;font-size:64px;fill:var(--logo-ink);letter-spacing:1px}
.dm-comb rect{fill:var(--logo-ink)}
.dm-ring{fill:none;stroke:var(--logo-ink);stroke-width:6}
.dm-shank{fill:none;stroke:var(--logo-ink);stroke-width:6.5;stroke-linecap:round}
.dm-hook{fill:none;stroke:var(--logo-ink);stroke-width:5;stroke-linecap:round}
.dm-blade{fill:var(--logo-ink);transform-box:view-box;transform-origin:82px 129px}
.dm-screw{fill:var(--copper)}
/* animacja cięcia: raz po załadowaniu + przy najechaniu */
@keyframes dmSnipA{0%,100%{transform:rotate(0)}50%{transform:rotate(-8deg)}}
@keyframes dmSnipB{0%,100%{transform:rotate(0)}50%{transform:rotate(8deg)}}
.logo:hover .dm-blade-a,.logo.snip .dm-blade-a{animation:dmSnipA .55s ease-in-out 2}
.logo:hover .dm-blade-b,.logo.snip .dm-blade-b{animation:dmSnipB .55s ease-in-out 2}

.main-nav{display:flex;gap:26px;margin-left:auto}
.main-nav a{
  text-decoration:none;font-weight:550;font-size:.95rem;position:relative;padding:6px 0;
}
.main-nav a::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:0;
  background:var(--copper);transition:width .25s ease;
}
.main-nav a:hover::after{width:100%}
.header-phone{flex:none}

.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;margin-left:auto}
.nav-toggle span{display:block;width:26px;height:2.5px;background:var(--ink);margin:5.5px 0;border-radius:2px;transition:.25s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* =====================================================
   HERO
   ===================================================== */
.hero{position:relative;overflow:hidden;padding:88px 0 110px;background:
  radial-gradient(900px 480px at 85% 0%, rgba(233,201,189,.5), transparent 65%),
  var(--paper);
}
.hero-inner{
  max-width:1180px;margin:0 auto;padding:0 24px;
  display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;
  position:relative;z-index:2;
}
.hero-lead{max-width:46ch;margin-top:18px;font-size:1.08rem;color:#4c3a2c}
.hero-script{
  font-family:var(--font-script);font-size:clamp(1.5rem,2.6vw,2rem);
  color:var(--copper-deep);margin-top:10px;transform:rotate(-1.4deg);
}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.hero-meta{display:flex;align-items:center;gap:12px;margin-top:26px;font-size:.95rem;color:#5a4636}
.stars{color:var(--star);letter-spacing:2px;font-size:1.05rem}
.stars .half{position:relative;display:inline-block;color:rgba(44,30,22,.22)}
.stars .half::before{content:"★";position:absolute;inset:0;width:55%;overflow:hidden;color:var(--star)}
.stars.big{font-size:1.5rem}

/* falujący kosmyk */
.hero-wave{position:absolute;inset:auto 0 -40px 0;width:100%;height:420px;z-index:1;pointer-events:none}
.hero-wave .strand{
  fill:none;stroke-linecap:round;
  stroke-dasharray:2400;stroke-dashoffset:2400;
  animation:drawStrand 2.6s ease-out forwards;
}
.strand-1{stroke:var(--copper);stroke-width:3.2;opacity:.6;animation-delay:.2s}
.strand-2{stroke:var(--blush);stroke-width:2.6;opacity:.85;animation-delay:.45s}
.strand-3{stroke:var(--espresso);stroke-width:2;opacity:.2;animation-delay:.7s}
@keyframes drawStrand{to{stroke-dashoffset:0}}

/* lustra — łukowe ramki jak salonowe lustra */
.hero-mirrors{position:relative;min-height:520px}
.mirror{
  border-radius:var(--radius-arch);
  overflow:hidden;background:var(--sand);
  box-shadow:var(--shadow-soft);
  border:6px solid #fff;
}
.mirror img{width:100%;height:100%;object-fit:cover}
.mirror-big{position:absolute;right:8%;top:0;width:62%;aspect-ratio:3/4.3}
.mirror-small{
  position:absolute;left:0;bottom:-10px;width:44%;aspect-ratio:3/4;
  border-color:var(--blush);
  animation:floaty 7s ease-in-out infinite;
}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.hero-badge{
  position:absolute;right:0;bottom:8%;
  background:var(--espresso);color:var(--paper);
  border-radius:50%;width:138px;height:138px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;box-shadow:var(--shadow-soft);
  transform:rotate(6deg);
  animation:floaty 7s ease-in-out infinite reverse;
}
.badge-num{font-family:var(--font-display);font-size:2.3rem;font-weight:600;color:var(--blush);line-height:1}
.badge-txt{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;margin-top:4px;line-height:1.35}

/* =====================================================
   MARQUEE
   ===================================================== */
.marquee{
  background:var(--espresso);color:var(--paper);
  overflow:hidden;padding:16px 0;border-block:1px solid var(--espresso);
}
.marquee-track{
  display:flex;gap:34px;align-items:center;width:max-content;
  animation:marquee 36s linear infinite;
  font-family:var(--font-display);font-size:1.05rem;font-style:italic;letter-spacing:.02em;
}
.marquee-track i{font-style:normal;color:var(--copper);font-size:1rem}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes marquee{to{transform:translateX(-50%)}}

/* =====================================================
   O NAS
   ===================================================== */
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:center}
.about .amp{font-style:italic;color:var(--copper)}
.about-points{list-style:none;margin-top:22px;display:grid;gap:12px}
.about-points li{
  padding-left:34px;position:relative;
}
.about-points li::before{
  content:"✂";position:absolute;left:0;top:0;
  color:var(--copper);transform:rotate(-30deg);
}
.mirror-about{max-width:380px;margin:0 auto;aspect-ratio:3/4.1}
.mirror-about figcaption{
  font-family:var(--font-script);font-size:1.2rem;color:var(--copper-deep);
  text-align:center;padding:10px 0 4px;background:#fff;
}

/* =====================================================
   LINIA CIĘCIA (przerywnik z nożyczkami)
   ===================================================== */
.cutline{
  position:relative;max-width:1180px;margin:0 auto;padding:0 24px;height:48px;
  display:flex;align-items:center;
}
.cutline .dash{
  flex:1;border-top:2px dashed rgba(44,30,22,.35);
}
.cut-scissors{
  position:absolute;top:50%;left:24px;width:44px;height:24px;
  transform:translate(0,-50%);
  transition:left 2.4s cubic-bezier(.45,0,.2,1);
}
.cs-ring{fill:none;stroke:var(--copper-deep);stroke-width:2.6}
.cs-line{fill:none;stroke:var(--copper-deep);stroke-width:3;stroke-linecap:round;stroke-linejoin:round}
.cs-pivot{fill:var(--copper-deep)}
.cs-half{transform-box:view-box;transform-origin:30px 16px}
.cutline.cutting .cut-scissors{left:calc(100% - 70px)}
@keyframes cutA{0%,100%{transform:rotate(0)}50%{transform:rotate(8deg)}}
@keyframes cutB{0%,100%{transform:rotate(0)}50%{transform:rotate(-8deg)}}
.cutline.cutting .cs-a{animation:cutA .4s ease-in-out 6}
.cutline.cutting .cs-b{animation:cutB .4s ease-in-out 6}

/* =====================================================
   OFERTA — ONA / ON
   ===================================================== */
.offer-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-top:56px;
}
.offer-card h3{margin-top:26px}
.offer-photo{
  position:relative;border-radius:var(--radius-arch);overflow:hidden;
  aspect-ratio:3/3.9;box-shadow:var(--shadow-soft);border:6px solid #fff;
}
.offer-photo img,.offer-photo svg{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.offer-card:hover .offer-photo img{transform:scale(1.04)}
.offer-tag{
  position:absolute;left:50%;bottom:18px;transform:translateX(-50%) rotate(-2deg);
  background:var(--paper);color:var(--copper-deep);
  font-family:var(--font-script);font-size:1.6rem;line-height:1;
  padding:6px 22px 10px;border-radius:999px;box-shadow:0 6px 18px rgba(44,30,22,.25);
}
.offer-list{list-style:none;margin:16px 0 18px;display:grid;gap:8px}
.offer-list li{
  display:flex;justify-content:space-between;gap:16px;align-items:baseline;
  border-bottom:1px dashed var(--line);padding-bottom:8px;font-size:.97rem;
}
.offer-list b{color:var(--copper-deep);white-space:nowrap}

/* dzieci — wspólna nota pod kartami oferty */
.offer-kids{
  margin-top:44px;text-align:center;
  font-family:var(--font-script);font-size:1.55rem;color:var(--copper-deep);
  transform:rotate(-1deg);
}
.offer-kids strong{color:var(--espresso)}

/* ilustracja męska */
.men-caption{
  font-family:var(--font-script);font-size:26px;fill:var(--blush);
}
.stripes-move{animation:poleMove 3.6s linear infinite}
@keyframes poleMove{from{transform:translateY(0)}to{transform:translateY(-104px)}}

/* =====================================================
   CENNIK (sekcja ciemna)
   ===================================================== */
.section-dark{background:var(--espresso);color:var(--paper)}
.section-dark h2 em{color:var(--blush)}
.pricing-sub{color:rgba(251,246,238,.75);margin-top:-10px;margin-bottom:36px}

.price-tabs{
  display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:34px;
}
.tab{
  background:none;border:1.5px solid var(--line-light);color:var(--paper);
  font-family:var(--font-body);font-weight:600;font-size:.92rem;
  padding:.6em 1.3em;border-radius:999px;cursor:pointer;
  transition:background .2s,color .2s,border-color .2s;
}
.tab:hover{border-color:var(--copper)}
.tab.is-active{background:var(--copper);border-color:var(--copper);color:#fff}

.price-panel[hidden]{display:none}
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
.price-table{
  width:100%;border-collapse:collapse;min-width:560px;
  font-size:.98rem;table-layout:fixed;
}
.price-table th:first-child{width:46%}
.price-table td:not(:first-child),.price-table th:not(:first-child){font-variant-numeric:tabular-nums}
.price-table th{
  font-family:var(--font-display);font-weight:520;font-style:italic;
  text-align:left;font-size:1.02rem;color:var(--blush);
  padding:12px 14px;border-bottom:1px solid var(--line-light);
}
.price-table th:not(:first-child),
.price-table td:not(:first-child){text-align:right;white-space:nowrap}
.price-table td{
  padding:13px 14px;border-bottom:1px dashed var(--line-light);
}
.price-table td.flat{text-align:center;color:var(--blush)}
.price-table tbody tr{transition:background .15s}
.price-table tbody tr:nth-child(even){background:rgba(251,246,238,.04)}
.price-table tbody tr:hover{background:rgba(179,106,46,.12)}
.price-table td:first-child{font-weight:550}

.len-ic{
  width:11px;height:20px;margin-right:7px;vertical-align:-5px;
  fill:none;stroke:var(--copper);stroke-width:2.2;stroke-linecap:round;
}
.pill{
  display:inline-block;background:rgba(233,201,189,.12);
  border:1px solid var(--line-light);color:var(--blush);
  border-radius:999px;padding:2px 16px;font-size:.88rem;
}
.chip{
  display:inline-block;margin-left:8px;padding:1.5px 9px;
  font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  color:var(--copper);border:1px solid rgba(179,106,46,.6);border-radius:999px;
  vertical-align:1.5px;white-space:nowrap;
}
.length-note{
  text-align:center;font-family:var(--font-script);font-size:1.3rem;
  color:var(--blush);margin:-8px 0 28px;
}
.length-note.is-hidden{visibility:hidden}
@keyframes panelIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.price-panel.is-active{animation:panelIn .35s ease}

.price-notes{
  margin-top:30px;font-size:.85rem;color:rgba(251,246,238,.62);
  display:grid;gap:4px;max-width:760px;margin-inline:auto;text-align:center;
}

/* =====================================================
   GALERIA
   ===================================================== */
.gallery-sub{color:#5a4636;margin-top:-8px}
.gallery-grid{
  margin-top:48px;
  columns:3;column-gap:22px;
}
.g-item{
  break-inside:avoid;margin-bottom:22px;position:relative;
  border-radius:16px;overflow:hidden;cursor:zoom-in;
  box-shadow:0 10px 30px -16px rgba(44,30,22,.4);
}
.g-item img{width:100%;transition:transform .6s ease}
.g-item:hover img{transform:scale(1.05)}
.g-item figcaption{
  position:absolute;left:0;right:0;bottom:0;
  padding:34px 16px 12px;color:#fff;
  font-family:var(--font-script);font-size:1.3rem;
  background:linear-gradient(transparent,rgba(44,30,22,.78));
  opacity:0;transform:translateY(8px);transition:.35s ease;
}
.g-item:hover figcaption{opacity:1;transform:translateY(0)}

/* lightbox */
.lightbox[hidden]{display:none}
.lightbox{
  position:fixed;inset:0;z-index:100;background:rgba(30,20,14,.92);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:32px;gap:14px;
}
.lightbox img{max-width:min(92vw,860px);max-height:78vh;border-radius:14px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lb-caption{color:var(--blush);font-family:var(--font-script);font-size:1.5rem}
.lb-close{
  position:absolute;top:20px;right:24px;background:none;border:2px solid var(--blush);
  color:var(--blush);width:44px;height:44px;border-radius:50%;font-size:1.1rem;cursor:pointer;
  transition:.2s;
}
.lb-close:hover{background:var(--blush);color:var(--espresso)}

/* =====================================================
   OPINIE
   ===================================================== */
.reviews{background:
  radial-gradient(700px 380px at 10% 100%, rgba(233,201,189,.4), transparent 65%),
  var(--paper);
}
.reviews-score{
  display:flex;align-items:center;justify-content:center;gap:16px;margin:8px 0 44px;
}
.score-num{font-family:var(--font-display);font-size:3rem;font-weight:600;color:var(--copper-deep)}
.score-count{color:#5a4636}
.reviews-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:24px;max-width:920px;margin:0 auto;
}
.review-card{
  background:#fff;border-radius:18px;padding:26px 28px;
  box-shadow:0 14px 38px -22px rgba(44,30,22,.4);
  border:1px solid var(--line);
  position:relative;
}
.review-card::before{
  content:"”";position:absolute;top:6px;right:20px;
  font-family:var(--font-display);font-size:4.4rem;line-height:1;
  color:var(--blush);
}
.review-card header{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.avatar{
  width:44px;height:44px;border-radius:50%;background:var(--av,var(--copper));
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:1.1rem;flex:none;
}
.review-card small{display:block;color:#8a7460;font-size:.8rem}
.review-card small,.review-card header strong{line-height:1.3}
.review-card p{font-size:.97rem;color:#43342a}

/* =====================================================
   KONTAKT
   ===================================================== */
.section-sand{background:var(--sand)}
.contact-grid{
  display:grid;grid-template-columns:.9fr 1.1fr;gap:40px;margin-top:48px;align-items:stretch;
}
.contact-card{
  background:#fff;border-radius:22px;padding:36px 38px;box-shadow:var(--shadow-soft);
}
.contact-card address{font-style:normal;margin:6px 0 18px;color:#5a4636}
.contact-phone{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--font-display);font-size:1.9rem;font-weight:560;
  color:var(--copper-deep);text-decoration:none;
}
.contact-phone:hover{color:var(--copper)}
.fb-link{
  display:inline-flex;align-items:center;gap:.55em;margin-top:16px;
  padding:.6em 1.2em;border-radius:999px;text-decoration:none;
  font-weight:550;font-size:.95rem;
  background:rgba(179,106,46,.1);color:var(--copper-deep);
  border:1.5px solid rgba(179,106,46,.35);
  transition:background .2s,color .2s,transform .2s;
}
.fb-link:hover{background:var(--copper);color:#fff;transform:translateY(-2px)}
.fb-link b{font-weight:700}
.contact-card h4{
  font-family:var(--font-body);text-transform:uppercase;letter-spacing:.16em;
  font-size:.8rem;color:#8a7460;margin:30px 0 12px;
}
.hours{list-style:none;display:grid;gap:6px}
.hours li{
  display:flex;justify-content:space-between;gap:16px;
  border-bottom:1px dashed var(--line);padding-bottom:6px;font-size:.95rem;
}
.hours li.closed b{color:#a08b77}
.hours li.today{
  background:rgba(179,106,46,.1);border-radius:8px;padding:6px 10px;
  border-bottom-color:transparent;font-weight:600;
}
.hours li.today span::after{
  content:" · dziś";color:var(--copper-deep);font-size:.8em;font-weight:700;
}
.parking-note{margin-top:18px;font-size:.92rem;color:#5a4636}
.map-wrap{
  border-radius:22px;overflow:hidden;box-shadow:var(--shadow-soft);min-height:420px;
  border:6px solid #fff;
}
.map-wrap iframe{width:100%;height:100%;min-height:420px;border:0;display:block}

/* =====================================================
   STOPKA
   ===================================================== */
.site-footer{
  background:var(--espresso);color:var(--paper);padding:60px 0 40px;text-align:center;
}
.footer-logo{height:120px;margin:0 auto 18px;--logo-ink:var(--paper)}
.footer-tag{font-family:var(--font-display);font-style:italic;color:var(--blush)}
.footer-addr{margin-top:8px;font-size:.95rem;color:rgba(251,246,238,.75)}
.footer-addr a{color:var(--blush);text-decoration:none}
.footer-addr a:hover{text-decoration:underline}
.footer-fb{display:inline-flex;align-items:center;gap:.3em;vertical-align:-2px}
.footer-fb .ic{width:1em;height:1em}
.footer-small{margin-top:22px;font-size:.82rem;color:rgba(251,246,238,.5)}

/* pływający telefon */
.fab-call{
  position:fixed;right:18px;bottom:18px;z-index:70;
  width:58px;height:58px;border-radius:50%;
  background:var(--copper);color:#fff;
  display:none;align-items:center;justify-content:center;
  box-shadow:0 14px 34px -10px rgba(143,79,31,.9);
  animation:ringPulse 2.6s ease-in-out infinite;
}
.fab-call .ic{width:26px;height:26px}
@keyframes ringPulse{
  0%,100%{transform:scale(1)}
  8%{transform:scale(1.08) rotate(-6deg)}
  16%{transform:scale(1) rotate(5deg)}
  24%{transform:scale(1.05) rotate(-3deg)}
  32%{transform:scale(1)}
}

/* =====================================================
   REVEAL (scroll)
   ===================================================== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.d1{transition-delay:.12s}
.reveal.d2{transition-delay:.24s}
.reveal.d3{transition-delay:.36s}
.reveal.visible{opacity:1;transform:none}

/* =====================================================
   RESPONSYWNOŚĆ
   ===================================================== */
@media (max-width: 1020px){
  .hero-inner{grid-template-columns:1fr;gap:48px}
  .hero-mirrors{min-height:0;display:grid;grid-template-columns:1.2fr .9fr;gap:18px;align-items:end}
  .mirror-big,.mirror-small{position:static;width:auto}
  .hero-badge{right:6px;bottom:-14px;width:116px;height:116px}
  .about-grid{grid-template-columns:1fr;gap:44px}
  .reviews-grid{grid-template-columns:1fr}
  .gallery-grid{columns:2}
}

@media (max-width: 820px){
  .section{padding:72px 0}
  .main-nav{
    position:fixed;inset:var(--header-h) 0 auto 0;
    background:var(--paper);border-bottom:1px solid var(--line);
    flex-direction:column;gap:0;padding:10px 24px 18px;
    transform:translateY(-130%);transition:transform .3s ease;
    box-shadow:0 24px 40px -20px rgba(44,30,22,.35);
  }
  .main-nav.open{transform:translateY(0)}
  .main-nav a{padding:13px 0;border-bottom:1px dashed var(--line);font-size:1.05rem}
  .main-nav a:last-child{border-bottom:0}
  .nav-toggle{display:block}
  .header-phone span{display:none}
  .header-phone{padding:.7em;border-radius:50%}
  .offer-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .fab-call{display:flex}
}

/* cennik na małych ekranach: tabela → karty usług */
@media (max-width: 640px){
  .price-tabs{gap:8px}
  .tab{font-size:.85rem;padding:.55em 1.05em}
  .length-note{font-size:1.15rem}
  .price-table{min-width:0;table-layout:auto;font-size:.95rem}
  .price-table thead{display:none}
  .price-table tbody tr{
    display:block;padding:12px 2px;
    border-bottom:1px dashed var(--line-light);
  }
  .price-table tbody tr:nth-child(even){background:none}
  .price-table td{display:block;border:0;padding:2px 0}
  .price-table td:first-child{font-weight:600;padding-bottom:6px;font-size:1rem}
  .price-table td:not(:first-child){
    display:flex;justify-content:space-between;align-items:baseline;gap:12px;
  }
  .price-table td:not(:first-child)::before{
    content:attr(data-label);
    font-weight:400;color:rgba(251,246,238,.6);font-size:.88rem;
    white-space:nowrap;
  }
  .price-table td.flat{display:block;text-align:left}
  .price-table td.flat::before{content:none}
  .price-notes{text-align:left}
}

@media (max-width: 560px){
  body{font-size:16px}
  .hero{padding:56px 0 90px}
  .hero-mirrors{grid-template-columns:1fr 1fr}
  .gallery-grid{columns:1}
  .cutline{height:40px}
  .contact-card{padding:28px 22px}
  .hero-cta .btn{width:100%;justify-content:center}
}

/* =====================================================
   OGRANICZONY RUCH
   ===================================================== */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none !important;transition:none !important}
  .hero-wave .strand{stroke-dashoffset:0}
  .reveal{opacity:1;transform:none}
  .cutline .cut-scissors{left:50% !important}
}
