/* =========================================================
   Human Earth Lab
   jednotný CSS pro Úvod, Tým, Výzkum, Lokality
   ========================================================= */


/* =========================================================
   1. Proměnné a základ
   ========================================================= */

:root {
    --uk-red: #b51f2a;
    --uk-red-dark: #8f1620;
    --text: #111111;
    --muted: #5f6368;
    --line: #dedede;
    --bg: #ffffff;
    --soft: #f5f5f5;
    --soft-red: #f7e8ea;
    --max: 1180px;
    --container-pad: clamp(1rem, 3vw, 1.5rem);
    --radius-lg: 30px;
    --shadow-soft: 0 18px 50px rgba(0, 0, 0, .12);
}

* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
    text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
}

body {
    margin: 0;
    min-width: 320px;
    overflow-x: hidden;
    font-family: Arial, Helvetica, sans-serif;
    color: var(--text);
    background: var(--bg);
    line-height: 1.55;
}

img,
svg,
video,
canvas {
    max-width: 100%;
}

img,
video {
    height: auto;
}

button,
input,
textarea,
select {
    font: inherit;
}

a,
button {
    -webkit-tap-highlight-color: transparent;
}

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

    a:hover {
        text-decoration: underline;
    }

    a:focus-visible,
    button:focus-visible,
    input:focus-visible,
    textarea:focus-visible,
    select:focus-visible {
        outline: 3px solid rgba(181, 31, 42, .35);
        outline-offset: 3px;
    }


/* =========================================================
   2. Header
   ========================================================= */

.topbar {
    background: var(--uk-red);
    color: #fff;
    font-size: .88rem;
}

.topbar-inner {
    width: min(100%, var(--max));
    margin: auto;
    padding: .55rem var(--container-pad);
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
}

.brandbar {
    background: #fff;
    border-bottom: 1px solid var(--line);
}

.brandbar-inner {
    width: min(100%, var(--max));
    min-height: 86px;
    margin: auto;
    padding: 1.25rem var(--container-pad);
    display: flex;
    justify-content: space-between;
    gap: 1.5rem;
    align-items: center;
}

.brand {
    display: flex;
    gap: 1rem;
    align-items: center;
    color: var(--text);
}

    .brand:hover {
        text-decoration: none;
    }

.mark {
    width: 54px;
    height: 54px;
    background: var(--uk-red);
    color: #fff;
    display: grid;
    place-items: center;
    font-weight: 800;
    font-size: 1.25rem;
    letter-spacing: .02em;
}

    .logo-mark,
    .mark.logo-mark {
        display: block;
        width: clamp(40px, 6vw, 58px);
        height: clamp(40px, 6vw, 58px);
        object-fit: contain;
        background: #fff;
        border: 0;
        padding: 0;
    }

.brand h1 {
    font-size: clamp(1.05rem, 2.2vw, 1.42rem);
    margin: 0;
    line-height: 1.1;
    font-weight: 800;
}

.brand p {
    margin: .2rem 0 0;
    color: var(--muted);
    font-size: clamp(.78rem, 1.4vw, .92rem);
}

.lang {
    font-size: .9rem;
    color: var(--muted);
    white-space: nowrap;
}


/* =========================================================
   3. Navigace
   ========================================================= */

nav {
    background: #fff;
    border-bottom: 1px solid var(--line);
    position: sticky;
    top: 0;
    z-index: 20;
}

.nav-inner {
    width: min(100%, var(--max));
    margin: auto;
    padding: 0 var(--container-pad);
    display: flex;
    gap: .2rem;
    overflow: auto;
    scrollbar-width: thin;
    -webkit-overflow-scrolling: touch;
}

    .nav-inner a {
        min-height: 48px;
        display: flex;
        align-items: center;
        color: var(--text);
        font-weight: 700;
        padding: 1rem .9rem;
        border-bottom: 4px solid transparent;
        white-space: nowrap;
        text-decoration: none;
    }

        .nav-inner a:hover,
        .nav-inner a.active {
            border-bottom-color: var(--uk-red);
            color: var(--uk-red);
        }

/* Bootstrap navbar sjednocení */

.navbar {
    border-bottom: 1px solid var(--line);
}

    .navbar .nav-link {
        color: var(--text);
        font-weight: 700;
        border-bottom: 4px solid transparent;
    }

        .navbar .nav-link:hover,
        .navbar .nav-link.active {
            color: var(--uk-red);
            border-bottom-color: var(--uk-red);
        }


/* =========================================================
   4. Obecný layout
   ========================================================= */

main {
    width: min(100%, var(--max));
    margin: auto;
    padding: 3rem var(--container-pad);
}

section {
    margin-bottom: 4rem;
    scroll-margin-top: 90px;
}

.section {
    margin-bottom: 0;
}

.container {
    width: 100%;
    max-width: var(--max);
    margin: 0 auto;
    padding-left: var(--container-pad);
    padding-right: var(--container-pad);
}

.kicker,
.eyebrow {
    color: var(--uk-red);
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
    font-size: .83rem;
    margin-bottom: 1rem;
}

.breadcrumb {
    font-size: .88rem;
    color: var(--muted);
    margin-bottom: 1rem;
}


/* =========================================================
   5. Jednotná hlavička sekcí
   ========================================================= */

.section-head {
    display: grid;
    grid-template-columns: 220px 1fr 1.5fr;
    gap: 28px;
    align-items: start;
    padding-bottom: 22px;
    margin-bottom: 22px;
    border-bottom: 2px solid #161616;
}

    .section-head .eyebrow {
        margin: 0;
        color: #3d4554;
        font-size: .9rem;
    }

    .section-head h2 {
        margin: 0;
        font-size: clamp(2rem, 4vw, 3rem);
        line-height: 1;
        letter-spacing: -.04em;
        font-weight: 700;
    }

    .section-head p {
        margin: 0;
        max-width: 620px;
        color: #374151;
        line-height: 1.65;
    }


/* =========================================================
   6. Jednotné gridy
   ========================================================= */

.grid-2 {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.2rem;
}

.grid-3 {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.2rem;
}


/* =========================================================
   7. Jednotné karty
   ========================================================= */

.card,
.hero-card,
.site-preview-card,
.site-featured-card,
.now-card,
.now-live-card,
.study-card,
.map-panel,
.partner-tile {
    min-width: 0;
}

.card,
.site-preview-card,
.site-featured-card {
    height: 100%;
    min-height: 100%;
    border: 1px solid var(--line);
    border-radius: 0;
    background: #fff;
    box-shadow: none;
    overflow: hidden;
}

.card {
    padding: 1.4rem;
}

    .card h3,
    .site-preview-content h3 {
        font-size: 1.22rem;
        margin: 0 0 .7rem;
        line-height: 1.25;
        font-weight: 800;
    }

    .card p,
    .site-preview-content p,
    .hero-card p,
    .now-live-copy p,
    .now-copy p {
        color: var(--muted);
        margin: .45rem 0;
        line-height: 1.6;
        overflow-wrap: anywhere;
    }

    .card .meta,
    .site-preview-content .meta {
        font-size: .82rem;
        text-transform: uppercase;
        letter-spacing: .06em;
        color: var(--uk-red);
        font-weight: 800;
        margin-bottom: .75rem;
    }

.card-link {
    display: inline-block;
    margin-top: .75rem;
    font-weight: 800;
}

/* vypnutí Bootstrap paddingu uvnitř vlastních karet */

.card-body {
    padding: 0;
}

.card .h5 {
    font-size: 1.22rem;
}


/* =========================================================
   8. Hero jednotný pro Úvod, Tým, Výzkum, Lokality
   ========================================================= */

.hero,
.clean-hero,
.team-hero,
.research-hero,
.locations-hero {
    border-bottom: 1px solid var(--line);
    background: linear-gradient(90deg, #fff 0%, #fff 58%, var(--soft-red) 58%, var(--soft-red) 100%);
}

.hero-inner {
    width: min(100%, var(--max));
    margin: auto;
    padding: clamp(3rem, 7vw, 5rem) var(--container-pad);
    display: grid;
    grid-template-columns: 1.35fr .65fr;
    gap: clamp(1.5rem, 4vw, 3rem);
    align-items: center;
}

.hero h2,
.clean-hero h2,
.team-hero h2,
.research-hero h2,
.locations-hero h2 {
    font-size: clamp(2.35rem, 7vw, 4rem);
    line-height: .98;
    margin: 0 0 1.25rem;
    font-weight: 900;
    letter-spacing: -.04em;
    text-wrap: balance;
}

.hero .lead,
.clean-hero .lead,
.team-hero .lead,
.research-hero .lead,
.locations-hero .lead {
    font-size: clamp(1.08rem, 2.4vw, 1.42rem);
    max-width: 800px;
    color: #222;
    margin: 0 0 1.4rem;
}

.hero .lead-en {
    font-size: 1.05rem;
    max-width: 780px;
    color: var(--muted);
    margin: 0;
}

.hero-card,
.team-focus-card,
.research-focus-card,
.locations-focus-card {
    background: #fff;
    border-top: 7px solid var(--uk-red);
    border-radius: 0;
    box-shadow: 0 14px 40px rgba(0, 0, 0, .08);
    padding: 1.7rem;
}

    .hero-card h3,
    .team-focus-card h3,
    .research-focus-card h3,
    .locations-focus-card h3 {
        margin: 0 0 .9rem;
        font-size: 1.2rem;
    }

    .hero-card p,
    .team-focus-card p,
    .research-focus-card p,
    .locations-focus-card p {
        margin: 0 0 .9rem;
        color: var(--muted);
    }


/* =========================================================
   9. Tlačítka
   ========================================================= */

.cta,
.site-actions,
.now-actions,
.now-live-actions {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    margin-top: 1.4rem;
}

.btn,
.intro-skip,
.map-btn,
.signal-button {
    min-height: 44px;
    border-radius: 0;
}

.btn {
    display: inline-block;
    background: var(--uk-red);
    color: #fff;
    padding: .8rem 1rem;
    font-weight: 800;
    text-decoration: none;
}

    .btn.secondary {
        background: #111;
    }

    .btn:hover {
        text-decoration: none;
        background: var(--uk-red-dark);
    }

.replay-intro {
    border: 0;
    cursor: pointer;
    font-family: inherit;
    font-size: 1rem;
}


/* =========================================================
   10. Pásy, seznamy, tabulky
   ========================================================= */

.band {
    background: var(--soft);
    padding: 2rem;
    border-left: 8px solid var(--uk-red);
}

    .band h2 {
        margin-top: 0;
    }

    .band p {
        font-size: 1.1rem;
        color: #222;
    }

.list {
    padding-left: 1.1rem;
}

    .list li {
        margin: .45rem 0;
        color: #333;
    }

.info-table {
    width: 100%;
    border-collapse: collapse;
    background: #fff;
}

    .info-table th,
    .info-table td {
        border-bottom: 1px solid var(--line);
        padding: .9rem;
        text-align: left;
        vertical-align: top;
    }

    .info-table th {
        width: 220px;
        color: var(--uk-red);
    }

.method-tag {
    display: inline-block;
    border: 1px solid var(--line);
    padding: .35rem .6rem;
    margin: .15rem;
    background: #fff;
    font-weight: 700;
    font-size: .88rem;
}


/* =========================================================
   11. Team page
   ========================================================= */

.role {
    font-weight: 800;
    color: var(--uk-red);
    margin-bottom: .5rem;
}

.person {
    display: block;
}

    .person h3 {
        margin: .1rem 0 .3rem;
    }

.person-photo,
.advisor-photo {
    display: block;
    width: 100%;
    max-width: 180px;
    aspect-ratio: 4 / 5;
    height: auto;
    object-fit: cover;
    background: var(--soft);
    border: 1px solid var(--line);
}

.team-lead {
    border-top: 8px solid var(--uk-red);
}

.team-section-label {
    font-size: .82rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--uk-red);
    font-weight: 900;
}

.advisor-card-bootstrap {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    padding: 1.4rem;
}

    .advisor-card-bootstrap .advisor-photo,
    .advisor-card-bootstrap .advisor-initial {
        flex: 0 0 96px;
        width: 96px;
        height: 116px;
    }

    .advisor-card-bootstrap h3 {
        margin: .15rem 0 .5rem;
        font-size: 1.18rem;
        line-height: 1.2;
        overflow-wrap: normal;
        word-break: normal;
    }

    .advisor-card-bootstrap p {
        color: var(--muted);
        line-height: 1.55;
    }

    .advisor-card-bootstrap .role {
        color: var(--uk-red);
        font-weight: 900;
        margin-bottom: .35rem;
    }

    .advisor-initial,
    .advisor-card-bootstrap .advisor-initial {
        display: grid;
        place-items: center;
        background: var(--soft-red);
        color: var(--uk-red);
        font-size: 2.5rem;
        font-weight: 900;
        border: 1px solid var(--line);
    }


/* =========================================================
   12. Lokality přehled
   ========================================================= */

.site-preview-section {
    width: auto;
    max-width: none;
    margin: 0;
    padding: 3rem 0;
    background: transparent;
}

    .site-preview-section .container {
        width: min(100%, var(--max));
        margin: auto;
        padding-left: var(--container-pad);
        padding-right: var(--container-pad);
    }

.site-preview-card,
.site-featured-card {
    transition: none;
}

    .site-preview-card:hover,
    .site-featured-card:hover {
        transform: none;
        box-shadow: none;
        border-color: var(--line);
    }

.site-preview-image {
    position: relative;
    display: block;
    aspect-ratio: 16 / 9;
    min-height: 180px;
    background-size: cover;
    background-position: center;
    background-color: var(--soft);
    text-decoration: none;
    overflow: hidden;
}

    .site-preview-image::before {
        content: "";
        position: absolute;
        inset: 0;
        background: linear-gradient( to bottom, rgba(0, 0, 0, .08), rgba(0, 0, 0, .62) );
        z-index: 1;
    }

    .site-preview-image::after {
        display: none;
    }

.site-preview-overlay {
    position: absolute;
    left: 1.25rem;
    right: 1.25rem;
    bottom: 1.15rem;
    z-index: 2;
    color: #fff;
}

    .site-preview-overlay span {
        display: inline-block;
        margin-bottom: .55rem;
        padding: 0;
        border-radius: 0;
        background: transparent;
        color: rgba(255, 255, 255, .86);
        font-size: .78rem;
        text-transform: uppercase;
        letter-spacing: .08em;
        font-weight: 800;
    }

    .site-preview-overlay strong {
        display: block;
        max-width: none;
        color: #fff;
        font-size: 1rem;
        line-height: 1.35;
        text-shadow: none;
    }

.site-preview-content {
    padding: 1.4rem;
    display: flex;
    flex-direction: column;
    min-height: 100%;
}

    .site-preview-content h3 {
        margin: .25rem 0 .7rem;
    }

    .site-preview-content p {
        margin: 0 0 1rem;
    }

.site-tags {
    display: flex;
    flex-wrap: wrap;
    gap: .4rem;
    margin: 0 0 1rem;
}

    .site-tags span {
        display: inline-block;
        padding: .28rem .5rem;
        border-radius: 0;
        background: var(--soft);
        color: #333;
        font-size: .78rem;
        font-weight: 700;
    }

.site-preview-content .card-link {
    margin-top: auto;
}


/* obrázky lokalit */

.site-vaclavak .site-preview-image {
    background-image: linear-gradient(135deg, rgba(16, 25, 21, .12), rgba(194, 29, 45, .12)), url("sites/vaclavak/vaclavak-reconstruction.png");
}

.site-trebokov .site-preview-image {
    background-image: linear-gradient(135deg, rgba(16, 25, 21, .12), rgba(194, 29, 45, .12)), url("sites/trebokov/trebokov-lidar-zones.png");
}

.site-tel-burna .site-preview-image {
    background-image: linear-gradient(135deg, rgba(16, 25, 21, .12), rgba(194, 29, 45, .12)), url("sites/tel-burna/tel-burna-map-reconstruction.png");
}

.site-sadova .site-preview-image {
    background-image: linear-gradient(135deg, rgba(16, 25, 21, .12), rgba(194, 29, 45, .12)), url("sites/sadova/sadova.jpg");
}

.site-ravat .site-preview-image {
    background-image: linear-gradient(135deg, rgba(16, 25, 21, .12), rgba(194, 29, 45, .12)), url("sites/ravat/ravat.jpg");
}

.site-aldasin .site-preview-image {
    background-image: linear-gradient(135deg, rgba(16, 25, 21, .12), rgba(194, 29, 45, .12)), url("sites/aldasin/aldasin.jpg");
}

.site-muszkowice .site-preview-image {
    background-image: linear-gradient(135deg, rgba(16, 25, 21, .12), rgba(194, 29, 45, .12)), url("sites/muszkowice/muszkowice.jpg");
}

.site-vaclavak .site-preview-image,
.site-trebokov .site-preview-image,
.site-tel-burna .site-preview-image,
.site-sadova .site-preview-image,
.site-ravat .site-preview-image,
.site-aldasin .site-preview-image,
.site-muszkowice .site-preview-image {
    background-color: #18231e;
}


/* =========================================================
   13. Detail lokality
   ========================================================= */

.site-hero {
    background: var(--soft);
    border-bottom: 1px solid var(--line);
}

.site-hero-inner {
    width: min(100%, var(--max));
    margin: auto;
    padding: 3.2rem var(--container-pad);
}

.site-hero h2 {
    font-size: 3rem;
    line-height: 1.05;
    margin: .3rem 0;
    text-wrap: balance;
}

.site-hero p {
    font-size: 1.22rem;
    color: #333;
    max-width: 850px;
}

.site-hero-grid {
    display: grid;
    grid-template-columns: 1.05fr .95fr;
    gap: 2rem;
    align-items: center;
}

.vaclavak-hero {
    background: linear-gradient(90deg, #fff 0%, #fff 54%, #f7e8ea 54%, #f7e8ea 100%);
}

.trebokov-hero {
    background: linear-gradient(90deg, rgba(28, 34, 24, .92), rgba(28, 34, 24, .55)), url("./sites/trebokov/trebokov-lidar-zones.png") center / cover no-repeat;
    color: #fff;
}

.tel-burna-hero {
    background: linear-gradient(90deg, rgba(45, 35, 25, .92), rgba(45, 35, 25, .55)), url("./sites/tel-burna/tel-burna-map-reconstruction.png") center / cover no-repeat;
    color: #fff;
}

    .trebokov-hero h2,
    .tel-burna-hero h2,
    .trebokov-hero .kicker,
    .tel-burna-hero .kicker {
        color: #fff;
    }

    .trebokov-hero p,
    .trebokov-hero .breadcrumb,
    .trebokov-hero .breadcrumb a,
    .tel-burna-hero p,
    .tel-burna-hero .breadcrumb,
    .tel-burna-hero .breadcrumb a {
        color: rgba(255, 255, 255, .9);
    }

.hero-figure {
    margin: 0;
    background: #fff;
    border: 1px solid var(--line);
    box-shadow: 0 16px 38px rgba(0, 0, 0, .08);
}

    .hero-figure img {
        display: block;
        width: 100%;
        height: auto;
        aspect-ratio: 16 / 10;
        object-fit: cover;
    }

    .hero-figure figcaption {
        font-size: .88rem;
        color: var(--muted);
        padding: .8rem 1rem;
        border-top: 1px solid var(--line);
    }

.quick-facts {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 0;
    border: 1px solid var(--line);
    margin-bottom: 4rem;
}

.fact {
    padding: 1rem;
    border-right: 1px solid var(--line);
    background: #fff;
}

    .fact:last-child {
        border-right: 0;
    }

    .fact span {
        display: block;
        color: var(--uk-red);
        font-weight: 800;
        font-size: .76rem;
        text-transform: uppercase;
        letter-spacing: .08em;
        margin-bottom: .35rem;
    }

    .fact strong {
        display: block;
        font-size: 1rem;
        line-height: 1.25;
    }

.map-layout {
    display: grid;
    grid-template-columns: 1.25fr .75fr;
    gap: 1.2rem;
}

.site-map {
    min-height: 320px;
    height: min(520px, 62vh);
    border: 1px solid var(--line);
    background: var(--soft);
}

.map-panel {
    border: 1px solid var(--line);
    padding: 1.35rem;
    background: #fff;
}

    .map-panel h3 {
        margin-top: 0;
    }

.map-btn {
    background: var(--uk-red);
    color: #fff;
    border: 0;
    padding: .75rem 1rem;
    font-weight: 800;
    cursor: pointer;
}

    .map-btn:hover {
        background: var(--uk-red-dark);
    }


/* =========================================================
   14. Studie, výstupy, časové osy
   ========================================================= */

.feature-cards .card {
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

    .feature-cards .card:hover {
        transform: translateY(-4px);
        box-shadow: 0 16px 32px rgba(0, 0, 0, .08);
        border-color: #c9c9c9;
    }

.result-timeline {
    border-left: 5px solid var(--uk-red);
    padding-left: 1.4rem;
    display: grid;
    gap: 1rem;
}

.time-item {
    position: relative;
    background: #fff;
    border: 1px solid var(--line);
    padding: 1rem 1.2rem;
}

    .time-item::before {
        content: "";
        position: absolute;
        left: -2.02rem;
        top: 1.15rem;
        width: 14px;
        height: 14px;
        border-radius: 50%;
        background: var(--uk-red);
        box-shadow: 0 0 0 5px #f7e8ea;
    }

    .time-item span {
        display: block;
        color: var(--uk-red);
        font-weight: 900;
        margin-bottom: .25rem;
    }

    .time-item p {
        margin: .2rem 0;
        color: #333;
    }

.study-preview {
    background: var(--soft);
    padding: 2rem;
    margin-left: -1.25rem;
    margin-right: -1.25rem;
}

    .study-preview + .study-preview {
        margin-top: 2rem;
    }

.study-card {
    width: min(100%, var(--max));
    margin: auto;
    background: #fff;
    border-top: 8px solid var(--uk-red);
    display: grid;
    grid-template-columns: 1.35fr .65fr;
    gap: 1.5rem;
    padding: 1.6rem;
    box-shadow: 0 18px 45px rgba(0, 0, 0, .08);
}

    .study-card h2 {
        font-size: 2rem;
        line-height: 1.1;
        margin: .2rem 0 .3rem;
    }

.lead-small {
    font-size: 1.1rem;
    color: #333;
    margin-top: 0;
}

.study-side {
    border-left: 1px solid var(--line);
    padding-left: 1.4rem;
}

    .study-side strong {
        display: block;
        color: var(--uk-red);
        font-size: 1.1rem;
        margin-bottom: .4rem;
    }

.method-cloud {
    display: flex;
    flex-wrap: wrap;
    gap: .35rem;
    margin: 1rem 0;
}

    .method-cloud span {
        border: 1px solid var(--line);
        background: #fafafa;
        padding: .32rem .55rem;
        font-size: .85rem;
        font-weight: 700;
    }

.figure-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.figure-tile {
    margin: 0;
    border: 1px solid var(--line);
    background: #fff;
    overflow: hidden;
}

    .figure-tile.wide {
        grid-column: span 2;
    }

        .figure-tile img,
        .figure-tile.wide img {
            display: block;
            width: 100%;
            height: auto;
            max-height: none;
            object-fit: contain;
            background: #fff;
        }

    .figure-tile figcaption {
        padding: .85rem 1rem;
        color: #444;
        border-top: 1px solid var(--line);
        font-size: .92rem;
    }

.leaflet-container {
    font-family: Arial, Helvetica, sans-serif;
}

.tel-burna-signals .card {
    border-top: 5px solid var(--uk-red);
}


/* =========================================================
   15. Flight hero
   ========================================================= */

.hero-flight {
    position: relative;
    min-height: 620px;
    overflow: hidden;
    background: #fff;
    border-bottom: 1px solid var(--line);
}

    .hero-flight::after {
        content: "";
        position: absolute;
        inset: 0;
        background: linear-gradient( 90deg, rgba(255, 255, 255, .96) 0%, rgba(255, 255, 255, .86) 40%, rgba(255, 255, 255, .36) 66%, rgba(255, 255, 255, .05) 100% );
        z-index: 1;
        pointer-events: none;
    }

.flight-bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    transform: perspective(900px) rotateX(var(--rx, 0deg)) rotateY(var(--ry, 0deg)) scale(1.04);
    transform-origin: center center;
    transition: transform .18s ease-out;
}

    .flight-bg svg {
        width: 100%;
        height: 100%;
        display: block;
    }

.flight-layer {
    transform-box: fill-box;
    transform-origin: center;
    will-change: transform;
}

.layer-back {
    animation: flyBack 28s linear infinite;
}

.layer-mid {
    animation: flyMid 20s linear infinite;
}

.layer-front {
    animation: flyFront 12s linear infinite;
}

.field-lines {
    animation: fieldPulse 5s ease-in-out infinite;
}

.river {
    stroke-dasharray: 18 24;
    animation: riverMove 3.8s linear infinite;
}

.flight-points circle {
    fill: var(--uk-red);
}

.flight-points .pulse {
    fill: none;
    stroke: var(--uk-red);
    stroke-width: 3;
    opacity: .75;
    animation: pulsePoint 2.8s ease-out infinite;
}

.flight-points .delay1 {
    animation-delay: .7s;
}

.flight-points .delay2 {
    animation-delay: 1.4s;
}

.flight-inner {
    position: relative;
    z-index: 2;
    background: none;
    grid-template-columns: 1.15fr .85fr;
    min-height: 620px;
    padding-top: 4.5rem;
    padding-bottom: 4.5rem;
}

.flight-copy {
    max-width: 760px;
}

.flight-card {
    align-self: end;
    backdrop-filter: blur(8px);
    background: rgba(255, 255, 255, .88);
}

.flight-note {
    font-size: .82rem;
    color: var(--muted);
    border-top: 1px solid var(--line);
    padding-top: .8rem;
    margin-top: .8rem;
}


/* =========================================================
   16. Video intro
   ========================================================= */

.video-intro {
    position: fixed !important;
    inset: 0 !important;
    z-index: 9999 !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background: #000;
    color: #fff;
    opacity: 1;
    visibility: visible;
    contain: layout paint;
    transition: opacity .8s ease, visibility .8s ease;
}

    .video-intro.is-hidden {
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
    }

.intro-fallback {
    position: absolute !important;
    inset: 0 !important;
    z-index: 1 !important;
    width: 100%;
    height: 100%;
    background-image: url("intro-landscape-fallback.jpg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    opacity: 1;
    transition: opacity .8s ease;
}

.intro-video {
    position: absolute !important;
    inset: 0 !important;
    z-index: 2 !important;
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
    background: transparent !important;
    opacity: 0;
    visibility: visible !important;
    transition: opacity .8s ease;
}

.video-intro.video-phase .intro-fallback {
    opacity: 0 !important;
}

.video-intro.video-phase .intro-video {
    opacity: 1 !important;
}

.intro-shade {
    position: absolute !important;
    inset: 0 !important;
    z-index: 3 !important;
    background: linear-gradient(90deg, rgba(0, 0, 0, .55), rgba(0, 0, 0, .15));
    pointer-events: none;
}

.intro-content {
    position: relative !important;
    z-index: 4 !important;
    width: min(920px, 94vw);
    max-width: 900px;
    padding: 2rem;
    text-align: center;
    color: #f4ead8;
}

    .intro-content h1 {
        margin: 0 0 1rem;
        font-size: clamp(2.4rem, 6vw, 5.6rem);
        line-height: .96;
        letter-spacing: -.055em;
        text-wrap: balance;
    }

    .intro-content p {
        margin: 0;
        font-size: clamp(1.05rem, 2vw, 1.45rem);
        color: rgba(255, 255, 255, .88);
    }

.intro-logo {
    width: clamp(60px, 10vw, 86px);
    height: clamp(60px, 10vw, 86px);
    background: rgba(255, 255, 255, .94);
    padding: .55rem;
    margin-bottom: 1.1rem;
}

.intro-kicker {
    color: #fff;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
    font-size: .9rem;
    margin-bottom: .7rem;
}

.intro-skip {
    margin-top: 2rem;
    border: 0;
    background: var(--uk-red);
    color: #fff;
    font-weight: 900;
    padding: .85rem 1.1rem;
    cursor: pointer;
}

    .intro-skip:hover {
        background: var(--uk-red-dark);
    }

.intro-progress {
    position: absolute !important;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 5 !important;
    height: 4px;
    background: rgba(255, 255, 255, .18);
}

    .intro-progress span {
        display: block;
        height: 100%;
        width: 100%;
        background: rgba(244, 234, 216, .85);
        animation: introProgress 11.2s linear forwards;
    }


/* =========================================================
   17. Deep-tech / spolupráce
   ========================================================= */

.deeptech-hero {
    position: relative;
    overflow: hidden;
    background: radial-gradient(circle at 72% 38%, rgba(181, 31, 42, .14), transparent 24%), linear-gradient(90deg, #fff 0%, #fff 54%, #f7e8ea 54%, #f7e8ea 100%);
    border-bottom: 1px solid var(--line);
}

    .deeptech-hero::before {
        content: "";
        position: absolute;
        inset: 0;
        background: linear-gradient(90deg, rgba(255, 255, 255, .95), rgba(255, 255, 255, .55)), repeating-linear-gradient(0deg, transparent 0 34px, rgba(181, 31, 42, .06) 35px 36px);
        pointer-events: none;
    }

.deeptech-inner {
    position: relative;
    width: min(100%, var(--max));
    margin: auto;
    padding: 5rem var(--container-pad);
    display: grid;
    grid-template-columns: 1.12fr .88fr;
    gap: 3rem;
    align-items: center;
}

.deeptech-copy h2 {
    font-size: 4.6rem;
    line-height: .92;
    margin: 0 0 1.2rem;
    letter-spacing: -.06em;
    max-width: 900px;
    text-wrap: balance;
}

.deeptech-lead {
    font-size: 1.55rem;
    color: var(--uk-red);
    font-weight: 900;
    margin: 0 0 1rem;
}

.deeptech-copy p {
    font-size: 1.12rem;
    color: #222;
    max-width: 760px;
}

.soil-memory-visual {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .75rem;
}

.core-caption {
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .14em;
    color: var(--muted);
    font-weight: 900;
}

.memory-core {
    position: relative;
    width: min(320px, 80vw);
    border-radius: 170px;
    overflow: hidden;
    border: 1px solid #d2c0af;
    box-shadow: 0 28px 70px rgba(0, 0, 0, .16);
    background: #fff;
}

.core-band {
    min-height: 92px;
    padding: 1.15rem 1.2rem;
    color: #fff;
    text-align: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: .2rem;
}

    .core-band strong {
        font-size: 1.45rem;
        line-height: 1;
    }

    .core-band span {
        font-size: .88rem;
        opacity: .95;
    }

.band-now {
    background: #5b3c2e;
}

.band-historic {
    background: #795039;
}

.band-medieval {
    background: #9a6a45;
}

.band-deep {
    background: #c08a57;
}

.scan-line {
    position: absolute;
    left: 0;
    right: 0;
    height: 4px;
    background: rgba(255, 255, 255, .95);
    box-shadow: 0 0 22px rgba(255, 255, 255, .95), 0 0 38px rgba(181, 31, 42, .55);
    animation: scanSoil 4.8s ease-in-out infinite;
}

.deep-signal-strip {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 4rem;
}

.deep-signal {
    background: #fff;
    border: 1px solid var(--line);
    padding: 1.25rem 1rem;
    text-align: center;
    box-shadow: 0 12px 30px rgba(0, 0, 0, .05);
}

    .deep-signal span {
        display: block;
        color: var(--uk-red);
        font-size: 2.15rem;
        font-weight: 900;
        letter-spacing: -.05em;
    }

    .deep-signal p {
        margin: .35rem 0 0;
        color: #333;
    }

.soil-engine {
    display: grid;
    grid-template-columns: 1fr auto 1fr auto 1fr auto 1fr;
    gap: 1rem;
    align-items: stretch;
}

.engine-step {
    border: 1px solid var(--line);
    background: #fff;
    padding: 1.25rem;
    cursor: pointer;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

    .engine-step:hover,
    .engine-step.active {
        transform: translateY(-4px);
        box-shadow: 0 18px 38px rgba(0, 0, 0, .09);
        border-color: var(--uk-red);
    }

    .engine-step.strong {
        border-top: 6px solid var(--uk-red);
    }

.engine-icon {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: var(--uk-red);
    color: #fff;
    font-weight: 900;
    margin-bottom: .8rem;
}

.engine-step h3 {
    margin: 0 0 .45rem;
}

.engine-step p {
    margin: 0;
    color: #444;
}

.engine-flow {
    display: grid;
    place-items: center;
    font-size: 2rem;
    font-weight: 900;
    color: var(--uk-red);
}

.engine-detail {
    margin-top: 1.2rem;
    background: #111;
    color: #fff;
    padding: 1.4rem;
    border-left: 7px solid var(--uk-red);
}

    .engine-detail p {
        color: #eee;
        margin: .35rem 0 0;
    }

.comparison-graphic {
    display: grid;
    gap: 1rem;
}

.comparison-row {
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: 1rem;
    align-items: center;
}

.comparison-label {
    font-weight: 900;
}

.comparison-bar {
    min-height: 54px;
    background: #f2eee7;
    border: 1px solid #ddcfbf;
    position: relative;
    overflow: hidden;
}

    .comparison-bar::before {
        content: "";
        position: absolute;
        inset: 0 auto 0 0;
        background: var(--uk-red);
        opacity: .9;
    }

    .comparison-bar.short::before {
        width: 14%;
    }

    .comparison-bar.medium::before {
        width: 28%;
    }

    .comparison-bar.long::before {
        width: 100%;
    }

    .comparison-bar span {
        position: relative;
        z-index: 1;
        display: block;
        padding: 1rem;
        font-weight: 900;
        color: #111;
    }

.comparison-row.deep .comparison-bar span {
    color: #fff;
}

.signal-tabs {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 1.2rem;
}

.signal-buttons {
    display: grid;
    gap: .5rem;
}

.signal-button {
    border: 1px solid var(--line);
    background: #fff;
    padding: 1rem;
    font-weight: 900;
    text-align: left;
    cursor: pointer;
    color: #111;
    font-family: inherit;
}

    .signal-button.active,
    .signal-button:hover {
        background: var(--uk-red);
        color: #fff;
    }

.signal-panel {
    display: none;
    background: #111;
    color: #fff;
    padding: 2rem;
    min-height: 240px;
    border-left: 8px solid var(--uk-red);
}

    .signal-panel.active {
        display: block;
    }

    .signal-panel h3 {
        margin: 0 0 .8rem;
        font-size: 3rem;
        color: #fff;
    }

    .signal-panel p {
        color: #eee;
        font-size: 1.15rem;
    }

.future-card {
    border-top: 7px solid var(--uk-red);
}

.partner-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.partner-tile {
    background: #111;
    color: #fff;
    padding: 1.3rem;
    min-height: 150px;
    border-top: 6px solid var(--uk-red);
}

    .partner-tile span {
        display: block;
        font-size: 1.15rem;
        font-weight: 900;
        margin-bottom: .65rem;
    }

    .partner-tile p {
        color: #ddd;
        margin: 0;
    }

.deeptech-cta-box {
    background: radial-gradient(circle at 90% 10%, rgba(181, 31, 42, .35), transparent 24%), #111;
    color: #fff;
    padding: 2.8rem;
    border-left: 8px solid var(--uk-red);
}

    .deeptech-cta-box h2 {
        color: #fff;
        font-size: 2.4rem;
        margin: .2rem 0 .7rem;
    }

    .deeptech-cta-box p {
        color: #eee;
        font-size: 1.12rem;
    }


/* =========================================================
   18. Now / Bluesky
   ========================================================= */

.now-section,
.now-live-section {
    width: min(100%, var(--max));
    margin: 90px auto;
    padding: 0 var(--container-pad);
}

.now-inner,
.now-live-inner {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 28px;
    align-items: stretch;
}

.now-copy,
.now-card,
.now-live-copy,
.now-live-card {
    min-width: 0;
    border-radius: 30px;
    box-shadow: 0 24px 70px rgba(0, 0, 0, .16);
}

.now-copy,
.now-live-copy {
    padding: 38px;
    background: #101915;
    color: #f4efe2;
}

    .now-copy .eyebrow,
    .now-live-copy .eyebrow {
        margin: 0 0 12px;
        font-size: .78rem;
        letter-spacing: .14em;
        text-transform: uppercase;
        color: #d7b46a;
    }

    .now-copy h2,
    .now-live-copy h2 {
        margin: 0 0 18px;
        max-width: 760px;
        font-size: clamp(2.2rem, 5vw, 4.2rem);
        line-height: .98;
    }

    .now-copy > p,
    .now-live-copy > p {
        margin: 0;
        max-width: 760px;
        color: rgba(244, 239, 226, .82);
        font-size: 1.05rem;
        line-height: 1.7;
    }

.now-status-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-top: 28px;
}

.now-status {
    padding: 18px;
    border-radius: 20px;
    background: rgba(255, 255, 255, .06);
    border: 1px solid rgba(255, 255, 255, .1);
}

    .now-status span {
        display: block;
        margin-bottom: 8px;
        color: #d7b46a;
        font-size: .78rem;
        text-transform: uppercase;
        letter-spacing: .1em;
    }

    .now-status p {
        margin: 0;
        color: rgba(244, 239, 226, .82);
        line-height: 1.55;
    }

.now-card,
.now-live-card {
    overflow: hidden;
    background: #fff;
    border: 1px solid rgba(0, 0, 0, .08);
}

.now-card-head,
.now-live-card-head {
    padding: 22px 24px;
    color: #fff;
    background: radial-gradient(circle at top right, rgba(60, 123, 255, .34), transparent 42%), #101915;
}

    .now-card-head span,
    .now-live-card-head span {
        display: block;
        margin-bottom: 6px;
        color: #8fb6ff;
        font-size: .78rem;
        text-transform: uppercase;
        letter-spacing: .14em;
    }

    .now-card-head strong,
    .now-live-card-head strong {
        display: block;
        font-size: 1.05rem;
        overflow-wrap: anywhere;
        color: #fff;
    }

.now-card-body,
.now-live-card-body {
    padding: 24px;
    background: #fff;
    color: #111;
}

    .now-card-body .bluesky-embed {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 auto !important;
        color: #111 !important;
        background: #fff !important;
    }

        .now-card-body .bluesky-embed p,
        .now-card-body .bluesky-embed a {
            color: #111 !important;
        }

.bsky-loading,
.bsky-error {
    margin: 0;
    color: var(--muted);
}

.bsky-post-text {
    margin: 0 0 18px;
    color: #111;
    font-size: 1.08rem;
    line-height: 1.65;
    white-space: pre-wrap;
}

.bsky-post-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
    padding-top: 16px;
    border-top: 1px solid var(--line);
    font-size: .9rem;
    color: var(--muted);
}

    .bsky-post-meta a {
        font-weight: 900;
    }

.bsky-post-image {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    max-height: 360px;
    object-fit: cover;
    border-radius: 18px;
    margin: 0 0 18px;
    background: var(--soft);
}


/* =========================================================
   19. Footer
   ========================================================= */

.footer {
    background: #111;
    color: #fff;
    margin-top: 3rem;
}

.footer-inner {
    width: min(100%, var(--max));
    margin: auto;
    padding: 2.2rem var(--container-pad);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
}

.footer p {
    color: #ddd;
    margin: .3rem 0;
}


/* =========================================================
   20. Animace
   ========================================================= */

@keyframes flyBack {
    0% {
        transform: translateX(0);
    }

    50% {
        transform: translateX(-2.5%);
    }

    100% {
        transform: translateX(0);
    }
}

@keyframes flyMid {
    0% {
        transform: translateX(0) translateY(0);
    }

    50% {
        transform: translateX(3%) translateY(1%);
    }

    100% {
        transform: translateX(0) translateY(0);
    }
}

@keyframes flyFront {
    0% {
        transform: translateX(-2%) scale(1.02);
    }

    50% {
        transform: translateX(2%) scale(1.06);
    }

    100% {
        transform: translateX(-2%) scale(1.02);
    }
}

@keyframes fieldPulse {
    0%, 100% {
        opacity: .55;
    }

    50% {
        opacity: .9;
    }
}

@keyframes riverMove {
    to {
        stroke-dashoffset: -84;
    }
}

@keyframes pulsePoint {
    0% {
        transform: scale(.7);
        opacity: .8;
    }

    100% {
        transform: scale(2.1);
        opacity: 0;
    }
}

@keyframes introProgress {
    from {
        width: 100%;
    }

    to {
        width: 0%;
    }
}

@keyframes scanSoil {
    0% {
        top: 4%;
    }

    50% {
        top: 94%;
    }

    100% {
        top: 4%;
    }
}


/* =========================================================
   21. Responzivita
   ========================================================= */

@media (max-width: 1100px) {
    .grid-3,
    .partner-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .quick-facts {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .soil-engine,
    .map-layout,
    .site-hero-grid,
    .study-card,
    .deeptech-inner,
    .signal-tabs {
        grid-template-columns: 1fr;
    }

    .study-side {
        border-left: 0;
        border-top: 1px solid var(--line);
        padding-left: 0;
        padding-top: 1rem;
    }

    .engine-flow {
        transform: rotate(90deg);
        min-height: 34px;
    }

    .deep-signal-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 980px) {
    .site-preview-image {
        aspect-ratio: 16 / 11;
    }
}

@media (max-width: 900px) {
    .section-head {
        grid-template-columns: 1fr;
        gap: 10px;
    }

        .section-head h2 {
            font-size: clamp(1.75rem, 7vw, 2.3rem);
        }

    .now-inner,
    .now-live-inner {
        grid-template-columns: 1fr;
    }

    .now-status-list {
        grid-template-columns: 1fr;
    }

    .now-copy,
    .now-live-copy {
        padding: 28px;
    }

    .team-hero .hero-inner,
    .research-hero .hero-inner,
    .locations-hero .hero-inner {
        grid-template-columns: 1fr;
    }

    .team-focus-card,
    .research-focus-card,
    .locations-focus-card {
        margin-top: .5rem;
    }
}

@media (max-width: 850px) {
    .brandbar-inner {
        align-items: flex-start;
        min-height: auto;
    }

    .brand {
        gap: .75rem;
    }

    .lang {
        padding-top: .2rem;
    }

    .nav-inner a {
        padding: .85rem .7rem;
        font-size: .94rem;
    }

    .hero,
    .clean-hero,
    .team-hero,
    .research-hero,
    .locations-hero,
    .vaclavak-hero {
        background: #fff;
    }

        .hero-inner,
        .clean-hero .hero-inner,
        .flight-inner {
            grid-template-columns: 1fr;
        }

    .hero-flight {
        min-height: auto;
    }

        .hero-flight::after {
            background: rgba(255, 255, 255, .86);
        }

    .flight-inner {
        min-height: auto;
        padding-top: 3rem;
        padding-bottom: 3rem;
    }

    .flight-bg {
        opacity: .75;
    }

    .hero-card,
    .flight-card {
        align-self: auto;
    }

    .cta,
    .site-actions,
    .now-actions,
    .now-live-actions {
        display: grid;
        grid-template-columns: 1fr;
    }

    .btn,
    .intro-skip,
    .map-btn {
        width: 100%;
        text-align: center;
    }

    main {
        padding-top: 2rem;
        padding-bottom: 2rem;
    }

    section {
        margin-bottom: 3rem;
    }

    .band,
    .study-preview,
    .deeptech-cta-box {
        padding: 1.35rem;
    }

    .now-section,
    .now-live-section,
    .site-preview-section {
        margin-top: 64px;
        margin-bottom: 64px;
    }

    .now-copy,
    .now-live-copy,
    .now-card,
    .now-live-card {
        border-radius: 22px;
    }

    .site-map {
        height: 420px;
    }
}

@media (max-width: 700px) {
    .grid-2,
    .grid-3,
    .quick-facts,
    .deep-signal-strip,
    .partner-grid,
    .figure-grid,
    .now-status-list {
        grid-template-columns: 1fr;
    }

    .figure-tile.wide {
        grid-column: auto;
    }

    .deeptech-copy h2 {
        font-size: clamp(2.4rem, 13vw, 3rem);
    }

    .signal-panel h3 {
        font-size: clamp(2rem, 10vw, 3rem);
    }

    .comparison-row {
        grid-template-columns: 1fr;
    }

    .advisor-card-bootstrap {
        display: block;
    }

        .advisor-card-bootstrap .advisor-photo,
        .advisor-card-bootstrap .advisor-initial {
            width: 120px;
            height: 145px;
            margin-bottom: 1rem;
        }

    .site-preview-image {
        aspect-ratio: 4 / 3;
        min-height: 160px;
    }

    .site-preview-content {
        padding: 1.15rem;
    }

    .site-preview-overlay {
        left: 1rem;
        right: 1rem;
        bottom: 1rem;
    }
}

@media (max-width: 576px) {
    .topbar-inner {
        display: block;
        font-size: .82rem;
    }

    .brandbar-inner {
        gap: .75rem;
    }

    .brand p {
        display: none;
    }

    .nav-inner a {
        padding: .78rem .62rem;
        font-size: .9rem;
    }

    .hero-inner,
    .site-hero-inner,
    .deeptech-inner {
        padding-top: 2.4rem;
        padding-bottom: 2.4rem;
    }

    .hero h2,
    .site-hero h2 {
        font-size: clamp(2.1rem, 12vw, 2.9rem);
    }

    .hero .lead,
    .site-hero p {
        font-size: 1.05rem;
    }

    .card,
    .hero-card,
    .team-focus-card,
    .research-focus-card,
    .locations-focus-card,
    .map-panel,
    .site-preview-content,
    .now-live-copy,
    .now-live-card-body,
    .now-copy,
    .now-card-body {
        padding: 1.15rem;
    }

    .site-preview-image {
        aspect-ratio: 4 / 3;
    }

    .site-preview-overlay strong {
        font-size: .98rem;
    }

    .site-tags span {
        font-size: .74rem;
    }

    .site-map {
        height: 340px;
    }

    .intro-content {
        padding: 1rem;
    }

        .intro-content h1 {
            font-size: clamp(2rem, 14vw, 3.4rem);
        }

        .intro-content p {
            font-size: 1rem;
        }

    .intro-progress {
        height: 3px;
    }

    .person-photo,
    .advisor-photo,
    .advisor-card-bootstrap .advisor-initial {
        max-width: 130px;
    }
}


/* =========================================================
   22. Reduced motion
   ========================================================= */

@media (prefers-reduced-motion: reduce) {
    html {
        scroll-behavior: auto;
    }

    *,
    *::before,
    *::after {
        animation-duration: .01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .01ms !important;
    }

    .intro-progress span {
        animation: none !important;
        width: 0 !important;
    }
}


/* =========================================================
   23. Tisk
   ========================================================= */

@media print {
    .video-intro,
    nav,
    .cta,
    .site-actions,
    .now-live-section,
    .now-section,
    .intro-progress {
        display: none !important;
    }

    body {
        color: #000;
        background: #fff;
    }

    a {
        color: #000;
        text-decoration: underline;
    }

    main,
    .site-preview-section {
        max-width: none;
        padding: 0;
    }

    .card,
    .hero-card,
    .site-featured-card {
        box-shadow: none;
        break-inside: avoid;
    }
}


/* =========================================================
   TVRDÉ SJEDNOCENÍ HERO PRO TÝM / VÝZKUM / LOKALITY
   vložit úplně na konec style.css
   ========================================================= */

.team-hero,
.research-hero,
.locations-hero {
    padding: 0 !important;
    margin: 0 !important;
    background: linear-gradient( 90deg, #fff 0%, #fff 58%, var(--soft-red) 58%, var(--soft-red) 100% ) !important;
    border-bottom: 1px solid var(--line) !important;
}

    .team-hero .container,
    .research-hero .container,
    .locations-hero .container {
        width: min(100%, var(--max)) !important;
        max-width: var(--max) !important;
        margin: 0 auto !important;
        padding-left: var(--container-pad) !important;
        padding-right: var(--container-pad) !important;
    }

    .team-hero .row,
    .research-hero .row,
    .locations-hero .row {
        display: grid !important;
        grid-template-columns: 1.35fr .65fr !important;
        gap: clamp(1.5rem, 4vw, 3rem) !important;
        align-items: center !important;
        margin: 0 !important;
        padding: clamp(3rem, 7vw, 5rem) 0 !important;
    }

    .team-hero [class*="col-"],
    .research-hero [class*="col-"],
    .locations-hero [class*="col-"] {
        width: auto !important;
        max-width: none !important;
        flex: none !important;
        padding: 0 !important;
    }

    .team-hero h2,
    .research-hero h2,
    .locations-hero h2 {
        font-size: clamp(2.35rem, 7vw, 4rem) !important;
        line-height: .98 !important;
        margin: 0 0 1.25rem !important;
        font-weight: 900 !important;
        letter-spacing: -.04em !important;
        color: #111 !important;
    }

    .team-hero .kicker,
    .research-hero .kicker,
    .locations-hero .kicker {
        margin: 0 0 1rem !important;
        color: var(--uk-red) !important;
        font-size: .83rem !important;
        font-weight: 800 !important;
        letter-spacing: .08em !important;
        text-transform: uppercase !important;
    }

    .team-hero .lead,
    .research-hero .lead,
    .locations-hero .lead,
    .team-hero .site-hero-lead,
    .research-hero .site-hero-lead,
    .locations-hero .site-hero-lead {
        font-size: clamp(1.08rem, 2.4vw, 1.42rem) !important;
        max-width: 800px !important;
        color: #111 !important;
        margin: 0 0 1.1rem !important;
        line-height: 1.55 !important;
    }

.team-focus-card,
.research-focus-card,
.locations-focus-card {
    background: #fff !important;
    border-top: 7px solid var(--uk-red) !important;
    border-radius: 0 !important;
    box-shadow: 0 14px 40px rgba(0, 0, 0, .08) !important;
    padding: 1.7rem !important;
    margin: 0 !important;
}

    .team-focus-card h3,
    .research-focus-card h3,
    .locations-focus-card h3 {
        margin: 0 0 .9rem !important;
        font-size: 1.2rem !important;
        line-height: 1.25 !important;
        font-weight: 400 !important;
        color: #111 !important;
    }

    .team-focus-card p,
    .research-focus-card p,
    .locations-focus-card p {
        margin: 0 !important;
        color: var(--muted) !important;
        line-height: 1.6 !important;
    }

/* mobil */

@media (max-width: 850px) {
    .team-hero,
    .research-hero,
    .locations-hero {
        background: #fff !important;
    }

        .team-hero .row,
        .research-hero .row,
        .locations-hero .row {
            grid-template-columns: 1fr !important;
            padding: 2.5rem 0 !important;
        }
}


/* =========================================================
   ZMENŠENÍ HERO PRO TÝM / VÝZKUM / LOKALITY
   vložit úplně na konec style.css
   ========================================================= */

.team-hero,
.research-hero,
.locations-hero {
    background: linear-gradient( 90deg, #fff 0%, #fff 60%, var(--soft-red) 60%, var(--soft-red) 100% ) !important;
}

    .team-hero .row,
    .research-hero .row,
    .locations-hero .row {
        grid-template-columns: 1.2fr .8fr !important;
        padding: 2.7rem 0 !important;
        align-items: center !important;
    }

    .team-hero h2,
    .research-hero h2,
    .locations-hero h2 {
        font-size: clamp(2.4rem, 5vw, 3.25rem) !important;
        line-height: 1 !important;
        margin-bottom: 1rem !important;
        letter-spacing: -.045em !important;
    }

    .team-hero .kicker,
    .research-hero .kicker,
    .locations-hero .kicker {
        margin-bottom: .7rem !important;
        font-size: .78rem !important;
    }

    .team-hero .lead,
    .research-hero .lead,
    .locations-hero .lead,
    .team-hero .site-hero-lead,
    .research-hero .site-hero-lead,
    .locations-hero .site-hero-lead {
        font-size: clamp(1rem, 1.7vw, 1.16rem) !important;
        line-height: 1.45 !important;
        max-width: 720px !important;
        margin-bottom: 0 !important;
    }

.team-focus-card,
.research-focus-card,
.locations-focus-card {
    max-width: 340px !important;
    margin-left: auto !important;
    padding: 1.35rem !important;
    border-top-width: 6px !important;
}

    .team-focus-card h3,
    .research-focus-card h3,
    .locations-focus-card h3 {
        font-size: 1.05rem !important;
        margin-bottom: .7rem !important;
    }

    .team-focus-card p,
    .research-focus-card p,
    .locations-focus-card p {
        font-size: .95rem !important;
        line-height: 1.55 !important;
    }

/* mobil */

@media (max-width: 850px) {
    .team-hero,
    .research-hero,
    .locations-hero {
        background: #fff !important;
    }

        .team-hero .row,
        .research-hero .row,
        .locations-hero .row {
            grid-template-columns: 1fr !important;
            padding: 2.2rem 0 !important;
        }

    .team-focus-card,
    .research-focus-card,
    .locations-focus-card {
        max-width: none !important;
        margin-left: 0 !important;
    }
}


/* Metody sjednocené s Tým / Výzkum / Lokality */

.methods-hero {
    padding: 0 !important;
    margin: 0 !important;
    background: linear-gradient( 90deg, #fff 0%, #fff 60%, var(--soft-red) 60%, var(--soft-red) 100% ) !important;
    border-bottom: 1px solid var(--line) !important;
}

    .methods-hero .hero-inner {
        width: min(100%, var(--max)) !important;
        margin: 0 auto !important;
        padding: 2.7rem var(--container-pad) !important;
        display: grid !important;
        grid-template-columns: 1.2fr .8fr !important;
        gap: clamp(1.5rem, 4vw, 3rem) !important;
        align-items: center !important;
    }

    .methods-hero h2 {
        font-size: clamp(2.4rem, 5vw, 3.25rem) !important;
        line-height: 1 !important;
        margin: 0 0 1rem !important;
        font-weight: 900 !important;
        letter-spacing: -.045em !important;
        color: #111 !important;
    }

    .methods-hero .kicker {
        margin: 0 0 .7rem !important;
        color: var(--uk-red) !important;
        font-size: .78rem !important;
        font-weight: 800 !important;
        letter-spacing: .08em !important;
        text-transform: uppercase !important;
    }

    .methods-hero .lead {
        font-size: clamp(1rem, 1.7vw, 1.16rem) !important;
        line-height: 1.45 !important;
        max-width: 720px !important;
        margin: 0 !important;
        color: #111 !important;
    }

.methods-focus-card {
    max-width: 340px !important;
    margin-left: auto !important;
    background: #fff !important;
    border-top: 6px solid var(--uk-red) !important;
    border-radius: 0 !important;
    box-shadow: 0 14px 40px rgba(0, 0, 0, .08) !important;
    padding: 1.35rem !important;
}

    .methods-focus-card h3 {
        font-size: 1.05rem !important;
        margin: 0 0 .7rem !important;
        line-height: 1.25 !important;
        font-weight: 400 !important;
        color: #111 !important;
    }

    .methods-focus-card p {
        margin: 0 !important;
        color: var(--muted) !important;
        font-size: .95rem !important;
        line-height: 1.55 !important;
    }

@media (max-width: 850px) {
    .methods-hero {
        background: #fff !important;
    }

        .methods-hero .hero-inner {
            grid-template-columns: 1fr !important;
            padding: 2.2rem var(--container-pad) !important;
        }

    .methods-focus-card {
        max-width: none !important;
        margin-left: 0 !important;
    }
}



/* Výstupy sjednocené s ostatními stránkami */

.outputs-hero {
    padding: 0 !important;
    margin: 0 !important;
    background: linear-gradient( 90deg, #fff 0%, #fff 60%, var(--soft-red) 60%, var(--soft-red) 100% ) !important;
    border-bottom: 1px solid var(--line) !important;
}

    .outputs-hero .hero-inner {
        width: min(100%, var(--max)) !important;
        margin: 0 auto !important;
        padding: 2.7rem var(--container-pad) !important;
        display: grid !important;
        grid-template-columns: 1.2fr .8fr !important;
        gap: clamp(1.5rem, 4vw, 3rem) !important;
        align-items: center !important;
    }

    .outputs-hero h2 {
        font-size: clamp(2.4rem, 5vw, 3.25rem) !important;
        line-height: 1 !important;
        margin: 0 0 1rem !important;
        font-weight: 900 !important;
        letter-spacing: -.045em !important;
        color: #111 !important;
    }

    .outputs-hero .kicker {
        margin: 0 0 .7rem !important;
        color: var(--uk-red) !important;
        font-size: .78rem !important;
        font-weight: 800 !important;
        letter-spacing: .08em !important;
        text-transform: uppercase !important;
    }

    .outputs-hero .lead {
        font-size: clamp(1rem, 1.7vw, 1.16rem) !important;
        line-height: 1.45 !important;
        max-width: 720px !important;
        margin: 0 !important;
        color: #111 !important;
    }

.outputs-focus-card {
    max-width: 340px !important;
    margin-left: auto !important;
    background: #fff !important;
    border-top: 6px solid var(--uk-red) !important;
    border-radius: 0 !important;
    box-shadow: 0 14px 40px rgba(0, 0, 0, .08) !important;
    padding: 1.35rem !important;
}

    .outputs-focus-card h3 {
        font-size: 1.05rem !important;
        margin: 0 0 .7rem !important;
        line-height: 1.25 !important;
        font-weight: 400 !important;
        color: #111 !important;
    }

    .outputs-focus-card p {
        margin: 0 !important;
        color: var(--muted) !important;
        font-size: .95rem !important;
        line-height: 1.55 !important;
    }

@media (max-width: 850px) {
    .outputs-hero {
        background: #fff !important;
    }

        .outputs-hero .hero-inner {
            grid-template-columns: 1fr !important;
            padding: 2.2rem var(--container-pad) !important;
        }

    .outputs-focus-card {
        max-width: none !important;
        margin-left: 0 !important;
    }
}