/*
Theme Name:  Kayo Theme
Theme URI:   https://kayo.stargard.pl
Author:      Kayo Studio
Description: Dedykowany motyw salonu kosmetologii estetycznej Kayo w Stargardzie. Dark/gold design, SEO, schema.org.
Version:     1.0.0
Text Domain: kayo-theme
*/

/* =============================================
   ZMIENNE GLOBALNE
   ============================================= */
:root {
  --kayo-gold:        #C9A96E;
  --kayo-gold-light:  #E2C99A;
  --kayo-gold-dark:   #A8844A;
  --kayo-dark:        #0A0A0A;
  --kayo-dark2:       #111111;
  --kayo-dark3:       #1A1A1A;
  --kayo-dark4:       #222222;
  --kayo-text:        #F5F0E8;
  --kayo-text-muted:  #9A9080;
  --kayo-text-sub:    #CCC4B5;
  --kayo-border:      rgba(201,169,110,0.18);
  --kayo-radius:      6px;
  --kayo-shadow:      0 8px 40px rgba(0,0,0,0.45);
  --kayo-font-main:   'Cormorant Garamond', Georgia, serif;
  --kayo-font-ui:     'Raleway', 'Helvetica Neue', sans-serif;
  --kayo-max-w:       1240px;
  --kayo-transition:  0.25s ease;
}

/* =============================================
   RESET & BASE
   ============================================= */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; scroll-padding-top: 100px; font-size: 16px; }

body {
  background: var(--kayo-dark);
  color: var(--kayo-text);
  font-family: var(--kayo-font-ui);
  font-weight: 400;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; height: auto; display: block; }
a   { color: var(--kayo-gold); transition: color var(--kayo-transition); }
a:hover { color: var(--kayo-gold-light); }

h1,h2,h3,h4,h5,h6 {
  font-family: var(--kayo-font-main);
  font-weight: 700;
  line-height: 1.2;
  color: var(--kayo-text);
}

p { color: var(--kayo-text-sub); }

.container {
  width: 100%;
  max-width: var(--kayo-max-w);
  margin: 0 auto;
  padding: 0 40px;
}
@media (max-width: 768px) { .container { padding: 0 20px; } }

/* =============================================
   HEADER / NAWIGACJA
   ============================================= */
.site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 999;
  background: rgba(10,10,10,0.95);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--kayo-border);
  transition: background var(--kayo-transition), box-shadow var(--kayo-transition), top var(--kayo-transition);
}
.site-header.scrolled {
  background: rgba(10,10,10,0.99);
  box-shadow: 0 4px 30px rgba(0,0,0,0.5);
}
/* Kompensacja paska administratora WordPress */
.admin-bar .site-header { top: 32px; }
@media (max-width: 782px) {
  .admin-bar .site-header { top: 46px; }
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 96px;
  gap: 32px;
}

/* Logo */
.site-logo {
  flex-shrink: 0;
  text-decoration: none;
  display: flex;
  align-items: center;
}
.site-logo img {
  height: 82px;
  width: auto;
  display: block;
  max-width: 220px;
  object-fit: contain;
}
.site-logo-text {
  font-family: var(--kayo-font-main);
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--kayo-text);
  letter-spacing: 0.06em;
  text-decoration: none;
}
.site-logo-text span { color: var(--kayo-gold); }

/* Nawigacja główna */
.main-nav { display: flex; align-items: center; gap: 4px; }
.main-nav ul { list-style: none; display: flex; align-items: center; gap: 2px; }
.main-nav > ul > li { position: relative; }

.main-nav > ul > li > a {
  display: block;
  padding: 10px 14px;
  color: var(--kayo-text);
  text-decoration: none;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  transition: color var(--kayo-transition);
}
.main-nav > ul > li > a:hover,
.main-nav > ul > li.current-menu-item > a,
.main-nav > ul > li.current-menu-ancestor > a {
  color: var(--kayo-gold);
}

/* Dropdown */
.main-nav ul ul {
  display: none;
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  min-width: 220px;
  background: var(--kayo-dark2);
  border: 1px solid var(--kayo-border);
  border-radius: var(--kayo-radius);
  box-shadow: var(--kayo-shadow);
  flex-direction: column;
  z-index: 100;
  padding: 8px 0;
}
.main-nav ul li:hover > ul { display: flex; }
.main-nav ul ul li a {
  display: block;
  padding: 9px 18px;
  color: var(--kayo-text-sub);
  text-decoration: none;
  font-size: 0.82rem;
  white-space: nowrap;
  transition: background var(--kayo-transition), color var(--kayo-transition);
}
.main-nav ul ul li a:hover { background: var(--kayo-dark3); color: var(--kayo-gold); }

/* Przycisk CTA w headerze */
.header-cta {
  display: inline-block;
  padding: 11px 28px;
  background: transparent;
  color: var(--kayo-gold) !important;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-decoration: none;
  border: 1.5px solid var(--kayo-gold);
  border-radius: 2px;
  flex-shrink: 0;
  transition: background var(--kayo-transition), color var(--kayo-transition);
  white-space: nowrap;
}
.header-cta:hover {
  background: var(--kayo-gold);
  color: var(--kayo-dark) !important;
}
/* Header actions wrapper */
.header-actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-shrink: 0;
}

/* skip link */
.skip-link {
  position: absolute;
  top: -100px;
  left: 0;
  background: var(--kayo-gold);
  color: var(--kayo-dark);
  padding: 8px 16px;
  font-size: .8rem;
  z-index: 9999;
  transition: top .2s;
}
.skip-link:focus { top: 0; }


/* Hamburger mobile */
.menu-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 34px; height: 34px;
  cursor: pointer;
  background: none;
  border: none;
  padding: 0;
}
.menu-toggle span {
  display: block;
  width: 100%; height: 2px;
  background: var(--kayo-text);
  transition: transform 0.3s, opacity 0.3s;
}
.menu-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.menu-toggle.open span:nth-child(2) { opacity: 0; }
.menu-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 1024px) {
  .main-nav { display: none; }
  .menu-toggle { display: flex; }
  .main-nav.open {
    display: flex;
    position: fixed;
    top: 96px; left: 0; right: 0; bottom: 0;
    background: var(--kayo-dark2);
    flex-direction: column;
    align-items: flex-start;
    padding: 24px;
    overflow-y: auto;
  }
  .main-nav.open ul { flex-direction: column; width: 100%; gap: 0; }
  .main-nav.open > ul > li > a { padding: 14px 0; font-size: 1rem; border-bottom: 1px solid var(--kayo-border); }
  .main-nav ul ul { position: static; box-shadow: none; border: none; padding-left: 16px; }
  .main-nav ul li:hover > ul { display: none; }
  .main-nav ul li.submenu-open > ul { display: flex; }
}



/* ═══════════════════════════════════════
   PRZYCISKI
═══════════════════════════════════════ */
.btn-gold {
  display: inline-block;
  padding: 13px 36px;
  background: var(--kayo-gold);
  color: var(--kayo-dark);
  font-family: var(--kayo-font-ui);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .15em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: 2px;
  border: none;
  cursor: pointer;
  transition: background var(--kayo-transition), color var(--kayo-transition);
  white-space: nowrap;
}
.btn-gold:hover { background: var(--kayo-gold-light); color: var(--kayo-dark); }

.btn-outline {
  display: inline-block;
  padding: 12px 35px;
  background: transparent;
  color: var(--kayo-cream);
  font-family: var(--kayo-font-ui);
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: .15em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: 2px;
  border: 1px solid rgba(237,226,201,.45);
  cursor: pointer;
  transition: all var(--kayo-transition);
  white-space: nowrap;
}
.btn-outline:hover {
  border-color: var(--kayo-gold);
  color: var(--kayo-gold);
}

/* ═══════════════════════════════════════
   HERO SLIDER
═══════════════════════════════════════ */
.hero-slider {
    position: relative;
    height: 100vh;
    min-height: 620px;
    max-height: 960px;
    overflow: hidden;
    background: var(--kayo-dark);
}

.hero-track { width:100%; height:100%; position:relative; }

.hero-slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity .7s ease;
    pointer-events: none;
}
.hero-slide.aktywny {
    opacity: 1;
    pointer-events: all;
}

/* Zdjęcie — prawa strona */
.hero-slide-foto {
    position: absolute;
    right: 0;
    top: 0;
    width: 58%;
    height: 100%;
    overflow: hidden;
}
.hero-slide-foto img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    display: block;
    filter: grayscale(20%);
}
/* Gradient zasłaniający od lewej */
.hero-slide-foto::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to right,
        var(--kayo-dark) 0%,
        rgba(10,10,10,.75) 40%,
        rgba(10,10,10,.15) 75%,
        transparent 100%);
}
/* Gradient od dołu */
.hero-slide-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(10,10,10,.7) 0%, transparent 55%);
    pointer-events: none;
    z-index: 1;
}

/* Treść slajdu */
.hero-slider .container {
    position: relative;
    z-index: 2;
    height: 100%;
    display: flex;
    align-items: center;
}
.hero-slide-content {
    max-width: 560px;
    padding: 120px 0 80px;
}
.hero-eyebrow {
    font-family: var(--kayo-font-ui);
    font-size: .72rem;
    letter-spacing: .3em;
    text-transform: uppercase;
    color: var(--kayo-gold);
    margin: 0 0 20px;
}
.hero-slide-content h1 {
    font-family: var(--kayo-font-main);
    font-size: clamp(2.4rem, 4.5vw, 3.8rem);
    font-weight: 600;
    color: #fff;
    line-height: 1.15;
    margin: 0 0 24px;
}
.hero-slide-content h1 em {
    color: var(--kayo-gold);
    font-style: normal;
}
.hero-opis {
    font-size: .95rem;
    color: rgba(245,240,232,.7);
    line-height: 1.75;
    margin: 0 0 36px;
    max-width: 440px;
}
.hero-btns {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
}

/* Strzałki */
.hero-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    background: rgba(10,10,10,.5);
    border: 1px solid rgba(201,169,110,.3);
    color: var(--kayo-gold);
    width: 48px;
    height: 48px;
    border-radius: 50%;
    font-size: 1.6rem;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all var(--kayo-transition);
}
.hero-arrow:hover {
    background: var(--kayo-gold);
    color: var(--kayo-dark);
    border-color: var(--kayo-gold);
}
.hero-prev { left: 24px; }
.hero-next { right: 24px; }

/* Dots */
.hero-dots {
    position: absolute;
    bottom: 32px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 10;
    display: flex;
    gap: 10px;
}
.hero-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: rgba(255,255,255,.3);
    border: none;
    cursor: pointer;
    padding: 0;
    transition: all var(--kayo-transition);
}
.hero-dot.aktywny {
    background: var(--kayo-gold);
    width: 28px;
    border-radius: 4px;
}

@media (max-width: 768px) {
    .hero-slide-foto { width: 100%; }
    .hero-slide-foto::after {
        background: linear-gradient(to right, var(--kayo-dark) 0%, rgba(10,10,10,.85) 100%);
    }
    .hero-slide-content { max-width: 100%; }
    .hero-slide-content h1 { font-size: 2.2rem; }
    .hero-arrow { width: 38px; height: 38px; font-size: 1.2rem; }
    .hero-prev { left: 12px; }
    .hero-next { right: 12px; }
}

/* ═══════════════════════════════════════
   SEKCJE OGÓLNE
═══════════════════════════════════════ */
.section { padding: 80px 0; }
.section-dark2 { background: var(--kayo-dark2); }

.section-pretitle {
    font-family: var(--kayo-font-ui);
    font-size: .7rem;
    letter-spacing: .3em;
    text-transform: uppercase;
    color: var(--kayo-gold);
    margin: 0 0 10px;
}
.section-title {
    font-family: var(--kayo-font-main);
    font-size: clamp(1.8rem, 3vw, 2.6rem);
    font-weight: 600;
    color: var(--kayo-text);
    margin: 0;
}
.section-subtitle {
    color: var(--kayo-text-muted);
    font-size: .95rem;
    margin: 12px 0 0;
}
.section-header-row {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    margin-bottom: 40px;
    gap: 16px;
    flex-wrap: wrap;
}
.section-link-all {
    font-family: var(--kayo-font-ui);
    font-size: .75rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--kayo-gold);
    text-decoration: none;
    border-bottom: 1px solid rgba(201,169,110,.3);
    padding-bottom: 2px;
    white-space: nowrap;
    transition: border-color var(--kayo-transition);
}
.section-link-all:hover { border-color: var(--kayo-gold); }

/* ═══════════════════════════════════════
   SEKCJA ZABIEGÓW
═══════════════════════════════════════ */
.section-zabiegi {
    padding: 80px 0;
    background: var(--kayo-dark);
    border-top: 1px solid var(--kayo-border);
}

/* ═══════════════════════════════════════
   OPINIE GOOGLE
═══════════════════════════════════════ */
.section-opinie {
    background: var(--kayo-dark2);
    border-top: 1px solid var(--kayo-border);
    border-bottom: 1px solid var(--kayo-border);
}

.opinie-layout {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 60px;
    align-items: start;
}
@media (max-width: 860px) {
    .opinie-layout { grid-template-columns: 1fr; gap: 40px; }
}

/* Wynik ogólny */
.opinie-wynik { padding-top: 8px; }
.opinie-score-big {
    font-family: var(--kayo-font-main);
    font-size: 4rem;
    font-weight: 700;
    color: var(--kayo-cream);
    line-height: 1;
    margin: 12px 0 4px;
}
.opinie-gwiazdki-big { color: var(--kayo-gold); font-size: 1.3rem; letter-spacing: 2px; margin-bottom: 8px; }
.opinie-podstawa { font-size: .8rem; color: var(--kayo-text-muted); margin: 0 0 20px; }
.opinie-google-g {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: .8rem;
    color: var(--kayo-text-muted);
}

/* Karty opinii — slider */
.opinie-karty-wrap { overflow: hidden; }
.opinie-karty-slider {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}

.opinia-card {
    background: var(--kayo-dark3);
    border: 1px solid var(--kayo-border);
    border-radius: var(--kayo-radius);
    padding: 24px;
}
.opinia-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 14px;
}
.opinia-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--kayo-gold);
    color: var(--kayo-dark);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--kayo-font-main);
    font-weight: 700;
    font-size: 1rem;
    flex-shrink: 0;
}
.opinia-autor-name {
    display: block;
    font-size: .85rem;
    color: var(--kayo-text);
    font-family: var(--kayo-font-ui);
}
.opinia-gwiazdki { color: var(--kayo-gold); font-size: .85rem; }
.opinia-g-logo { margin-left: auto; flex-shrink: 0; }
.opinia-tresc {
    font-size: .85rem;
    color: var(--kayo-text-muted);
    line-height: 1.65;
    margin: 0;
    font-style: italic;
}
.opinie-dots { display: none; }

@media (max-width: 960px) {
    .opinie-karty-slider { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 640px) {
    .opinie-karty-slider { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════
   CENNIK SECTION
═══════════════════════════════════════ */
.section-cennik {
    position: relative;
    background: var(--kayo-dark);
    overflow: hidden;
    min-height: 560px;
}
/* Zdjęcie — pełna szerokość sekcji */
.cennik-foto-bg {
    position: absolute;
    inset: 0;
}
.cennik-foto-bg img {
    width: 100%; height: 100%;
    object-fit: cover;
    object-position: center top;
    display: block;
}
/* Gradient od lewej — tekst czytelny, prawa strona zdjęcie widoczne */
.cennik-foto-gradient {
    position: absolute;
    inset: 0;
    background: linear-gradient(to right,
        rgba(10,10,10,1)   0%,
        rgba(10,10,10,.97) 25%,
        rgba(10,10,10,.6)  50%,
        rgba(10,10,10,.15) 75%,
        transparent        95%
    );
}
/* Warstwa z treścią */
.cennik-body {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    padding: 90px 80px;
    min-height: 560px;
}
.cennik-content {
    max-width: 440px;
}
.cennik-tytul {
    font-family: var(--kayo-font-main);
    font-size: clamp(3rem, 5.5vw, 4.8rem);
    font-weight: 600;
    color: var(--kayo-gold);
    letter-spacing: .02em;
    text-transform: uppercase;
    line-height: 1;
    margin: 0 0 16px;
}
.cennik-sub {
    font-family: var(--kayo-font-main);
    font-size: 1.15rem;
    color: var(--kayo-text);
    margin: 0 0 16px;
}
.cennik-opis {
    color: var(--kayo-text-muted);
    font-size: .9rem;
    line-height: 1.8;
    margin: 0 0 36px;
}
.cennik-btn {
    display: inline-block;
    padding: 12px 32px;
    border: 1.5px solid var(--kayo-gold);
    color: var(--kayo-gold);
    text-decoration: none;
    font-family: var(--kayo-font-ui);
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .18em;
    text-transform: uppercase;
    transition: background var(--kayo-transition), color var(--kayo-transition);
}
.cennik-btn:hover { background: var(--kayo-gold); color: var(--kayo-dark); }
.cennik-ikona { flex-shrink: 0; opacity: .7; }

@media (max-width: 900px) {
    .cennik-foto-bg { left: 0; }
    .cennik-foto-gradient { background: linear-gradient(to right, var(--kayo-dark) 0%, rgba(10,10,10,.9) 100%); }
    .cennik-body { padding: 60px 40px; }
    .cennik-ikona { display: none; }
}
@media (max-width: 600px) {
    .cennik-body { padding: 50px 24px; min-height: 360px; }
    .cennik-tytul { font-size: 2.8rem; }
}

/* ═══════════════════════════════════════
   VOUCHER SECTION
═══════════════════════════════════════ */
.section-voucher {
    position: relative;
    background: var(--kayo-dark);
    overflow: hidden;
    min-height: 480px;
}
/* Zdjęcie — pełna szerokość */
.voucher-foto-bg {
    position: absolute;
    inset: 0;
}
.voucher-foto-bg img {
    width: 100%; height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}
/* Gradient od prawej — tekst po prawej, zdjęcie widoczne po lewej */
.voucher-foto-gradient {
    position: absolute;
    inset: 0;
    background: linear-gradient(to left,
        rgba(10,10,10,1)   0%,
        rgba(10,10,10,.97) 25%,
        rgba(10,10,10,.6)  50%,
        rgba(10,10,10,.15) 75%,
        transparent        95%
    );
}
.voucher-inner {
    position: relative;
    z-index: 2;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    padding: 90px 80px;
    min-height: 480px;
}
.voucher-content {
    max-width: 420px;
    text-align: right;
}
.voucher-placeholder {
    display: none;
}
.voucher-tytul {
    font-family: var(--kayo-font-main);
    font-size: clamp(2.2rem, 4vw, 3.4rem);
    font-weight: 600;
    color: var(--kayo-gold);
    text-transform: uppercase;
    letter-spacing: .03em;
    line-height: 1.1;
    margin: 0 0 20px;
}
.voucher-sub {
    font-family: var(--kayo-font-main);
    font-size: 1.05rem;
    color: var(--kayo-text);
    margin: 0 0 12px;
}
.voucher-opis {
    color: var(--kayo-text-muted);
    font-size: .9rem;
    line-height: 1.7;
    margin: 0 0 32px;
}
.voucher-btn {
    display: inline-block;
    padding: 13px 36px;
    background: var(--kayo-gold);
    color: var(--kayo-dark);
    text-decoration: none;
    font-family: var(--kayo-font-ui);
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    border-radius: 2px;
    transition: background var(--kayo-transition);
}
.voucher-btn:hover { background: var(--kayo-gold-light); color: var(--kayo-dark); }
.voucher-ikona { display: none; }

@media (max-width: 900px) {
    .voucher-inner { padding: 60px 40px; }
    .voucher-content { max-width: 340px; }
}
@media (max-width: 600px) {
    .voucher-inner { padding: 50px 24px; justify-content: center; }
    .voucher-content { max-width: 100%; text-align: center; }
}

/* ═══════════════════════════════════════
   FOOTER
═══════════════════════════════════════ */
.site-footer {
    background: var(--kayo-dark2);
    border-top: 1px solid var(--kayo-border);
    padding: 60px 0 30px;
}
.footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 40px;
    padding-bottom: 40px;
    border-bottom: 1px solid var(--kayo-border);
}
.footer-logo {
    display: inline-block;
    margin-bottom: 12px;
    text-decoration: none;
}
.footer-logo img {
    height: 40px;
    width: auto;
    display: block;
}
.footer-logo-text {
    font-family: var(--kayo-font-main);
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: .08em;
    color: var(--kayo-text);
    text-decoration: none;
    display: block;
    margin-bottom: 12px;
}
.footer-logo-text span { color: var(--kayo-gold); }
.footer-logo-sub {
    font-size: .75rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--kayo-text-muted);
    margin-bottom: 16px;
}
.footer-desc { font-size: .85rem; color: var(--kayo-text-muted); line-height: 1.7; margin-bottom: 20px; }
.footer-social, .footer-socials { display: flex; gap: 12px; }
.footer-social-link {
    width: 36px; height: 36px;
    border: 1px solid var(--kayo-border);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    color: var(--kayo-gold);
    text-decoration: none;
    transition: all var(--kayo-transition);
}
.footer-social-link svg {
    width: 16px; height: 16px;
    stroke: currentColor; fill: none;
}
.footer-social-link:hover {
    border-color: var(--kayo-gold);
    background: var(--kayo-gold);
    color: var(--kayo-dark);
}
.footer-col-title {
    font-family: var(--kayo-font-ui);
    font-size: .68rem;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--kayo-gold);
    margin-bottom: 16px;
}
.footer-col ul { list-style: none; }
.footer-col li { margin-bottom: 8px; }
.footer-col a {
    font-size: .875rem;
    color: var(--kayo-text-muted);
    text-decoration: none;
    transition: color var(--kayo-transition);
}
.footer-col a:hover { color: var(--kayo-gold); }
.footer-contact-item {
    display: flex; gap: 12px; align-items: flex-start;
    font-size: .875rem; color: var(--kayo-text-muted); margin-bottom: 14px;
    line-height: 1.55;
}
.footer-contact-icon {
    color: var(--kayo-gold);
    flex-shrink: 0;
    width: 18px; height: 18px;
    display: inline-flex; align-items: center; justify-content: center;
    margin-top: 2px;
}
.footer-contact-icon svg {
    width: 16px; height: 16px;
    stroke: currentColor; fill: none;
    /* zapobiega kolorowemu rendererowi emoji */
    color: var(--kayo-gold);
}
.footer-contact-item strong { color: var(--kayo-text); font-weight: 600; }
.footer-contact-item a { color: var(--kayo-text-muted); text-decoration: none; transition: color var(--kayo-transition); }
.footer-contact-item a:hover { color: var(--kayo-gold); }
.footer-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 24px;
    font-size: .78rem;
    color: var(--kayo-text-muted);
    flex-wrap: wrap;
    gap: 12px;
}
.footer-bottom a { color: var(--kayo-text-muted); text-decoration: none; }
.footer-bottom a:hover { color: var(--kayo-gold); }
@media (max-width: 900px) {
    .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
    .footer-grid { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════
   UTILITIES & ANIMACJE
═══════════════════════════════════════ */
.text-gold   { color: var(--kayo-gold); }
.text-center { text-align: center; }
.mt-8  { margin-top: 8px; }
.mt-16 { margin-top: 16px; }
.mt-32 { margin-top: 32px; }
.reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity .55s ease, transform .55s ease;
}
.revealed { opacity: 1; transform: none; }

/* ═══════════════════════════════════════
   STRONA CENNIK (/cennik/)
═══════════════════════════════════════ */
.cennik-hero {
    background: linear-gradient(135deg, var(--kayo-dark) 60%, #0D0D0D 100%);
    border-bottom: 1px solid rgba(201,169,110,.2);
    padding: 100px 24px 60px;
    text-align: center;
}
.cennik-hero-eyebrow {
    font-family: var(--kayo-font-ui); font-size:.75rem;
    letter-spacing:.25em; text-transform:uppercase;
    color:var(--kayo-gold); margin:0 0 16px;
}
.cennik-hero-title {
    font-family:var(--kayo-font-main); font-size:clamp(2.5rem,6vw,4rem);
    font-weight:600; color:var(--kayo-text); margin:0 0 16px;
}
.cennik-hero-sub { color:rgba(237,226,201,.65); font-size:1rem; margin:0; }
.cennik-wrap { max-width:1100px; margin:0 auto; padding:60px 24px 100px; }
.cennik-note {
    background:rgba(201,169,110,.07); border-left:3px solid var(--kayo-gold);
    border-radius:0 6px 6px 0; padding:16px 20px;
    color:rgba(237,226,201,.75); font-size:.9rem; margin:0 0 56px; line-height:1.6;
}
.cennik-sekcja { margin-bottom:60px; scroll-margin-top:90px; }
.cennik-sekcja-title {
    font-family:var(--kayo-font-main); font-size:1.6rem; font-weight:600;
    color:var(--kayo-text); display:flex; align-items:center;
    gap:16px; margin:0 0 24px; white-space:nowrap;
}
.cennik-sekcja-linia {
    flex:1; height:1px;
    background:linear-gradient(90deg,rgba(201,169,110,.5),transparent);
}
.cennik-sekcja-title .cennik-sekcja-linia:first-child {
    background:linear-gradient(270deg,rgba(201,169,110,.5),transparent); max-width:40px;
}
.cennik-tabela { width:100%; border-collapse:collapse; border-radius:8px; overflow:hidden; }
.cennik-tabela thead tr { background:rgba(201,169,110,.12); }
.cennik-tabela thead th {
    font-family:var(--kayo-font-ui); font-size:.7rem; letter-spacing:.15em;
    text-transform:uppercase; color:var(--kayo-gold); padding:12px 16px;
    text-align:left; font-weight:600;
}
.cennik-tabela thead th:last-child { width:100px; }
.cennik-tabela thead th:nth-child(2) { width:110px; }
.cennik-tabela thead th:nth-child(3) { width:160px; }
.cennik-row { border-bottom:1px solid rgba(201,169,110,.1); transition:background .2s; }
.cennik-row:last-child { border-bottom:none; }
.cennik-row:hover { background:rgba(201,169,110,.05); }
.cennik-row td { padding:14px 16px; vertical-align:middle; }
.cennik-link-nazwa { color:var(--kayo-text); text-decoration:none; font-size:1rem; font-family:var(--kayo-font-main); font-weight:500; transition:color .2s; display:block; }
.cennik-link-nazwa:hover { color:var(--kayo-gold); }
.cennik-seria { display:block; font-size:.75rem; color:rgba(237,226,201,.45); font-family:var(--kayo-font-ui); margin-top:3px; }
.cennik-czas { font-size:.875rem; color:rgba(237,226,201,.6); font-family:var(--kayo-font-ui); white-space:nowrap; }
.cennik-cena-wartosc { font-family:var(--kayo-font-main); font-size:1.2rem; font-weight:600; color:var(--kayo-gold); white-space:nowrap; }
.cennik-cena-kontakt { font-size:.8rem; color:rgba(237,226,201,.4); font-style:italic; font-family:var(--kayo-font-ui); }
.cennik-btn-zabieg {
    display:inline-block; font-family:var(--kayo-font-ui); font-size:.7rem;
    letter-spacing:.12em; text-transform:uppercase; color:var(--kayo-gold);
    text-decoration:none; border:1px solid rgba(201,169,110,.3); border-radius:3px;
    padding:6px 12px; transition:all .2s; white-space:nowrap;
}
.cennik-btn-zabieg:hover { background:var(--kayo-gold); color:var(--kayo-dark); border-color:var(--kayo-gold); }
.cennik-cta {
    text-align:center; margin-top:80px; padding:48px 24px;
    border:1px solid rgba(201,169,110,.2); border-radius:8px; background:rgba(201,169,110,.04);
}
.cennik-cta p { color:rgba(237,226,201,.75); font-size:1.1rem; margin:0 0 24px; font-family:var(--kayo-font-main); }
@media(max-width:700px){
    .cennik-tabela thead th:nth-child(2),.cennik-tabela .cennik-czas { display:none; }
    .cennik-sekcja-title { font-size:1.3rem; }
}

/* =================================================
   STRONA VOUCHER (/voucher/)
   ================================================= */
.kayo-voucher-page { background:var(--kayo-dark); color:var(--kayo-text); }

.voucher-hero {
    position:relative;
    padding:130px 24px 90px;
    background:linear-gradient(180deg, rgba(201,169,110,.07), transparent);
    border-bottom:1px solid rgba(201,169,110,.12);
    overflow:hidden;
}
.voucher-hero-inner {
    max-width:680px; margin:0 auto;
    position:relative; z-index:2;
    text-align:center;
}
.voucher-hero-eyebrow {
    font-family:var(--kayo-font-ui); font-size:.7rem; letter-spacing:.25em;
    text-transform:uppercase; color:var(--kayo-gold); margin:0 0 14px;
}
.voucher-hero-title {
    font-family:var(--kayo-font-main); font-size:3.4rem; font-weight:400;
    line-height:1.1; margin:0 0 18px;
}
.voucher-hero-sub {
    font-family:var(--kayo-font-main); font-style:italic; font-size:1.2rem;
    color:rgba(237,226,201,.78); line-height:1.55; margin:0 0 32px;
}
.voucher-hero-buttons {
    display:flex; gap:14px; justify-content:center; flex-wrap:wrap;
}
/* Voucher card mock — dekoracyjna karta w tle hero */
.voucher-hero-decor {
    position:absolute; right:-40px; top:50%; transform:translateY(-50%) rotate(-8deg);
    opacity:.13; pointer-events:none; z-index:1;
}
.voucher-card-mock {
    width:300px; padding:36px 30px;
    background:linear-gradient(135deg, var(--kayo-gold-dark), var(--kayo-gold) 60%, var(--kayo-gold-light));
    border-radius:10px;
    display:flex; flex-direction:column; gap:6px;
    color:var(--kayo-dark);
    font-family:var(--kayo-font-main);
}
.voucher-card-mock .voucher-card-eyebrow {
    font-family:var(--kayo-font-ui); font-size:.65rem; letter-spacing:.3em;
    text-transform:uppercase; opacity:.7;
}
.voucher-card-mock .voucher-card-title {
    font-size:2.6rem; font-weight:400; letter-spacing:.04em;
}
.voucher-card-mock .voucher-card-amount {
    font-style:italic; font-size:1.1rem; opacity:.85;
}
.voucher-card-mock .voucher-card-foot {
    margin-top:auto; font-family:var(--kayo-font-ui); font-size:.6rem;
    letter-spacing:.25em; text-transform:uppercase; opacity:.6;
    padding-top:30px;
}

.voucher-wrap { max-width:1100px; margin:0 auto; padding:80px 60px 100px; }

/* Intro */
.voucher-intro { max-width:780px; margin:0 auto 80px; text-align:center; }
.voucher-intro-title {
    font-family:var(--kayo-font-main); font-size:2.2rem; font-weight:500;
    margin:0 0 22px; line-height:1.2;
}
.voucher-intro p {
    color:rgba(237,226,201,.78); font-size:1.05rem; line-height:1.8;
    font-family:var(--kayo-font-ui); margin:0 0 16px;
}
.voucher-intro p strong { color:var(--kayo-gold-light); font-weight:600; }

/* Section title (z linijkami obok) */
.voucher-section-title {
    display:flex; align-items:center; justify-content:center; gap:20px;
    font-family:var(--kayo-font-ui); font-size:.85rem; letter-spacing:.25em;
    text-transform:uppercase; color:var(--kayo-gold); font-weight:600;
    margin:0 0 48px; text-align:center;
}
.voucher-section-linia {
    flex:1; max-width:120px; height:1px;
    background:linear-gradient(90deg, transparent, rgba(201,169,110,.5));
}
.voucher-section-linia:last-child { background:linear-gradient(270deg, transparent, rgba(201,169,110,.5)); }

/* Options grid */
.voucher-options { margin-bottom:90px; }
.voucher-options-grid {
    display:grid; grid-template-columns:repeat(2,1fr); gap:24px;
}
.voucher-option-card {
    background:rgba(255,255,255,.02); border:1px solid rgba(201,169,110,.18);
    border-radius:10px; padding:38px 32px;
    transition:border-color .25s, transform .25s, background .25s;
}
.voucher-option-card:hover {
    border-color:rgba(201,169,110,.45);
    transform:translateY(-3px);
    background:rgba(201,169,110,.04);
}
.voucher-option-icon {
    width:54px; height:54px; margin-bottom:20px;
    border:1px solid rgba(201,169,110,.4); border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    color:var(--kayo-gold);
}
.voucher-option-icon svg { width:22px; height:22px; }
.voucher-option-title {
    font-family:var(--kayo-font-main); font-size:1.55rem; font-weight:500;
    margin:0 0 14px; line-height:1.25;
}
.voucher-option-card p {
    color:rgba(237,226,201,.72); font-size:.97rem; line-height:1.7;
    font-family:var(--kayo-font-ui); margin:0;
}

/* How it works */
.voucher-how { padding:70px 0; margin-bottom:80px; border-top:1px solid rgba(201,169,110,.1); border-bottom:1px solid rgba(201,169,110,.1); }
.voucher-how-grid {
    display:grid; grid-template-columns:repeat(3,1fr); gap:24px;
}
.voucher-step {
    text-align:center; padding:24px 16px;
}
.voucher-step-num {
    font-family:var(--kayo-font-main); font-size:2.4rem; color:var(--kayo-gold);
    font-weight:300; line-height:1; margin-bottom:16px;
}
.voucher-step h3 {
    font-family:var(--kayo-font-main); font-size:1.35rem; font-weight:500;
    margin:0 0 12px;
}
.voucher-step p {
    color:rgba(237,226,201,.72); font-size:.95rem; line-height:1.7;
    font-family:var(--kayo-font-ui); margin:0;
}
.voucher-step p strong { color:var(--kayo-gold-light); }

/* Info section (split) */
.voucher-info { margin-bottom:80px; }
.voucher-info-grid {
    display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center;
}
.voucher-info-eyebrow {
    font-family:var(--kayo-font-ui); font-size:.7rem; letter-spacing:.25em;
    text-transform:uppercase; color:var(--kayo-gold); margin:0 0 12px;
}
.voucher-info-title {
    font-family:var(--kayo-font-main); font-size:2.1rem; font-weight:500;
    line-height:1.2; margin:0 0 22px;
}
.voucher-info-text p {
    color:rgba(237,226,201,.78); font-size:1rem; line-height:1.75;
    font-family:var(--kayo-font-ui); margin:0 0 14px;
}
.voucher-info-text p strong { color:var(--kayo-gold-light); font-weight:600; }
.voucher-info-decor {
    aspect-ratio:4/5; min-height:340px;
    background:linear-gradient(135deg, rgba(201,169,110,.08), rgba(201,169,110,.02));
    border:1px solid rgba(201,169,110,.18); border-radius:6px;
    display:flex; align-items:center; justify-content:center;
}
.voucher-info-line {
    width:60%; height:1px; background:rgba(201,169,110,.4); position:relative;
}
.voucher-info-line::before, .voucher-info-line::after {
    content:''; position:absolute; width:10px; height:10px;
    border:1px solid var(--kayo-gold); border-radius:50%;
    top:50%; transform:translateY(-50%);
}
.voucher-info-line::before { left:-12px; }
.voucher-info-line::after  { right:-12px; }

/* CTA */
.voucher-cta {
    text-align:center; padding:64px 32px;
    border:1px solid rgba(201,169,110,.2); border-radius:10px;
    background:rgba(201,169,110,.04);
}
.voucher-cta-eyebrow {
    font-family:var(--kayo-font-ui); font-size:.7rem; letter-spacing:.25em;
    text-transform:uppercase; color:var(--kayo-gold); margin:0 0 16px;
}
.voucher-cta-title {
    font-family:var(--kayo-font-main); font-size:2rem; font-weight:500;
    margin:0 0 16px;
}
.voucher-cta-address {
    color:rgba(237,226,201,.78); font-family:var(--kayo-font-main);
    font-size:1.1rem; line-height:1.55; margin:0 0 8px;
}
.voucher-cta-phone {
    color:rgba(237,226,201,.65); font-size:.95rem; margin:0 0 28px;
}
.voucher-cta-phone a {
    color:var(--kayo-gold); text-decoration:none; border-bottom:1px solid transparent;
    transition:border-color .2s;
}
.voucher-cta-phone a:hover { border-bottom-color:var(--kayo-gold); }
.voucher-cta-buttons { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }

@media (max-width:900px) {
    .voucher-hero { padding:100px 16px 70px; }
    .voucher-hero-title { font-size:2.4rem; }
    .voucher-hero-sub { font-size:1.05rem; }
    .voucher-hero-decor { display:none; }
    .voucher-wrap { padding:60px 20px 80px; }
    .voucher-options-grid { grid-template-columns:1fr; }
    .voucher-how-grid { grid-template-columns:1fr; gap:14px; }
    .voucher-info-grid { grid-template-columns:1fr; gap:32px; }
    .voucher-info-decor { min-height:200px; aspect-ratio:auto; }
    .voucher-intro-title { font-size:1.7rem; }
    .voucher-info-title { font-size:1.6rem; }
    .voucher-cta-title { font-size:1.5rem; }
}

/* =================================================
   STRONA ARCHIWUM ZABIEGÓW (/zabiegi/)
   ================================================= */
.kayo-zabiegi-archive { background:var(--kayo-dark); color:var(--kayo-text); }
.zabiegi-hero {
    padding:120px 24px 60px; text-align:center;
    background:linear-gradient(180deg, rgba(201,169,110,.06), transparent);
    border-bottom:1px solid rgba(201,169,110,.12);
}
.zabiegi-hero-inner { max-width:860px; margin:0 auto; }
.zabiegi-hero-eyebrow {
    font-family:var(--kayo-font-ui); font-size:.7rem; letter-spacing:.25em;
    text-transform:uppercase; color:var(--kayo-gold); margin:0 0 14px;
}
.zabiegi-hero-title {
    font-family:var(--kayo-font-main); font-size:3.2rem; font-weight:400;
    line-height:1.1; margin:0 0 14px;
}
.zabiegi-hero-sub {
    font-family:var(--kayo-font-main); font-style:italic; font-size:1.15rem;
    color:rgba(237,226,201,.7); margin:0 0 36px; line-height:1.5;
}
.zabiegi-search {
    display:flex; align-items:center; gap:0;
    max-width:640px; margin:0 auto;
    background:rgba(255,255,255,.03);
    border:1px solid rgba(201,169,110,.25); border-radius:50px;
    padding:6px 6px 6px 22px;
    transition:border-color .2s;
}
.zabiegi-search:focus-within { border-color:var(--kayo-gold); }
.zabiegi-search-icon {
    color:var(--kayo-gold); width:20px; height:20px;
    display:inline-flex; align-items:center; justify-content:center; flex-shrink:0;
}
.zabiegi-search-icon svg { width:18px; height:18px; }
.zabiegi-search input[type="search"] {
    flex:1; background:transparent; border:none; outline:none;
    color:var(--kayo-text); font-family:var(--kayo-font-ui); font-size:.95rem;
    padding:12px 16px; min-width:0;
}
.zabiegi-search input::placeholder { color:rgba(237,226,201,.45); }
.zabiegi-search input::-webkit-search-cancel-button { -webkit-appearance:none; }
.zabiegi-search-clear {
    color:rgba(237,226,201,.5); font-size:1.4rem; line-height:1;
    text-decoration:none; padding:0 8px; transition:color .2s;
}
.zabiegi-search-clear:hover { color:var(--kayo-gold); }
.zabiegi-search-submit {
    background:var(--kayo-gold); color:var(--kayo-dark);
    border:none; border-radius:50px;
    font-family:var(--kayo-font-ui); font-size:.78rem; letter-spacing:.15em;
    text-transform:uppercase; font-weight:600;
    padding:10px 22px; cursor:pointer;
    transition:background .2s;
}
.zabiegi-search-submit:hover { background:var(--kayo-gold-light); }
.zabiegi-archive-wrap { max-width:1300px; margin:0 auto; padding:50px 60px 100px; }

@media (max-width:700px) {
    .zabiegi-hero { padding:100px 16px 40px; }
    .zabiegi-hero-title { font-size:2.2rem; }
    .zabiegi-hero-sub { font-size:1rem; margin-bottom:24px; }
    .zabiegi-search { padding:6px 6px 6px 16px; }
    .zabiegi-search input[type="search"] { font-size:.9rem; padding:10px 8px; }
    .zabiegi-search-submit { padding:8px 14px; font-size:.7rem; }
    .zabiegi-archive-wrap { padding:30px 16px 60px; }
}

/* =================================================
   HEADER — wyszukiwarka (lupka + dropdown)
   ================================================= */
.header-search-toggle {
    width:38px; height:38px; padding:0;
    background:transparent; border:1px solid rgba(201,169,110,.4);
    border-radius:50%; color:var(--kayo-gold);
    display:inline-flex; align-items:center; justify-content:center;
    cursor:pointer; transition:all .2s;
    margin-right:6px;
}
.header-search-toggle:hover {
    background:var(--kayo-gold); color:var(--kayo-dark);
    border-color:var(--kayo-gold);
}
.header-search-toggle svg { width:18px; height:18px; }
.header-search-toggle[aria-expanded="true"] {
    background:var(--kayo-gold); color:var(--kayo-dark);
}

.header-search-panel {
    position:absolute; top:100%; left:0; right:0;
    background:rgba(10,10,10,0.98); backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);
    border-bottom:1px solid rgba(201,169,110,.18);
    box-shadow:0 12px 30px rgba(0,0,0,.4);
    padding:24px 0 28px;
    z-index:998;
    animation:kayoSearchSlide .25s ease;
}
@keyframes kayoSearchSlide {
    from { opacity:0; transform:translateY(-8px); }
    to   { opacity:1; transform:translateY(0); }
}
.header-search-form {
    display:flex; align-items:center;
    max-width:780px; margin:0 auto;
    background:rgba(255,255,255,.04);
    border:1px solid rgba(201,169,110,.3); border-radius:6px;
    padding:4px 4px 4px 18px;
    transition:border-color .2s;
}
.header-search-form:focus-within { border-color:var(--kayo-gold); }
.header-search-form-icon {
    color:var(--kayo-gold); width:20px; height:20px;
    display:inline-flex; align-items:center; justify-content:center; flex-shrink:0;
}
.header-search-form-icon svg { width:18px; height:18px; }
.header-search-form input[type="search"] {
    flex:1; background:transparent; border:none; outline:none;
    color:var(--kayo-text); font-family:var(--kayo-font-ui); font-size:1rem;
    padding:14px 14px;
}
.header-search-form input::placeholder { color:rgba(237,226,201,.4); }
.header-search-form input::-webkit-search-cancel-button { -webkit-appearance:none; }
.header-search-close {
    background:transparent; border:none; color:rgba(237,226,201,.55);
    font-size:1.6rem; line-height:1; padding:0 14px;
    cursor:pointer; transition:color .2s;
}
.header-search-close:hover { color:var(--kayo-gold); }

.header-search-results {
    max-width:780px; margin:18px auto 0;
}
.header-search-list { list-style:none; padding:0; margin:0; }
.header-search-list li {
    border-bottom:1px solid rgba(201,169,110,.08);
}
.header-search-list li:last-child { border-bottom:none; }
.header-search-list a {
    display:grid; grid-template-columns:1fr auto; gap:4px 20px;
    align-items:center;
    padding:14px 6px; text-decoration:none; color:var(--kayo-text);
    transition:background .2s, padding .2s;
    border-radius:4px;
}
.header-search-list a:hover {
    background:rgba(201,169,110,.06);
    padding-left:14px; padding-right:14px;
}
.hsr-title {
    grid-column:1; font-family:var(--kayo-font-main); font-size:1.05rem;
    font-weight:500; color:var(--kayo-text);
}
.hsr-opis {
    grid-column:1; font-family:var(--kayo-font-ui); font-size:.82rem;
    color:rgba(237,226,201,.55); line-height:1.4;
}
.hsr-cena {
    grid-column:2; grid-row:1 / span 2; align-self:center;
    font-family:var(--kayo-font-main); font-weight:600; font-size:1rem;
    color:var(--kayo-gold); white-space:nowrap;
}
.header-search-empty {
    text-align:center; color:rgba(237,226,201,.6); padding:24px;
    font-family:var(--kayo-font-main); font-style:italic;
}
.header-search-all {
    display:block; text-align:center; margin-top:14px;
    padding:10px; color:var(--kayo-gold); text-decoration:none;
    font-family:var(--kayo-font-ui); font-size:.78rem; letter-spacing:.15em;
    text-transform:uppercase; font-weight:500;
    border-top:1px solid rgba(201,169,110,.15);
    transition:opacity .2s;
}
.header-search-all:hover { opacity:.7; }

body.kayo-search-open { overflow:hidden; }

@media (max-width:780px) {
    .header-search-toggle { width:36px; height:36px; }
    .header-search-form { padding:4px 4px 4px 14px; }
    .header-search-form input[type="search"] { font-size:.95rem; padding:12px 8px; }
    .header-search-list a { padding:12px 6px; grid-template-columns:1fr; gap:4px; }
    .hsr-cena { grid-column:1; grid-row:auto; }
}

/* =================================================
   STRONA O GABINECIE
   ================================================= */
.kayo-about-page { background:var(--kayo-dark); color:var(--kayo-text); }
.about-hero {
    padding:120px 24px 80px; text-align:center;
    background:linear-gradient(180deg, rgba(201,169,110,.06), transparent);
    border-bottom:1px solid rgba(201,169,110,.12);
}
.about-hero-inner { max-width:760px; margin:0 auto; }
.about-hero-eyebrow {
    font-family:var(--kayo-font-ui); font-size:.7rem; letter-spacing:.25em;
    text-transform:uppercase; color:var(--kayo-gold); margin:0 0 14px;
}
.about-hero-title {
    font-family:var(--kayo-font-main); font-size:3.2rem; font-weight:400;
    line-height:1.1; margin:0 0 14px;
}
.about-hero-sub {
    font-family:var(--kayo-font-main); font-style:italic; font-size:1.2rem;
    color:rgba(237,226,201,.7); margin:0;
}
.about-wrap { max-width:1100px; margin:0 auto; padding:80px 60px 100px; }
.about-section { padding:48px 0; }
.about-section-grid {
    display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center;
}
.about-section-text { font-family:var(--kayo-font-ui); }
.about-section-eyebrow {
    font-size:.7rem; letter-spacing:.25em; text-transform:uppercase;
    color:var(--kayo-gold); margin:0 0 12px;
}
.about-section-title {
    font-family:var(--kayo-font-main); font-size:2.1rem; font-weight:500;
    line-height:1.2; margin:0 0 22px;
}
.about-section-text p {
    color:rgba(237,226,201,.78); font-size:1rem; line-height:1.75;
    margin:0 0 14px;
}
.about-section-text p strong { color:var(--kayo-gold-light); font-weight:600; }
.about-section-decor {
    aspect-ratio:4/5; position:relative; min-height:360px;
    background:linear-gradient(135deg, rgba(201,169,110,.08), rgba(201,169,110,.02));
    border:1px solid rgba(201,169,110,.18); border-radius:6px;
    display:flex; align-items:center; justify-content:center;
}
.about-decor-line {
    width:60%; height:1px; background:rgba(201,169,110,.4);
    position:relative;
}
.about-decor-line::before, .about-decor-line::after {
    content:''; position:absolute; width:10px; height:10px;
    border:1px solid var(--kayo-gold); border-radius:50%;
    top:50%; transform:translateY(-50%);
}
.about-decor-line::before { left:-12px; }
.about-decor-line::after  { right:-12px; }

/* Wartości */
.about-values { padding:60px 0; border-top:1px solid rgba(201,169,110,.1); border-bottom:1px solid rgba(201,169,110,.1); margin:48px 0; }
.about-values-title {
    display:flex; align-items:center; justify-content:center; gap:20px;
    font-family:var(--kayo-font-ui); font-size:.85rem; letter-spacing:.25em;
    text-transform:uppercase; color:var(--kayo-gold); font-weight:600;
    margin:0 0 48px; text-align:center;
}
.about-values-linia {
    flex:1; max-width:120px; height:1px;
    background:linear-gradient(90deg, transparent, rgba(201,169,110,.5));
}
.about-values-linia:last-child { background:linear-gradient(270deg, transparent, rgba(201,169,110,.5)); }
.about-values-grid {
    display:grid; grid-template-columns:repeat(2,1fr); gap:24px;
}
.about-value-card {
    background:rgba(255,255,255,.015); border:1px solid rgba(201,169,110,.18);
    border-radius:10px; padding:32px 28px; transition:border-color .2s, transform .25s;
}
.about-value-card:hover { border-color:rgba(201,169,110,.35); transform:translateY(-2px); }
.about-value-num {
    font-family:var(--kayo-font-main); font-size:2.2rem; color:var(--kayo-gold);
    font-weight:300; line-height:1; margin-bottom:14px;
}
.about-value-title {
    font-family:var(--kayo-font-main); font-size:1.4rem; font-weight:500;
    color:var(--kayo-text); margin:0 0 12px;
}
.about-value-card p {
    color:rgba(237,226,201,.7); font-size:.95rem; line-height:1.7;
    font-family:var(--kayo-font-ui); margin:0;
}

/* CTA */
.about-cta {
    text-align:center; padding:64px 32px; margin-top:60px;
    border:1px solid rgba(201,169,110,.2); border-radius:10px;
    background:rgba(201,169,110,.04);
}
.about-cta-eyebrow {
    font-family:var(--kayo-font-ui); font-size:.7rem; letter-spacing:.25em;
    text-transform:uppercase; color:var(--kayo-gold); margin:0 0 16px;
}
.about-cta-title {
    font-family:var(--kayo-font-main); font-size:2.2rem; font-weight:500;
    margin:0 0 16px;
}
.about-cta-text { color:rgba(237,226,201,.75); font-size:1.05rem; margin:0 0 32px; font-family:var(--kayo-font-main); }
.about-cta-buttons { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }
.btn-gold-outline {
    display:inline-block; padding:14px 32px;
    border:1px solid var(--kayo-gold); border-radius:4px;
    color:var(--kayo-gold); text-decoration:none;
    font-family:var(--kayo-font-ui); font-size:.8rem; letter-spacing:.15em;
    text-transform:uppercase; font-weight:500; transition:all .2s;
}
.btn-gold-outline:hover { background:var(--kayo-gold); color:var(--kayo-dark); }

@media (max-width:800px) {
    .about-wrap { padding:60px 20px 80px; }
    .about-hero-title { font-size:2.4rem; }
    .about-section-grid { grid-template-columns:1fr; gap:32px; }
    .about-section-decor { min-height:220px; aspect-ratio:auto; }
    .about-values-grid { grid-template-columns:1fr; }
    .about-cta-title { font-size:1.7rem; }
}

/* =================================================
   STRONA KONTAKT
   ================================================= */
.kayo-contact-page { background:var(--kayo-dark); color:var(--kayo-text); }
.contact-hero {
    padding:120px 24px 70px; text-align:center;
    background:linear-gradient(180deg, rgba(201,169,110,.06), transparent);
    border-bottom:1px solid rgba(201,169,110,.12);
}
.contact-hero-inner { max-width:780px; margin:0 auto; }
.contact-hero-eyebrow {
    font-family:var(--kayo-font-ui); font-size:.7rem; letter-spacing:.25em;
    text-transform:uppercase; color:var(--kayo-gold); margin:0 0 14px;
}
.contact-hero-title {
    font-family:var(--kayo-font-main); font-size:3.2rem; font-weight:400;
    line-height:1.1; margin:0 0 14px;
}
.contact-hero-sub {
    font-family:var(--kayo-font-main); font-style:italic; font-size:1.1rem;
    color:rgba(237,226,201,.7); margin:0; line-height:1.5;
}
.contact-wrap { max-width:1200px; margin:0 auto; padding:80px 60px 100px; }
.contact-grid {
    display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start;
    margin-bottom:80px;
}
.contact-info { display:flex; flex-direction:column; gap:30px; }
.contact-block { display:flex; gap:20px; align-items:flex-start; }
.contact-block-icon {
    width:48px; height:48px; flex-shrink:0;
    border:1px solid rgba(201,169,110,.4); border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    color:var(--kayo-gold);
}
.contact-block-icon svg { width:22px; height:22px; }
.contact-block-content { flex:1; }
.contact-block-title {
    font-family:var(--kayo-font-ui); font-size:.7rem; letter-spacing:.2em;
    text-transform:uppercase; color:var(--kayo-gold); font-weight:600;
    margin:6px 0 8px;
}
.contact-block-text {
    font-family:var(--kayo-font-main); font-size:1.15rem; line-height:1.45;
    color:var(--kayo-text); margin:0;
}
.contact-block-text a {
    color:var(--kayo-text); text-decoration:none; transition:color .2s;
    border-bottom:1px solid transparent;
}
.contact-block-text a:hover { color:var(--kayo-gold); border-bottom-color:var(--kayo-gold); }
.contact-block-link {
    display:inline-block; margin-top:8px;
    font-family:var(--kayo-font-ui); font-size:.75rem; letter-spacing:.12em;
    text-transform:uppercase; color:var(--kayo-gold); text-decoration:none;
    transition:opacity .2s;
}
.contact-block-link:hover { opacity:.75; }
.contact-godziny-lista { list-style:none; padding:0; margin:0; }
.contact-godziny-lista li {
    display:flex; justify-content:space-between; gap:20px;
    padding:6px 0; border-bottom:1px dashed rgba(201,169,110,.1);
    font-family:var(--kayo-font-ui); font-size:.95rem; color:rgba(237,226,201,.85);
}
.contact-godziny-lista li:last-child { border-bottom:none; }
.contact-social {
    display:flex; align-items:center; gap:14px; padding-top:24px;
    border-top:1px solid rgba(201,169,110,.12); margin-top:12px;
}
.contact-social-label {
    font-family:var(--kayo-font-ui); font-size:.7rem; letter-spacing:.2em;
    text-transform:uppercase; color:rgba(237,226,201,.6);
}
.contact-social-link {
    width:38px; height:38px; display:flex; align-items:center; justify-content:center;
    border:1px solid rgba(201,169,110,.4); border-radius:50%;
    color:var(--kayo-gold); transition:all .2s;
}
.contact-social-link:hover { background:var(--kayo-gold); color:var(--kayo-dark); }
.contact-social-link svg { width:18px; height:18px; }

.contact-map {
    height:100%; min-height:480px; border-radius:10px; overflow:hidden;
    border:1px solid rgba(201,169,110,.2);
    background:rgba(255,255,255,.02);
}

/* Dane firmy */
.contact-firma {
    border:1px solid rgba(201,169,110,.18); border-radius:10px;
    padding:36px 40px; margin-bottom:60px;
    background:rgba(255,255,255,.015);
}
.contact-firma-title {
    font-family:var(--kayo-font-ui); font-size:.75rem; letter-spacing:.25em;
    text-transform:uppercase; color:var(--kayo-gold); font-weight:600;
    margin:0 0 22px;
}
.contact-firma-grid { margin:0; }
.contact-firma-row {
    display:grid; grid-template-columns:180px 1fr; gap:24px;
    padding:14px 0; border-bottom:1px dashed rgba(201,169,110,.12);
}
.contact-firma-row:last-child { border-bottom:none; }
.contact-firma-row dt {
    font-family:var(--kayo-font-ui); font-size:.85rem; color:rgba(237,226,201,.55);
}
.contact-firma-row dd {
    font-family:var(--kayo-font-main); font-size:1.05rem; color:var(--kayo-text);
    margin:0; font-weight:500;
}

.contact-cta {
    text-align:center; padding:48px 24px;
    border:1px solid rgba(201,169,110,.2); border-radius:10px;
    background:rgba(201,169,110,.04);
}
.contact-cta p {
    font-family:var(--kayo-font-main); font-size:1.2rem;
    color:rgba(237,226,201,.85); margin:0 0 24px;
}

@media (max-width:900px) {
    .contact-wrap { padding:60px 20px 80px; }
    .contact-hero-title { font-size:2.4rem; }
    .contact-grid { grid-template-columns:1fr; gap:48px; }
    .contact-map { min-height:360px; }
    .contact-firma { padding:24px; }
    .contact-firma-row { grid-template-columns:1fr; gap:4px; padding:10px 0; }
}

/* ─── FAQ (single zabieg) ─── */
.kayo-faq-lista {
    display:flex; flex-direction:column; gap:8px;
    margin-top:8px;
}
.kayo-faq-item {
    border:1px solid rgba(201,169,110,.18);
    border-radius:8px;
    background:rgba(255,255,255,.015);
    overflow:hidden;
    transition:border-color .2s;
}
.kayo-faq-item:hover { border-color:rgba(201,169,110,.32); }
.kayo-faq-pytanie {
    /* override default <button> */
    appearance:none; -webkit-appearance:none;
    display:flex; align-items:center; justify-content:space-between;
    gap:24px;
    width:100%;
    margin:0;
    padding:18px 22px;
    background:transparent;
    border:none;
    cursor:pointer;
    text-align:left;
    font-family:var(--kayo-font-main);
    font-size:1.05rem;
    font-weight:500;
    line-height:1.4;
    color:var(--kayo-text);
    transition:color .2s, background .2s;
}
.kayo-faq-pytanie:hover { color:var(--kayo-gold); }
.kayo-faq-pytanie:focus { outline:none; }
.kayo-faq-pytanie:focus-visible {
    outline:2px solid var(--kayo-gold); outline-offset:-2px;
}
.kayo-faq-pytanie::after {
    content:'+';
    flex-shrink:0;
    width:28px; height:28px;
    display:flex; align-items:center; justify-content:center;
    font-family:var(--kayo-font-ui); font-size:1.4rem; font-weight:300;
    color:var(--kayo-gold);
    border:1px solid rgba(201,169,110,.4);
    border-radius:50%;
    transition:transform .25s ease, background .2s;
    line-height:1;
}
.kayo-faq-pytanie.open::after {
    content:'−';
    background:var(--kayo-gold);
    color:var(--kayo-dark);
    border-color:var(--kayo-gold);
}
.kayo-faq-odpowiedz {
    max-height:0;
    overflow:hidden;
    opacity:0;
    padding:0 22px;
    color:rgba(237,226,201,.78);
    font-family:var(--kayo-font-ui);
    font-size:.95rem;
    line-height:1.65;
    transition:max-height .35s ease, opacity .25s ease, padding .25s ease;
}
.kayo-faq-odpowiedz.open {
    max-height:1000px;
    opacity:1;
    padding:0 22px 20px;
}
.kayo-faq-odpowiedz > span[itemprop="text"] { display:block; }
@media(max-width:600px) {
    .kayo-faq-pytanie { padding:14px 16px; font-size:.98rem; gap:14px; }
    .kayo-faq-odpowiedz { padding:0 16px; font-size:.9rem; }
    .kayo-faq-odpowiedz.open { padding:0 16px 16px; }
}

/* ─── Cennik: zabieg z wariantami ─── */
.cennik-zabieg {
    border:1px solid rgba(201,169,110,.18); border-radius:10px;
    background:rgba(255,255,255,.015); margin-bottom:32px; padding:24px 28px;
    transition:border-color .2s;
}
.cennik-zabieg:hover { border-color:rgba(201,169,110,.32); }
.cennik-zabieg-header {
    display:flex; flex-wrap:wrap; align-items:baseline; justify-content:space-between;
    gap:14px 28px; padding-bottom:14px;
    border-bottom:1px solid rgba(201,169,110,.12); margin-bottom:14px;
}
.cennik-zabieg-tytul {
    font-family:var(--kayo-font-main); font-size:1.4rem; color:var(--kayo-text);
    text-decoration:none; font-weight:500; line-height:1.2; transition:color .2s;
}
.cennik-zabieg-tytul:hover { color:var(--kayo-gold); }
.cennik-zabieg-meta {
    display:flex; align-items:center; gap:16px; flex-wrap:wrap;
    font-family:var(--kayo-font-ui); font-size:.85rem;
}
.cennik-zabieg-od {
    color:var(--kayo-gold); font-family:var(--kayo-font-main); font-size:1.05rem; font-weight:600;
}
.cennik-zabieg-seria {
    color:rgba(237,226,201,.5); font-size:.78rem; letter-spacing:.04em;
}
.cennik-zabieg-link {
    font-size:.7rem; letter-spacing:.12em; text-transform:uppercase;
    color:var(--kayo-gold); text-decoration:none;
    border:1px solid rgba(201,169,110,.3); border-radius:3px; padding:5px 11px;
    transition:all .2s;
}
.cennik-zabieg-link:hover { background:var(--kayo-gold); color:var(--kayo-dark); }
.cennik-zabieg-grupa-tytul {
    color:var(--kayo-gold-light); font-family:var(--kayo-font-ui);
    font-size:.72rem; letter-spacing:.18em; text-transform:uppercase;
    margin:14px 0 6px; padding-top:6px;
}
.cennik-zabieg-tabela { width:100%; border-collapse:collapse; }
.cennik-zabieg-tabela tr { border-bottom:1px dashed rgba(201,169,110,.08); }
.cennik-zabieg-tabela tr:last-child { border-bottom:none; }
.cennik-zabieg-tabela td { padding:8px 4px; vertical-align:middle; font-family:var(--kayo-font-ui); }
.cennik-zabieg-wariant { color:rgba(237,226,201,.85); font-size:.95rem; }
.cennik-zabieg-czas    { color:rgba(237,226,201,.55); font-size:.85rem; width:120px; white-space:nowrap; }
.cennik-zabieg-cena    {
    color:var(--kayo-gold); font-family:var(--kayo-font-main); font-size:1rem;
    font-weight:600; text-align:right; width:140px; white-space:nowrap;
}
@media(max-width:600px) {
    .cennik-zabieg { padding:18px 16px; }
    .cennik-zabieg-tytul { font-size:1.2rem; }
    .cennik-zabieg-czas { display:none; }
    .cennik-zabieg-header { flex-direction:column; align-items:flex-start; }
}

/* ─── Single zabieg: sekcja Ceny zabiegu ─── */
.kayo-sekcja-cennik .kayo-cennik-grupa-tytul {
    color:var(--kayo-gold-light); font-family:var(--kayo-font-ui);
    font-size:.75rem; letter-spacing:.18em; text-transform:uppercase;
    margin:20px 0 8px;
}
.kayo-cennik-zabieg-tabela-wrap { overflow-x:auto; }
.kayo-cennik-zabieg-tabela {
    width:100%; border-collapse:collapse;
    background:rgba(255,255,255,.015); border-radius:8px; overflow:hidden;
    margin-bottom:8px;
}
.kayo-cennik-zabieg-tabela thead tr { background:rgba(201,169,110,.1); }
.kayo-cennik-zabieg-tabela thead th {
    font-family:var(--kayo-font-ui); font-size:.7rem; letter-spacing:.15em;
    text-transform:uppercase; color:var(--kayo-gold);
    padding:12px 14px; text-align:left; font-weight:600;
}
.kayo-cennik-zabieg-tabela tbody tr { border-bottom:1px solid rgba(201,169,110,.08); }
.kayo-cennik-zabieg-tabela tbody tr:last-child { border-bottom:none; }
.kayo-cennik-zabieg-tabela tbody tr:hover { background:rgba(201,169,110,.04); }
.kayo-cennik-zabieg-tabela td {
    padding:12px 14px; vertical-align:middle; font-family:var(--kayo-font-ui);
}
.kayo-cennik-zabieg-nazwa { color:rgba(237,226,201,.9); }
.kayo-cennik-zabieg-czas  { color:rgba(237,226,201,.55); font-size:.85rem; white-space:nowrap; }
.kayo-cennik-zabieg-cena  {
    color:var(--kayo-gold); font-family:var(--kayo-font-main);
    font-size:1.05rem; font-weight:600; text-align:right; white-space:nowrap;
}
.kayo-cennik-zabieg-note {
    font-size:.78rem; color:rgba(237,226,201,.45); font-style:italic;
    margin-top:14px; font-family:var(--kayo-font-ui);
}
@media(max-width:600px) {
    .kayo-cennik-zabieg-tabela td, .kayo-cennik-zabieg-tabela thead th { padding:10px 8px; }
    .kayo-cennik-zabieg-czas { display:none; }
    .kayo-cennik-zabieg-tabela thead th:nth-child(2) { display:none; }
}
