/* Aeonik Pro — hlavní písmo webu (nahradilo Poppins) */
@font-face {
    font-family: 'Aeonik Pro';
    src: url('fonts/Aeonik Pro Regular.woff2') format('woff2');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Aeonik Pro';
    src: url('fonts/Aeonik Pro Medium.woff2') format('woff2');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Aeonik Pro';
    src: url('fonts/Aeonik Pro Bold.woff2') format('woff2');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

:root {
    --accent: #007681;
    --bg: #FFFFFF;
    --text: #212529;
    --heading: #212529;
    --muted: #5a7378;
    --radius: 4px;

    /* Type scale — jednotná škála font-size pro celý web.
       REV 12 Krok 2B: zvětšeno pro „obsah vyplní plochu" pocit (USSPA-aligned).
       Mobile @media (≤900 px) má vlastní override níže — nesahán. */
    --fs-hero:      clamp(3rem, 7vw, 6rem);
    --fs-h1:        clamp(3.5rem, 7vw, 6rem);
    --fs-h2:        clamp(2rem, 3.5vw, 3rem);
    --fs-podnadpis: 1.375rem;
    --fs-text:      1.0625rem;
    --fs-maly:      0.9rem;
    --fs-eyebrow:   0.875rem;
    --fs-button:    1rem;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    font-family: 'Aeonik Pro', system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    color: var(--text);
    background: var(--bg);
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
}

/* === Generický fade-in pro bloky bez vlastní animace ===
   Element s class .fade-in startuje neviditelný a mírně posunutý dolů.
   IntersectionObserver v script.js přidá .is-visible jakmile blok
   vstoupí do viewportu → opacity 0→1 + transform reset. Animace proběhne
   jen jednou. prefers-reduced-motion: bloky rovnou viditelné, žádný motion. */
.fade-in {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity .55s ease-out, transform .55s ease-out;
    will-change: opacity, transform;
}

.fade-in.is-visible {
    opacity: 1;
    transform: translateY(0);
    will-change: auto;
}

@media (prefers-reduced-motion: reduce) {
    .fade-in {
        opacity: 1;
        transform: none;
        transition: none;
    }
}

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

a {
    color: var(--accent);
    text-decoration: none;
}

em {
    font-style: italic;
}

.container {
    /* REV 14: 1600 → 1400, gutter 40 → 48 (sjednoceno) */
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 48px;
}

.container-wide {
    max-width: 1905px;
    margin: 0 auto;
    padding: 0 24px;
}

.block {
    padding: 80px 0;
}

/* GRID */
.grid {
    display: grid;
    gap: 24px;
}

.grid-12 {
    grid-template-columns: repeat(12, 1fr);
}

.col-3 { grid-column: span 3; }
.col-5 { grid-column: span 5; }
.col-6 { grid-column: span 6; }
.col-9 { grid-column: span 9; }
.col-start-7 { grid-column-start: 7; }

/* HEADER — TŘI stavy řízené dvěma class flagy:
   • STAV 1 — .at-top (scrollY < 70): poloprůhledné pozadí, LOGO SKRYTÉ,
     menu VĚTŠÍ a BÍLÝ text se shadow (čitelnost na hero fotce).
   • STAV 2 — bez class (70 ≤ scrollY < 200): plné bílé pozadí, logo
     PLNÁ velikost (72 px), menu normální velikost, tmavý text.
   • STAV 3 — .compact (scrollY ≥ 200): plné bílé pozadí, logo zmenšené
     na ~78 % (56 px), padding zmenšen, menu mírně menší → CELÁ LIŠTA
     NIŽŠÍ (padding-driven height).
   Plynulý CSS transition .25s na všechny věci. */
.site-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 20;
    padding-top: 12px;
    padding-bottom: 8px;
    /* REV 9: žádný pás. REV 10: header viditelný JEN v hero (.at-top).
       Po scrollu se slide up + fade out — žádný header po hero. */
    background: transparent;
    box-shadow: none;
    transform: translateY(-100%);
    opacity: 0;
    pointer-events: none;
    transition: transform .35s cubic-bezier(0.32, 0.72, 0, 1),
                opacity .25s ease,
                background-color .25s ease, box-shadow .25s ease,
                padding-top .25s ease, padding-bottom .25s ease,
                backdrop-filter .25s ease, -webkit-backdrop-filter .25s ease;
}

/* === STAV 1 — na vrchu nad hero ===
   Skleněný "frosted glass" efekt s granulemi: backdrop-filter aplikuje
   inline SVG filtr #header-glass (feTurbulence + feGaussianBlur +
   feDisplacementMap) na obsah pod headerem → zkreslené, rozmazané hero
   pozadí s viditelnou granulovanou texturou. Plus jemný blur a saturace
   pro klasický liquid-glass dojem. Light translucent overlay držhrupí
   kontrast pro bílé menu. */
.site-header.at-top {
    /* Žádné podkladové pozadí, žádný shadow — header na hero je JEN
       samotný backdrop SVG glass filtr (granule + blur efekt nad hero
       videem) + menu. Nic nesplývá jako pás.
       REV 10: header je viditelný JEN v .at-top — override schovaného
       defaultu (translateY -100%, opacity 0). */
    background: transparent;
    backdrop-filter: url(#header-glass) blur(8px) saturate(1.4);
    -webkit-backdrop-filter: blur(14px) saturate(1.4);  /* Safari fallback bez SVG filtru */
    box-shadow: none;
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
}

/* === STAV 3 — kompaktní (scroll dál dolů, scrollY ≥ 200) ===
   Padding ↓ a logo ↓ — výška lišty se automaticky propíše dolů.
   REV 10: compact stav je taky SCHOVANÝ (header po hero zmizí). */
.site-header.compact {
    padding-top: 4px;
    padding-bottom: 4px;
    transform: translateY(-100%);
    opacity: 0;
    pointer-events: none;
}

.nav {
    max-width: 1400px;
    margin: 0 auto;
    /* Logo posunutý DOLEVA: padding-left 16 px (oproti default .container 40 px). */
    padding: 6px 40px 6px 16px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
}

.nav__logo {
    display: flex;
    align-items: center;
    transition: opacity .25s ease;
}

/* Stav 1 — LOGO VIDITELNÉ i v hero stavu (bílá ikona na průhledném headeru).
   REV 7: desktop logo se mění z původního "hidden in at-top" na "vždy
   viditelné" — stejný princip jako mobil. Bílá vs tmavá ikona se přepíná
   přes background-image podle stavu. */
.site-header.at-top .nav__logo {
    opacity: 1;
    pointer-events: auto;
}

/* Default desktop logo (po scroll, bílá lišta) — tmavá ikona domu.
   REV 7: nahrazeno celé logo s textem za samostatnou ikonu domu
   (wh-logo.png, nativ 496×496). Desktop má víc místa → 96×96 px
   (factor 5.2× downsample, hluboko pod nativem = ostré). */
.nav__logo .logo-wh {
    height: 96px;
    width: 96px;
    background-image: url('logos/wh-logo.png');
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    transition: height .25s ease, width .25s ease,
                background-image .15s ease;
    image-rendering: -webkit-optimize-contrast;
    image-rendering: high-quality;
}

/* Hero stav desktop — bílá varianta ikony na průhledném headeru.
   REV 7: container 96×96 px (zachováno = stejně velké napříč stavy);
   bílá PNG nativ 416×264 (aspect ~1.576:1), v 96×96 čtvercovém containeru
   `background-size: contain` ikona zobrazí proporčně (efektivně ~96×61 px,
   factor 4.3× downsample, ostré). */
.site-header.at-top .nav__logo .logo-wh {
    background-image: url('logos/wh-logo-white.png');
}

/* Compact stav desktop — tmavá ikona, menší. REV 7: 72×72 px
   (factor ~6.9× downsample, hluboko pod nativem). */
.site-header.compact .nav__logo .logo-wh {
    height: 72px;
    width: 72px;
}

/* ====================================================================
   REV 9 — Adaptivní logo + hamburger podle pozadí.
   body.on-dark se aktivuje přes IntersectionObserver v script.js když
   některá ze 3 tmavých sekcí (#highlifeSection / #collintroSection /
   #hsadv) je za headerem. Logo se přepíná z tmavé varianty na bílou.
   Hero .at-top má vlastní override (pravidlo ř. 232 výše) — ten platí
   bez ohledu na on-dark. PNG swap (žádný filter) — čistý ostrý přechod.
   ==================================================================== */
body.on-dark .nav__logo .logo-wh {
    background-image: url('logos/wh-logo-white.png');
}

/* Hamburger pruhy: default tmavé (čitelné na světlé sekci),
   body.on-dark → bílé, hero .at-top → bílé (existující v mobile @media). */
.nav__toggle-bar {
    background: #0b1115;
    transition: background-color 200ms cubic-bezier(0.32, 0.72, 0, 1);
}
body.on-dark .nav__toggle-bar {
    background: #ffffff;
}

.nav__menu {
    display: flex;
    align-items: center;
    /* Větší mezera mezi položkami (z 4 → 18 px) — položky dýchají. */
    gap: 18px;
    list-style: none;
    /* Default (stav 2) — větší a tučnější menu než dřív (1.125 rem ≈ 18 px,
       +25 % oproti původním var(--fs-maly) 14.4 px). Medium váha. */
    font-size: 1.125rem;
    font-weight: 500;
    transition: font-size .25s ease;
}

/* Stav 1 — menu VÝRAZNĚ VĚTŠÍ na poloprůhledném headeru (1.125 → 1.5 rem). */
.site-header.at-top .nav__menu {
    font-size: 1.5rem;
}

/* Stav 3 — menu mírně menší v kompaktní liště (1.125 → 0.95 rem),
   pořád ale větší/tučnější než původní --fs-maly. */
.site-header.compact .nav__menu {
    font-size: 0.95rem;
}

.nav__menu a {
    /* Default (stav 2) — tmavé položky na bílé liště. */
    color: #3a3a3a;
    padding: 8px 16px;
    border-radius: 999px;
    transition: background .2s ease, color .2s ease, text-shadow .25s ease;
}

/* Stav 1 — BÍLÝ text menu se silným stínem pro čitelnost na hero fotce. */
.site-header.at-top .nav__menu a {
    color: #ffffff;
    text-shadow: 0 1px 8px rgba(0, 0, 0, .6);
}

.nav__menu a:hover {
    color: #fff;
    background: var(--accent);
}

/* HAMBURGER TOGGLE — defaultně skryto (na desktopu nikdy nezobrazit).
   Aktivuje se až v mobilním @media (max-width: 900px) — viz dole. */
.nav__toggle {
    display: none;
}

.nav__toggle-bar {
    display: block;
    width: 24px;
    height: 2px;
    background: #3a3a3a;
    border-radius: 1px;
    transition: transform .25s ease, opacity .25s ease;
}

/* PANEL HEAD (logo + zavírací křížek) — defaultně skryto na desktopu.
   Aktivuje se až v mobilním @media. */
.nav__panel-head,
.nav__close {
    display: none;
}

/* Wrapper .nav__panel — na desktopu transparentní (display: contents),
   ať se .nav__menu chová jako přímý flex child .nav (stejně jako před
   přidáním tohoto wrapperu). Mobilně přepneme na fullscreen overlay. */
.nav__panel {
    display: contents;
}

/* Hover ve stavu 1 — pill background mírně transparentní, ať se s
   poloprůhledným headerem nehádá. */
.site-header.at-top .nav__menu a:hover {
    background: rgba(0, 118, 129, .85);
}

/* === Mobilní override stavu 1 ===
   Na mobilu je menu skryté (.nav__menu display:none v media query níž),
   takže poloprůhledný at-top stav by zanechal prázdnou lištu s jediným
   skrytým logem. Místo toho mobil ZŮSTÁVÁ v solid bílém stavu i na vrchu
   — lišta s logem je trvale viditelná, žádné poloprůhledné překvapení. */
@media (max-width: 900px) {
    /* Mobilní Hero — header KOMPLETNĚ neviditelný před scrollem.
       Předchozí pokus s `background: transparent` selhal, protože hamburger
       `.nav__toggle { display: inline-flex }` (v mobile @media) byl pořád
       viditelný na transparentní liště — uživatel viděl "ikonu visící
       na vzduchu". Tady řešíme přes TRANSFORM: celý header se posune
       o vlastní výšku NAHORU mimo obrazovku → logo + hamburger + lišta
       VŠE pryč. Po scrollu (mimo .at-top) header najede zpět translateY(0). */
    .site-header {
        transition: transform .3s ease, background-color .25s ease,
                    box-shadow .25s ease, padding-top .25s ease,
                    padding-bottom .25s ease;
        transform: translateY(0);
    }
    .site-header.at-top {
        transform: translateY(-100%) !important;
        background: transparent !important;
        box-shadow: none !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
    }
}

.site-header .btn--outline {
    border-color: rgba(255, 255, 255, .6);
    color: #fff;
    background: rgba(255, 255, 255, .12);
    /* backdrop-filter odstraněn — třída není v aktuálním DOM použitá,
       ale pravidlo necháváme pro budoucí použití */
}

.site-header .btn--outline:hover {
    background: rgba(255, 255, 255, .25);
}

.nav__actions {
    display: flex;
    gap: 12px;
}

/* BUTTONS */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    border-radius: 999px;
    font-weight: 500;
    line-height: 1;
    cursor: pointer;
    transition: background .15s ease, color .15s ease;
}

.btn--sm {
    height: 36px;
    padding: 0 16px;
    font-size: var(--fs-button);
}

.btn--lg {
    height: 48px;
    padding: 0 20px;
    font-size: var(--fs-button);
}

.btn--primary {
    background: var(--accent);
    color: #fff;
}

.btn--primary:hover {
    background: #005f68;
}

.btn--ghost {
    background: transparent;
    color: var(--text);
}

.btn--ghost:hover {
    background: rgba(0, 0, 0, .05);
}

/* Hero ghost button — REV 23: na dark editorial blocku (#0e1112), ne nad videem.
   Lehčí outline (35 % bílá), transparent bg — premium ne plastické. */
.hero__actions .btn--ghost {
    color: #fff;
    border: 1px solid rgba(255, 255, 255, .35);
    background: transparent;
    transition: background .15s ease, border-color .15s ease;
}

.hero__actions .btn--ghost:hover {
    background: rgba(255, 255, 255, .08);
    border-color: rgba(255, 255, 255, .65);
}

.btn--outline {
    background: transparent;
    border: 1px solid rgba(0, 0, 0, .15);
    color: var(--text);
}

.btn--outline:hover {
    background: rgba(0, 0, 0, .05);
}

.btn .chevron {
    font-size: 1.2rem;
}

/* HERO — REV 23: split layout (text dark editorial blok + video full-bleed pod).
   Mobile @media obnoví overlay vzhled (full-screen video + text overlay). */
.hero {
    position: relative;
    height: auto;
    background: #0e1112;           /* match .hsadv */
    /* REV 25: overflow: hidden → overflow-x: clip. hidden vytváří implicitní
       scroll containing block → sticky child .hero__video-block se kotvil
       k .hero ne k window → video "plavalo" místo pin. clip (stejný pattern
       jako .truckseq) ten problem nemá. */
    overflow-x: clip;
}

/* TEXT BLOCK — horní dark editorial blok (background #0e1112 = .hsadv).
   REV 32: horní padding 200 → 310 px (+110 px), posun celého obsahu dolů
   pryč od headeru. Bottom 180 beze změny. */
.hero__text-block {
    background: #0e1112;
    color: #ffffff;
    padding: 310px 0 180px;
}

.hero__inner {
    position: relative;
    max-width: 1400px;             /* match .container */
    margin: 0 auto;
    padding: 0 48px;               /* match .container gutter */
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
    animation: heroLineUp .7s ease both;
}

/* REV 27: nadpis ještě o kus větší (max 152 → 176 px), line 2 offset 3ch → 7ch
   (slovo "vířivkami" začíná opticky pod "mezi" z prvního řádku). */
.hero__head {
    max-width: none;
    font-size: clamp(4.5rem, 12vw, 11rem);   /* max 176 px (z REV 24 9.5rem = 152) */
    line-height: 0.95;
    font-weight: 700;
    letter-spacing: -0.035em;
    color: #ffffff;
    text-shadow: none;
    margin: 0;
}

.hero__head-line1 {
    display: block;
    animation: heroLineUp .7s ease both;
}

.hero__head-line2 {
    display: block;
    font-weight: 700;
    color: #ffffff;
    margin-top: 0;
    /* REV 31: padding-left ODSTRANĚN. Zarovnání "vířivkami" pod "mezi" je teď
       řešeno přes neviditelný mirror span "Špička " uvnitř line2 (HTML
       struktura): browser vykreslí mirror s identickou šířkou jako span
       "Špička " v line1 → "vířivkami" automaticky začne přesně tam, kde "mezi".
       Žádné odhady, žádné %, přesná pixelová shoda. */
    animation: heroLineUp .7s ease .15s both;
}

/* REV 31: helper span pro zarovnání "vířivkami" pod "mezi".
   - .hero__head-word v line1 = visible "Špička " (struktura zachovává shodu fontu / tracking)
   - .hero__head-word--mirror v line2 = invisible "Špička " (zabírá identickou šířku) */
.hero__head-word--mirror {
    visibility: hidden;
}

@keyframes heroLineUp {
    from { opacity: 0; transform: translateY(22px); }
    to { opacity: 1; transform: translateY(0); }
}

.hero__word {
    display: inline-block;
    white-space: nowrap;
}

.hero__letter {
    display: inline-block;
    transition: transform .08s linear;
    /* will-change odstraněn — letters dostávaly ~22 vlastních
       compositor vrstev i v idle, bez aktivní animace */
}

.hero__text {
    /* REV 27: +15 % velikost (1.375rem → 1.58rem ≈ 25.3 px), align-self center
       (parent .hero__inner má align-items: flex-start pro nadpis vlevo),
       text-align: center (text uvnitř centrován). */
    margin: 32px 0 0;
    max-width: 44rem;
    font-size: 1.58rem;
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.78);
    text-shadow: none;
    align-self: center;
    text-align: center;
}

/* VIDEO SCOPE — REV 25: scroll-budget proporcionálně dle Δ scale.
   START 0.85 → END 1.0 (Δ 0.15). Zachovaná rychlost z REV 24 (0.005 per vh,
   tj. 0.25/50vh) → 0.15 / 0.005 = 30vh anim. Scope = 100vh sticky + 30vh anim
   = 130vh. Pin se uvolní PŘESNĚ když animace skončí (scale = 1.0). */
.hero__video-scope {
    position: relative;
    width: 100%;
    height: 130vh;
}

/* VIDEO BLOCK — sticky pin viewport-sized, flex-center wrapperu */
.hero__video-block {
    position: sticky;
    top: 0;
    width: 100%;
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background: #0e1112;
}

/* VIDEO WRAP — transform target, native 16:9 ratio (hero-video-9s.mp4 = 1920×1080).
   JS animuje --hero-zoom (0.75 → 1.0) podle scroll progress. */
.hero__video-wrap {
    position: relative;
    /* REV 26: aspect-ratio 16/9 + max-height 100vh ODSTRANĚNO. Na non-16:9
       monitorech (16:10, 21:9 ultrawide atd.) wrapper s 16:9 ratio nepokryl
       celou výšku sticky parent (100vh) → kolem vznikaly černé pruhy z
       .hero__video-block background. Wrapper teď vyplní 100 % sticky bloku
       (= 100vw × 100vh) na všech aspect ratios. Video uvnitř s object-fit:
       cover pokryje plochu bez letterboxu (mírné oříznutí shora/zdola na
       non-16:9 monitorech je akceptovatelné). */
    width: 100%;
    height: 100%;
    transform-origin: center center;
    transform: scale(var(--hero-zoom, 0.85));
    will-change: transform;
}

/* Společné pravidlo pro oba video elementy — class-based selektor
   (.hero__video). REV 26: object-fit contain → cover. Contain letterboxoval
   na non-16:9 monitorech (černé pruhy). Cover vyplní celou plochu wrapperu
   bez pruhů, na 16:9 perfektní fit, na ultrawide / 16:10 mírný ořez shora/
   zdola — full-bleed je priorita. */
.hero__video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Desktop default — zobraz 16:9 video, skryj mobilní 9:16. */
.hero__video--mobile {
    display: none !important;
}

/* Scrim — na desktopu skryt (video je SAMOSTATNÝ blok pod textem, ne pozadí).
   Mobile @media ho obnoví pro overlay text kontrast. */
.hero__scrim {
    display: none;
}

.hero__actions {
    /* REV 27: align-self center (centruje skupinu tlačítek v column flex parent),
       justify-content: center (kdyby wrapnula na 2 řádky, taky centruje).
       Větší margin-top kvůli většímu rozestupu od podnadpisu. */
    margin-top: 36px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 14px;
    align-self: center;
}

/* REV 27: CTA tlačítka v hero scoped — větší padding + font (nezasáhne ostatní .btn--lg na webu) */
.hero__actions .btn--lg {
    padding: 16px 28px;
    font-size: 1.05rem;
}

/* REV 23: hero trust řádek na dark editorial bg — ztlumený */
.hero__trust {
    margin: 28px 0 0;
    font-size: 0.875rem;
    color: rgba(255, 255, 255, 0.55);
    text-shadow: none;
}

/* VIDEO BLOCK */
.video-block,
.video {
    border-radius: var(--radius);
    overflow: hidden;
}

.video-block__video,
.video__video {
    width: 100%;
    height: auto;
    display: block;
}

/* TEXT */
/* Kdo jsme — dlouhý prozaický odstavec "Wellness Home je váš partner…".
   Velikost +15 % (1.5rem → 1.725rem), Medium váha, levo zarovnáno.
   max-width zajišťuje, že text NEPŘETÉKÁ pod video v pravé části sekce. */
/* === KDO JSME — premium textový redesign ===
   Staré .kdojsme .text-bigger / .col-5 / .container pravidla pro
   sticky-video-zoom layout ODSTRANĚNA — nahrazena scoped .kdojsme__*
   v sekci níže (po .truckseq). */

.section-head {
    font-size: var(--fs-h1);
    line-height: 1.05;
    font-weight: 700;
    letter-spacing: -0.02em;
    margin-bottom: 48px;
    color: var(--heading);
}

.btn-inline {
    /* Bývalý tyrkysový pill kolem slova "HotSpring" — odstraněn.
       Slovo zůstává jako normální text v barvě rodičovského odstavce. */
    display: inline;
    color: inherit;
    line-height: inherit;
}

/* KDO JSME — SCROLL EXPANSION */
/* ============================================================
   KDO JSME — premium textový redesign
   Design rules (scoped jen na .kdojsme*):
   • high-end-visual-design — Soft Structuralism vibe, Editorial typography,
     eyebrow pill tag, massive whitespace, brand inline accent
   • usspa-design — light bg, 4px grid, single typeface (Aeonik Pro global)
   • Konzistence se sekcí .proc-wh (3 body) níže — stejný container max-width,
     stejný eyebrow style, stejný section padding, stejný brand accent
   • Žádný scroll efekt — sekce v normálním flow, krátká, vzdušná
   ============================================================ */
.kdojsme {
    position: static;
    height: auto;
    background: var(--bg);
    color: var(--text);
    /* REV 14: 100/100 */
    padding: 100px 0;
}

.kdojsme__container {
    /* REV 14: 1600 → 1400, gutter 48 */
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 48px;
}

.kdojsme__head {
    margin-bottom: 32px;
}

/* Eyebrow pill — IDENTICKÝ se .proc-wh__eyebrow pro vizuální kontinuitu
   mezi dvěma sousedícími premium sekcemi */
.kdojsme__eyebrow {
    display: inline-block;
    padding: 6px 14px;
    border: 1px solid rgba(0, 118, 129, 0.25);
    border-radius: 999px;
    background: rgba(0, 118, 129, 0.05);
    font-family: inherit;
    /* REV 12 2B: 11 → 14 px (čitelnější) */
    font-size: 14px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.22em;
    color: var(--accent);
}

/* Hlavní odstavec — editorial typography, větší než běžný body, ale ne
   plný display H1. Premium reading rhythm. */
.kdojsme__lead {
    font-family: inherit;
    /* REV 14: 40 px exact, line-height 1.4, weight 500 */
    font-size: 40px;
    font-weight: 500;
    line-height: 1.4;
    letter-spacing: -0.005em;
    color: var(--text);
    margin: 0;
    /* REV 14: max-width 1000 */
    max-width: 1000px;
}

/* HotSpring brand inline accent — subtle teal highlight místo border-pill.
   Konzistentní s tím, jak .proc-wh používá var(--accent) jen na čísla. */
.kdojsme__brand {
    color: var(--accent);
    font-weight: 600;
    /* Žádný background, žádný border — čistý inline accent */
}

@media (max-width: 900px) {
    .kdojsme {
        padding: 64px 0;
    }
    .kdojsme__container {
        padding: 0 20px;
    }
    .kdojsme__head {
        margin-bottom: 24px;
    }
    .kdojsme__eyebrow {
        font-size: 10px;
        letter-spacing: 0.2em;
        padding: 5px 12px;
    }
    .kdojsme__lead {
        font-size: 1.25rem;
        max-width: none;
    }
}

/* TEXT REVEAL */
/* TRUCK SCROLL SEQUENCE */
.truckseq {
    position: relative;
    width: 100%;
    /* prodlouženo z 215vh na 280vh: první ~50 % scrollu = wavy text fáze
       (truck stojí na frame 0), druhých ~50 % = framová sekvence kamiona */
    height: 280vh;
    background: #ffffff;
    margin: 0;
    padding: 0;
    /* zachytí případný horizontální přesah z wavyblock transformace,
       žádný page scrollbar */
    overflow-x: clip;
}

/* Wavy text block — sticky pin v horní části truck sekce. Sticky scope =
   celá .truckseq (280vh), takže wavy text JE VIDĚT PO CELOU TRUCK FÁZI
   včetně rozjezdu kamionu — neodscrolluje pryč. */
.wavyblock {
    position: sticky;
    top: 2vh;
    z-index: 2;
    width: 100%;
    pointer-events: none;
    padding: 0 4vw;
    box-sizing: border-box;
}

.wavyblock__inner {
    display: flex;
    flex-direction: column;
    /* Větší vertikální mezera mezi řádky — vodorovná vlna (translateX
       ±17px na mobilu, ±60px na desktopu) je tak zřetelně čitelná. */
    gap: 0.4em;
    /* Centrovaný sloupec — řádky vodorovně vystředěné na společné ose.
       translateX z JS posouvá každý řádek od středu (L/R), nikoli od kraje. */
    align-items: center;
    max-width: 1280px;
    margin: 0 auto;
    text-align: center;
}

.wavyblock__line {
    /* Aeonik Pro Medium — sjednocený typografický systém,
       žádné letter-spacing, žádné uppercase. */
    font-family: 'Aeonik Pro', system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    font-weight: 500;
    font-size: clamp(3.5rem, 9vw, 7rem);
    /* Větší line-height pro vzdušné dýchání mezi řádky — vodorovná vlna
       v každém řádku je tak zřetelně čitelná, řádky se neslévají. */
    line-height: 1.5;
    color: #000000;
    margin: 0;
    white-space: nowrap;
    /* jen transform animuje — will-change opacity odstraněn, aby
       text byl ostřejší (žádná zbytečná GPU vrstva pro opacity) */
    will-change: transform;
    /* font smoothing pro ostrost textu při transformaci */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Mobilní clamp je redukován z původně zadaného 2.4-3.8rem, aby se
   nejdelší řádek "Vířivka míří k vám" (18 znaků vč. mezer) vešel
   na ~380px včetně amplitudy vlny. */
@media (max-width: 600px) {
    .wavyblock { top: 2vh; padding: 0 4vw; }
    .wavyblock__line { font-size: clamp(2.2rem, 9vw, 3.4rem); line-height: 1.45; }
    .wavyblock__inner { gap: 0.35em; }
}

@media (prefers-reduced-motion: reduce) {
    .wavyblock__line { transform: none !important; }
}

.truckseq__sticky {
    position: sticky;
    /* Truck odsunut k DOLNÍ hraně viewportu — horní hrana kamionu sedí
       co nejníž, aby vlna textu nahoře měla nad ním klidnou mezeru. */
    top: calc(100vh - 35vw);
    width: 100%;
    /* height ≈ the truck's own drawn height — no empty letterbox band */
    height: 35vw;
    background: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.truckseq__canvas {
    display: block;
    width: 100%;
    height: 100%;
}

.truckseq__loader {
    position: absolute;
    inset: 0;
    background: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity .4s ease;
}

.truckseq__loader.is-hidden {
    opacity: 0;
    pointer-events: none;
}

.truckseq__bar {
    width: min(240px, 50vw);
    height: 3px;
    border-radius: 999px;
    background: rgba(0, 118, 129, .15);
    overflow: hidden;
}

.truckseq__bar span {
    display: block;
    height: 100%;
    width: 0%;
    background: var(--accent);
    transition: width .2s ease;
}

.truckseq__hint {
    position: absolute;
    bottom: 36px;
    left: 50%;
    transform: translateX(-50%);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-size: var(--fs-eyebrow);
    color: var(--muted);
    will-change: opacity;
}

/* TRUST BAR — běžící pruh (vanilla marquee) na bílé stránce */
.trustbar {
    background: transparent;
    border: 0;
    box-shadow: none;
    overflow: hidden;
    padding: 48px 0;
    margin: 128px 0 40px;
}

.trustbar__viewport {
    position: relative;
    width: 100%;
    overflow: hidden;
    contain: layout paint;
}

.trustbar__viewport::before,
.trustbar__viewport::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    width: 9%;
    pointer-events: none;
    z-index: 2;
}

.trustbar__viewport::before {
    left: 0;
    background: linear-gradient(to right, #ffffff 0%, rgba(255, 255, 255, 0) 100%);
}

.trustbar__viewport::after {
    right: 0;
    background: linear-gradient(to left, #ffffff 0%, rgba(255, 255, 255, 0) 100%);
}

.trustbar__track {
    display: flex;
    width: max-content;
    /* Animace se startuje až po načtení fontu — viz .trustbar__track.is-ready (JS) */
    animation: trustbar-scroll 28s linear infinite paused;
    will-change: transform;
    transform: translate3d(0, 0, 0);
}

.trustbar__track.is-ready {
    animation-play-state: running;
}

.trustbar__group {
    display: flex;
    align-items: center;
    gap: 32px;
    padding-right: 32px;
    flex-shrink: 0;
}

.trustbar__item {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-shrink: 0;
    white-space: nowrap;
}

.trustbar__text {
    /* Aeonik Pro Medium — sjednocený typografický systém */
    font-family: 'Aeonik Pro', system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    font-size: 2.6rem;
    font-weight: 500;
    line-height: 1.2;
    color: #000000;
}

.trustbar__sep {
    font-family: 'Aeonik Pro', system-ui, sans-serif;
}

.trustbar__sep {
    color: rgba(0, 0, 0, .28);
    font-size: 1.8rem;
    line-height: 1;
    flex-shrink: 0;
    user-select: none;
}

.trustbar .trustbar__logo {
    /* Výška definovaná, šířka se dopočítá z poměru stran loga — neměníme,
       nedeformujeme. Funguje pro libovolný poměr stran nového souboru. */
    height: 85px;
    width: auto;
    display: block;
    flex-shrink: 0;
    align-self: center;
    user-select: none;
    -webkit-user-drag: none;
}

/* === Scroll-margin-top pro kotvy v menu ===
   Fixní header má v plném stavu cca 104-108 px výšky. Bez scroll-margin-top
   by skok na #whySection / #highlifeSection / atd. zakryl horní okraj
   sekce pod headerem. 120 px rezerva pokrývá i mobilní 108 px. */
#whySection,
#highlifeSection,
#jetsetterSection,
#faqSection,
#kontakt {
    scroll-margin-top: 120px;
}
/* #reviewsSection má vlastní scroll-margin-top z dřívějška (100 px),
   zachováno. */

@keyframes trustbar-scroll {
    from { transform: translate3d(0, 0, 0); }
    to   { transform: translate3d(-50%, 0, 0); }
}

@media (prefers-reduced-motion: reduce) {
    .trustbar__track { animation: none; }
}

/* PROC VIRIVKA */
.why {
    background: var(--bg);
    /* REV 14: 100/100 padding */
    padding: 100px 0;
    color: var(--text);
}

.why__inner {
    /* REV 14: 2-col 1fr 1fr, gap 64, align-items center */
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    align-items: center;
}

.why__col--text {
    align-self: center;
}

.why__col--media {
    /* REV 16: image height 560 */
    width: 100%;
    height: 560px;
    overflow: hidden;
    border-radius: 20px;
}

.why__frame {
    /* REV 16: desktop frame fill — image musí vyplnit .why__col--media 560 px */
    width: 100%;
    height: 100%;
    display: block;
}

.why__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.why__title {
    /* REV 14: exact 56 px */
    font-size: 56px;
    font-weight: 500;
    line-height: 1.05;
    letter-spacing: -0.02em;
    color: var(--text);
    margin-bottom: 24px;
}

.why__title-accent {
    color: inherit;
}

.why__lead {
    /* REV 14: 22 px, line-height 1.6 */
    font-size: 22px;
    line-height: 1.6;
    color: var(--text);
    max-width: 56ch;
    margin-bottom: 0;
}

/* Reveal — výchozí stav pro IntersectionObserver */
.why-reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity .6s ease, transform .6s ease;
}

.why-reveal[data-why-step="1"] { transition-delay: 0ms; }
.why-reveal[data-why-step="2"] { transition-delay: 90ms; }
.why-reveal[data-why-step="3"] { transition-delay: 180ms; }
.why-reveal[data-why-step="4"] { transition-delay: 270ms; }

.why-reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
    .why-reveal {
        opacity: 1;
        transform: none;
        transition: none;
    }
}

/* RECENZE — 3 svislé kolony s nekonečnou marquee smyčkou (CSS @keyframes) */
.reviews {
    background: var(--bg);
    /* REV 14: 100/100 */
    padding: 100px 0;
    scroll-margin-top: 100px;
    color: var(--text);
}

.reviews__head {
    text-align: center;
    /* REV 12 2B: 720 → 800 */
    max-width: 800px;
    margin: 0 auto 56px;
}

.reviews__title {
    /* REV 14: 64 px exact */
    font-size: 64px;
    font-weight: 700;
    line-height: 1.15;
    letter-spacing: -0.02em;
    margin: 0 0 14px;
    color: var(--text);
}

.reviews__subtitle {
    font-size: var(--fs-podnadpis);
    line-height: 1.55;
    color: var(--text);
    opacity: 0.75;
    margin: 0;
}

.reviews__cols {
    display: flex;
    justify-content: center;
    /* REV 12 2B: 28 → 32 */
    gap: 32px;
    max-height: 720px;
    overflow: hidden;
    -webkit-mask-image: linear-gradient(to bottom, transparent 0, #000 12%, #000 88%, transparent 100%);
    mask-image: linear-gradient(to bottom, transparent 0, #000 12%, #000 88%, transparent 100%);
}

.reviews__col {
    flex: 1 1 0;
    min-width: 0;
    /* REV 13: 400 → 480 (širší karty pro full-bleed container 1600) */
    max-width: 480px;
    overflow: hidden;
}

.reviews__track {
    display: flex;
    flex-direction: column;
    gap: 24px;
    padding-bottom: 24px;
    will-change: transform;
    transform: translate3d(0, 0, 0);
    animation: reviews-scroll 40s linear infinite;
}

.reviews__col--1 .reviews__track { animation-duration: 40s; }
.reviews__col--2 .reviews__track { animation-duration: 48s; }
.reviews__col--3 .reviews__track { animation-duration: 44s; }

@keyframes reviews-scroll {
    from { transform: translate3d(0, 0, 0); }
    to   { transform: translate3d(0, -50%, 0); }
}

@media (prefers-reduced-motion: reduce) {
    .reviews__track { animation: none; }
}

.review-card {
    background: #ffffff;
    border: 1px solid rgba(0, 0, 0, .06);
    border-radius: 20px;
    /* padding 0 — fotka jde od kraje ke kraji, overflow:hidden zaobluje
       horní rohy fotky podle border-radius karty */
    padding: 0;
    overflow: hidden;
    box-shadow: 0 12px 28px rgba(0, 118, 129, .07), 0 2px 6px rgba(0, 0, 0, .04);
}

.review-card__cover {
    /* nízký, široký pruh nad obsahem — pevná výška IDENTICKÁ pro všechny
       karty bez ohledu na rozměr zdrojového souboru. min/max-height a
       flex-shrink:0 zaručí, že žádný flex/aspect-ratio override výšku
       nezmění. */
    width: 100%;
    height: 140px;
    min-height: 140px;
    max-height: 140px;
    object-fit: cover;
    display: block;
    background: rgba(0, 0, 0, .05);
    flex-shrink: 0;
}

.review-card__body {
    /* REV 14: padding 32 (větší vnitřní vzduch) */
    padding: 32px;
}

.review-card__stars {
    color: var(--accent);
    font-size: var(--fs-text);
    letter-spacing: 0.1em;
    line-height: 1;
    margin-bottom: 14px;
}

.review-card__text {
    /* REV 14: 18 px exact */
    font-size: 18px;
    line-height: 1.55;
    color: var(--text);
    margin: 0 0 14px;
}

.review-card__name {
    display: block;
    font-size: var(--fs-maly);
    font-weight: 600;
    color: var(--text);
}

/* Tablet — 2 kolony, skryj 3. */
@media (max-width: 1100px) {
    .reviews__col--3 { display: none; }
}

/* Mobil — 1 kolona, skryj 2. + 3., menší max-height, rychlejší smyčka */
@media (max-width: 700px) {
    .reviews { padding: 64px 0; }
    .reviews__head { margin-bottom: 36px; }
    .reviews__cols { max-height: 560px; gap: 0; }
    .reviews__col { max-width: 100%; }
    .reviews__col--2, .reviews__col--3 { display: none; }
    .reviews__col--1 .reviews__track { animation-duration: 32s; }
    .review-card__body { padding: 18px 20px 20px; }
    .review-card__cover { height: 120px; min-height: 120px; max-height: 120px; }
    .reviews { padding: 120px 0 64px; scroll-margin-top: 80px; }
}

/* FAQ + formulář — VÝCHOZÍ SVĚTLÝ STAV.
   Sekce má dva barevné stavy:
   1) DEFAULT (bez class .is-blue): bílé pozadí, světlé bordery, vodní šedé
      pole. Toto je viditelné, dokud uživatel nedoscrolluje k sekci.
   2) ".is-blue" stav (přidaný IntersectionObserverem v script.js, když sekce
      vstoupí do viewportu): HotSpring modré pozadí, černé bordery, bílá
      pole. Plynulý CSS transition 0.45s. */
.faq {
    background: var(--bg);
    /* REV 14: 100/100 */
    padding: 100px 0;
    color: var(--text);
    transition: background-color .45s ease, color .45s ease;
}

.faq__list {
    list-style: none;
    margin: 0 auto;
    padding: 0;
    /* REV 12 2B: reading width zachován 820 (vyhovuje, FAQ je čitelný list) */
    max-width: 820px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.faq__item {
    background: #ffffff;
    border: 1px solid rgba(0, 0, 0, .08);
    border-radius: 14px;
    overflow: hidden;
    transition: border-color .45s ease, box-shadow .45s ease, background-color .45s ease;
}

.faq__item.is-open {
    border-color: rgba(0, 118, 129, .35);
    box-shadow: 0 6px 18px rgba(0, 118, 129, .08);
}

.faq__question {
    width: 100%;
    background: transparent;
    border: 0;
    /* REV 14: padding 24×28 zachováno, font-size 20 px exact */
    padding: 24px 28px;
    font-size: 20px;
    font-family: 'Aeonik Pro', system-ui, sans-serif;
    font-size: var(--fs-podnadpis);
    font-weight: 600;
    line-height: 1.4;
    color: var(--text);
    text-align: left;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    cursor: pointer;
    transition: color .2s ease;
}

.faq__question:hover {
    color: var(--accent);
}

.faq__question:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: -2px;
    border-radius: 14px;
}

.faq__icon {
    flex-shrink: 0;
    position: relative;
    width: 22px;
    height: 22px;
    transition: transform .25s ease;
}

.faq__icon::before,
.faq__icon::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    /* default = accent (světlý stav); v .is-blue scope se override na #000 */
    background: var(--accent);
    border-radius: 2px;
    transition: transform .25s ease, opacity .25s ease, background-color .45s ease;
}

.faq__icon::before {
    /* horizontální čárka — vždy viditelná */
    width: 14px;
    height: 2px;
    transform: translate(-50%, -50%);
}

.faq__icon::after {
    /* svislá čárka — zmizí při otevření, dohromady "+ → −" */
    width: 2px;
    height: 14px;
    transform: translate(-50%, -50%);
}

.faq__item.is-open .faq__icon::after {
    transform: translate(-50%, -50%) rotate(90deg);
    opacity: 0;
}

.faq__answer {
    /* skrytá výchozí — max-height animace pro plynulé rozbalení */
    max-height: 0;
    overflow: hidden;
    transition: max-height .35s ease;
}

.faq__item.is-open .faq__answer {
    /* dostatečně velké pro nejdelší odpověď — overflow:hidden ořeže */
    max-height: 400px;
}

.faq__answer-inner {
    padding: 0 26px 22px;
}

.faq__answer-inner p {
    margin: 0;
    font-size: var(--fs-text);
    line-height: 1.6;
    color: var(--text);
    opacity: 0.85;
}

@media (max-width: 700px) {
    .faq { padding: 64px 0; }
    .faq__list { gap: 10px; }
    .faq__question { padding: 18px 20px; gap: 16px; }
    .faq__answer-inner { padding: 0 20px 18px; }
    .faq__item.is-open .faq__answer { max-height: 480px; }
}

@media (prefers-reduced-motion: reduce) {
    .faq__answer,
    .faq__icon,
    .faq__icon::before,
    .faq__icon::after { transition: none; }
}

/* HIGHLIFE — krátký pinned reveal (≈ 1 obrazovka scrollu) */
.highlife {
    --hl-p: 0;
    position: relative;
    background: #0e1112;
    color: #fff;
    height: 200vh; /* 100vh pin + 100vh scroll-through */
}

.highlife__sticky {
    position: sticky;
    top: 0;
    height: 100vh;
    width: 100%;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 32px;
    box-sizing: border-box;
}

.highlife__title {
    /* Vlastní velikost — výrazně větší než ostatní nadpisy sekcí (~2× --fs-h1).
       Sekce má pinned reveal s pin scale-down → potřebuje velký display effekt. */
    font-size: clamp(3.5rem, 9vw, 8rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1;
    text-align: center;
    margin: 0;
    /* fáze 1 (var(--hl-p)=0): velký nadpis na střed
       fáze 2 (var(--hl-p)=1): zmenšený a posunutý nahoru, fotka + features se odhalují */
    transform: translate3d(0, calc(var(--hl-p) * -28vh), 0) scale(calc(1 - var(--hl-p) * 0.42));
    transform-origin: center top;
    will-change: transform;
}

.highlife__title-accent {
    color: inherit;
}

.highlife__stage {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 6vh;
    padding: 0 32px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 36px;
    opacity: var(--hl-p);
    transform: translate3d(0, calc((1 - var(--hl-p)) * 36px), 0);
    pointer-events: none;
    will-change: opacity, transform;
}

.highlife__media {
    width: 100%;
    max-width: 720px;
    display: flex;
    justify-content: center;
}

.highlife__image {
    width: 100%;
    height: auto;
    /* REV 14: 42vh → 36vh (uvolní místo pro full karty pod vířivkou). */
    max-height: 36vh;
    object-fit: contain;
    display: block;
}

.highlife__features {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    /* REV 14: gap 32 → 24 (kompaktnější), max-width 1080 → 1100 */
    gap: 24px;
    width: 100%;
    max-width: 1100px;
}

/* REV 14: karta plná — padding 32, bg rgba(255,255,255,0.06), radius 16. */
.highlife__feature {
    text-align: left;
    padding: 32px;
    background: rgba(255, 255, 255, 0.06);
    border-radius: 16px;
}

.highlife__feature-title {
    /* REV 14: 22 px exact */
    font-size: 22px;
    font-weight: 500;
    margin: 0 0 8px;
    color: #ffffff;
}

.highlife__feature-text {
    /* REV 14: 16 px exact, line-height 1.6, display:block (REV 7 hidden override smazán). */
    display: block;
    font-size: 16px;
    line-height: 1.6;
    color: rgba(255, 255, 255, .72);
    margin: 0;
    text-align: left;
}

@media (prefers-reduced-motion: reduce) {
    .highlife { --hl-p: 1; }
    .highlife__title { transform: translate3d(0, -28vh, 0) scale(0.58); }
    .highlife__stage { opacity: 1; transform: none; }
}

/* JETSETTER LX — interaktivní půdorys s hotspots */
.jetsetter {
    background: var(--bg);
    color: var(--text);
    /* REV 14: 100/100 */
    padding: 100px 0;
    /* zachytí přesah karty panelu doprava (width +200 přes cell) */
    overflow-x: clip;
}

/* REV 18: container override jen pro Jetsetter — 1500 → 1700 (víc šířky pro
   image vířivky, která je landscape 1240×697 a v úzkém cell s height: 600
   + object-fit contain byla letterbox-malá). */
@media (min-width: 901px) {
    .jetsetter > .container {
        max-width: 1700px;
    }
}

/* Desktop default — carousel wrappery jsou neutralizované přes
   display: contents, takže .jetsetter__intro a .jetsetter__layout
   se chovají jako přímé děti .container (desktop layout IDENTICKÝ).
   Dots jsou skryté. Na mobilu mobilní @media všechny tyto vlastnosti
   přepíše a vytvoří swipe carousel. */
.jet-carousel,
.jet-track,
.jet-slide {
    display: contents;
}

.jet-dots {
    display: none;
}

.jetsetter__head {
    text-align: center;
    max-width: 720px;
    /* Větší vertikální mezera pod nadpisem k obsahu (intro blok, vířivka). */
    margin: 0 auto 96px;
}

.jetsetter__title {
    /* REV 12 2B: custom clamp → globální --fs-h1 token */
    font-size: var(--fs-h1);
    font-weight: 700;
    line-height: 1.05;
    letter-spacing: -0.02em;
    margin: 0 0 16px;
}

.jetsetter__title-accent {
    color: inherit;
}

.jetsetter__subtitle {
    font-size: var(--fs-podnadpis);
    line-height: 1.5;
    color: var(--text);
    margin: 0 0 12px;
}

/* Úvodní blok — text vlevo, render z boku vpravo */
.jetsetter__intro {
    display: grid;
    /* REV 18: 1fr | 1.5fr — image cell dostatečně širší než text,
       aby landscape render vířivky (1240×697) vyplnil bez letterboxu.
       Container 1700 → inner ≈ 1604, gap 80 → text ≈ 610, image ≈ 914. */
    grid-template-columns: 1fr 1.5fr;
    gap: 80px;
    align-items: center;
    margin-bottom: 64px;
}

.jetsetter__intro-media {
    display: flex;
    justify-content: center;
    align-items: center;
}

.jetsetter__side {
    /* REV 18: height: auto — image renderuje v native aspect ratio
       (1240×697 = 1.78:1) a vyplní celý image cell (~914 px). Žádný
       letterbox, žádné prázdné místo. Render výška ≈ 914 × 697/1240
       ≈ 514 px. Max-height 640 px chrání proti přepalu na ultrawide. */
    width: 100%;
    height: auto;
    max-height: 640px;
    object-fit: contain;
    display: block;
}

.jetsetter__intro-text {
    /* REV 18: 480 → 560 (širší karta dle REV 17 záměru,
       text cell ≈ 610 → karta vyplní s rezervou). */
    max-width: 560px;
}

.jetsetter__intro-lead {
    font-size: var(--fs-podnadpis);
    line-height: 1.6;
    color: var(--text);
    margin: 0 0 28px;
}

.jetsetter__specs {
    margin: 0 0 28px;
    border: 1px solid rgba(0, 0, 0, .08);
    border-radius: 6px;
    overflow: hidden;
}

.jetsetter__specs-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
    gap: 16px;
    /* REV 16: padding 12×20, font-size 16 (tabulka nedominuje vedle vířivky) */
    padding: 12px 20px;
    font-size: 16px;
    line-height: 1.4;
}

.jetsetter__specs-row:nth-child(odd) {
    background: rgba(0, 0, 0, .035);
}

.jetsetter__specs dt {
    font-weight: 500;
    color: var(--muted);
}

.jetsetter__specs dd {
    margin: 0;
    color: var(--text);
    font-weight: 500;
}

.jetsetter__intro-cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 22px;
    border: 1.5px solid var(--accent);
    border-radius: 999px;
    background: transparent;
    color: var(--accent);
    font-size: var(--fs-button);
    font-weight: 500;
    text-decoration: none;
    transition: background .15s ease, color .15s ease;
}

.jetsetter__intro-cta:hover {
    background: var(--accent);
    color: #ffffff;
}

.jetsetter__intro-cta .chevron {
    font-size: 1.1rem;
    line-height: 1;
}

.jetsetter__layout {
    display: grid;
    /* REV 17: 1fr | 1.15fr (panel cell širší než plan cell), gap 64.
       Plus plan má justify-self: start (posunutí doleva). */
    grid-template-columns: 1fr 1.15fr;
    gap: 64px;
    align-items: center;
}

.jetsetter__plan {
    position: relative;
    /* REV 17: max-width 600 → 700 (zvětšeno), justify-self: start (posun doleva
       v 1fr cell — plán začíná u levého kraje cell, ne centered). aspect-ratio
       1/1 drží square pro hotspoty (left:40%/top:38% sedí proporcionálně). */
    width: 100%;
    max-width: 700px;
    aspect-ratio: 1 / 1;
    height: auto;
    margin: 0;
    justify-self: start;
}

.jetsetter__overhead {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
    user-select: none;
    -webkit-user-drag: none;
}

.jetsetter__hotspot {
    position: absolute;
    /* left/top inline via style (% vůči .jetsetter__plan);
       translate posouvá tak, aby % označovalo STŘED tlačítka */
    transform: translate(-50%, -50%);
    width: 38px;
    height: 38px;
    border-radius: 50%;
    border: 0;
    padding: 0;
    background: var(--accent);
    color: #ffffff;
    font: 600 1.2rem/1 'Aeonik Pro', system-ui, sans-serif;
    cursor: pointer;
    box-shadow: 0 4px 12px rgba(0, 118, 129, .3), 0 1px 4px rgba(0, 0, 0, .12);
    transition: background .2s ease, box-shadow .2s ease, transform .2s ease;
    z-index: 2;
}

/* Neviditelný touch target (44×44 i když je vizuálně menší) */
.jetsetter__hotspot::before {
    content: "";
    position: absolute;
    inset: -8px;
    border-radius: 50%;
}

.jetsetter__hotspot span {
    display: block;
    line-height: 1;
    transform: translateY(-1px);
}

.jetsetter__hotspot:hover {
    background: #005f68;
    transform: translate(-50%, -50%) scale(1.08);
}

.jetsetter__hotspot.is-active {
    background: #ffffff;
    color: var(--accent);
    box-shadow: 0 0 0 2px var(--accent), 0 6px 16px rgba(0, 0, 0, .15);
}

.jetsetter__hotspot:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 4px;
}

.jetsetter__panel {
    position: relative;
    /* Panel vyplní celý pravý sloupec gridu (1fr) — žádný max-width,
       žádný width, žádný margin override. */
    min-height: clamp(290px, calc(50vw - 130px), 450px);
}

/* Karta Jetsetteru — výrazný tyrkysový "skleněný" podklad s viditelnou
   granulovou texturou (matné/pískované sklo). Dvě složené background
   vrstvy + tyrkysový podkladový tón:

   1) Radial gradient sheen (vlevo-nahoře) — světelný odraz, glass dojem
   2) SVG noise tile (feTurbulence fractalNoise, opacity 0.18) — granule
   3) background-color #e3f1f2 — světlá tyrkysová, NE bílá, jasně odlišná

   Vše STATICKÉ — data-URI raster, žádný backdrop-filter ani živý SVG
   filtr na DOM elementu. Přepínání sedadel zůstává plynulé. */
.jet-glow {
    border: 1px solid rgba(0, 118, 129, .4);
    border-radius: 16px;
    background-color: #e3f1f2;
    background-image:
        radial-gradient(at 28% 18%, rgba(255, 255, 255, .55), transparent 60%),
        url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' seed='4' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.18'/></svg>");
    background-repeat: no-repeat, repeat;
    box-shadow:
        0 0 0 1px rgba(0, 118, 129, .05),
        0 0 14px rgba(0, 118, 129, .12),
        0 6px 16px rgba(0, 0, 0, .04);
}

.jetsetter__intro-text.jet-glow {
    /* REV 17: padding 26×28 → 36×40 (text + tabulka uvnitř nemačkané) */
    padding: 36px 40px;
}

.jetsetter__panel.jet-glow {
    overflow: hidden;
    padding: 48px;
    min-height: 480px;
    /* REV 18: max-width 760 → 840 (border posunutý ven o 80 px doprava).
       Text uvnitř se NEPOSOUVÁ — kompenzace přes `.jetsetter__seat`
       padding-right (viz níže), takže figurka i textový sloupec zůstanou
       v původní obrazovkové pozici, jen modrá linka rámečku se rozšíří. */
    width: 100%;
    max-width: 840px;
    min-width: 0;
    margin: 0;
    justify-self: start;
}

.jetsetter__panel.jet-glow .jetsetter__seat {
    /* REV 14: panel je teď 1fr cell-bound, žádný offset */
    right: 0;
}

.jetsetter__seat {
    position: absolute;
    inset: 0;
    /* REV 18: padding-right 80 — kompenzuje rozšíření panel borderu
       (max-width 760 → 840) tak, aby text uvnitř zůstal v původní
       obrazovkové pozici. Border se posune 80 px doprava, textový sloupec
       (1fr) se zúží o 80 px → text se na obrazovce nepohne. */
    padding-right: 80px;
    display: none;
    /* REV 14: silueta 180 px col (menší → víc místa textu), gap 32 */
    grid-template-columns: 180px minmax(0, 1fr);
    gap: 32px;
    align-items: center;
    pointer-events: none;
    transform: translateZ(0);
}

.jetsetter__seat.is-active {
    display: grid;
    pointer-events: auto;
}

.jetsetter__seat-body {
    /* Silueta vrácena na původní velikost (matchne výšku panelu / vířivky). */
    width: 100%;
    height: clamp(290px, calc(50vw - 130px), 450px);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.jetsetter__seat-body img {
    height: 100%;
    width: auto;
    max-width: 100%;
    object-fit: contain;
    display: block;
    margin: 0 auto;
}

.jetsetter__seat-text {
    /* Společné pro celý textový sloupec — zarovnání vlevo, žádné
       justify mezery, žádné dělení slov mezi řádky. */
    text-align: left;
    hyphens: none;
    -webkit-hyphens: none;
    overflow-wrap: normal;
    word-break: normal;
}

.jetsetter__seat-title {
    font-size: var(--fs-h2);
    font-weight: 600;
    line-height: 1.35;
    letter-spacing: -0.005em;
    margin: 0 0 12px;
    color: var(--text);
    text-align: left;
    /* white-space: nowrap odstraněno — při --fs-h2 (až 33.6 px) by nadpisy
       1 a 2 mohly přesahovat úzký textový sloupec. Přirozený wrap je bezpečnější. */
    hyphens: none;
    -webkit-hyphens: none;
    overflow-wrap: normal;
    word-break: normal;
}

/* "(Bucket Seat)" pod hlavním textem na samostatném řádku — display:block
   překoná white-space: nowrap rodiče. Velikost a barva mírně potlumené. */
.jetsetter__seat-title-sub {
    display: block;
    font-size: 0.85em;
    font-weight: 500;
    color: var(--muted);
    line-height: 1.2;
    margin-top: 2px;
}

.jetsetter__seat-summary {
    /* REV 14: 17 px exact, line-height 1.6 */
    font-size: 17px;
    line-height: 1.6;
    color: var(--text);
    margin: 0 0 20px;
    text-align: left;
    hyphens: none;
    -webkit-hyphens: none;
    overflow-wrap: normal;
    word-break: normal;
}

.jetsetter__jets {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.jetsetter__jets li {
    font-size: var(--fs-maly);
    line-height: 1.5;
    color: var(--text);
    padding-left: 14px;
    position: relative;
    text-align: left;
    hyphens: none;
    -webkit-hyphens: none;
    overflow-wrap: normal;
    word-break: normal;
}

.jetsetter__jets li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.7em;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--accent);
}

.jetsetter__jets strong {
    color: var(--text);
    font-weight: 600;
}

/* fade-up celé sekce (jako .why-reveal — jednorázový IO) */
.jetsetter-reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity .6s ease, transform .6s ease;
}

.jetsetter-reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
    .jetsetter-reveal { opacity: 1; transform: none; transition: none; }
    .jetsetter__seat { transition: none; }
}

/* =========================================================
   REV 19 — Jetsetter premium polish (agency-tier)
   Scope: desktop only (≥901 px). Mobil úplně netknut.
   Funkčnost (hotspot přepínání seat karet) NEDOTKNUTA — jen vizuál.
   HTML/JS beze změny.
   ========================================================= */
@media (min-width: 901px) {

    /* — Section ambient: subtle dual radial gradient mesh za obsahem
       (tyrkysový glow top + bottom) — místo ploché --bg barvy.
       Dává sekci tichou hloubku bez křiklavosti. */
    .jetsetter {
        position: relative;
        background:
            radial-gradient(ellipse 70% 50% at 50% 0%, rgba(0, 118, 129, .06), transparent 70%),
            radial-gradient(ellipse 80% 40% at 50% 100%, rgba(0, 118, 129, .04), transparent 70%),
            var(--bg);
    }

    /* — Header: rozšířená šířka pro premium dech, větší margin pod */
    .jetsetter__head {
        max-width: 880px;
        margin: 0 auto 112px;
    }

    /* — Eyebrow: pilulka s teal dot indikátorem + halo (NE plochý text) */
    .jetsetter__head .m-eyebrow {
        display: inline-flex;
        align-items: center;
        gap: 10px;
        padding: 7px 16px 7px 14px;
        border-radius: 999px;
        background: rgba(0, 118, 129, .07);
        border: 1px solid rgba(0, 118, 129, .18);
        color: var(--accent);
        font-size: 12px;
        font-weight: 600;
        letter-spacing: 0.14em;
        text-transform: uppercase;
        margin-bottom: 32px;
    }
    .jetsetter__head .m-eyebrow::before {
        content: "";
        display: block;
        width: 6px;
        height: 6px;
        border-radius: 50%;
        background: var(--accent);
        box-shadow: 0 0 0 3px rgba(0, 118, 129, .18);
    }

    /* REV 22: REV 19 gradient text-fill na .jetsetter__title-accent ODSTRANĚN.
       Uživatel chce celý nadpis "Jetsetter LX" jednobarevný černý. Default
       (L1550) `.jetsetter__title-accent { color: inherit }` se vrací k dědění
       z .jetsetter__title (var(--text) = černá). */

    /* — INTRO KARTA: odlišit od panel karty.
       Panel zůstává tyrkysový glass. Intro karta = bílá editorial s hairline.
       Vytváří hierarchii: text-card (calmní) vs panel (aktivní/interaktivní). */
    .jetsetter__intro-text.jet-glow {
        background-color: #ffffff;
        background-image: none;
        border: 1px solid rgba(0, 0, 0, .06);
        border-radius: 22px;
        padding: 44px 48px;
        box-shadow:
            0 0 0 1px rgba(0, 0, 0, .02),
            0 24px 48px -24px rgba(0, 0, 0, .12),
            0 4px 12px rgba(0, 0, 0, .03);
    }

    /* — Intro lead: větší, editorial váha */
    .jetsetter__intro-lead {
        font-size: 1.2rem;
        line-height: 1.6;
        margin: 0 0 32px;
        color: var(--text);
    }

    /* — Specs: hairline-only místo zebra (Bootstrap pryč) */
    .jetsetter__specs {
        border: none;
        border-top: 1px solid rgba(0, 0, 0, .08);
        border-radius: 0;
        overflow: visible;
        margin: 0 0 32px;
    }
    .jetsetter__specs-row {
        padding: 14px 0;
        border-bottom: 1px solid rgba(0, 0, 0, .06);
        background: transparent;
        font-size: 15px;
        grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
        gap: 16px;
    }
    .jetsetter__specs-row:nth-child(odd) {
        background: transparent;
    }
    .jetsetter__specs dt {
        font-size: 12px;
        text-transform: uppercase;
        letter-spacing: 0.08em;
        color: var(--muted);
        font-weight: 500;
        align-self: center;
    }
    .jetsetter__specs dd {
        font-size: 16px;
        font-weight: 600;
        color: var(--text);
    }

    /* — CTA: filled accent pill s nested circular chevron (button-in-button).
       Magnetic hover s premium cubic-bezier. */
    .jetsetter__intro-cta {
        background: var(--accent);
        color: #ffffff;
        border-color: var(--accent);
        padding: 8px 8px 8px 24px;
        gap: 14px;
        font-weight: 600;
        box-shadow: 0 4px 14px rgba(0, 118, 129, .25);
        transition:
            transform .4s cubic-bezier(.32, .72, 0, 1),
            box-shadow .4s cubic-bezier(.32, .72, 0, 1),
            background .25s ease;
    }
    .jetsetter__intro-cta:hover {
        background: #005a63;
        color: #ffffff;
        transform: translateY(-1px);
        box-shadow: 0 10px 24px rgba(0, 118, 129, .35);
    }
    .jetsetter__intro-cta:active {
        transform: translateY(0) scale(.98);
    }
    .jetsetter__intro-cta .chevron {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 34px;
        height: 34px;
        border-radius: 50%;
        background: rgba(255, 255, 255, .18);
        font-size: 1rem;
        line-height: 1;
        transition: transform .4s cubic-bezier(.32, .72, 0, 1);
    }
    .jetsetter__intro-cta:hover .chevron {
        transform: translateX(3px);
        background: rgba(255, 255, 255, .26);
    }

    /* — Side image: ambient drop-shadow → „floating" pocit */
    .jetsetter__side {
        filter:
            drop-shadow(0 30px 40px rgba(0, 118, 129, .14))
            drop-shadow(0 10px 18px rgba(0, 0, 0, .08));
    }

    /* — Hotspots: refined design + pulse animation na aktivním */
    .jetsetter__hotspot {
        width: 44px;
        height: 44px;
        background: #ffffff;
        color: var(--accent);
        border: 1.5px solid var(--accent);
        font-size: 1.35rem;
        box-shadow:
            0 0 0 4px rgba(0, 118, 129, .12),
            0 8px 18px rgba(0, 118, 129, .25);
        transition:
            transform .35s cubic-bezier(.32, .72, 0, 1),
            box-shadow .35s cubic-bezier(.32, .72, 0, 1),
            background .25s ease;
    }
    .jetsetter__hotspot:hover {
        background: #f0fbfc;
        transform: translate(-50%, -50%) scale(1.1);
    }
    .jetsetter__hotspot.is-active {
        background: var(--accent);
        color: #ffffff;
        box-shadow:
            0 0 0 4px rgba(0, 118, 129, .18),
            0 0 0 10px rgba(0, 118, 129, .08),
            0 10px 22px rgba(0, 118, 129, .38);
        animation: jetsetter-hotspot-pulse 2.6s ease-in-out infinite;
    }
    @keyframes jetsetter-hotspot-pulse {
        0%, 100% {
            box-shadow:
                0 0 0 4px rgba(0, 118, 129, .18),
                0 0 0 10px rgba(0, 118, 129, .08),
                0 10px 22px rgba(0, 118, 129, .38);
        }
        50% {
            box-shadow:
                0 0 0 6px rgba(0, 118, 129, .22),
                0 0 0 16px rgba(0, 118, 129, .04),
                0 10px 22px rgba(0, 118, 129, .42);
        }
    }

    /* — Panel (Moto-Massage glass): zjemnit border, větší radius, refined shadow */
    .jetsetter__panel.jet-glow {
        border-radius: 22px;
        border-color: rgba(0, 118, 129, .22);
        box-shadow:
            0 0 0 1px rgba(0, 118, 129, .06),
            0 24px 48px -20px rgba(0, 118, 129, .18),
            0 6px 16px rgba(0, 0, 0, .04);
    }

    /* — Seat title: editorial váha, sub-text v accent místo grey muted */
    .jetsetter__seat-title {
        font-size: 1.9rem;
        font-weight: 600;
        line-height: 1.15;
        letter-spacing: -0.015em;
        margin: 0 0 16px;
    }
    .jetsetter__seat-title-sub {
        font-size: 0.62em;
        color: var(--accent);
        font-weight: 600;
        letter-spacing: 0.02em;
        margin-top: 8px;
        text-transform: none;
    }

    /* — Seat summary: muted color pro hierarchii vůči title + jets */
    .jetsetter__seat-summary {
        font-size: 16px;
        line-height: 1.6;
        color: var(--muted);
        margin: 0 0 24px;
    }

    /* — Jets list: refined dot s halo, lehce větší gap */
    .jetsetter__jets {
        gap: 16px;
    }
    .jetsetter__jets li {
        padding-left: 22px;
        font-size: 15px;
        line-height: 1.55;
    }
    .jetsetter__jets li::before {
        width: 8px;
        height: 8px;
        top: 0.55em;
        box-shadow: 0 0 0 3px rgba(0, 118, 129, .15);
    }

} /* /REV 19 @media min-width 901 */

.reveal-section {
    position: relative;
    height: 200vh;
    background: #ffffff;
}

.reveal-sticky {
    position: sticky;
    top: 0;
    height: 100vh;
    display: flex;
    align-items: center;
}

.reveal-word {
    transition: opacity .12s linear;
}

/* Vítejte text is black; only the pill phrases stay teal — like Kdo jsme. */
p.reveal-text {
    color: var(--text);
}

p.reveal-text .btn-inline {
    color: var(--accent);
}

/* "Odpočinek je začátek úspěchu" — black heading, teal pill word. */
.uspech-head {
    color: var(--text);
}

.uspech-head .btn-inline {
    color: var(--accent);
}

/* STORY SCROLL */
/* KOLEKCE HOTSPRING — INTRO */
.collintro {
    background: #0e1112;
    color: #ffffff;
    /* REV 14: 100/100 */
    padding: 100px 0;
    position: relative;
}

.collintro__divider {
    display: block;
    width: min(120px, 22vw);
    height: 2px;
    margin: 0 auto 64px;
    background: rgba(255, 255, 255, .22);
}

.collintro__head {
    /* REV 14: max-width 900 */
    max-width: 900px;
    margin: 0 auto;
    text-align: center;
}

.collintro__title {
    /* REV 14: 64 px exact */
    font-size: 64px;
    font-weight: 700;
    line-height: 1.05;
    letter-spacing: -0.02em;
    color: #ffffff;
}

.collintro__subtitle {
    margin-top: 20px;
    color: rgba(255, 255, 255, .75);
    /* REV 14: 22 px exact */
    font-size: 22px;
    line-height: 1.6;
}

/* Fade-in reveal — opacity + jemný posun zdola, jednorázový přes IO */
.collintro-reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity .7s ease, transform .7s ease;
}

.collintro__divider.collintro-reveal[data-coll-step] { transition-delay: 0ms; }
.collintro-reveal[data-coll-step="1"] { transition-delay: 80ms; }
.collintro-reveal[data-coll-step="2"] { transition-delay: 180ms; }
.collintro-reveal[data-coll-step="3"] { transition-delay: 280ms; }

.collintro-reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
    .collintro-reveal { opacity: 1; transform: none; transition: none; }
}

@media (max-width: 700px) {
    .collintro { padding: 72px 0 56px; }
    .collintro__divider { margin-bottom: 36px; }
}

.story-scroll {
    position: relative;
}

.flow-section {
    position: sticky;
    top: 0;
    height: 100vh;
    width: 100%;
    overflow: hidden;
}

.flow-inner {
    position: relative;
    min-height: 100vh;
    width: 100%;
    will-change: transform;
    transform-origin: bottom left;
}

.flow-inner .category-teaser {
    border-radius: 0;
    width: 100%;
    height: 100%;
}

.flow-inner .category-teaser__image {
    /* dvh stabilní mobilní výška (na desktopu identické s vh) */
    height: 100vh;
    height: 100dvh;
}

/* CATEGORY TEASER */
.category-teaser {
    position: relative;
    border-radius: var(--radius);
    overflow: hidden;
    color: #fff;
}

.category-teaser__image-wrap {
    position: relative;
}

.category-teaser__image {
    width: 100%;
    height: 88vh;
    object-fit: cover;
}

.category-teaser__content-wrap {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 124px 56px 56px;
    background: linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.05) 40%, rgba(0,0,0,.55));
}

.category-teaser__intro {
    max-width: 760px;
}

.category-teaser__subtitle {
    margin-top: 16px;
    font-size: var(--fs-podnadpis);
    line-height: 1.5;
    color: rgba(255, 255, 255, .85);
}

.category-teaser__head-link {
    color: #fff;
    display: inline-flex;
    align-items: center;
    gap: 20px;
}

.feature-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
    margin-top: auto;
}

.feature-item__icon {
    width: 44px;
    height: 44px;
    margin-bottom: 16px;
}

.feature-item__title {
    font-size: var(--fs-h2);
    font-weight: 700;
    margin-bottom: 8px;
}

.feature-item p {
    font-size: var(--fs-text);
    line-height: 1.5;
}

.feature-item strong {
    font-weight: 700;
}

.category-teaser-link {
    display: flex;
    align-items: center;
    gap: 16px;
    color: #fff;
    margin-top: 32px;
}

.category-teaser-link__content {
    display: flex;
    align-items: center;
    gap: 14px;
    font-size: var(--fs-podnadpis);
    font-weight: 500;
}

.category-teaser-link__img {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    object-fit: cover;
}

/* CIRCLE ICON */
.circle-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    border: 1px solid currentColor;
    font-size: 1rem;
    flex-shrink: 0;
}

.circle-icon--big {
    width: 56px;
    height: 56px;
    font-size: 1.4rem;
}

.circle-icon--white {
    border-color: #fff;
    color: #fff;
}

/* CURSOR LABEL */
.cursor {
    position: absolute;
    top: 32px;
    right: 32px;
    background: #fff;
    color: #000;
    border-radius: 66px;
    padding: 10px 22px;
    font-size: 0.9rem;
}

/* VYHODY HOTSPRING — REV 14: exact values, padding 100/100. */
.hsadv {
    background: #0e1112;
    color: #fff;
    padding: 100px 0;
    overflow: hidden;
}

.hsadv__head {
    max-width: 900px;
    margin: 0 auto 80px;
    text-align: center;
}

.hsadv__title {
    /* REV 14: 64 px exact */
    font-size: 64px;
    font-weight: 700;
    line-height: 1.05;
    letter-spacing: -0.02em;
}

.hsadv__subtitle {
    margin-top: 16px;
    /* REV 14: 22 px exact (podnadpis hsadv = subtitle pod hlavním nadpisem sekce) */
    font-size: 22px;
    color: rgba(255, 255, 255, .6);
    font-size: var(--fs-podnadpis);
}

.hsadv__rows {
    display: flex;
    flex-direction: column;
    gap: 32px;
}

.hsrow {
    /* REV 14: min-height removed (let content drive), grid 1fr|1fr gap 80 */
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
}

.hsrow[data-reverse="true"] .hsrow__text {
    order: 2;
}

.hsrow[data-reverse="true"] .hsrow__media {
    order: 1;
}

.hsrow__title {
    /* REV 14: 36 px exact */
    font-size: 36px;
    font-weight: 600;
    line-height: 1.1;
    margin-bottom: 20px;
}

.hsrow__desc {
    color: rgba(255, 255, 255, .65);
    /* REV 14: 20 px exact, line-height 1.6 */
    font-size: 20px;
    line-height: 1.6;
    max-width: 56ch;
}

.hsrow__media {
    position: relative;
    /* REV 14: width 100%, height 480, border-radius 16 */
    width: 100%;
    height: 480px;
    border-radius: 16px;
    overflow: hidden;
    opacity: 0;
    transform: translateY(20px);
    transition: opacity .7s ease, transform .7s ease;
}

.hsrow__media.is-visible {
    opacity: 1;
    transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
    .hsrow__media { opacity: 1; transform: none; transition: none; }
}

.hsrow__video,
.hsrow__img {
    width: 100%;
    border-radius: 16px;
    display: block;
    aspect-ratio: 4 / 3;
}

.hsrow__video {
    object-fit: cover;
}

.hsrow__img {
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
}

.hsadv__cta {
    text-align: center;
    margin-top: 56px;
}

/* Image comparison slider */
.imgcompare {
    position: relative;
    width: 100%;
    aspect-ratio: 4 / 3;
    border-radius: 16px;
    overflow: hidden;
    user-select: none;
    box-shadow: 0 30px 60px rgba(0, 0, 0, .45);
}

.imgcompare__img {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
}

.imgcompare__after {
    position: absolute;
    inset: 0;
    overflow: hidden;
    clip-path: inset(0 50% 0 0);
}

.imgcompare__handle {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 3px;
    background: #fff;
    left: 50%;
    transform: translateX(-50%);
    cursor: ew-resize;
    z-index: 5;
}

.imgcompare__knob {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 46px;
    height: 46px;
    border-radius: 50%;
    background: #fff;
    color: var(--accent);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.05rem;
    box-shadow: 0 4px 16px rgba(0, 0, 0, .35);
}

.imgcompare__label {
    position: absolute;
    bottom: 16px;
    padding: 6px 14px;
    border-radius: 999px;
    background: rgba(0, 0, 0, .6);
    color: #fff;
    font-size: var(--fs-maly);
    font-weight: 500;
    z-index: 4;
}

.imgcompare__label--before {
    right: 16px;
}

.imgcompare__label--after {
    left: 16px;
}

@media (max-width: 900px) {
    .hsrow {
        grid-template-columns: 1fr;
        min-height: auto;
        gap: 28px;
    }

    .hsrow[data-reverse="true"] .hsrow__text,
    .hsrow[data-reverse="true"] .hsrow__media {
        order: initial;
    }
}

/* FEATURE TABS — proč Wellness Home */
.feature-tabs__list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px;
    margin-bottom: 32px;
}

.feature-tab {
    display: flex;
    align-items: center;
    gap: 10px;
    border: 1px solid #d4e3e4;
    background: #fff;
    border-radius: 999px;
    padding: 12px 22px;
    cursor: pointer;
    font-family: inherit;
    font-size: var(--fs-button);
    color: var(--muted);
    transition: background .2s ease, color .2s ease, border-color .2s ease;
}

.feature-tab:hover {
    border-color: var(--accent);
}

.feature-tab.is-active {
    background: var(--accent);
    border-color: var(--accent);
    color: #fff;
}

.feature-tab__num {
    font-size: var(--fs-maly);
    opacity: 0.7;
}

.feature-tab__label {
    font-weight: 500;
}

.feature-tabs__panels {
    background: #f1f6f6;
    border-radius: 20px;
    padding: clamp(24px, 4vw, 64px);
}

.feature-panel {
    display: none;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    align-items: center;
}

.feature-panel.is-active {
    display: grid;
}

.feature-panel__text {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.feature-panel__badge {
    align-self: flex-start;
    border: 1px solid var(--accent);
    color: var(--accent);
    border-radius: 999px;
    padding: 4px 14px;
    font-size: var(--fs-maly);
    font-weight: 600;
}

.feature-panel__title {
    font-size: var(--fs-h2);
    font-weight: 600;
    line-height: 1.1;
    color: var(--heading);
}

.feature-panel__text p {
    color: var(--muted);
    font-size: var(--fs-podnadpis);
    line-height: 1.6;
}

.feature-panel__media {
    border-radius: 14px;
    overflow: hidden;
}

.feature-panel__video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    aspect-ratio: 1 / 1;
}

@media (max-width: 900px) {
    .feature-panel {
        grid-template-columns: 1fr;
        gap: 28px;
    }
}

/* ============================================================
   PROČ WELLNESS HOME — premium textový redesign
   Design rules (scoped jen na .proc-wh*):
   • high-end-visual-design — Soft Structuralism vibe, Editorial Split layout,
     Double-Bezel nested cards, custom cubic-bezier transitions, magnetic CTA
   • usspa-design — light bg, 4px grid spacing, single typeface (Aeonik Pro,
     current global font), nested rounded radii
   • NEMĚNÍ globální tokeny — používá pouze existing --accent, --text, --muted, --bg
   ============================================================ */

.proc-wh {
    /* REV 14: 100/100 */
    padding: 100px 0;
    background: var(--bg);
    color: var(--text);
    position: relative;
}

.proc-wh__container {
    /* REV 14: 1600 → 1400, gutter 48 */
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 48px;
}

/* === EYEBROW TAG (high-end Section 4C — microscopic pill before H2) === */
.proc-wh__eyebrow {
    display: inline-block;
    padding: 6px 14px;
    border: 1px solid rgba(0, 118, 129, 0.25);
    border-radius: 999px;
    background: rgba(0, 118, 129, 0.05);
    font-family: inherit;
    /* REV 12 2B: 11 → 14 px (čitelnější) */
    font-size: 14px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.22em;
    color: var(--accent);
    margin: 0 0 24px;
}

/* === HEAD === */
.proc-wh__head {
    text-align: center;
    max-width: 720px;
    margin: 0 auto 80px;
}

.proc-wh__title {
    font-family: inherit;
    /* REV 14: 64 px exact */
    font-size: 64px;
    font-weight: 700;
    line-height: 1.05;
    letter-spacing: -0.02em;
    color: var(--text);
    margin: 0 0 20px;
}

.proc-wh__lead {
    font-family: inherit;
    /* REV 14: 20 px exact */
    font-size: 20px;
    line-height: 1.55;
    color: var(--muted);
    margin: 0;
}

/* === STEPS LIST === */
/* REV 14: 3 kroky vedle sebe — grid repeat(3, 1fr) gap 32 */
.proc-wh__steps {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
}

.proc-wh__step {
    /* Reset list item indent */
}

/* === DOUBLE-BEZEL (high-end Section 4A — physical/haptic nested architecture).
   Outer shell = subtle tinted background with hairline border.
   Inner core = solid white card with inset highlight + concentric radius.
   On hover: subtle lift via cubic-bezier (real-world spring physics). */
.proc-wh__step-shell {
    background: rgba(0, 118, 129, 0.04);
    border: 1px solid rgba(0, 118, 129, 0.12);
    border-radius: 32px;
    padding: 6px;
    box-shadow:
        0 1px 2px rgba(0, 0, 0, 0.03),
        0 0 0 1px rgba(0, 118, 129, 0.02);
    transition:
        transform .7s cubic-bezier(0.32, 0.72, 0, 1),
        box-shadow .7s cubic-bezier(0.32, 0.72, 0, 1);
}

.proc-wh__step-shell:hover {
    transform: translateY(-2px);
    box-shadow:
        0 12px 32px rgba(0, 118, 129, 0.10),
        0 2px 6px rgba(0, 0, 0, 0.04),
        0 0 0 1px rgba(0, 118, 129, 0.04);
}

.proc-wh__step-core {
    background: #ffffff;
    /* REV 14: padding 48 (3-col steps vedle sebe → vnitřní vzduch menší) */
    border-radius: 28px;
    padding: 48px;
    box-shadow: inset 0 1px 1px rgba(255, 255, 255, 0.6);
    /* REV 14: vertikální stack (number nahoře, body dole) — 3-col layout
       vyžaduje vertical kompozici v kartě, ne split */
    display: flex;
    flex-direction: column;
    gap: 20px;
    align-items: flex-start;
}

/* === STEP NUMBER (editorial typography) === */
.proc-wh__step-num {
    font-family: inherit;
    font-size: clamp(3rem, 5vw, 4.5rem);
    font-weight: 700;
    line-height: 0.9;
    letter-spacing: -0.04em;
    color: var(--accent);
    font-variant-numeric: tabular-nums;
    user-select: none;
}

.proc-wh__step-body {
    /* Body container — left-aligned text */
}

.proc-wh__step-title {
    font-family: inherit;
    /* REV 14: 26 px exact */
    font-size: 26px;
    font-weight: 600;
    line-height: 1.2;
    letter-spacing: -0.01em;
    color: var(--text);
    margin: 0 0 16px;
}

.proc-wh__step-text {
    font-family: inherit;
    /* REV 14: 18 px exact */
    font-size: 18px;
    line-height: 1.6;
    color: var(--muted);
    margin: 0;
    max-width: 60ch;
}

/* === CTA === */
.proc-wh__cta {
    margin-top: 80px;
    text-align: center;
}

/* === MAGNETIC BUTTON (high-end Section 4B + 5B — pill + button-in-button icon + active scale) === */
.proc-wh__btn {
    display: inline-flex;
    align-items: center;
    gap: 16px;
    padding: 16px 16px 16px 28px;
    background: var(--accent);
    color: #ffffff;
    border-radius: 999px;
    text-decoration: none;
    font-family: inherit;
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: -0.005em;
    box-shadow:
        0 4px 14px rgba(0, 118, 129, 0.22),
        inset 0 1px 0 rgba(255, 255, 255, 0.12);
    transition:
        transform .4s cubic-bezier(0.32, 0.72, 0, 1),
        filter .4s cubic-bezier(0.32, 0.72, 0, 1),
        box-shadow .4s cubic-bezier(0.32, 0.72, 0, 1);
}

.proc-wh__btn:hover {
    filter: brightness(1.08);
    box-shadow:
        0 8px 22px rgba(0, 118, 129, 0.28),
        inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.proc-wh__btn:active {
    transform: scale(0.98);
}

.proc-wh__btn-label {
    line-height: 1;
}

/* Button-in-button trailing icon — kruhový wrapper flush k pravé hraně */
.proc-wh__btn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.18);
    color: #ffffff;
    transition:
        transform .4s cubic-bezier(0.32, 0.72, 0, 1),
        background .4s cubic-bezier(0.32, 0.72, 0, 1);
}

/* Magnetic hover physics — internal kinetic tension (icon translates + scales) */
.proc-wh__btn:hover .proc-wh__btn-icon {
    transform: translate(2px, -1px) scale(1.06);
    background: rgba(255, 255, 255, 0.28);
}

/* === MOBILNÍ adaptace (≤900 px) — single column, kompaktnější padding === */
@media (max-width: 900px) {
    .proc-wh {
        padding: 64px 0;
    }
    .proc-wh__container {
        padding: 0 20px;
    }
    .proc-wh__head {
        margin-bottom: 48px;
    }
    .proc-wh__eyebrow {
        font-size: 10px;
        letter-spacing: 0.2em;
        padding: 5px 12px;
        margin-bottom: 20px;
    }
    .proc-wh__steps {
        gap: 16px;
    }
    .proc-wh__step-shell {
        border-radius: 24px;
        padding: 4px;
    }
    .proc-wh__step-core {
        border-radius: 20px;
        padding: 28px 24px;
        grid-template-columns: 1fr;
        gap: 12px;
    }
    .proc-wh__step-num {
        font-size: 2.4rem;
    }
    .proc-wh__step-title {
        font-size: 1.25rem;
        margin-bottom: 10px;
    }
    .proc-wh__step-text {
        font-size: 0.9875rem;
        line-height: 1.55;
        max-width: none;
    }
    .proc-wh__cta {
        margin-top: 40px;
    }
    .proc-wh__btn {
        padding: 14px 14px 14px 22px;
        font-size: 0.95rem;
        gap: 12px;
    }
    .proc-wh__btn-icon {
        width: 28px;
        height: 28px;
    }
}

/* === PREFERS-REDUCED-MOTION — vypne hover transitions === */
@media (prefers-reduced-motion: reduce) {
    .proc-wh__step-shell,
    .proc-wh__btn,
    .proc-wh__btn-icon {
        transition: none;
    }
    .proc-wh__step-shell:hover {
        transform: none;
    }
    .proc-wh__btn:hover .proc-wh__btn-icon {
        transform: none;
    }
}

/* CONTACT */
/* .contact původně samostatná sekce — sloučena s FAQ (viz .contact-block
   uvnitř .faq). Tato pravidla zůstávají pro zpětnou kompatibilitu, ale
   v DOM už třídy .contact / .contact__grid nejsou. */
.contact {
    padding: 100px 0;
    background: var(--bg);
}

.contact__grid {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 64px;
    justify-content: space-between;
}

.contact__info {
    flex: 1 1 320px;
    max-width: 420px;
    display: flex;
    flex-direction: column;
    gap: 40px;
}

.contact__list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 10px;
    color: var(--text);
}

.contact__list span {
    font-weight: 600;
    color: var(--heading);
}

.contact__list a {
    color: var(--accent);
    text-decoration: underline;
}

.contact__form {
    flex: 1 1 480px;
    max-width: 620px;
    display: flex;
    flex-direction: column;
    gap: 20px;
    border: 1px solid #d4e3e4;
    border-radius: 8px;
    padding: 40px;
    background: #fff;
}

.form-row {
    display: flex;
    gap: 16px;
}

.form-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
    width: 100%;
}

.form-field label {
    font-size: var(--fs-maly);
    font-weight: 500;
    /* sjednoceno s FAQ textem (.faq__title, .faq__question = var(--text)) */
    color: var(--text);
}

.form-field .req {
    color: #d14233;
}

.form-field input,
.form-field textarea {
    /* REV 14: padding 16 vše, font-size 16 px (anti-iOS-zoom). */
    background: #E6EFF0;
    border: 1px solid #cdd9da;
    border-radius: 6px;
    padding: 16px;
    font-family: inherit;
    font-size: 16px;
    color: var(--text);
    width: 100%;
    transition: background-color .45s ease, border-color .45s ease;
}

.form-field textarea {
    min-height: 130px;
    resize: vertical;
}

.form-field input::placeholder,
.form-field textarea::placeholder {
    color: #8aa1a5;
}

.form-field input:focus,
.form-field textarea:focus {
    outline: none;
    border-color: var(--accent);
}

.contact__submit {
    align-self: flex-start;
    justify-content: center;
    border: none;
}

/* === Sloučená sekce FAQ + Kontakt — DVOUSLOUPCOVÝ layout === */

/* Wider container just for this section — posune sloupce blíž k okrajům. */
.faq > .container {
    max-width: 1500px;
    padding: 0 32px;
}

/* Dvousloupcový grid 50/50: VLEVO FAQ sloupec, VPRAVO kontaktní blok.
   align-items: flex-start → oba sloupce začínají na stejné horní Y. */
.faq__layout {
    /* REV 14: 2-col 1fr 1fr gap 48 — oba sloupce STEJNĚ ŠIROKÉ */
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    align-items: flex-start;
    max-width: none;
    margin: 0;
}

/* REV 14: oba sloupce stejně — width 100%, padding 48, radius 20. */
.faq__col,
.contact-block {
    width: 100%;
    background: #ffffff;
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: 20px;
    padding: 48px;
    box-sizing: border-box;
    transition: background-color .45s ease, border-color .45s ease;
}

.faq__col-head,
.contact-block__title {
    /* REV 14: 48 px exact */
    font-size: 48px;
    font-weight: 700;
    line-height: 1.15;
    letter-spacing: -0.01em;
    color: var(--text);
    margin: 0 0 12px;
}

/* Společný styl popisků pod nadpisy — identické, takže první obsah
   v každém sloupci (FAQ položka / formulářové pole) začíná na stejné Y. */
.faq__col-desc,
.contact-block__desc {
    color: var(--muted);
    font-size: var(--fs-podnadpis);
    line-height: 1.55;
    margin: 0 0 24px;
}

/* Override centrování accordionu — v grid sloupci vyplní celou šířku */
.faq__layout .faq__list {
    max-width: none;
    margin: 0;
}

/* Kontaktní blok jako pravý sloupec gridu — vyplní celou šířku cell. */
.contact-block {
    width: 100%;
}

.contact-block__head {
    text-align: left;
    margin: 0;
    max-width: none;
}

/* Formulář vyplní svůj sloupec — card styling je teď na .contact-block
   (rodičovská karta), takže form sám už nemá vlastní border/padding/bg. */
.contact-block .contact__form {
    max-width: none;
    width: 100%;
    margin: 0;
    border: 0;
    border-radius: 0;
    padding: 0;
    background: transparent;
}

/* Tlačítko submit — zachovat původní align-self: flex-start (přirozené v
   levém zarovnaném formuláři) */
.contact-block .contact__submit {
    align-self: flex-start;
}

/* Kontaktní údaje (adresa, e-mail) — pod formulářem v pravém sloupci,
   zarovnané vlevo s formulářem */
.contact-block__info {
    margin: 24px 0 0;
}

.contact-block__info .contact__list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 0;
    margin: 0;
    list-style: none;
}

/* ============================================================
   .is-blue STAV — všechny modré overrides v jednom místě.
   Aktivuje se přidáním class .is-blue na .faq sekci (skrze IO).
   Bez class = výchozí světlý vzhled (definovaný výše).
   ============================================================ */

/* Plynulý přechod color/border/bg pro všechny prvky, které mění
   barevný stav mezi světlou a modrou verzí sekce. */
.faq .faq__col-head,
.faq .contact-block__title,
.faq .faq__col-desc,
.faq .contact-block__desc,
.faq .faq__question,
.faq .form-field label,
.faq .contact__list,
.faq .contact__list span,
.faq .contact__list a,
.faq .contact-block__info,
.faq .contact__submit.btn--primary {
    transition: color .45s ease, background-color .45s ease, border-color .45s ease;
}

/* Pozadí celé sekce → HotSpring modrá */
.faq.is-blue {
    background: var(--accent);
}

/* Karty: subtle light overlay nad modrou + černý border */
.faq.is-blue .faq__col,
.faq.is-blue .contact-block {
    background: rgba(255, 255, 255, .08);
    border-color: #000;
}

/* FAQ položky (bílé tiles inside blue card) — border čistě černý */
.faq.is-blue .faq__item {
    border-color: #000;
}
.faq.is-blue .faq__item.is-open {
    border-color: #000;
    box-shadow: 0 6px 18px rgba(0, 0, 0, .15);
}

/* +/− symbol u otázek — z accent na černý */
.faq.is-blue .faq__icon::before,
.faq.is-blue .faq__icon::after {
    background: #000;
}

/* Formulářová pole — bílé pozadí, černý border (max kontrast vůči modré) */
.faq.is-blue .form-field input,
.faq.is-blue .form-field textarea {
    background: #ffffff;
    border-color: #000;
}
.faq.is-blue .form-field input:focus,
.faq.is-blue .form-field textarea:focus {
    border-color: #000;
    box-shadow: 0 0 0 2px rgba(0, 0, 0, .15);
}

/* Texty — VŠECHNO na černou (proti modré ploše čitelné) */
.faq.is-blue .faq__col-head,
.faq.is-blue .contact-block__title,
.faq.is-blue .form-field label,
.faq.is-blue .contact__list,
.faq.is-blue .contact__list span,
.faq.is-blue .contact-block__info {
    color: var(--text);
}

.faq.is-blue .faq__col-desc,
.faq.is-blue .contact-block__desc {
    color: var(--text);
    opacity: 0.85;
}

/* Odkazy v kontaktním listu (email/telefon) — z accent na černou + podtržení */
.faq.is-blue .contact__list a {
    color: var(--text);
    text-decoration: underline;
}

/* Hover otázky FAQ — místo accent (modré na modré splývá) decentní opacity */
.faq.is-blue .faq__question:hover {
    color: var(--text);
    opacity: 0.7;
}

/* Submit tlačítko — z modré (.btn--primary) na bílé pozadí / černý text */
.faq.is-blue .contact__submit.btn--primary {
    background: #ffffff;
    color: var(--text);
    border: 1px solid #000;
}
.faq.is-blue .contact__submit.btn--primary:hover {
    background: #f1f1f1;
}

/* MOBIL — dva sloupce se složí pod sebe. Pořadí: FORMULÁŘ nahoře
   (hlavní cíl / leady), FAQ pod ním. DOM order je FAQ first / form
   second, takže na mobilu prohazujeme přes CSS `order`. */
@media (max-width: 900px) {
    .faq > .container { padding: 0 20px; }
    .faq__layout {
        grid-template-columns: 1fr;
        gap: 28px;
    }
    .faq__col,
    .contact-block { padding: 28px; }
    .faq__layout .contact__form { padding: 0; }
    .faq__layout .contact-block { order: 1; }
    .faq__layout .faq__col      { order: 2; }
}

/* FOOTER */
/* Celý footer má modré pozadí — žádné bílé štěrbiny mezi map a bar. */
.footer {
    background: var(--accent);
}

/* Sekce s mapou showroomu — HotSpring modré pozadí, návazně na modrou
   FAQ+formulář sekci výše. Iframe Google Maps má vlastní vnitřní vzhled
   (nepřemalovatelný), framework kolem je modrý. */
.footer__map {
    padding: 48px 0;
    background: var(--accent);
    color: #ffffff;
}

/* SHINE BORDER */
.shine-border {
    position: relative;
    border-radius: 12px;
    padding: 4px;
    background: var(--bg);
    line-height: 0;
}

.shine-border::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    padding: 4px;
    background-image: radial-gradient(transparent, transparent, #007681, transparent, transparent);
    background-size: 300% 300%;
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    mask-composite: exclude;
    will-change: background-position;
    animation: shine 14s infinite linear;
    pointer-events: none;
}

@keyframes shine {
    0% { background-position: 0% 0%; }
    50% { background-position: 100% 100%; }
    100% { background-position: 0% 0%; }
}

.shine-border iframe {
    display: block;
    width: 100%;
    border-radius: 8px;
}

/* Footer bar — HotSpring modré pozadí, ČERNÝ text adresy + ikon
   (vysoký kontrast vůči modré ploše). Nad ním je tmavá oddělovací linka. */
.footer__bar {
    background: var(--accent);
    color: var(--text);  /* ČERNÁ text v celém footer baru */
    padding: 20px 0;
    border-top: 1px solid #000;  /* ČERNÁ oddělovací linka, viditelná na modré */
}

.footer__bar-inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 16px 24px;
    justify-content: space-between;
}

.footer__addr {
    color: var(--text);  /* ČERNÁ — kontrast na modré */
    font-size: var(--fs-maly);
}

.footer__socials {
    display: flex;
    gap: 12px;
    align-items: center;
}

/* Sociální ikony — outline kruh s ČERNÝM borderem + ČERNÁ ikona uvnitř
   (vidět na modré). Hover: výplň ČERNÁ, ikona modrá (HotSpring accent),
   jasná inverze + scale 1.12 pro feedback. */
.footer__social {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1.5px solid #000;
    color: #000;
    transition: transform .2s ease, background-color .2s ease,
                color .2s ease, border-color .2s ease;
}

.footer__social:hover,
.footer__social:focus-visible {
    transform: scale(1.12);
    background: #000;
    color: var(--accent);  /* ikona HotSpring modrá na černé výplni */
    border-color: #000;
    outline: none;
}

@media (max-width: 700px) {
    .footer__bar-inner {
        justify-content: center;
        text-align: center;
        gap: 14px;
    }
}

/* RESPONSIVE */
@media (max-width: 900px) {
    .container { padding: 0 20px; }
    /* Mobil — logo blíž k levému okraji (8 px), pravý padding 20 px. */
    .nav { padding: 8px 20px 8px 8px; position: relative; }

    /* HAMBURGER — viditelný jen na mobilu/tabletu, 44 × 44 px touch target. */
    .nav__toggle {
        display: inline-flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 5px;
        width: 44px;
        height: 44px;
        background: transparent;
        border: 0;
        padding: 0;
        cursor: pointer;
    }
    .site-header.at-top .nav__toggle-bar {
        background: #ffffff;
    }
    /* Hamburger → "X" když je menu otevřené */
    .site-header.menu-open .nav__toggle-bar:nth-child(1) {
        transform: translateY(7px) rotate(45deg);
    }
    .site-header.menu-open .nav__toggle-bar:nth-child(2) {
        opacity: 0;
    }
    .site-header.menu-open .nav__toggle-bar:nth-child(3) {
        transform: translateY(-7px) rotate(-45deg);
    }

    /* MOBILNÍ MENU — FULLSCREEN PANEL.
       Wrapper .nav__panel přepneme z desktop display:contents na fixed
       overlay přes celou obrazovku. 100dvh fallback 100vh — žádné
       prosvítání obsahu pod menu. Default hidden (translateX 100% mimo
       obrazovku zprava); .menu-open ho přivolá. */
    .nav__panel {
        display: flex;
        flex-direction: column;
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        height: 100vh;
        height: 100dvh;
        background: #ffffff;
        z-index: 30;                  /* nad headerem, který má z-index: 20 */
        transform: translateX(100%);
        transition: transform .3s ease;
        overflow-y: auto;             /* dlouhé menu by mělo scrollovat uvnitř */
    }
    .site-header.menu-open .nav__panel {
        transform: translateX(0);
    }

    /* Hlavička panelu — logo vlevo, zavírací křížek vpravo. Nahrazuje
       "prázdný bílý blok" který vznikal kvůli position:absolute top:100%. */
    .nav__panel-head {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 12px 16px;
        border-bottom: 1px solid rgba(0, 0, 0, .08);
    }
    .nav__panel-logo {
        display: flex;
        align-items: center;
    }
    /* Menší logo v panelu — ať se vejde do horního pruhu (60% velikosti
       header loga). Logo SVG sample je 150×72, tady 100×48. */
    .nav__panel-logo .logo-wh {
        /* 84×40 = přesně 25% nativní 336×160 PNG → exact integer downsample */
        height: 40px;
        width: 84px;
        image-rendering: -webkit-optimize-contrast;
        image-rendering: high-quality;
    }
    /* Zavírací křížek — 44×44 touch target, tmavý ostrý × */
    .nav__close {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 44px;
        height: 44px;
        background: transparent;
        border: 0;
        padding: 0;
        cursor: pointer;
        color: #1a1a1a;
        font-size: 32px;
        line-height: 1;
        font-weight: 400;
    }
    .nav__close:hover,
    .nav__close:focus-visible {
        color: var(--accent);
        outline: none;
    }

    /* Menu list — ostré odkazy bez jakéhokoli text-shadow */
    .nav__menu {
        display: flex;
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        list-style: none;
        margin: 0;
        padding: 8px 0;
        font-size: 1.15rem;
        background: transparent;
        box-shadow: none;
    }
    .nav__menu li {
        list-style: none;
    }
    .nav__menu a {
        display: block;
        padding: 16px 24px;
        border-radius: 0;
        color: #1a1a1a;
        text-shadow: none !important;  /* eliminuje text-shadow leak z .site-header.at-top .nav__menu a */
        font-weight: 500;
    }
    .nav__menu a:hover,
    .nav__menu a:focus-visible {
        background: rgba(0, 118, 129, .08);
        color: var(--accent);
        outline: none;
    }
    /* Override at-top stavu — panel má vlastní bílý fullscreen,
       text musí být tmavý a OSTRÝ (žádný text-shadow z hero stylu). */
    .site-header.at-top .nav__menu a {
        color: #1a1a1a;
        text-shadow: none !important;
    }

    .hero__inner { padding: 0 20px; }
    .hero__text { max-width: 100%; font-size: 1rem; line-height: 1.5; }

    /* Hero CTA tlačítka — vedle sebe na jednom řádku, stejně široká,
       stejně vysoká, menší padding/font, žádný wrap (přetékají by způsobily
       horizontální scroll → min-width: 0 + flex: 1 zaručí, že se vejdou). */
    .hero__actions {
        flex-direction: row;
        flex-wrap: nowrap;
        align-items: stretch;
        gap: 10px;
        margin-top: 24px;
    }
    .hero__actions .btn {
        flex: 1 1 0;
        min-width: 0;
        height: auto;
        padding: 12px 16px;
        font-size: 0.9rem;
        line-height: 1.25;
        text-align: center;
        justify-content: center;
        white-space: normal;
    }

    /* MOBILNÍ VIDEO swap — !important brání tomu, aby cokoli z desktop
       cascadu přebilo (např. .hero__media video element selector v starších
       verzích). Desktop video pryč, mobilní vyplní celou plochu hero. */
    .hero__video--desktop { display: none !important; }
    .hero__video--mobile { display: block !important; }

    /* Hero text — zmenšení pro mobilní viewport */
    .hero__head {
        font-size: clamp(2rem, 8vw, 3rem);
        line-height: 1.05;
        max-width: 100%;
    }
    /* Why mobile — žádný negativní margin (odstraněn starý hack).
       Mezera k Trust baru je řízena pouze přes .trustbar margin-bottom (40px). */
    .why {
        padding: 0 0 60px;
        margin-top: 0;
    }
    .why__inner { grid-template-columns: 1fr; gap: 28px; }
    .why__col--media { order: 2; max-height: 420px; }
    .why__col--text { align-self: stretch; }
    /* Jetsetter LX mobil — swipe carousel + kompaktnější mezery uvnitř slidů */
    .jetsetter { padding: 56px 0; }
    .jetsetter__head { margin-bottom: 24px; }

    /* === CAROUSEL — aktivní na mobilu ===
       Break out of .container's 20px side padding (margin: 0 -20px)
       → carousel spans plnou šířku viewportu (380 px na 380 viewport).
       Tím .jetsetter__plan (top-view vířivky) na slidu 2 dostane plnou
       380×380 px velikost a stane se dominantním prvkem slidu.
       Slide 1 vířivka zboku natural ratio 16:9 → 380×~213 (jen plnější
       horizontal space, žádné cropping). */
    .jet-carousel {
        display: block;
        overflow: hidden;
        width: auto;
        margin-left: -20px;
        margin-right: -20px;
        transition: height .3s ease;
    }
    .jet-track {
        display: flex;
        align-items: flex-start;   /* slidy NESTREČUJÍ — každý vlastní výška */
        transition: transform .3s ease;
        will-change: transform;
    }
    .jet-slide {
        display: block;
        flex: 0 0 100%;
        min-width: 0;
        box-sizing: border-box;
        padding: 0 4px;
    }

    /* Dots indikátor — viditelný jen na mobilu */
    .jet-dots {
        display: flex;
        justify-content: center;
        gap: 10px;
        margin-top: 20px;
    }
    .jet-dot {
        width: 8px;
        height: 8px;
        border-radius: 50%;
        border: 0;
        padding: 0;
        background: rgba(0, 118, 129, .25);
        cursor: pointer;
        transition: background .2s ease, transform .2s ease;
    }
    .jet-dot.is-active {
        background: var(--accent);
        transform: scale(1.25);
    }

    /* Sekce — víc místa nahoře nad nadpisem, rozumný gap k carouselu */
    .jetsetter { padding-top: 36px; }
    .jetsetter__head { margin-bottom: 28px; }

    /* Slidy bez bočního paddingu — využijí plnou šířku viewport-wide
       carouselu (380 px na 380 viewport). Top padding 8 px pro vzdušnost. */
    .jet-slide { padding: 8px 0; }

    /* SLIDE 1 — pořadí: obrázek vířivky NAHOŘE, text/tabulka/CTA pod ním.
       Flex column + order swap (žádná HTML změna). Gap 24 px = mezera mezi
       obrázkem a textovou kartou. */
    .jetsetter__intro {
        display: flex;
        flex-direction: column;
        gap: 24px;
        margin-bottom: 0;
    }
    .jetsetter__intro-media { order: 1; }
    .jetsetter__intro-text  { order: 2; max-width: 100%; }

    /* SLIDE 1 — popisný odstavec SKRYTÝ na mobilu (zůstává na desktopu).
       Tabulka + CTA + obrázek dělají hlavní info. */
    .jetsetter__intro-lead { display: none; }

    /* SLIDE 1 — vířivka zboku VRÁCENA do původního stavu: width 100%,
       height auto (přirozený poměr 16:9 z 1240×697 zdroje). Žádné
       aspect-ratio, žádný object-fit cover, žádné ořezávání. Obrázek
       celý, neoříznutý, v přirozené velikosti. */
    .jetsetter__side {
        width: 100%;
        max-width: 100%;
        height: auto;
    }

    /* SLIDE 1 — KOMPAKTNÍ tabulka specs (menší padding + menší font).
       Místo vzdušné se vrátíme k těsnější — uvolní prostor pro velký obrázek. */
    .jetsetter__specs-row {
        padding: 9px 14px;
        font-size: 0.85rem;
    }
    .jetsetter__specs {
        margin-bottom: 20px;
    }

    /* SLIDE 1 — CTA na plnou šířku */
    .jetsetter__intro-cta { width: 100%; justify-content: center; }

    .jetsetter__intro-text.jet-glow { padding: 22px 22px; }

    /* SLIDE 2 — layout single column, hotspot plan + panel karty */
    .jetsetter__layout { grid-template-columns: 1fr; gap: 20px; }
    .jetsetter__plan { width: 100%; max-width: 100%; }

    /* SLIDE 2 — KARTA SEDADLA (.jetsetter__panel):
       Předchozí mobile mělo `min-height: 336px` + `overflow: hidden` (z desktop
       .jet-glow) + silueta 280 px → text se vůbec nevešel a byl ořezán.
       Fix: panel + seat na mobilu rostou s obsahem (žádný fixed min-height,
       overflow visible), silueta zmenšena na 160 px max → na text zbude
       dost místa pro nadpis + popis + 3 odrážky. */
    .jetsetter__panel {
        min-height: 0;
        height: auto;
        max-width: 100%;
        width: 100%;
        margin-right: 0;
        margin-left: 0;
    }
    .jetsetter__panel.jet-glow {
        min-height: 0;
        height: auto;
        padding: 20px 18px;
        width: 100%;
        overflow: visible;       /* zruší desktop overflow:hidden → text není ořezán */
    }
    .jetsetter__panel.jet-glow .jetsetter__seat { right: 0; }

    /* Karta sedadla — position: static (z absolute), aktivní karta roste
       s obsahem v normálním flow. Neaktivní jsou display:none (z desktopu),
       neberou místo. */
    .jetsetter__seat {
        position: static;
        grid-template-columns: 1fr;
        gap: 14px;
    }
    /* Silueta postavy — zvětšena na 260 px max (z 220). Karta jet-glow
       má overflow:visible + height:auto → veškerý text karty (nadpis,
       sub, summary, 3× odrážka) zůstává viditelný i s větší siluetou. */
    .jetsetter__seat-body {
        width: 100%;
        height: auto;
        max-height: 260px;
    }
    .jetsetter__seat-body img {
        height: auto;
        max-height: 260px;
        width: auto;
    }
    /* .jetsetter__seat-title font-size řízen --fs-h2 (clamp) */
    /* Mobil — hotspot 44×44 px (≥ touch target standard, vizuálně dobře vidět).
       Desktopová velikost 38×38 px zůstává mimo media query beze změny. */
    .jetsetter__hotspot { width: 44px; height: 44px; font-size: 1.2rem; }
    .jetsetter__hotspot::before { inset: 0; }
    /* Highlife na mobilu — STATICKÁ sekce, žádný pinned scroll efekt.
       Pokus o zapnutí reveal efektu na mobilu byl revertován — drží se
       klidný layout: nadpis nahoře → vířivka → 3 features pod sebou.
       flex-direction: column a mobilně zmenšený nadpis ZACHOVÁNY. */
    .highlife { height: auto; --hl-p: 1; }
    .highlife__sticky {
        position: static;
        height: auto;
        min-height: 0;
        padding: 60px 20px;
        flex-direction: column;     /* drží title a stage pod sebou */
        align-items: stretch;
        justify-content: flex-start;
        overflow: visible;
        gap: 32px;
    }
    .highlife__title {
        font-size: clamp(2.2rem, 8vw, 3rem);  /* mobilně menší nadpis ZACHOVÁN */
        transform: none;
        margin-bottom: 0;
    }
    .highlife__stage {
        position: static;
        opacity: 1;
        transform: none;
        padding: 0;
        gap: 28px;
    }
    .highlife__image { max-height: none; }
    .highlife__features { grid-template-columns: 1fr; gap: 20px; }
    /* === TRUCK SCROLL SEQUENCE — mobilní override ===
       Desktop má .truckseq__sticky { top: calc(100vh - 35vw); height: 35vw }.
       Na portrait mobile je 35vw jen ~133px — kamion byl maličký proužek
       nalepený skoro na dně. Předchozí fix (top:58vh, height:42vh) řešil
       velikost, ale kamion byl pořád dole + velká bílá díra pod wave textem.

       Nyní: top: 32vh — kamion sedí TĚSNĚ POD usazeným wave textem.
       Wave text (sticky top 2vh, 3 řádky × clamp(2.2-3.4rem) font 1.45 LH)
       končí kolem 23-28vh od top viewportu (podle výšky zařízení) →
       top: 32vh dává malou mezeru 4-9vh pod textem.
       height: 42vh ponechán — kamion výrazný.
       top + height = 32vh + 42vh = 74vh — pod truck zbývá 26vh vzduchu,
       nesahá pod spodní hranu viewportu. */
    .truckseq__sticky {
        top: 24vh;
        height: 42vh;
    }

    /* Trust bar mobile — VYSTŘEDĚNO mezi Hero a "Proč vířivka".
       Margin-top 40 = margin-bottom 40 → stejná vizuální mezera nad i pod.
       Padding 32 0 (vnitřní spacing trustbar marquee) zachován. */
    .trustbar { padding: 32px 0; margin: 40px 0; background: transparent; border: 0; }
    .trustbar__track { animation-duration: 22s; }
    .trustbar__group { gap: 24px; padding-right: 24px; }
    .trustbar .trustbar__logo { height: 66px; width: auto; }
    .trustbar__text { font-size: 1.85rem; }
    .trustbar__sep { font-size: 2rem; }
    /* Hero na mobilu — žádný padding-top.
       Předchozí `.hero { padding: 130px 0 70px }` rezervoval prostor pro
       viditelný header. Nyní header je `transform: translateY(-100%)`
       mimo obrazovku na `.at-top`, takže 130 px nahoře nic nerezervuje —
       jen tam prosvítalo bílé pozadí body skrz průhlednou `.hero`.
       Padding: 0 → video začíná na úplném vrchu obrazovky.
       Plus tmavý fallback background pro případ pomalého načtení videa
       (kdyby ani poster nestihl, uživatel neuvidí bílou plochu). */
    .hero {
        padding: 0;
        background: #000;
    }
    .col-3, .col-5, .col-6, .col-9 { grid-column: span 12; }
    .col-start-7 { grid-column-start: auto; }
    /* === KOLEKCE HOTSPRING — mobilní rework ===
       Card efekt (sticky pin + GSAP rotace) je VYPNUTÝ — viz JS guard.
       Tady přepisujeme CSS na prostý vertikální blokový layout:
       - sekce není sticky, height auto
       - flow-inner žádný transform, žádné min-height 100vh
       - obrázek čtvercový 1:1, object-fit: contain (celá vířivka)
       - rámeček obrázku se světle šedým pozadím (vyplní letterbox kolem contain)
       - text v karty pod obrázkem v normal flow, ne absolute overlay
       - 20 px mezera mezi kartami */
    .story-scroll {
        padding: 0 20px;       /* boční padding pro karty uvnitř */
    }
    .flow-section {
        position: static;
        height: auto;
        overflow: visible;
        margin-bottom: 20px;   /* mezera mezi kartami */
    }
    .flow-section:last-child { margin-bottom: 0; }
    .flow-inner {
        position: static;
        min-height: 0;
        transform: none !important;   /* defenzivně vůči GSAP inline transformům */
        will-change: auto;
    }
    .flow-inner .category-teaser,
    .category-teaser {
        position: static;
        display: block;
        width: 100%;
        height: auto;
        border-radius: 12px;
        overflow: hidden;
        border: 1px solid #d4e3e4;
        background: #ffffff;
        color: var(--text);
    }
    .category-teaser__image-wrap {
        position: relative;
        /* aspect-ratio: 1/1 ODSTRANĚN — wrapper se přizpůsobí výšce
           obrázku v jeho přirozeném 16:9 poměru. Žádný šedý letterbox. */
        overflow: hidden;
    }
    .flow-inner .category-teaser__image,
    .category-teaser__image {
        width: 100%;
        height: auto;                   /* přirozený poměr 16:9, plná šířka karty */
        object-fit: initial;            /* zrušit cover/contain — obrázek se zobrazí přirozeně */
        display: block;
    }
    /* "Objevit" floating label uvnitř card image — na mobile bez hover smyslu, skrýt */
    .category-teaser .cursor {
        display: none;
    }
    /* Text karty — v normal flow pod obrázkem, ne absolute overlay */
    .flow-inner .category-teaser__content-wrap,
    .category-teaser__content-wrap {
        position: static;
        inset: auto;
        display: block;
        padding: 20px 20px 24px;
        background: transparent;
        color: var(--text);
    }
    .category-teaser__head-link {
        color: var(--text);
        text-decoration: none;
    }
    .category-teaser-link {
        color: var(--text);
        text-decoration: none;
        display: inline-block;
        margin-top: 12px;
    }
    .category-teaser-link__content {
        color: var(--text);
    }
    .flow-inner .feature-list { grid-template-columns: 1fr; gap: 14px; }
    .feature-list { grid-template-columns: 1fr; }
    .why { grid-template-columns: 1fr; }
    .why__media { position: static; }
    .contact { padding: 70px 0; }
    .contact__grid { gap: 40px; }
    .contact__form { padding: 24px; }
    .form-row { flex-direction: column; gap: 20px; }
}

/* ============================================================================
   MOBILNÍ REDESIGN — sjednocená vrstva (Minimalistic + Futuristic)
   ============================================================================
   Aplikuje se jen na ≤900 px (90 % traffic). Desktop NESAHAT.
   Vše pod tímto bodem přepíše dřívější mobilní pravidla díky pořadí v souboru.

   Vizuální jazyk:
   - Jediný font: Aeonik Pro (Regular 400, Medium 500, Bold 700)
   - Hairline: 1px rgba(11,17,21,0.08)
   - Radii: 20 outer / 14 inner / 9999 pill / 14 inputy
   - Spacing 4px grid: sekce 64px V padding, container 20px H padding
   - Žádné stíny kromě jediného floating CTA glow
   - Motion: cubic-bezier(0.32, 0.72, 0, 1), 300/500/800ms
   - Transform + opacity only (GPU safe)
*/
@media (max-width: 900px) {
    :root {
        /* Sjednocená mobilní typo škála — 3 váhy Aeonik Pro */
        --fs-hero:      clamp(2.4rem, 9vw, 3rem);
        --fs-h1:        clamp(2rem, 7.5vw, 2.5rem);
        --fs-h2:        clamp(1.4rem, 5vw, 1.7rem);
        --fs-podnadpis: 1.05rem;
        --fs-text:      1rem;
        --fs-maly:      0.875rem;
        --fs-eyebrow:   0.6875rem; /* 11px */
        --fs-button:    0.9375rem; /* 15px */

        /* Akcent + hairline tokeny pro mobile vrstvu — REV 2 vizuální jazyk */
        --hairline:        rgba(11, 17, 21, 0.08);   /* default karty, dividers */
        --hairline-strong: rgba(11, 17, 21, 0.14);   /* inputy, focusable */
        --hairline-accent: rgba(0, 118, 129, 0.32);  /* :hover / :active / open */
        --ring-halo:       0 0 0 3px rgba(0, 118, 129, 0.12);
        --halo-flash:      0 0 0 4px rgba(0, 118, 129, 0.18);

        --accent-soft:   rgba(0, 118, 129, 0.08);    /* badge pilly */
        --accent-mid:    rgba(0, 118, 129, 0.18);    /* press/hover bg */
        --ice:           #cfe1e4;
        --surface:       #f7f8f9;
        --surface-press: #eef2f3;

        --ink:          #0b1115;
        --ink-soft:     #101418;
        --ink-muted:    #5a7378;
    }

    /* Globální typo pravidla pro mobil */
    body {
        font-family: 'Aeonik Pro', system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
        font-weight: 400;
        line-height: 1.55;
        color: var(--ink-soft);
    }

    h1, h2, h3 {
        font-family: 'Aeonik Pro', system-ui, sans-serif;
        font-weight: 700;
        letter-spacing: -0.02em;
        line-height: 1.05;
        color: var(--ink);
    }

    /* Univerzální mobilní eyebrow chip — futuristický mono detail
       v minimalistickém balení. Použít jako .m-eyebrow class. */
    .m-eyebrow {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        font-family: 'Aeonik Pro', system-ui, sans-serif;
        font-size: var(--fs-eyebrow);
        font-weight: 500;
        letter-spacing: 0.22em;
        text-transform: uppercase;
        color: var(--ink-muted);
        font-feature-settings: "tnum";
    }
    .m-eyebrow::before {
        content: "";
        display: block;
        width: 24px;
        height: 1px;
        background: var(--hairline-strong);
    }

    /* Mono caption — drobný technický detail pod text bloky */
    .m-mono {
        font-family: 'Aeonik Pro', system-ui, sans-serif;
        font-size: var(--fs-maly);
        font-weight: 400;
        font-feature-settings: "tnum";
        color: var(--ink-muted);
        letter-spacing: 0.01em;
    }

    /* Globální reveal pravidla (jen opacity + transform, GPU-safe) */
    .fade-in {
        transform: translateY(16px);
        transition: opacity 600ms cubic-bezier(0.32, 0.72, 0, 1),
                    transform 600ms cubic-bezier(0.32, 0.72, 0, 1);
    }

    /* ===== REV 2 HELPER TŘÍDY =====
       Jeden vizuální jazyk — sjednocené reveal + tap haptika + accent stripe.
       Použité napříč všemi sekcemi (kromě Trucku). */

    /* .lift — quiet stagger reveal. Stagger přes inline style="--i:0|1|2|3".
       JS IIFE přidá .is-in když element vstoupí do viewportu (IntersectionObserver). */
    .lift {
        opacity: 0;
        transform: translateY(18px);
        transition: opacity 700ms cubic-bezier(0.32, 0.72, 0, 1),
                    transform 700ms cubic-bezier(0.32, 0.72, 0, 1);
        transition-delay: calc(var(--i, 0) * 80ms);
        will-change: opacity, transform;
    }
    .lift.is-in {
        opacity: 1;
        transform: none;
        will-change: auto;
    }

    /* .tap-respond — univerzální tap haptika (scale 0.97 na :active).
       Karta-link variant: na .tap-respond--card mění bg + border. */
    .tap-respond {
        transition: transform 140ms cubic-bezier(0.32, 0.72, 0, 1),
                    background-color 140ms cubic-bezier(0.32, 0.72, 0, 1),
                    border-color 140ms cubic-bezier(0.32, 0.72, 0, 1),
                    box-shadow 140ms cubic-bezier(0.32, 0.72, 0, 1);
    }
    .tap-respond:active {
        transform: scale(0.97);
    }
    .tap-respond--card:active {
        background-color: var(--surface-press);
        border-color: var(--hairline-accent);
    }

    /* Halo flash na primary buttonech — jeden pattern napříč webem. */
    .btn--primary:active,
    .contact__submit:active,
    .proc-wh__btn:active {
        box-shadow: var(--halo-flash);
    }

    /* Magnetic icon — :active posune ikonku v buttonu doprava. */
    .btn--primary:active .chevron,
    .btn--primary:active .btn__icon,
    .contact__submit:active .contact__submit-icon,
    .proc-wh__btn:active .proc-wh__btn-icon {
        transform: translateX(3px);
    }

    /* .accent-stripe — 2 px teal vertikální stripe na levé hraně. JEN dvě místa:
       FAQ open item + Proc-WH krok 02. */
    .accent-stripe {
        position: relative;
    }
    .accent-stripe::before {
        content: "";
        position: absolute;
        left: 0;
        top: 0;
        bottom: 0;
        width: 2px;
        background: var(--accent);
        border-radius: 2px;
        transform: scaleY(0);
        transform-origin: top;
        transition: transform 250ms cubic-bezier(0.32, 0.72, 0, 1);
    }
    .accent-stripe.is-on::before,
    .accent-stripe.faq__item.is-open::before {
        transform: scaleY(1);
    }

    /* ===== HERO (3.1) ===== */
    .hero__head {
        font-size: var(--fs-hero);
        font-weight: 700;
        line-height: 1.05;
        letter-spacing: -0.025em;
    }
    .hero__text {
        font-size: var(--fs-podnadpis);
        font-weight: 500;
        line-height: 1.35;
    }
    .hero__actions {
        flex-direction: column !important;
        gap: 12px !important;
        width: 100%;
        max-width: 360px;
        margin: 24px auto 0 !important;
    }
    .hero__actions .btn--lg {
        width: 100%;
        flex: 0 0 auto !important;
        min-height: 52px;
        padding: 14px 22px !important;
        font-size: var(--fs-button) !important;
        font-weight: 500 !important;
        letter-spacing: 0;
        border-radius: 9999px;
    }
    .hero__actions .btn--ghost {
        background: rgba(255, 255, 255, 0.06);
        border: 1px solid rgba(255, 255, 255, 0.32);
        color: #ffffff;
        backdrop-filter: blur(4px);
        -webkit-backdrop-filter: blur(4px);
    }
    .hero__actions .chevron {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 24px;
        height: 24px;
        margin-left: 6px;
        border-radius: 9999px;
        background: rgba(255, 255, 255, 0.18);
        font-size: 14px;
        line-height: 1;
        transform: translateY(-1px);
    }

    .hero__micro {
        margin: 14px auto 0;
        font-family: 'Aeonik Pro', system-ui, sans-serif;
        font-size: 0.75rem;
        font-weight: 500;
        letter-spacing: 0.18em;
        text-transform: uppercase;
        color: rgba(255, 255, 255, 0.78);
        font-feature-settings: "tnum";
        display: inline-flex;
        align-items: center;
        gap: 8px;
        justify-content: center;
        text-align: center;
    }
    .hero__micro-dot {
        opacity: 0.55;
    }

    /* Trust řádek pod CTA — prostý text, 3 signály oddělené tnum dot.
       Žádné ikony, žádná hairline kapsulka. Aeonik Regular 12 px. */
    .hero__trust {
        margin: 12px auto 0;
        font-family: 'Aeonik Pro', system-ui, sans-serif;
        font-size: 12px;
        font-weight: 400;
        letter-spacing: 0.04em;
        color: rgba(255, 255, 255, 0.82);
        font-feature-settings: "tnum";
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        align-items: center;
        gap: 8px;
        text-align: center;
        max-width: 360px;
    }
    .hero__trust-sep {
        color: var(--accent);
        opacity: 0.85;
        font-size: 14px;
        line-height: 1;
    }

    /* ===== FAQ + FORMULÁŘ (3.12) — anti-iOS-zoom + premium inputy ===== */
    .contact-block {
        padding: 24px !important;
        border-radius: 20px !important;
    }
    .contact-block__title {
        font-size: var(--fs-h1);
        font-weight: 700;
        letter-spacing: -0.02em;
        line-height: 1.08;
    }
    .contact-block__desc {
        font-size: var(--fs-text);
        line-height: 1.55;
    }
    .form-row {
        gap: 14px !important;
    }
    .form-field label {
        font-size: var(--fs-maly);
        font-weight: 500;
        color: var(--ink);
        margin-bottom: 6px;
        letter-spacing: 0;
    }
    .form-field .req {
        color: var(--accent);
        font-weight: 500;
    }
    .form-field input,
    .form-field textarea {
        background: #ffffff;
        border: 1px solid var(--hairline-strong);
        border-radius: 14px;
        padding: 14px 16px;
        min-height: 48px;
        font-size: 16px; /* iOS no-zoom guard */
        font-weight: 400;
        color: var(--ink-soft);
        transition: border-color 200ms cubic-bezier(0.32, 0.72, 0, 1),
                    box-shadow 200ms cubic-bezier(0.32, 0.72, 0, 1);
    }
    .form-field textarea {
        min-height: 120px;
        line-height: 1.5;
    }
    .form-field input:focus,
    .form-field textarea:focus {
        outline: none;
        border-color: var(--accent);
        box-shadow: 0 0 0 3px rgba(0, 118, 129, 0.14);
    }

    /* SUBMIT button — button-in-button stylem */
    .contact__submit {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 12px;
        width: 100%;
        min-height: 52px;
        padding: 14px 18px 14px 22px !important;
        border-radius: 9999px !important;
        font-family: 'Aeonik Pro', system-ui, sans-serif;
        font-size: var(--fs-button) !important;
        font-weight: 500 !important;
        letter-spacing: 0 !important;
        background: var(--accent) !important;
        color: #ffffff !important;
        border: none !important;
        box-shadow: 0 4px 14px rgba(0, 118, 129, 0.22);
        transition: transform 200ms cubic-bezier(0.32, 0.72, 0, 1),
                    background 200ms cubic-bezier(0.32, 0.72, 0, 1);
    }
    .contact__submit:active {
        transform: scale(0.98);
    }
    .contact__submit-icon {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 28px;
        height: 28px;
        border-radius: 9999px;
        background: rgba(255, 255, 255, 0.18);
        flex-shrink: 0;
    }

    /* Pod-formulářová assure-věta — mono caption pattern */
    .contact__assure {
        margin: 14px 0 0;
        font-family: 'Aeonik Pro', system-ui, sans-serif;
        font-size: var(--fs-maly);
        font-weight: 400;
        font-feature-settings: "tnum";
        color: var(--ink-muted);
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        align-items: center;
        gap: 8px;
        text-align: center;
        letter-spacing: 0.01em;
    }
    .contact__phone {
        color: var(--accent);
        text-decoration: none;
        font-weight: 500;
        border-bottom: 1px solid rgba(0, 118, 129, 0.35);
        padding-bottom: 1px;
    }

    /* is-blue scope override — když je FAQ sekce v modrém režimu,
       inputy si drží bílé pozadí, jen text/labely se přebarví. */
    .faq.is-blue .form-field input,
    .faq.is-blue .form-field textarea {
        background: #ffffff;
        border-color: rgba(255, 255, 255, 0.18);
        color: var(--ink-soft);
    }
    .faq.is-blue .form-field input:focus,
    .faq.is-blue .form-field textarea:focus {
        border-color: #ffffff;
        box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.18);
    }
    .faq.is-blue .form-field label,
    .faq.is-blue .contact-block__title {
        color: #ffffff;
    }
    .faq.is-blue .contact__assure {
        color: rgba(255, 255, 255, 0.78);
    }
    .faq.is-blue .contact__phone {
        color: #ffffff;
        border-bottom-color: rgba(255, 255, 255, 0.45);
    }
    .faq.is-blue .contact__submit {
        background: #ffffff !important;
        color: var(--accent) !important;
        box-shadow: 0 4px 14px rgba(0, 0, 0, 0.18);
    }
    .faq.is-blue .contact__submit-icon {
        background: rgba(0, 118, 129, 0.12);
        color: var(--accent);
    }

    /* FAQ accordion — sjednocení s novým vizuálním jazykem (REV 2) */
    .faq__question {
        font-size: var(--fs-podnadpis);
        font-weight: 500;
        padding: 18px 20px !important;
        letter-spacing: 0;
        background: transparent;
    }
    .faq__answer-inner {
        font-size: var(--fs-text);
        line-height: 1.6;
    }
    .faq__item {
        border-radius: 14px;
        border: 1px solid var(--hairline);
        overflow: hidden;
        transition: border-color 250ms cubic-bezier(0.32, 0.72, 0, 1);
    }
    .faq__item.is-open {
        border-color: var(--hairline-accent);
    }

    /* FAQ toggle ikon + / − v hairline circle, rotuje 45° na open. */
    .faq__icon {
        width: 24px;
        height: 24px;
        border-radius: 9999px;
        border: 1px solid var(--hairline-strong);
        position: relative;
        flex-shrink: 0;
        transition: transform 300ms cubic-bezier(0.32, 0.72, 0, 1),
                    border-color 300ms cubic-bezier(0.32, 0.72, 0, 1);
    }
    .faq__icon::before,
    .faq__icon::after {
        content: "";
        position: absolute;
        top: 50%;
        left: 50%;
        background: var(--ink);
        transition: background 300ms cubic-bezier(0.32, 0.72, 0, 1);
    }
    .faq__icon::before {
        width: 10px;
        height: 1.5px;
        transform: translate(-50%, -50%);
    }
    .faq__icon::after {
        width: 1.5px;
        height: 10px;
        transform: translate(-50%, -50%);
    }
    .faq__item.is-open .faq__icon {
        transform: rotate(45deg);
        border-color: var(--hairline-accent);
    }
    .faq__item.is-open .faq__icon::before,
    .faq__item.is-open .faq__icon::after {
        background: var(--accent);
    }
    .faq.is-blue .faq__icon {
        border-color: rgba(255, 255, 255, 0.32);
    }
    .faq.is-blue .faq__icon::before,
    .faq.is-blue .faq__icon::after {
        background: #ffffff;
    }
    .faq.is-blue .faq__item.is-open .faq__icon {
        border-color: #ffffff;
    }

    /* ===== FLOATING LABEL inputs (REV 2) =====
       Pattern: label je absolutně pozicovaná uvnitř pole. Na :focus nebo
       :not(:placeholder-shown) nebo .is-filled (JS autofill fallback) se
       label přesune nahoru a změní barvu na teal. placeholder=" " whitespace
       je nezbytný aby :placeholder-shown reagoval na empty value. */
    .form-field {
        position: relative;
    }
    .form-field label {
        position: absolute;
        top: 50%;
        left: 16px;
        transform: translateY(-50%);
        margin: 0 !important;
        padding: 0 6px !important;
        background: #ffffff;
        font-family: 'Aeonik Pro', system-ui, sans-serif;
        font-size: 16px !important;
        font-weight: 400 !important;
        color: var(--ink-muted) !important;
        line-height: 1 !important;
        pointer-events: none;
        z-index: 1;
        transition: top 220ms cubic-bezier(0.32, 0.72, 0, 1),
                    transform 220ms cubic-bezier(0.32, 0.72, 0, 1),
                    color 220ms cubic-bezier(0.32, 0.72, 0, 1);
        white-space: nowrap;
        max-width: calc(100% - 24px);
        overflow: hidden;
        text-overflow: ellipsis;
    }
    .form-field:has(textarea) label {
        top: 18px;
        transform: none;
    }
    .form-field input,
    .form-field textarea {
        padding-top: 20px !important;
        padding-bottom: 8px !important;
    }
    .form-field textarea {
        padding-top: 28px !important;
    }
    .form-field:has(input:focus) label,
    .form-field:has(input:not(:placeholder-shown)) label,
    .form-field:has(input.is-filled) label,
    .form-field:has(textarea:focus) label,
    .form-field:has(textarea:not(:placeholder-shown)) label,
    .form-field:has(textarea.is-filled) label {
        top: 0;
        transform: translateY(-50%) scale(0.78);
        color: var(--accent) !important;
        background: #ffffff;
    }

    /* Phone link s tel-ikonkou + accent-soft pill na :active */
    .contact__phone {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        padding: 4px 10px !important;
        border-radius: 9999px !important;
        border-bottom: none !important;
    }
    .contact__phone:active {
        background: var(--accent-soft);
    }
    .contact__phone-icon {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        color: var(--accent);
    }
    .faq.is-blue .contact__phone:active {
        background: rgba(255, 255, 255, 0.14);
    }
    .faq.is-blue .contact__phone-icon {
        color: #ffffff;
    }

    /* ===== TRUSTBAR (3.2) — REV 2: teal dot separator + logo 52 ===== */
    .trustbar {
        padding: 56px 0;
        margin: 0;
    }
    .trustbar__text {
        font-family: 'Aeonik Pro', system-ui, sans-serif;
        font-size: 1.5rem;
        font-weight: 500;
        letter-spacing: -0.01em;
    }
    .trustbar__sep {
        font-size: 1.3rem;
        color: var(--accent);
        opacity: 0.55;
        font-feature-settings: "tnum";
    }
    .trustbar .trustbar__logo {
        height: 52px;
    }

    /* ===== WHY (3.3) — eyebrow + hairline image ===== */
    .why {
        padding: 64px 0 !important;
    }
    .why__inner {
        gap: 24px;
        padding: 0 20px;
    }
    .why__col--text {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 14px;
    }
    .why__title {
        font-size: var(--fs-h1);
        font-weight: 700;
        line-height: 1.06;
        letter-spacing: -0.02em;
    }
    /* Statické teal podtržení pod slovem "vířivka" (REV 2). Neanimované —
       vstoupí spolu s titulkem. */
    .why__title-accent {
        position: relative;
        display: inline-block;
    }
    .why__title-accent::after {
        content: "";
        position: absolute;
        left: 0;
        right: 0;
        bottom: -2px;
        height: 2px;
        background: var(--accent);
        border-radius: 2px;
    }

    /* Lead split do 3 odstavců s 14 px gap */
    .why__lead-stack {
        display: flex;
        flex-direction: column;
        gap: 14px;
    }
    .why__lead {
        font-size: var(--fs-text);
        line-height: 1.6;
        color: var(--ink-soft);
        margin: 0;
    }

    /* Framed image (REV 2): outer hairline ring + 8 px white inner padding +
       inner radius 14. Premium gallery feel. */
    .why__frame {
        border: 1px solid var(--hairline);
        border-radius: 20px;
        padding: 8px;
        background: #ffffff;
        display: block;
    }
    .why__image {
        display: block;
        border-radius: 14px;
        border: none;
        max-height: 380px;
        width: 100%;
        object-fit: cover;
    }

    /* ===== HIGHLIFE (3.4) — minimalistické feature karty ===== */
    .highlife {
        padding: 64px 0 !important;
    }
    .highlife__sticky {
        padding: 0 20px;
        display: flex;
        flex-direction: column;
        gap: 16px;
    }
    .highlife__title {
        font-size: var(--fs-h1);
        font-weight: 700;
        letter-spacing: -0.02em;
        line-height: 1.05;
    }
    .highlife__features {
        list-style: none;
        margin: 8px 0 0;
        padding: 0;
        display: grid;
        grid-template-columns: 1fr;
        gap: 12px;
    }
    .highlife__feature {
        background: #ffffff;
        border: 1px solid var(--hairline);
        border-radius: 20px;
        padding: 20px 22px;
        display: flex;
        flex-direction: column;
        gap: 6px;
    }
    .highlife__feature-title {
        font-size: var(--fs-h2);
        font-weight: 500;
        letter-spacing: -0.005em;
        color: var(--ink);
    }
    .highlife__feature-text {
        font-size: var(--fs-text);
        line-height: 1.55;
        color: var(--ink-muted);
    }

    /* Drawn divider pod Highlife title — JEDINÉ drawn-line místo na webu */
    .highlife__divider {
        display: block;
        width: 48px;
        height: 1.5px;
        background: var(--accent);
        border-radius: 2px;
        margin: 4px 0 4px;
        transform: scaleX(0);
        transform-origin: left center;
        transition: transform 600ms cubic-bezier(0.32, 0.72, 0, 1) 200ms;
        will-change: transform;
    }
    /* Spouštíme drawn animaci stejně jako .lift — když rodič sticky vstoupí
       do viewportu. Použijeme parent .lift.is-in cascade. */
    .highlife .lift.is-in ~ .highlife__divider,
    .highlife__sticky:has(.lift.is-in) .highlife__divider {
        transform: scaleX(1);
    }

    /* Highlife mid-section CTA wrap */
    .highlife__cta {
        padding: 0 20px;
        margin-top: 24px;
    }

    /* ===== Sjednocený section-cta button =====
       Sdílený pro Highlife + Jetsetter mid-section CTA. Plain primary teal pill
       + button-in-button šipka. Halo flash + magnetic icon přes obecné selektory. */
    .section-cta {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 12px;
        width: 100%;
        min-height: 52px;
        padding: 14px 18px 14px 22px;
        background: var(--accent);
        color: #ffffff;
        font-family: 'Aeonik Pro', system-ui, sans-serif;
        font-size: var(--fs-button);
        font-weight: 500;
        border-radius: 9999px;
        text-decoration: none;
        box-shadow: 0 4px 14px rgba(0, 118, 129, 0.22);
        letter-spacing: 0;
    }
    .section-cta:active {
        box-shadow: var(--halo-flash);
    }
    .section-cta__icon {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 28px;
        height: 28px;
        border-radius: 9999px;
        background: rgba(255, 255, 255, 0.18);
        flex-shrink: 0;
        transition: transform 140ms cubic-bezier(0.32, 0.72, 0, 1);
    }
    .section-cta:active .section-cta__icon {
        transform: translateX(3px);
    }

    /* ===== JETSETTER (3.5) — eyebrow + dots refactor ===== */
    .jetsetter {
        padding: 48px 0 !important;
    }
    .jetsetter__head {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
        padding: 0 20px 8px;
    }
    .jetsetter__title {
        font-size: var(--fs-h1);
        font-weight: 700;
        letter-spacing: -0.02em;
        line-height: 1.05;
    }
    /* Dots — hairline ring → teal fill */
    /* Pill dots — REV 2: aktivní = pill 10 × 24, neaktivní = kroužek 10 × 10. */
    .jet-dots {
        gap: 10px;
    }
    .jet-dots .jet-dot {
        width: 10px;
        height: 10px;
        border-radius: 9999px;
        background: transparent;
        border: 1px solid rgba(11, 17, 21, 0.22);
        padding: 0;
        transition: width 350ms cubic-bezier(0.32, 0.72, 0, 1),
                    background 350ms cubic-bezier(0.32, 0.72, 0, 1),
                    border-color 350ms cubic-bezier(0.32, 0.72, 0, 1);
    }
    .jet-dots .jet-dot.is-active {
        width: 24px;
        background: var(--accent);
        border-color: var(--accent);
    }

    /* Jetsetter CTA wrap pod dots */
    .jetsetter__cta {
        margin: 24px 20px 0;
    }
    /* Seat panel sjednocení */
    .jetsetter__panel {
        border-radius: 20px;
        border: 1px solid var(--hairline);
        padding: 24px;
    }
    .jetsetter__seat-title {
        font-size: var(--fs-h2);
        font-weight: 500;
        letter-spacing: -0.005em;
    }

    /* ===== COLLINTRO (3.6) ===== */
    .collintro {
        padding: 64px 0 32px !important;
    }
    .collintro__head {
        padding: 0 20px;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }
    .collintro__title {
        font-size: var(--fs-h1);
        font-weight: 700;
        letter-spacing: -0.02em;
        line-height: 1.05;
    }
    .collintro__subtitle {
        font-size: var(--fs-podnadpis);
        font-weight: 500;
        color: var(--ink-muted);
        line-height: 1.45;
    }
    .collintro__divider {
        background: var(--accent);
        height: 1px;
        width: 48px;
        margin: 0 0 28px 20px;
        display: block;
    }

    /* ===== STORY-SCROLL / FLOW (3.7) ===== */
    .flow-section .flow-inner > div {
        border-radius: 20px;
        border: 1px solid var(--hairline);
        overflow: hidden;
    }
    .flow-section h2 {
        font-size: var(--fs-h2);
        font-weight: 500;
        letter-spacing: -0.005em;
        color: var(--ink);
    }

    /* ===== KDOJSME (3.9) — text-only sekce s mono detailem ===== */
    .kdojsme {
        padding: 64px 0 !important;
    }
    .kdojsme__container {
        padding: 0 20px;
        display: flex;
        flex-direction: column;
        gap: 18px;
    }
    .kdojsme__head {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }
    .kdojsme__eyebrow {
        font-size: var(--fs-eyebrow) !important;
        font-weight: 500;
        letter-spacing: 0.22em !important;
        text-transform: uppercase;
        color: var(--ink-muted);
        padding: 0 !important;
        border: none !important;
        background: transparent !important;
        display: inline-flex;
        align-items: center;
        gap: 8px;
    }
    .kdojsme__eyebrow::before {
        content: "";
        display: block;
        width: 24px;
        height: 1px;
        background: var(--hairline-strong);
    }
    .kdojsme__lead {
        font-size: 1.35rem !important;
        font-weight: 500;
        line-height: 1.35;
        letter-spacing: -0.005em;
        color: var(--ink);
        max-width: none;
    }
    .kdojsme__brand {
        color: var(--accent);
        font-weight: 700;
    }
    .kdojsme__meta {
        font-family: 'Aeonik Pro', system-ui, sans-serif;
        font-size: var(--fs-maly);
        font-weight: 400;
        color: var(--ink-muted);
        font-feature-settings: "tnum";
        letter-spacing: 0.02em;
        margin: 4px 0 0;
    }

    /* ===== PROC-WH (3.8) — sjednocení s novou typo/radii ===== */
    .proc-wh {
        padding: 64px 0 !important;
    }
    .proc-wh__head {
        padding: 0 20px;
        gap: 14px;
    }
    .proc-wh__eyebrow {
        font-size: var(--fs-eyebrow) !important;
        letter-spacing: 0.22em !important;
        font-weight: 500;
        padding: 0 !important;
        border: none !important;
        background: transparent !important;
        color: var(--ink-muted) !important;
        display: inline-flex;
        align-items: center;
        gap: 8px;
    }
    .proc-wh__eyebrow::before {
        content: "";
        display: block;
        width: 24px;
        height: 1px;
        background: var(--hairline-strong);
    }
    .proc-wh__title {
        font-size: var(--fs-h1) !important;
        font-weight: 700;
        letter-spacing: -0.02em;
        line-height: 1.05;
    }
    .proc-wh__lead {
        font-size: var(--fs-text);
        line-height: 1.55;
        color: var(--ink-muted);
    }
    .proc-wh__step-shell {
        border-radius: 20px !important;
        padding: 4px !important;
        background: var(--hairline) !important;
        border: 1px solid var(--hairline);
    }
    .proc-wh__step-core {
        border-radius: 14px !important;
        padding: 22px 20px !important;
        background: #ffffff !important;
        gap: 8px !important;
    }
    /* Step number badge — accent-soft pill obal okolo "Krok 01" textu */
    .proc-wh__step-num {
        display: inline-flex;
        align-items: center;
        font-size: 0.6875rem !important;
        font-weight: 500;
        font-feature-settings: "tnum";
        letter-spacing: 0.18em;
        text-transform: uppercase;
        color: var(--accent) !important;
        background: var(--accent-soft) !important;
        padding: 4px 10px !important;
        border: none !important;
        position: static !important;
        line-height: 1;
        height: auto !important;
        width: auto !important;
        border-radius: 9999px !important;
        align-self: flex-start;
    }
    .proc-wh__step-num::before {
        content: "Krok ";
        color: var(--accent);
        opacity: 0.75;
        font-weight: 500;
    }
    .proc-wh__step-title {
        font-size: var(--fs-h2);
        font-weight: 500;
        letter-spacing: -0.005em;
        color: var(--ink);
        line-height: 1.2;
    }
    .proc-wh__step-text {
        font-size: var(--fs-text);
        line-height: 1.55;
        color: var(--ink-muted);
    }
    /* Mono stat fakta pod step text — konkrétní trust signál */
    .proc-wh__step-stat {
        margin-top: 10px;
        font-family: 'Aeonik Pro', system-ui, sans-serif;
        font-size: var(--fs-maly);
        font-weight: 500;
        font-feature-settings: "tnum";
        letter-spacing: 0.02em;
        color: var(--accent);
        display: inline-block;
    }
    /* Accent stripe na klíčovém kroku 02 — viz .proc-wh__step--key */
    .proc-wh__step--key .proc-wh__step-shell {
        background: var(--accent-soft) !important;
    }
    .proc-wh__step--key .proc-wh__step-shell::before {
        left: 0;
        border-radius: 20px 0 0 20px;
    }
    .proc-wh__cta {
        padding: 0 20px;
        margin-top: 32px !important;
    }
    .proc-wh__btn {
        width: 100%;
        min-height: 52px;
        padding: 14px 18px 14px 22px !important;
        font-size: var(--fs-button);
        font-weight: 500;
        border-radius: 9999px !important;
        background: var(--accent) !important;
        color: #ffffff !important;
        box-shadow: 0 4px 14px rgba(0, 118, 129, 0.22);
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 12px;
    }
    .proc-wh__btn-icon {
        width: 28px;
        height: 28px;
        border-radius: 9999px;
        background: rgba(255, 255, 255, 0.18) !important;
        color: #ffffff !important;
        flex-shrink: 0;
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }

    /* ===== REVIEWS (3.11) — minimalistická karta + mono meta ===== */
    .reviews {
        padding: 64px 0 48px !important;
    }
    .reviews__head {
        padding: 0 20px 24px;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }
    .reviews__title {
        font-size: var(--fs-h1);
        font-weight: 700;
        letter-spacing: -0.02em;
        line-height: 1.05;
    }
    .reviews__subtitle {
        font-size: var(--fs-text);
        color: var(--ink-muted);
        line-height: 1.5;
    }
    .reviews__meta {
        font-family: 'Aeonik Pro', system-ui, sans-serif;
        font-size: var(--fs-maly);
        font-weight: 400;
        color: var(--ink-muted);
        font-feature-settings: "tnum";
        letter-spacing: 0.02em;
        margin-top: 4px;
    }
    /* Karty recenzí — hairline ring, žádný shadow, REV 2 quote mark + stars */
    .reviews__card,
    .review-card {
        background: #ffffff;
        border: 1px solid var(--hairline);
        border-radius: 20px !important;
        padding: 20px !important;
        box-shadow: none !important;
    }
    .reviews__card-text,
    .reviews__quote,
    .review-card__text {
        font-size: var(--fs-text);
        line-height: 1.6;
    }
    .reviews__card-author,
    .reviews__author,
    .review-card__name {
        font-size: var(--fs-maly);
        font-weight: 500;
        color: var(--ink-muted);
    }

    /* Review card tap-respond — všechny review karty dostávají haptiku
       (přiřazeno na .review-card globálně). Není to link, ale engage feel. */
    .review-card {
        transition: transform 140ms cubic-bezier(0.32, 0.72, 0, 1),
                    background-color 140ms cubic-bezier(0.32, 0.72, 0, 1),
                    border-color 140ms cubic-bezier(0.32, 0.72, 0, 1);
        position: relative;
    }
    .review-card:active {
        transform: scale(0.985);
        background-color: var(--surface-press);
        border-color: var(--hairline-accent);
    }
    /* Quote SVG mark v levém horním rohu — CSS-only přes background. */
    .review-card__body {
        position: relative;
        padding-top: 28px;
    }
    .review-card__body::before {
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        width: 22px;
        height: 22px;
        background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23007681' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><path d='M3 21c3 0 6-2 6-7V5H3v9h4'/><path d='M14 21c3 0 6-2 6-7V5h-6v9h4'/></svg>");
        background-repeat: no-repeat;
        background-size: contain;
        opacity: 0.35;
    }
    /* Hvězdičky teal — text ★ rendered v accent barvě, malé 12 px */
    .review-card__stars {
        color: var(--accent);
        font-size: 13px;
        letter-spacing: 0.08em;
        margin-bottom: 10px;
        line-height: 1;
    }

    /* ===== FOOTER (3.14) — sticky CTA clearance ===== */
    .footer {
        padding: 48px 0 96px;
    }
    .footer__bar {
        padding: 20px 0 0;
    }
    .footer__bar-inner {
        /* REV 10.3: padding-left 18 px lícuje s mobile hero logem
           (.nav padding 8 + .nav__logo margin-left 10 = 18 px). */
        padding: 0 18px;
        gap: 12px;
    }
    .footer__addr {
        font-size: var(--fs-maly);
        color: var(--ink-muted);
    }
    .footer a {
        color: var(--ink);
        text-decoration: none;
        border-bottom: 1px solid rgba(11, 17, 21, 0.16);
        padding-bottom: 1px;
    }
    .footer a:active,
    .footer a:hover {
        color: var(--accent);
        border-bottom-color: var(--accent);
    }
    /* Sociální ikonky bez podtržení */
    .footer__social,
    .footer__social:hover,
    .footer__social:active {
        border-bottom: none;
    }

    /* ===== REV 2 dodatečné styly pro 3.6–3.14 sekce ===== */

    /* COLLINTRO — divider stálý, žádná drawn animace */
    .collintro__divider {
        background: var(--accent);
        height: 1.5px;
        width: 48px;
        margin: 0 0 28px 20px;
        display: block;
        border-radius: 2px;
    }

    /* STORY-SCROLL / FLOW-SECTION — layered karta + flow-link */
    .flow-section {
        padding: 40px 0 24px;
    }
    .flow-section .flow-inner {
        padding: 0 20px;
    }
    .category-teaser__image-wrap {
        border-radius: 20px 20px 0 0;
        overflow: hidden;
        margin: 0;
    }
    .category-teaser__image {
        display: block;
        width: 100%;
        height: auto;
        /* REV 4 fix: aspect-ratio + object-fit odstraněny → vířivka se zobrazí
           v přirozeném poměru, celá vidět, žádný ořez. */
        transform: scale(0.96);
        opacity: 0;
        transition: transform 800ms cubic-bezier(0.32, 0.72, 0, 1),
                    opacity 600ms cubic-bezier(0.32, 0.72, 0, 1);
    }
    .lift.is-in .category-teaser__image,
    .category-teaser:has(.lift.is-in) .category-teaser__image,
    .flow-section.is-revealed .category-teaser__image {
        transform: scale(1);
        opacity: 1;
    }
    .category-teaser__content-wrap {
        border: 1px solid var(--hairline);
        border-top: none;
        border-radius: 0 0 20px 20px;
        padding: 20px;
        background: #ffffff;
        display: flex;
        flex-direction: column;
        gap: 12px;
    }

    /* Textový odkaz pod kartou — minimalistický, ne plné tlačítko */
    .flow-link {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        font-family: 'Aeonik Pro', system-ui, sans-serif;
        font-size: 14px;
        font-weight: 500;
        color: var(--accent);
        text-decoration: none;
        align-self: flex-start;
        padding-bottom: 2px;
        border-bottom: 1px solid var(--hairline-accent);
        transition: color 200ms cubic-bezier(0.32, 0.72, 0, 1),
                    border-color 200ms cubic-bezier(0.32, 0.72, 0, 1);
    }
    .flow-link:active {
        color: var(--ink);
        border-color: var(--accent);
    }

    /* KDOJSME — credibility chips */
    .kdojsme__chips {
        list-style: none;
        margin: 4px 0 0;
        padding: 0;
        display: flex;
        flex-wrap: wrap;
        gap: 8px;
    }
    .kdojsme__chip {
        font-family: 'Aeonik Pro', system-ui, sans-serif;
        font-size: 11px;
        font-weight: 500;
        letter-spacing: 0.02em;
        color: var(--ink-muted);
        padding: 6px 12px;
        border: 1px solid var(--hairline);
        border-radius: 9999px;
        background: #ffffff;
        font-feature-settings: "tnum";
    }

    /* FOOTER — pin ikon u adresy + social v hairline circle */
    .footer__addr {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        font-size: var(--fs-maly);
        color: var(--ink-muted);
    }
    .footer__addr-icon {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        color: var(--accent);
        flex-shrink: 0;
    }
    .footer__social {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 44px;
        height: 44px;
        border-radius: 9999px;
        border: 1px solid var(--hairline);
        color: var(--ink);
        transition: border-color 200ms cubic-bezier(0.32, 0.72, 0, 1),
                    color 200ms cubic-bezier(0.32, 0.72, 0, 1),
                    transform 140ms cubic-bezier(0.32, 0.72, 0, 1);
    }
    .footer__social:active {
        transform: scale(0.95);
        border-color: var(--hairline-accent);
        color: var(--accent);
    }
    .footer__social svg {
        width: 20px;
        height: 20px;
    }
    .footer__socials {
        display: flex;
        gap: 12px;
    }
}

/* Desktop: sticky CTA bar vůbec nerenderovat */

@media (max-width: 900px) and (prefers-reduced-motion: reduce) {
    .fade-in {
        transition: none !important;
        transform: none !important;
    }
    /* REV 2 helpers: reduced motion → bez transform, jen opacity */
    .lift {
        transform: none !important;
        transition: opacity 300ms ease-out !important;
        transition-delay: 0ms !important;
    }
    .tap-respond:active {
        transform: none !important;
    }
    .accent-stripe::before {
        transition: none !important;
    }
}

/* ============================================================================
   REV 5 doladění — sticky bar clearance, logo ořez, header v hero stavu,
   karty kolekcí jako <a>, mrtvý kód cleanup.
   ============================================================================ */

/* Globální — .category-teaser je teď <a> element, vypnutí default underline.
   REV 7 fix: smazáno `color: inherit` které přebíjelo desktop default
   color: #fff a způsobovalo tmavý text na obrázku. Desktop má vlastní
   color: #fff (ř. 1995), mobile override v REV 6 mobile @media bloku. */
.category-teaser {
    text-decoration: none;
    display: block;
}

@media (max-width: 900px) {
    /* REV 5 sticky bar clearance odstraněn v REV 6 — sticky bar zmizel,
       sekce se vrací na své REV 2 padding hodnoty (definované výše v souboru). */

    /* ===== ÚKOL 4/5 — Karty kolekcí (po smazání .flow-link) =====
       .category-teaser__content-wrap drží jen <h2> + .category-teaser-link.
       Sjednocený gap 16 px pro dech mezi nadpisem a "chip" linkem. */
    .category-teaser__content-wrap {
        gap: 16px;
    }

    /* ===== ÚKOL 1 REV 6 — Logo: samostatný PNG soubor jen s ikonou domu =====
       Dvě varianty:
       - wh-logo.png (tmavá, 496×496 nativ) — default + compact stav
       - wh-logo-white.png (bílá, 416×264 nativ) — hero .at-top stav
       Container velikost respektuje nativní aspect ratio (žádné stretching).
       background-size: contain → ikona vždy celá, ostrá.
       REV 6.1: zvětšeno (default 40→52, compact 32→40, hero 48×30→64×40)
       + lehké odsazení od levého kraje (.nav__logo margin-left 6px).
       REV 6.2: VÝRAZNÉ zvětšení všech 3 stavů: default+hero 56 výška,
       compact 44; margin-left 6→10 px. */
    .nav__logo {
        margin-left: 10px;
    }
    .nav__logo .logo-wh,
    .nav__panel-logo .logo-wh {
        width: 88px;
        height: 88px;
        background-image: url('logos/wh-logo.png');
        background-size: contain;
        background-position: center;
        background-repeat: no-repeat;
        image-rendering: -webkit-optimize-contrast;
        image-rendering: high-quality;
        filter: none;  /* override starého REV 5 filteru z desktop pravidel */
    }
    .site-header.compact .nav__logo .logo-wh {
        /* REV 8: zvětšeno o ~20 % z 44 → 53 px (factor ÷ 9.4 z nativ 496, ostré) */
        width: 53px;
        height: 53px;
        /* Stejný PNG, jen menší container */
    }

    /* ===== ÚKOL 7 (REV 5 zachováno) — Header v hero stavu (.at-top) =====
       Override REV 2 `transform: translateY(-100%) !important`. V hero stavu:
       header VIDITELNÝ (transform: none), background TRANSPARENT, logo
       VIDITELNÉ (opacity 1) s BÍLÝM PNG. Hamburger pruhy už bílé z ř. 3173. */
    .site-header.at-top {
        transform: none !important;
    }
    .site-header.at-top .nav__logo {
        opacity: 1;
        pointer-events: auto;
    }
    /* Hero stav — přepnutí na bílou variantu PNG.
       REV 6.2: container 88×56 px proporční k 416:264 nativ (factor ~4.7
       downsample). Výška 56 = STEJNÁ jako default stav → vizuálně stejně
       velké logo napříč stavy. */
    .site-header.at-top .nav__logo .logo-wh,
    .site-header.at-top .nav__panel-logo .logo-wh {
        width: 88px;
        height: 56px;
        background-image: url('logos/wh-logo-white.png');
        filter: none;
    }

    /* ===== Cleanup mrtvého kódu (REV 5 odebrané prvky) =====
       Selektory pro odebrané CTA elementy a flow-link mohou zůstat v CSS
       jako mrtvé (nezpůsobí škodu). Explicitně neoddenelovat — neexistující
       elementy zkrátka nematchují, žádný runtime overhead. */

    /* ===== REV 8.1 — .hsadv sekce hlavička: sjednoceno s "Další kolekce HotSpring"
       (.collintro) =====
       Stejné design — tmavá sekce, bílý velký nadpis Bold, light subtitle.
       Eyebrow chip ODSTRANĚN z HTML (REV 8.1 — duplikoval titulek). Mobile
       globální `h1,h2,h3 { color: var(--ink) }` přebíjí desktop default
       color #fff → explicitní `color: #ffffff` v title override je nutný. */
    .hsadv {
        padding: 72px 0 !important;
    }
    .hsadv__head {
        max-width: none;
        margin: 0 0 32px;
        padding: 0 20px;
        text-align: left;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 16px;
    }
    .hsadv__title {
        font-size: var(--fs-h1);
        font-weight: 700;
        line-height: 1.05;
        letter-spacing: -0.02em;
        color: #ffffff;       /* override globální h2 color: var(--ink) */
        margin: 0;
    }
    .hsadv__subtitle {
        font-size: var(--fs-podnadpis);
        font-weight: 500;
        line-height: 1.45;
        color: rgba(255, 255, 255, 0.75);   /* sjednoceno s .collintro__subtitle desktop default */
        margin: 0;
    }
}

/* ============================================================================
   REV 6 footer barvy — světlý text na tyrkysovém pozadí (globální).
   ============================================================================
   User explicit výjimka mantinelu "desktop nesahat" — footer je shared content,
   černý text na teal pozadí byl nečitelný / esteticky nevyhovující. Override
   na bílou platí pro VŠECHNY viewporty (mobile i desktop). Žádný @media wrap.

   Kontrast: bílá #ffffff na teal #007681 = ~5.5:1 (WCAG AA pro normální text).
*/
.footer__bar,
.footer__bar-inner {
    color: #ffffff;
}
.footer__addr {
    color: #ffffff;
}
.footer__addr-icon {
    color: #ffffff;
}
.footer a {
    color: #ffffff;
    border-bottom-color: rgba(255, 255, 255, 0.4);
}
.footer a:hover,
.footer a:active {
    color: #ffffff;
    border-bottom-color: #ffffff;
}
.footer__social {
    border-color: rgba(255, 255, 255, 0.6);
    color: #ffffff;
}
.footer__social:hover,
.footer__social:active {
    background: rgba(255, 255, 255, 0.12);
    border-color: #ffffff;
    color: #ffffff;
}

/* ============================================================================
   REV 7 DESKTOP úpravy (>900px). MOBIL NESAHÁNUT — všechny změny v @media
   (min-width: 901px). Mobile @media (≤900px) bloky zůstávají přebíjet díky
   stejné specificity ALE mobile @media přijde POZDĚJI v souboru, takže
   v případě konfliktu desktop @media nepřebije mobile. Tady ovšem desktop
   @media JE POZDĚJI než většina default pravidel → desktop overrides fungují.
   ============================================================================ */
@media (min-width: 901px) {
    /* ===== ÚKOL 1 — Hero: skrýt "Certifikovaný prodejce" ===== */
    .hero__trust {
        display: none;
    }

    /* ===== ÚKOL 3a — Highlife: skrýt eyebrow "Highlife kolekce" ===== */
    .highlife__sticky > .m-eyebrow,
    .highlife .m-eyebrow {
        display: none;
    }

    /* REV 7 pillify ODSTRANĚN v REV 13 — Highlife features zobrazí PLNÉ
       karty (title + text) přes default 3-col grid (ř. 1448). HTML obsah
       byl REV 7 jen schovaný přes CSS — teď se obnoví. Sticky-pin 100vh
       stage zachován, karty se vejdou pod vířivku. */

    /* ===== ÚKOL 4 — Jetsetter: skrýt eyebrow "Jetsetter" ===== */
    .jetsetter__head .m-eyebrow,
    .jetsetter .m-eyebrow {
        display: none;
    }

    /* ===== ÚKOL 5 — Karty kolekcí: bílý text (failsafe + cleanup) =====
       Globální REV 5 `color: inherit` byl smazán výše. Desktop default
       `.category-teaser { color: #fff }` ř. 1995 platí. Tento blok zajišťuje
       že všechny vnitřní textové elementy karty jsou bílé. */
    .category-teaser,
    .category-teaser .section-head,
    .category-teaser-link,
    .category-teaser-link__content,
    .category-teaser__subtitle,
    .category-teaser__head-link {
        color: #ffffff;
    }

    /* ===== ÚKOL 1 / REV 7.3 — Logo zvětšeno na 110/90 =====
       Z 88/64 (REV 7.2) na 110/90 — výraznější logo na všech desktop
       rozlišeních. Plus vertikální padding .nav drobně zvětšen aby logo
       110px se vešlo, ale header zůstal přiměřený. */
    .site-header {
        padding-top: 8px;
        padding-bottom: 6px;
    }
    .nav {
        padding-top: 6px;
        padding-bottom: 6px;
    }
    .nav__logo .logo-wh {
        width: 110px;
        height: 110px;
    }
    .site-header.compact .nav__logo .logo-wh {
        width: 90px;
        height: 90px;
    }

    /* ===== ÚKOL 6b / REV 7.2 — Standard desktop nav alignment =====
       Symetrický padding 40px sjednocený s .container (sekce dole). */
    .nav {
        padding-left: 40px;
        padding-right: 40px;
    }

    /* REV 7.3 glass header background ODSTRANĚN v REV 9 — header je teď
       transparent (žádný pás), prvky leží přímo na obsahu. Hero .at-top
       zachovává glass effect (desktop default ř. 164-172). Logo + hamburger
       barva se adaptivně přepíná přes body.on-dark třídu (IntersectionObserver). */

    /* ===== REV 9 — Desktop menu jako pilulky =====
       Bez headerového pásu musí být menu vidět samo na obsahu. Každá položka
       = bílá pilulka s tmavým textem, jemný hairline border + drobný shadow.
       Kontrastní nad LIBOVOLNÝM pozadím (tmavým i světlým). Hero .at-top má
       vlastní override (bílý text, velká velikost, žádné pilulky). */
    .nav__menu {
        gap: 10px;
    }
    .nav__menu a {
        background: rgba(255, 255, 255, 0.94);
        color: #0b1115;
        padding: 10px 20px;
        border-radius: 9999px;
        border: 1px solid rgba(0, 0, 0, 0.06);
        box-shadow: 0 2px 10px rgba(0, 0, 0, 0.08);
        backdrop-filter: blur(6px);
        -webkit-backdrop-filter: blur(6px);
        font-size: 0.95rem;
        font-weight: 500;
        text-shadow: none;
        transition: background 200ms cubic-bezier(0.32, 0.72, 0, 1),
                    box-shadow 200ms cubic-bezier(0.32, 0.72, 0, 1),
                    transform 140ms cubic-bezier(0.32, 0.72, 0, 1);
    }
    .nav__menu a:hover {
        background: #ffffff;
        box-shadow: 0 4px 14px rgba(0, 0, 0, 0.12);
        transform: translateY(-1px);
    }
    .nav__menu a:active {
        transform: translateY(0) scale(0.98);
    }

    /* Hero .at-top — zruš pilulky, vrať na transparent bílý text (REV 9). */
    .site-header.at-top .nav__menu a {
        background: transparent;
        color: #ffffff;
        border: none;
        box-shadow: none;
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
        text-shadow: 0 2px 8px rgba(0, 0, 0, 0.45);
        padding: 8px 16px;
        font-size: 1.5rem;  /* zachovat existující hero menu size */
    }
    .site-header.at-top .nav__menu a:hover {
        background: rgba(255, 255, 255, 0.12);
        box-shadow: none;
        transform: none;
    }
}

/* ============================================================================
   REV 7.2 — Ultrawide header (>1600px): header roztažený přes plnou šířku
   obrazovky. Logo blízko levého kraje, menu blízko pravého kraje. Sekce
   .container zůstávají center 1400px — netknuto.
   ============================================================================ */
@media (min-width: 1601px) {
    .nav {
        max-width: none;
        padding-left: 56px;
        padding-right: 56px;
    }
}

/* ============================================================================
   REV 10.3 — Footer logo: bílá ikona ve spodním pruhu (.footer__bar) vlevo
   vedle adresy. Klikací zpět na hero. Velikost IDENTICKÁ s hero header logem
   (desktop 96×96, mobile 88×56), pozice na stejné svislici jako hero logo.
   ============================================================================ */
.footer__bar-left {
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
}
.footer__logo {
    display: inline-block;
    /* Desktop velikost = .nav__logo .logo-wh ř. 214 (96×96, dědí v hero stavu). */
    width: 96px;
    height: 96px;
    background-image: url('logos/wh-logo-white.png');
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    image-rendering: -webkit-optimize-contrast;
    image-rendering: high-quality;
    flex-shrink: 0;
    cursor: pointer;
    transition: transform 200ms cubic-bezier(0.32, 0.72, 0, 1),
                opacity 200ms ease;
}
.footer__logo:hover {
    transform: translateY(-2px);
    opacity: 0.92;
}
.footer__logo:active {
    transform: scale(0.96);
}

@media (max-width: 900px) {
    /* Mobile velikost IDENTICKÁ s hero header logem (88×56, REV 6.2). */
    .footer__logo {
        width: 88px;
        height: 56px;
    }
    .footer__bar-left {
        gap: 16px;
    }
}

@media (min-width: 1601px) {
    /* Ultrawide: header REV 7.2 `.nav { max-width: none; padding-left: 56px }`.
       Footer __bar-inner musí mít stejné chování aby logo lícovalo na svislici
       56 px od viewport kraje (header logo je tam taky). */
    .footer__bar > .container.footer__bar-inner {
        max-width: none;
        padding-left: 56px;
        padding-right: 56px;
    }
}

/* ============================================================================
   REV 10.4 — Desktop only: adresa ve footeru +50 % a vycentrovaná.
   `position: absolute` na adrese vystoupí z flex flow → logo + social
   zachovají space-between layout (logo vlevo, social vpravo), adresa
   zobrazí absolutně uprostřed pruhu (50% .footer__bar-inner).
   Mobil ≤900 px nedotčen — adresa zůstává inline v .footer__bar-left.
   ============================================================================ */
@media (min-width: 901px) {
    .footer__bar-inner {
        position: relative;
    }
    .footer__bar .footer__addr {
        position: absolute;
        left: 50%;
        top: 50%;
        transform: translate(-50%, -50%);
        font-size: calc(var(--fs-maly) * 1.5);
        white-space: nowrap;
        margin: 0;
    }
}

/* ============================================================================
   REV 15 — Desktop full-bleed obrázky (usspa.cz pattern) + premium karty
   ============================================================================
   Princip: sekce text+obrázek → grid 1fr 1fr přes celou 100% width (container
   max-width: none). Obrázek vyplní svou polovinu do kraje obrazovky. Text na
   druhé straně drží reading-width max 600 px s padding od kraje.
   ============================================================================ */

@media (min-width: 901px) {

    /* REV 16: REV 15 full-bleed pro .why / .jetsetter intro / .jetsetter
       Moto-Massage / .hsadv ODSTRANĚN. Sekce se vrací na REV 14 default
       2-col grid side-by-side (text a obrázek vedle sebe na stejné lince).
       Highlife premium karty, FAQ premium polish a Kdojsme editorial zůstávají. */

    /* ===== ÚKOL 5 — .highlife premium karty (ui-ux-pro-max) =====
       Glass effect + accent stripe + concentric radii + drobné lift na hover. */
    .highlife__feature {
        position: relative;
        text-align: left;
        padding: 36px 32px 32px;
        background: linear-gradient(180deg, rgba(255, 255, 255, 0.10), rgba(255, 255, 255, 0.04));
        border: 1px solid rgba(255, 255, 255, 0.14);
        border-radius: 20px;
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
        backdrop-filter: blur(10px) saturate(140%);
        -webkit-backdrop-filter: blur(10px) saturate(140%);
        transition: transform 400ms cubic-bezier(0.32, 0.72, 0, 1),
                    background 400ms cubic-bezier(0.32, 0.72, 0, 1),
                    border-color 400ms cubic-bezier(0.32, 0.72, 0, 1);
        overflow: hidden;
    }
    .highlife__feature::before {
        /* Top accent gradient stripe — premium brand touch */
        content: "";
        position: absolute;
        top: 0;
        left: 24px;
        right: 24px;
        height: 2px;
        background: linear-gradient(90deg, transparent, rgba(0, 118, 129, 0.6), transparent);
        opacity: 0.7;
    }
    .highlife__feature:hover {
        transform: translateY(-3px);
        background: linear-gradient(180deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.06));
        border-color: rgba(255, 255, 255, 0.22);
    }
    .highlife__feature-title {
        font-size: 22px;
        font-weight: 500;
        margin: 0 0 12px;
        color: #ffffff;
        letter-spacing: -0.005em;
    }
    .highlife__feature-text {
        display: block;
        font-size: 16px;
        line-height: 1.6;
        color: rgba(255, 255, 255, 0.72);
        margin: 0;
    }

    /* ===== ÚKOL 6 — .faq + .contact-block premium polish (ui-ux-pro-max) =====
       Subtle teal accent na bordery, premium shadow, větší submit button. */
    .faq__col,
    .contact-block {
        background: #ffffff;
        border: 1px solid rgba(0, 118, 129, 0.14);
        border-radius: 20px;
        padding: 48px;
        box-shadow: 0 2px 24px rgba(0, 118, 129, 0.06);
        transition: box-shadow 400ms cubic-bezier(0.32, 0.72, 0, 1),
                    border-color 400ms cubic-bezier(0.32, 0.72, 0, 1);
    }
    .faq__col:hover,
    .contact-block:hover {
        box-shadow: 0 4px 32px rgba(0, 118, 129, 0.08);
        border-color: rgba(0, 118, 129, 0.22);
    }
    .faq__item {
        border-radius: 16px;
        border: 1px solid rgba(0, 0, 0, 0.06);
        transition: border-color 300ms cubic-bezier(0.32, 0.72, 0, 1),
                    box-shadow 300ms cubic-bezier(0.32, 0.72, 0, 1);
    }
    .faq__item.is-open {
        border-color: rgba(0, 118, 129, 0.32);
        box-shadow: 0 4px 16px rgba(0, 118, 129, 0.08);
    }
    .contact__submit {
        padding: 18px 32px;
        font-size: 18px;
        font-weight: 500;
        letter-spacing: 0;
    }

    /* ===== ÚKOL 7 — .kdojsme premium editorial (high-end + usspa-design) =====
       Center-aligned editorial typography, větší padding, decentní accent. */
    .kdojsme {
        padding: 120px 0;
        text-align: center;
    }
    .kdojsme__container {
        max-width: 1200px;
    }
    .kdojsme__head {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 24px;
        margin-bottom: 48px;
    }
    .kdojsme__eyebrow {
        align-self: center;
    }
    .kdojsme__lead {
        font-size: 44px;
        font-weight: 500;
        line-height: 1.35;
        letter-spacing: -0.01em;
        max-width: 1000px;
        margin: 0 auto;
        text-align: center;
        color: var(--text);
    }
    .kdojsme__brand {
        color: var(--accent);
        font-weight: 600;
    }
}

/* ============================================================================
   REV 20 — Mobile defaults override fix
   ============================================================================
   Účel: explicitní mobile @media override pro desktop DEFAULT pravidla
   z REV 13–18, která protékala na mobil ≤900 px a rozbíjela ho.

   Mantinely (zachovány):
   - Desktop (>900 px) NETKNUT — žádné změny v default ani v
     `(min-width: 901px)` blocích.
   - Truck animace samotná (.truckseq, .wavyblock, canvas) NEDOTKNUTA.
     Jediný "truck-related" zásah je vrácení .hero height na 100dvh na
     mobilu — tím přestane hero tlačit truck o 120vh níž.
   - HTML/JS beze změny.
   ============================================================================ */
@media (max-width: 900px) {

    /* === HERO — fix "černá díra pod hero" ===
       Default `.hero { height: 220vh }` (line 478) je scroll-budget pro
       desktop letter-morph animaci. Na mobilu sticky child = 100dvh, ale
       parent 220vh → po projetí stickyho zůstane 120vh prázdné tmavé
       plochy (.hero__media bg = #0e1112) = "černá díra". Mobile potřebuje
       hero = 1× viewport. */
    .hero {
        height: 100dvh !important;
    }

    /* === HSROW — fix obří desktop typo/výška protékající z REV 14 === */
    .hsrow__title {
        /* Default 36 px (REV 14, L2527) leaks → mobile 1.4 rem ≈ 22 px. */
        font-size: 1.4rem;
        line-height: 1.2;
        margin-bottom: 12px;
    }
    .hsrow__desc {
        /* Default 20 px + max-width 56ch (REV 14, L2536-2538) leaks.
           Mobile token + full width. */
        font-size: var(--fs-text);
        line-height: 1.55;
        max-width: 100%;
    }
    .hsrow__media {
        /* Default fixed height 480 px (REV 14, L2545) leaks → obří obrázek
           na phone. Auto height + radius zmenšen pro mobile měřítko. */
        height: auto;
        border-radius: 12px;
    }
    .hsadv__rows {
        /* Default gap 32 px (L2506) je málo na mobilu mezi 3 rows.
           Větší rytmus mezi řádky. */
        gap: 48px;
    }

    /* === JETSETTER — fix REV 18 padding leak na .jetsetter__seat ===
       REV 18 default `padding-right: 80 px` kompenzoval rozšíření panel
       borderu na desktopu. Na mobilu panel je full-width single-column,
       text 80 px padding-right zbytečně cramps. */
    .jetsetter__seat {
        padding-right: 0;
        align-items: start;
    }

    /* === REV 21 FIX 1 — TRUCK scroll-budget ===
       Default `.truckseq { height: 280vh }` (L740) protéká na mobil = ~2000 px
       scroll-budget. Sticky child se odepne po 180vh scroll-pinu, ale
       visualně truck canvas zabírá jen 35vw ≈ 133 px → ~1500 px bílé prázdné
       plochy pod truckem.

       Animace SAMOTNÁ (.truckseq__sticky, canvas, .wavyblock) NEDOTKNUTA.
       Jen výška kontejneru zkrácena: 280vh → 160vh. Sticky se odepne po
       (160-100) = 60vh pinu = dost na wavy text + truck frame sekvenci.

       NOTE: pokud canvas animace potřebuje na mobilu více scroll-budgetu,
       lze upravit 160vh → 180–200vh. 160 = startovní hodnota, vyladí se
       podle reálného mobile testu. */
    .truckseq {
        height: 160vh;
    }

    /* === REV 21 FIX 2 — PROC-WH steps (3 kroky pod sebou na mobilu) ===
       Default REV 14 `.proc-wh__steps { grid-template-columns: repeat(3, 1fr) }`
       (L2857) protéká — mobile override (L3023) měnil JEN gap, ne layout.
       → na mobilu 3 kroky vedle sebe ve squashovaných sloupcích.

       Fix: na mobilu jednosloupcový stack = 3 karty plná šířka pod sebou. */
    .proc-wh__steps {
        grid-template-columns: 1fr;
    }

    /* === REV 23 — HERO mobile overlay (po split layout přestavbě) ===
       Desktop má text-block (dark editorial) nad video-block (full-bleed pod).
       Mobile musí vypadat IDENTICKY se současným stavem = full-screen video
       s text overlay dole + dark scrim. Tady to obnovíme z nové HTML
       struktury (.hero__text-block + .hero__video-block + .hero__scrim).

       Desktop animace (letter scale on mouse, hero video 0-12s loop, .lift IO)
       nezávisí na overlay vs split → fungují stejně.

       Mantinely: REV 20 .hero { height: 100dvh !important } zůstává v platnosti
       (deklarováno výše v tomto bloku). */

    /* TEXT BLOCK → absolutní overlay nad videem */
    .hero__text-block {
        position: absolute;
        inset: 0;
        z-index: 5;
        background: transparent;     /* video pod ním je vidět */
        padding: 0;
        display: flex;
        align-items: flex-end;        /* text dole ve viewportu (jako original) */
        pointer-events: none;         /* klikání projde — CTA si přepne pointer-events: auto níž */
    }
    .hero__text-block .hero__inner,
    .hero__text-block .hero__head,
    .hero__text-block .hero__text,
    .hero__text-block .hero__actions,
    .hero__text-block .hero__trust {
        pointer-events: auto;          /* obnoví klikání na text/CTA */
    }
    /* REV 31: mirror "Špička " span (zarovnání line2 pod "mezi") je čistě
       desktop feature. Na mobilu by mirror posunul "vířivkami" doprava o ~75 px
       a rozbil mobilní layout. display: none úplně odstraní z flow. */
    .hero__head-word--mirror {
        display: none;
    }

    .hero__text-block .hero__inner {
        /* Mobile inner — žádný 1400 max-width / 48 px gutter; mobile padding 20 px,
           text dole ve viewportu (bottom margin přes padding-bottom). */
        max-width: 100%;
        padding: 0 20px 11vh;
    }

    /* REV 24: scroll-zoom scope wrapper na mobilu zruším — žádné 150vh,
       žádný sticky. Mobile drží overlay strukturu (REV 23). */
    .hero__video-scope {
        position: absolute;
        inset: 0;
        z-index: 1;
        height: auto;          /* zruší 150vh desktop */
        width: 100%;
    }

    /* VIDEO BLOCK → absolute, fill hero (zruší sticky/flex z desktopu) */
    .hero__video-block {
        position: absolute;
        inset: 0;
        z-index: 1;
        width: 100%;
        height: 100%;
        min-height: 0;
        max-height: none;
        display: block;        /* zruší flex */
        align-items: initial;
        justify-content: initial;
    }

    /* REV 24: WRAP transform reset — žádný scale na mobilu */
    .hero__video-wrap {
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
        aspect-ratio: auto;    /* zruší 16/9 */
        max-height: none;
        transform: none !important;
        will-change: auto;
    }

    /* SCRIM → obnovený pro overlay text kontrast */
    .hero__scrim {
        display: block;
        position: absolute;
        inset: 0;
        z-index: 2;
        pointer-events: none;
        background: rgba(0, 0, 0, 0.6);
    }
}

