@import url('https://fonts.googleapis.com/css2?family=Source+Serif+4:opsz,wght@8..60,300..600&display=swap');

/* ============================================================
   skinspecialist.cz / bioby.cz — ss-konzultace-1.css — v1
   PRODUCTION CSS for /konzultace/ page (Shoptet Stránka)
   HYBRID PATTERN — ZERO JS. HTML žije v těle Shoptet stránky
   (Vzhled a Obsah → Stránky → /konzultace/ → Zdrojový kód <>).

   DETECTION: body.in-konzultace
   (slug "konzultace" → Shoptet generuje body.in-konzultace + type-page)

   !! ZAVISLOST: vyzaduje ss-docs-12.css (genericke body.type-page selektory maji
   :not(.in-konzultace), takze do konzultace nebleeduji). Nasadit ss-docs-12 SOUCASNE.

   ARCHITEKTURA (vzor ss-b2b):
   - .ss-konz breakout z uzkeho page sloupce na full 100vw
   - Hero = 100vh sage zeleny (calc kvuli fixnimu headeru 168/96px), bily text
   - Steps = cream, Zaver = sage-deep + Tamarin podpis
   - Fonty: Luxury Rigane + Manrope z style.css?v=11, Source Serif 4 z @import vyse
   ============================================================ */

:root {
  --kz-sage: #6B8B85;
  --kz-sage-deep: #5C7A74;
  --kz-dark: #2C2823;
  --kz-rigane: "Luxury Rigane", Georgia, "Times New Roman", serif;
  --kz-serif: "Source Serif 4", Georgia, serif;
  --kz-sans: var(--ss-sans, "Manrope", -apple-system, BlinkMacSystemFont, sans-serif);
  --kz-cream: var(--ss-cream, #E8DDC8);
  --kz-cream-deep: var(--ss-cream-deep, #DAC6A4);
}

/* ============================================================
   0) NEUTRALIZE Shoptet page chrome — full-width breakout (vzor ss-b2b)
   DOM: .container.content-wrapper > .content-wrapper-in
        > aside.sidebar (HIDE) | main#content.narrow > .content-inner
        > article.pageArticleDetail > header[itemprop=headline]>h1 (HIDE)
        + [itemprop=about] > .ss-konz (NAS OBSAH)
   ============================================================ */
body.in-konzultace aside.sidebar,
body.in-konzultace .sidebar-left,
body.in-konzultace .sidebar-right,
body.in-konzultace .sidebar { display: none !important; }

body.in-konzultace .container.content-wrapper,
body.in-konzultace .content-wrapper-in,
body.in-konzultace main#content,
body.in-konzultace main#content.narrow,
body.in-konzultace main#content .content-inner,
body.in-konzultace .pageArticleDetail,
body.in-konzultace .pageArticleDetail > [itemprop="about"] {
  display: block !important;
  background: transparent !important;
  max-width: 100% !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
  border: none !important;
}
body.in-konzultace { background: var(--kz-sage-deep); }
body.in-konzultace .breadcrumbs-wrapper { display: none !important; }
body.in-konzultace .pageArticleDetail > header,
body.in-konzultace .pageArticleDetail > header[itemprop="headline"],
body.in-konzultace article.pageArticleDetail > header { display: none !important; }

/* ============================================================
   1) SPOLECNE
   ============================================================ */
.ss-konz { font-family: var(--kz-sans); color: var(--kz-dark); }
.ss-konz *, .ss-konz *::before, .ss-konz *::after { box-sizing: border-box; }
.ss-konz a { text-decoration: none; }
.ss-konz__eyebrow {
  font-family: var(--kz-sans); font-size: 11px; font-weight: 600;
  letter-spacing: .18em; text-transform: uppercase; margin: 0 0 22px;
}

/* ============================================================
   2) HERO — 100vh sage, bily text
   ============================================================ */
.ss-konz__hero {
  min-height: calc(100vh - 168px); /* desktop: pod fixnim headerem (topbar 36 + main 84 + nav 48) */
  background: var(--kz-sage);
  color: #fff;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; padding: 60px 24px; position: relative;
}
.ss-konz__hero .ss-konz__eyebrow { color: rgba(255, 255, 255, .7); }
.ss-konz__title {
  font-family: var(--kz-rigane); font-weight: 300;
  font-size: clamp(40px, 6.4vw, 60px); line-height: 1.04; letter-spacing: -.03em;
  color: #fff; margin: 0 0 26px; max-width: 15ch;
}
.ss-konz__title em { font-style: italic; color: rgba(255, 255, 255, .72); }
.ss-konz__sub {
  font-family: var(--kz-serif); font-size: 19px; line-height: 1.6;
  color: rgba(255, 255, 255, .85); margin: 0 0 40px; max-width: 600px;
}
.ss-konz__actions { display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; }
.ss-konz__cta {
  display: inline-flex; align-items: center; gap: 9px; padding: 15px 28px; border-radius: 6px;
  font-family: var(--kz-sans); font-size: 12px; font-weight: 600; letter-spacing: .14em;
  text-transform: uppercase; text-decoration: none; border: 1px solid transparent;
  transition: background .28s cubic-bezier(.4,0,.2,1), color .28s cubic-bezier(.4,0,.2,1);
}
.ss-konz__cta--solid { background: #fff; color: #0F0F0F; }
.ss-konz__cta--solid:hover { background: var(--kz-cream); color: #0F0F0F; }
.ss-konz__scroll {
  position: absolute; bottom: 28px; left: 50%; transform: translateX(-50%);
  font-family: var(--kz-sans); font-size: 10.5px; letter-spacing: .2em; text-transform: uppercase;
  color: rgba(255, 255, 255, .6); display: flex; flex-direction: column; align-items: center; gap: 7px;
  text-decoration: none;
}
.ss-konz__scroll span:last-child { font-size: 14px; animation: ssKzBob 1.8s ease-in-out infinite; }
@keyframes ssKzBob { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(4px); } }

/* ============================================================
   3) STEPS — cream
   ============================================================ */
.ss-konz__steps { background: var(--kz-cream); padding: 100px 24px; }
.ss-konz__inner { max-width: 1040px; margin: 0 auto; }
.ss-konz__steps-head { text-align: center; margin-bottom: 56px; }
.ss-konz__steps .ss-konz__eyebrow { color: var(--kz-sage-deep); }
.ss-konz__h2 {
  font-family: var(--kz-rigane); font-weight: 300; font-size: clamp(30px, 4.2vw, 42px);
  line-height: 1.08; letter-spacing: -.02em; color: var(--kz-dark); margin: 0;
}
.ss-konz__h2 em { font-style: italic; color: var(--kz-sage-deep); }
.ss-konz__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 42px; }
.ss-konz__step { position: relative; text-align: left; }
.ss-konz__num {
  font-family: var(--kz-rigane); font-style: italic; font-weight: 300; font-size: 42px;
  color: var(--kz-sage); line-height: 1; margin: 0 0 16px;
}
.ss-konz__step-title {
  font-family: var(--kz-sans); font-size: 17px; font-weight: 600; color: var(--kz-dark);
  margin: 0 0 9px; letter-spacing: -.01em;
}
.ss-konz__step-text { font-family: var(--kz-serif); font-size: 15px; line-height: 1.6; color: rgba(15, 15, 15, .62); margin: 0; }
.ss-konz__step + .ss-konz__step::before {
  content: ''; position: absolute; left: -21px; top: 8px; bottom: 8px; width: 1px; background: rgba(15, 15, 15, .1);
}

/* ============================================================
   4) ZAVER — sage-deep + Tamarin podpis
   ============================================================ */
.ss-konz__closing { background: var(--kz-sage-deep); color: #fff; text-align: center; padding: 96px 24px; }
.ss-konz__closing-title {
  font-family: var(--kz-rigane); font-weight: 300; font-size: clamp(28px, 4vw, 40px);
  line-height: 1.1; letter-spacing: -.02em; color: #fff; margin: 0 0 14px;
}
.ss-konz__closing-title em { font-style: italic; color: rgba(255, 255, 255, .72); }
.ss-konz__closing-text {
  font-family: var(--kz-serif); font-size: 17px; color: rgba(255, 255, 255, .85);
  margin: 0 auto 32px; max-width: 520px; line-height: 1.6;
}
.ss-konz__sign { font-family: var(--kz-rigane); font-style: italic; font-size: 18px; color: var(--kz-cream-deep); margin: 30px 0 0; }

/* ============================================================
   5) MOBILE
   ============================================================ */
@media (max-width: 900px) {
  .ss-konz__hero { min-height: calc(100vh - 96px); } /* mobil header = topbar 32 + main 64 */
}
@media (max-width: 720px) {
  .ss-konz__grid { grid-template-columns: 1fr; gap: 30px; }
  .ss-konz__step + .ss-konz__step::before { display: none; }
  .ss-konz__sub { font-size: 17px; }
  .ss-konz__steps, .ss-konz__closing { padding: 72px 22px; }
}
