/* ============================================================
   AMIS VetCare – Main Stylesheet
   Fonts: DM Serif Display (headings) + Plus Jakarta Sans (body)
   ============================================================ */

/* ============================================================
   1. CSS Custom Properties
   ============================================================ */
:root {
    /* Colours */
    --clr-primary:        #0B3D91;
    --clr-primary-dark:   #082d6b;
    --clr-primary-mid:    #1565C0;
    --clr-primary-light:  #2196F3;
    --clr-accent:         #00ACC1;
    --clr-accent-dark:    #00838F;
    --clr-success:        #27AE60;
    --clr-warning:        #F39C12;
    --clr-danger:         #E74C3C;

    --clr-bg:             #F5F9FF;
    --clr-bg-alt:         #EBF3FF;
    --clr-surface:        #FFFFFF;
    --clr-border:         #D1E3F8;

    --clr-text:           #0D1B2A;
    --clr-text-body:      #374151;
    --clr-text-muted:     #6B7280;
    --clr-text-light:     #9CA3AF;

    /* Gradients */
    --gradient-hero: linear-gradient(135deg, #0B3D91 0%, #1565C0 55%, #0097A7 100%);
    --gradient-card: linear-gradient(145deg, #ffffff 0%, #EBF3FF 100%);

    /* Typography */
    --font-heading: 'DM Serif Display', Georgia, serif;
    --font-body:    'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;

    /* Sizes */
    --container-width: 1200px;
    --container-px:    clamp(1rem, 4vw, 2rem);

    /* Spacing scale */
    --sp-xs:  0.25rem;
    --sp-sm:  0.5rem;
    --sp-md:  1rem;
    --sp-lg:  1.5rem;
    --sp-xl:  2rem;
    --sp-2xl: 3rem;
    --sp-3xl: 4rem;
    --sp-4xl: 6rem;
    --sp-5xl: 8rem;

    /* Radius */
    --radius-sm:   0.375rem;
    --radius-md:   0.75rem;
    --radius-lg:   1.25rem;
    --radius-xl:   2rem;
    --radius-full: 9999px;

    /* Shadows */
    --shadow-sm:  0 1px 3px rgba(11,61,145,.06), 0 1px 2px rgba(0,0,0,.04);
    --shadow-md:  0 4px 16px rgba(11,61,145,.10), 0 2px 4px rgba(0,0,0,.04);
    --shadow-lg:  0 10px 40px rgba(11,61,145,.14), 0 4px 8px rgba(0,0,0,.04);
    --shadow-xl:  0 20px 60px rgba(11,61,145,.18);

    /* Transitions */
    --ease:       cubic-bezier(0.4, 0, 0.2, 1);
    --ease-out:   cubic-bezier(0, 0, 0.2, 1);
    --dur-fast:   150ms;
    --dur-med:    300ms;
    --dur-slow:   500ms;

    /* Nav */
    --nav-h:      72px;
}

/* ============================================================
   2. Reset & Base
   ============================================================ */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
    scroll-padding-top: calc(var(--nav-h) + var(--infobar-h, 0px));
    font-size: 16px;
    -webkit-text-size-adjust: 100%;
}

body {
    font-family: var(--font-body);
    font-size: 1rem;
    line-height: 1.7;
    color: var(--clr-text-body);
    background: var(--clr-surface);
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
}

img, video, svg {
    display: block;
    max-width: 100%;
    height: auto;
}

a {
    color: var(--clr-primary-mid);
    text-decoration: none;
    transition: color var(--dur-fast) var(--ease);
}
a:hover { color: var(--clr-primary); }

ul, ol { list-style: none; }

address { font-style: normal; }

button {
    font-family: inherit;
    cursor: pointer;
    border: none;
    background: transparent;
}

/* Focus visible */
:focus-visible {
    outline: 2px solid var(--clr-accent);
    outline-offset: 3px;
    border-radius: var(--radius-sm);
}

/* Selection */
::selection {
    background: var(--clr-primary-light);
    color: white;
}

/* ============================================================
   3. Info lišta
   ============================================================ */
.info-bar {
    background: #FFB300;
    color: #0B2545;
    padding: .625rem 0;
    font-size: .875rem;
    font-weight: 500;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 150; /* nad nav (100), pod modálmi */
}

.info-bar__inner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .75rem;
    flex-wrap: wrap;
    text-align: center;
}

.info-bar__icon {
    flex-shrink: 0;
    opacity: .8;
}

.info-bar__text {
    line-height: 1.5;
}

.info-bar__btn {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    background: rgba(0, 0, 0, .15);
    color: inherit;
    text-decoration: none;
    padding: .25rem .75rem;
    border-radius: 999px;
    font-weight: 600;
    font-size: .8125rem;
    white-space: nowrap;
    transition: background .15s;
    flex-shrink: 0;
}

.info-bar__btn:hover {
    background: rgba(0, 0, 0, .25);
    color: inherit;
}

/* ============================================================
   4. Layout Utilities
   ============================================================ */
.container {
    max-width: var(--container-width);
    margin-inline: auto;
    padding-inline: var(--container-px);
}

.section {
    padding-block: var(--sp-5xl);
}

.section--alt {
    background: var(--clr-bg);
}

.section__header {
    text-align: center;
    margin-bottom: var(--sp-4xl);
}

.section__eyebrow {
    display: inline-block;
    font-family: var(--font-body);
    font-size: 0.8125rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--clr-accent-dark);
    background: rgba(0, 172, 193, 0.1);
    padding: 0.35rem 1rem;
    border-radius: var(--radius-full);
    margin-bottom: var(--sp-md);
}

.section__title {
    font-family: var(--font-heading);
    font-size: clamp(2rem, 4vw, 2.875rem);
    font-weight: 400;
    line-height: 1.15;
    color: var(--clr-text);
    margin-bottom: var(--sp-md);
}

.section__lead {
    font-size: 1.1rem;
    color: var(--clr-text-muted);
    max-width: 56ch;
    margin-inline: auto;
    line-height: 1.75;
}

/* ============================================================
   4. Buttons
   ============================================================ */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.8125rem 1.75rem;
    font-family: var(--font-body);
    font-size: 0.9375rem;
    font-weight: 600;
    line-height: 1;
    border-radius: var(--radius-full);
    transition:
        background var(--dur-med) var(--ease),
        color var(--dur-med) var(--ease),
        transform var(--dur-fast) var(--ease),
        box-shadow var(--dur-med) var(--ease);
    white-space: nowrap;
    cursor: pointer;
    text-decoration: none;
}

.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }

.btn--primary {
    background: var(--clr-primary-mid);
    color: #fff;
    box-shadow: 0 4px 20px rgba(21, 101, 192, 0.35);
}
.btn--primary:hover {
    background: var(--clr-primary);
    color: #fff;
    box-shadow: 0 8px 30px rgba(21, 101, 192, 0.45);
}

.btn--accent {
    background: var(--clr-accent);
    color: #fff;
    box-shadow: 0 4px 20px rgba(0, 172, 193, 0.35);
}
.btn--accent:hover {
    background: var(--clr-accent-dark);
    color: #fff;
    box-shadow: 0 8px 30px rgba(0, 172, 193, 0.45);
}

.btn--outline-white {
    background: transparent;
    color: #fff;
    border: 2px solid rgba(255,255,255,0.7);
}
.btn--outline-white:hover {
    background: rgba(255,255,255,0.12);
    color: #fff;
    border-color: #fff;
}

.btn--outline-primary {
    background: transparent;
    color: var(--clr-primary-mid);
    border: 2px solid var(--clr-primary-mid);
}
.btn--outline-primary:hover {
    background: var(--clr-primary-mid);
    color: #fff;
}

.btn--lg {
    padding: 1rem 2.25rem;
    font-size: 1.0625rem;
}

/* ============================================================
   5. Navigation
   ============================================================ */
.site-header {
    position: fixed;
    top: var(--infobar-h, 0px);
    left: 0;
    right: 0;
    z-index: 100;
    height: var(--nav-h);
    transition:
        background var(--dur-med) var(--ease),
        box-shadow var(--dur-med) var(--ease),
        backdrop-filter var(--dur-med) var(--ease);
    background: transparent;
}

.site-header.scrolled {
    background: rgba(11, 61, 145, 0.96);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    box-shadow: 0 2px 20px rgba(0,0,0,0.15);
}

.nav {
    display: flex;
    align-items: center;
    gap: var(--sp-xl);
    height: var(--nav-h);
}

/* Logo */
.nav__logo {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    text-decoration: none;
    color: #fff;
    flex-shrink: 0;
}
.nav__logo:hover,
.nav__logo:focus { color: #fff; text-decoration: none; opacity: 1; }
.nav__logo:hover .nav__logo-name { color: #fff; }
.nav__logo:hover .nav__logo-sub  { color: rgba(255,255,255,0.75); }
/* WordPress custom-logo-link hover override */
.nav__logo .custom-logo-link:hover,
.nav__logo .custom-logo-link:focus { opacity: 1; }

.nav__logo svg {
    flex-shrink: 0;
    filter: drop-shadow(0 2px 4px rgba(0,0,0,0.2));
}

.nav__logo-text {
    display: flex;
    flex-direction: column;
    line-height: 1.1;
}

.nav__logo-name {
    font-family: var(--font-heading);
    font-size: 1.375rem;
    color: #fff;
    letter-spacing: 0.04em;
}

.nav__logo-sub {
    font-size: 0.6875rem;
    font-weight: 500;
    color: rgba(255,255,255,0.75);
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

/* Nav links */
.nav__links {
    display: flex;
    align-items: center;
    gap: var(--sp-lg);
    margin-left: auto;
}

.nav__link {
    font-size: 0.9375rem;
    font-weight: 500;
    color: rgba(255,255,255,0.88);
    text-decoration: none;
    padding: 0.25rem 0;
    position: relative;
    transition: color var(--dur-fast) var(--ease);
}

.nav__link::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 0;
    height: 2px;
    background: var(--clr-accent);
    border-radius: 1px;
    transition: width var(--dur-med) var(--ease);
}

.nav__link:hover,
.nav__link--active {
    color: #fff;
}

.nav__link:hover::after,
.nav__link--active::after {
    width: 100%;
}

/* CTA */
.nav__cta {
    padding: 0.5rem 1.25rem;
    font-size: 0.875rem;
    font-weight: 600;
    flex-shrink: 0;
}

/* Hamburger */
.nav__hamburger {
    display: none;
    flex-direction: column;
    gap: 5px;
    padding: 8px;
    margin-left: auto;
    border-radius: var(--radius-sm);
    background: transparent;
    border: none;
    cursor: pointer;
    transition: background var(--dur-fast) var(--ease);
}
.nav__hamburger:hover { background: rgba(255,255,255,0.1); }

.nav__hamburger-line {
    display: block;
    width: 24px;
    height: 2px;
    background: #fff;
    border-radius: 1px;
    transition:
        transform var(--dur-med) var(--ease),
        opacity var(--dur-med) var(--ease);
    transform-origin: center;
}

.nav__hamburger.is-open .nav__hamburger-line:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
}
.nav__hamburger.is-open .nav__hamburger-line:nth-child(2) {
    opacity: 0;
}
.nav__hamburger.is-open .nav__hamburger-line:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
}

/* ============================================================
   6. Hero Section
   ============================================================ */
.hero {
    position: relative;
    min-height: 100svh;
    display: flex;
    align-items: center;
    background: var(--gradient-hero);
    overflow: hidden;
    padding-top: calc(var(--nav-h) + var(--infobar-h, 0px));
}

/* Decorative shapes */
.hero::before {
    content: '';
    position: absolute;
    top: -15%;
    right: -10%;
    width: 60vw;
    max-width: 720px;
    aspect-ratio: 1;
    background: radial-gradient(circle, rgba(255,255,255,0.06) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
}

.hero::after {
    content: '';
    position: absolute;
    bottom: -20%;
    left: -8%;
    width: 50vw;
    max-width: 600px;
    aspect-ratio: 1;
    background: radial-gradient(circle, rgba(0,172,193,0.12) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
}

.hero__inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-4xl);
    align-items: center;
    padding-block: var(--sp-2xl);
}

.hero__content {}

.hero__badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background: rgba(255,255,255,0.15);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,0.2);
    color: rgba(255,255,255,0.95);
    padding: 0.4rem 1rem;
    border-radius: var(--radius-full);
    font-size: 0.8125rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin-bottom: var(--sp-xl);
}

.hero__badge-dot {
    width: 8px;
    height: 8px;
    background: #4caf50;
    border-radius: 50%;
    box-shadow: 0 0 0 3px rgba(76,175,80,0.25);
    animation: pulse 2s ease-in-out infinite;
}

@keyframes pulse {
    0%, 100% { box-shadow: 0 0 0 3px rgba(76,175,80,0.25); }
    50%       { box-shadow: 0 0 0 6px rgba(76,175,80,0.1); }
}

.hero__title {
    font-family: var(--font-heading);
    font-size: clamp(2.5rem, 5.5vw, 4rem);
    font-weight: 400;
    line-height: 1.1;
    color: #fff;
    margin-bottom: var(--sp-lg);
}

.hero__title em {
    font-style: italic;
    color: rgba(255,255,255,0.85);
}

.hero__title-accent {
    background: linear-gradient(135deg, #80DEEA 0%, #4FC3F7 55%, #29B6F6 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
    display: block;
}

.hero__subtitle {
    font-size: 1.125rem;
    color: rgba(255,255,255,0.82);
    line-height: 1.75;
    margin-bottom: var(--sp-2xl);
    max-width: 52ch;
}

.hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-md);
    margin-bottom: var(--sp-3xl);
}

/* Hero stats strip */
.hero__stats {
    display: flex;
    gap: var(--sp-xl);
    flex-wrap: wrap;
}

.hero__stat {
    display: flex;
    flex-direction: column;
}

.hero__stat-val {
    font-family: var(--font-heading);
    font-size: 2rem;
    color: #fff;
    line-height: 1;
}

.hero__stat-label {
    font-size: 0.8125rem;
    color: rgba(255,255,255,0.65);
    font-weight: 500;
    margin-top: 0.25rem;
}

/* Hero visual (right side) */
.hero__visual {
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
}

.hero__card {
    background: rgba(255,255,255,0.12);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(255,255,255,0.2);
    border-radius: var(--radius-xl);
    padding: var(--sp-2xl);
    width: 100%;
    max-width: 380px;
    box-shadow: var(--shadow-xl);
}

.hero__card-title {
    font-family: var(--font-heading);
    font-size: 1.5rem;
    color: #fff;
    margin-bottom: var(--sp-lg);
}

.hero__hours-list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.hero__hours-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.45rem 0;           /* trochu kompaktnejšie pre 7 riadkov */
    border-bottom: 1px solid rgba(255,255,255,0.08);
    font-size: 0.875rem;
    color: rgba(255,255,255,0.9);
}

.hero__hours-item:last-child { border-bottom: none; }

.hero__hours-day { font-weight: 500; }

.hero__hours-time {
    font-weight: 600;
    color: #80DEEA;
}

.hero__hours-time--closed {
    color: rgba(255,255,255,0.35) !important;
    font-weight: 400 !important;
}

.hero__hours-item--today {
    background: rgba(128,222,234,0.13);
    border-radius: 6px;
    border-bottom-color: transparent;
    padding: 0.45rem 0.625rem;
    margin-inline: -0.625rem;
}
.hero__hours-item--today .hero__hours-day {
    color: #fff;
    font-weight: 700;
}

.hero__card-phone {
    margin-top: var(--sp-md);
    padding-top: var(--sp-md);
    border-top: 1px solid rgba(255,255,255,0.15);
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
}

.hero__card-contacts {
    display: flex;
    gap: var(--sp-lg);
    flex-wrap: wrap;
}

.hero__card-contacts > div {
    display: flex;
    flex-direction: column;
}

.hero__phone-label {
    font-size: 0.75rem;
    color: rgba(255,255,255,0.55);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 0.15rem;
}

.hero__phone-number {
    font-family: var(--font-heading);
    font-size: 1.375rem;
    color: #fff;
    text-decoration: none;
    transition: color var(--dur-fast) var(--ease);
    line-height: 1.2;
}
.hero__phone-number:hover { color: #80DEEA; }

/* Sociálne siete v Hero sekcii */
.hero__socials {
    display: flex;
    gap: 0.625rem;
    margin-top: var(--sp-xl);
    flex-wrap: wrap;
    align-items: center;
}

.hero__social-link {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.5rem 1.1rem;
    background: rgba(255,255,255,0.1);
    border: 1px solid rgba(255,255,255,0.2);
    border-radius: var(--radius-full);
    color: rgba(255,255,255,0.88);
    font-size: 0.875rem;
    font-weight: 600;
    text-decoration: none;
    transition:
        background var(--dur-fast) var(--ease),
        border-color var(--dur-fast) var(--ease),
        color var(--dur-fast) var(--ease);
}

.hero__social-link:hover {
    background: rgba(255,255,255,0.2);
    border-color: rgba(255,255,255,0.5);
    color: #fff;
}

/* Floating paw decorations */
.hero__paw {
    position: absolute;
    opacity: 0.06;
    pointer-events: none;
}
.hero__paw--1 {
    top: 10%;
    right: 5%;
    width: 120px;
    transform: rotate(20deg);
}
.hero__paw--2 {
    bottom: 15%;
    left: 2%;
    width: 80px;
    transform: rotate(-15deg);
}

/* ============================================================
   7. Services Section
   ============================================================ */
.services {
    background: var(--clr-surface);
    position: relative;
    overflow: hidden;
}

.services__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: var(--sp-lg);
}

.service-card {
    background: var(--clr-surface);
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-lg);
    padding: var(--sp-xl) var(--sp-xl) var(--sp-lg);
    position: relative;
    overflow: hidden;
    transition:
        transform var(--dur-med) var(--ease),
        box-shadow var(--dur-med) var(--ease),
        border-color var(--dur-med) var(--ease);
    cursor: default;
}

.service-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--clr-primary-mid), var(--clr-accent));
    opacity: 0;
    transition: opacity var(--dur-med) var(--ease);
}

.service-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-lg);
    border-color: var(--clr-primary-light);
}
.service-card:hover::before { opacity: 1; }

.service-card__icon {
    width: 56px;
    height: 56px;
    background: linear-gradient(135deg, var(--clr-bg), var(--clr-bg-alt));
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: var(--sp-lg);
    color: var(--clr-primary-mid);
    transition: background var(--dur-med) var(--ease), color var(--dur-med) var(--ease);
    flex-shrink: 0;
}

.service-card:hover .service-card__icon {
    background: linear-gradient(135deg, var(--clr-primary-mid), var(--clr-accent));
    color: #fff;
}

.service-card__title {
    font-family: var(--font-heading);
    font-size: 1.3125rem;
    font-weight: 400;
    color: var(--clr-text);
    margin-bottom: var(--sp-sm);
    line-height: 1.3;
}

.service-card__desc {
    font-size: 0.9375rem;
    color: var(--clr-text-muted);
    line-height: 1.7;
}

.service-card__number {
    position: absolute;
    bottom: var(--sp-lg);
    right: var(--sp-lg);
    font-family: var(--font-heading);
    font-size: 3.5rem;
    color: var(--clr-border);
    line-height: 1;
    font-style: italic;
    pointer-events: none;
    transition: color var(--dur-med) var(--ease);
}
.service-card:hover .service-card__number {
    color: rgba(21, 101, 192, 0.08);
}

/* ============================================================
   8. Team Section
   ============================================================ */
.team {
    background: var(--clr-bg);
    position: relative;
    overflow: hidden;
}

.team::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 40%;
    height: 100%;
    background: radial-gradient(ellipse at top right, rgba(21,101,192,0.05) 0%, transparent 70%);
    pointer-events: none;
}

.team__intro {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-4xl);
    align-items: center;
    margin-bottom: var(--sp-4xl);
}

.team__intro-text {
    font-size: 1.075rem;
    color: var(--clr-text-body);
    line-height: 1.8;
}
.team__intro-text + .team__intro-text {
    margin-top: var(--sp-md);
}

/* Fotografia v sekci O klinike */
.team__about-photo {
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: 0 24px 64px rgba(11, 61, 145, 0.18);
    margin: 0;
    aspect-ratio: 4 / 5;
    align-self: stretch;
}

.team__about-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    transition: transform .5s var(--ease);
}

.team__about-photo:hover img {
    transform: scale(1.03);
}

/* Keď nie je fotka – text na celú šírku */
.team__intro--full {
    grid-template-columns: 1fr;
    max-width: 72ch;
}

/* Team cards */
.team__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: var(--sp-xl);
}

.team-card {
    background: var(--clr-surface);
    border-radius: var(--radius-lg);
    overflow: hidden;
    text-align: center;
    border: 1px solid var(--clr-border);
    box-shadow: var(--shadow-sm);
    transition:
        transform var(--dur-med) var(--ease),
        box-shadow var(--dur-med) var(--ease);
}
.team-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
}

/* Portrétnа fotografia – celá šírka karty */
.team-card__photo {
    width: 100%;
    aspect-ratio: 2 / 3;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

.team-card__photo-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
    display: block;
    transition: transform .4s var(--ease);
}
.team-card:hover .team-card__photo-img {
    transform: scale(1.04);
}

/* Fallback – iniciály keď nie je fotka */
.team-card__initials {
    font-family: var(--font-heading);
    font-size: 4rem;
    color: #fff;
    font-style: italic;
    opacity: .85;
    user-select: none;
}

/* Obsah pod fotkou */
.team-card__body {
    padding: var(--sp-lg) var(--sp-xl) var(--sp-xl);
}

.team-card__name {
    font-family: var(--font-heading);
    font-size: 1.1rem;
    color: var(--clr-text);
    margin-bottom: 0.25rem;
}

.team-card__role {
    font-size: 0.8125rem;
    color: var(--clr-accent-dark);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: var(--sp-sm);
}

.team-card__bio {
    font-size: 0.875rem;
    color: var(--clr-text-muted);
    line-height: 1.65;
}

/* ============================================================
   9. Contact Section
   ============================================================ */
.contact {
    background: var(--clr-surface);
}

.contact__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-4xl);
    align-items: stretch;
}

/* Contact Panel – dark card */
.contact__panel {
    background: linear-gradient(155deg, var(--clr-primary-dark) 0%, #0f51b8 100%);
    border-radius: var(--radius-xl);
    padding: var(--sp-2xl);
    display: flex;
    flex-direction: column;
}

.contact__panel-divider {
    height: 1px;
    background: rgba(255,255,255,0.12);
    margin: var(--sp-xl) 0;
    flex-shrink: 0;
}

/* Contact items */
.contact__item {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-md);
    padding: 0.625rem 0;
}
.contact__item + .contact__item {
    border-top: 1px solid rgba(255,255,255,0.07);
}

.contact__item-icon {
    width: 36px;
    height: 36px;
    flex-shrink: 0;
    background: rgba(255,255,255,0.1);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #80DEEA;
    margin-top: 2px;
}

.contact__item-body {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.contact__item-label {
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: rgba(255,255,255,0.45);
}

.contact__item-value {
    font-size: 0.9375rem;
    color: rgba(255,255,255,0.9);
    font-weight: 500;
    line-height: 1.5;
    text-decoration: none;
    transition: color var(--dur-fast) var(--ease);
}
.contact__item-value:hover { color: #80DEEA; }

/* Hours in panel */
.contact__panel-hours-title {
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: rgba(255,255,255,0.45);
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: var(--sp-sm);
}

.contact__hours-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.45rem 0;
    border-bottom: 1px solid rgba(255,255,255,0.07);
    font-size: 0.875rem;
}
.contact__hours-row:last-child { border-bottom: none; }

.contact__hours-day {
    color: rgba(255,255,255,0.75);
    font-weight: 500;
}

.contact__hours-time {
    color: #80DEEA;
    font-weight: 600;
}

.contact__hours-row--closed .contact__hours-time {
    color: rgba(255,255,255,0.28);
    font-weight: 400;
}

.contact__hours-row--today {
    background: rgba(128,222,234,0.12);
    border-radius: 6px;
    border-bottom-color: transparent;
    padding: 0.45rem 0.625rem;
    margin-inline: -0.625rem;
}
.contact__hours-row--today .contact__hours-day {
    color: #fff;
    font-weight: 700;
}

/* Parking in panel */
.contact__parking {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-md);
}

.contact__parking-icon {
    width: 36px;
    height: 36px;
    flex-shrink: 0;
    background: rgba(255,255,255,0.1);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #80DEEA;
    margin-top: 2px;
}

.contact__parking-body { flex: 1; }

.contact__parking-body strong {
    display: block;
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: rgba(255,255,255,0.45);
    margin-bottom: 4px;
}

.contact__parking-body p {
    font-size: 0.8125rem;
    color: rgba(255,255,255,0.5);
    line-height: 1.6;
    margin: 0 0 6px;
}

.contact__parking-link {
    font-size: 0.8125rem;
    color: #80DEEA;
    font-weight: 600;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    transition: opacity var(--dur-fast) var(--ease);
}
.contact__parking-link:hover { opacity: 0.75; }

/* Map */
.contact__map {
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
    border: 1px solid var(--clr-border);
    height: 100%;
    min-height: 480px;
    display: flex;
    flex-direction: column;
}

.contact__map iframe {
    width: 100%;
    flex: 1;
    border: none;
    display: block;
    min-height: 400px;
}

.contact__map-footer {
    padding: var(--sp-md) var(--sp-lg);
    background: var(--clr-bg);
    border-top: 1px solid var(--clr-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--sp-sm);
}

.contact__map-address {
    font-size: 0.875rem;
    color: var(--clr-text-body);
    font-weight: 500;
}

.contact__map-link {
    font-size: 0.8125rem;
    color: var(--clr-primary-mid);
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 4px;
    text-decoration: none;
}
.contact__map-link:hover {
    text-decoration: underline;
    color: var(--clr-primary);
}

/* ============================================================
   10. Footer
   ============================================================ */
.site-footer {
    background: var(--clr-primary-dark);
    color: rgba(255,255,255,0.75);
    padding-block: var(--sp-4xl) var(--sp-2xl);
}

.footer__grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1.5fr;
    gap: var(--sp-3xl);
    padding-bottom: var(--sp-3xl);
    border-bottom: 1px solid rgba(255,255,255,0.1);
    margin-bottom: var(--sp-xl);
}

.footer__logo {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    color: #fff;
    font-family: var(--font-heading);
    font-size: 1.125rem;
    text-decoration: none;
    margin-bottom: var(--sp-md);
}
.footer__logo:hover,
.footer__logo:focus { color: #fff; text-decoration: none; opacity: 1; }

.footer__motto {
    font-family: var(--font-heading);
    font-style: italic;
    font-size: 1.0625rem;
    color: rgba(255,255,255,0.6);
    margin-bottom: var(--sp-md);
}

.footer__desc {
    font-size: 0.9rem;
    line-height: 1.7;
    color: rgba(255,255,255,0.55);
}

.footer__heading {
    font-family: var(--font-body);
    font-size: 0.8125rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: rgba(255,255,255,0.5);
    margin-bottom: var(--sp-lg);
}

.footer__links {
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
}
.footer__links a {
    font-size: 0.9375rem;
    color: rgba(255,255,255,0.7);
    text-decoration: none;
    transition: color var(--dur-fast) var(--ease);
}
.footer__links a:hover { color: #fff; }

.footer__address {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}
.footer__address p {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    font-size: 0.9rem;
    color: rgba(255,255,255,0.7);
    line-height: 1.5;
}
.footer__address svg { flex-shrink: 0; margin-top: 3px; opacity: 0.7; }
.footer__address a {
    color: rgba(255,255,255,0.85);
    text-decoration: none;
}
.footer__address a:hover { color: #fff; text-decoration: underline; }

.badge-emergency {
    background: rgba(243,156,18,0.2);
    color: #FFB74D;
    border: 1px solid rgba(243,156,18,0.3);
    border-radius: var(--radius-full);
    font-size: 0.7rem;
    font-weight: 700;
    padding: 0.15rem 0.5rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-left: 4px;
}

.footer__social {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: var(--sp-lg);
    padding: 0.5rem 1.1rem;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: var(--radius-full);
    color: rgba(255,255,255,0.75);
    font-size: 0.875rem;
    font-weight: 600;
    text-decoration: none;
    transition:
        background var(--dur-fast) var(--ease),
        color var(--dur-fast) var(--ease),
        border-color var(--dur-fast) var(--ease);
}

.footer__social:hover {
    background: rgba(255,255,255,0.15);
    color: #fff;
    border-color: rgba(255,255,255,0.3);
}

.footer__bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--sp-sm);
}

.footer__copy,
.footer__made {
    font-size: 0.875rem;
    color: rgba(255,255,255,0.4);
    display: flex;
    align-items: center;
    gap: 4px;
}

/* ============================================================
   11. Scroll Animations
   ============================================================ */
[data-reveal] {
    opacity: 0;
    transition:
        opacity 0.65s var(--ease-out),
        transform 0.65s var(--ease-out);
}

[data-reveal="up"]    { transform: translateY(36px); }
[data-reveal="left"]  { transform: translateX(-36px); }
[data-reveal="right"] { transform: translateX(36px); }
[data-reveal="scale"] { transform: scale(0.92); }

[data-reveal].is-visible {
    opacity: 1;
    transform: translate(0) scale(1);
}

/* Stagger delays */
[data-delay="1"] { transition-delay: 0.1s; }
[data-delay="2"] { transition-delay: 0.2s; }
[data-delay="3"] { transition-delay: 0.3s; }
[data-delay="4"] { transition-delay: 0.4s; }
[data-delay="5"] { transition-delay: 0.5s; }
[data-delay="6"] { transition-delay: 0.6s; }
[data-delay="7"] { transition-delay: 0.7s; }

/* ============================================================
   12. Page Templates
   ============================================================ */
.page-hero {
    background: var(--gradient-hero);
    padding: calc(var(--nav-h) + var(--infobar-h, 0px) + 3rem) 0 3rem;
}
.page-hero__title {
    font-family: var(--font-heading);
    font-size: clamp(1.75rem, 3.5vw, 3rem);
    color: #fff;
}

.page-content {
    padding-block: var(--sp-4xl);
    max-width: 780px;
}
.page-content p { margin-bottom: var(--sp-md); }
.page-content h2, .page-content h3 {
    font-family: var(--font-heading);
    color: var(--clr-text);
    margin: var(--sp-xl) 0 var(--sp-md);
}

/* ============================================================
   13. Responsive
   ============================================================ */

/* Tablet: ≤1024px */
@media (max-width: 1024px) {
    .hero__inner {
        grid-template-columns: 1fr;
        gap: var(--sp-3xl);
        text-align: center;
    }
    .hero__subtitle { margin-inline: auto; }
    .hero__actions { justify-content: center; }
    .hero__stats { justify-content: center; }
    .hero__visual { margin-inline: auto; max-width: 420px; }

    .team__intro { grid-template-columns: 1fr; gap: var(--sp-2xl); }

    .contact__grid { grid-template-columns: 1fr; gap: var(--sp-3xl); }

    .footer__grid { grid-template-columns: 1fr 1fr; gap: var(--sp-xl); }
}

/* Mobile nav: ≤768px */
@media (max-width: 768px) {
    :root { --nav-h: 64px; }

    .nav__hamburger { display: flex; }
    .nav__cta { display: none; }
    .hero__visual { display: none; }

    .nav__links {
        position: fixed;
        top: calc(var(--infobar-h, 0px) + var(--nav-h));
        left: 0;
        right: 0;
        bottom: 0;
        background: rgba(8,45,107,0.98);
        backdrop-filter: blur(20px);
        -webkit-backdrop-filter: blur(20px);
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: var(--sp-xl);
        transform: translateX(100%);
        transition: transform var(--dur-med) var(--ease);
        z-index: 200;   /* nad všetkým ostatným vrátane header (100) */
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
    }
    .nav__links.is-open { transform: translateX(0); }

    .nav__link {
        font-size: 1.5rem;
        color: rgba(255,255,255,0.9);
    }
    .nav__link::after { display: none; }

    /* Services grid */
    .services__grid { grid-template-columns: 1fr; }

    /* Team grid */
    .team__grid { grid-template-columns: repeat(2, 1fr); }

    /* Contact panel – full width on mobile */
    .contact__panel { border-radius: var(--radius-lg); }

    /* Footer */
    .footer__grid { grid-template-columns: 1fr; gap: var(--sp-xl); }
    .footer__bottom { flex-direction: column; text-align: center; }

    /* Section spacing */
    .section { padding-block: var(--sp-4xl); }
}

/* Small mobile: ≤480px */
@media (max-width: 480px) {
    .hero__title { font-size: 2.25rem; }
    .hero__actions { flex-direction: column; align-items: stretch; }
    .hero__actions .btn { justify-content: center; }
    .team__grid { grid-template-columns: 1fr; }
    .hero__stats { gap: var(--sp-lg); }
}

/* ============================================================
   14. Utility classes
   ============================================================ */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0,0,0,0);
    white-space: nowrap;
    border-width: 0;
}

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

/* ============================================================
   15. (Parking moved inside .contact__panel)
   ============================================================ */


/* ============================================================
   16. Hero – photo background + overlay
   ============================================================ */
.hero__bg-photo {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    z-index: 0;
    display: block;
}

.hero__bg-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        135deg,
        rgba(11,61,145,0.88) 0%,
        rgba(21,101,192,0.82) 55%,
        rgba(0,151,167,0.74) 100%
    );
    z-index: 0;
}

/* ============================================================
   17. Hero – today's hours + float animation
   ============================================================ */
.hero__today {
    margin-bottom: var(--sp-lg);
}

.hero__today-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--sp-md) 0;
    border-bottom: 1px solid rgba(255,255,255,0.12);
    margin-bottom: var(--sp-md);
}

.hero__today-day {
    font-size: 1rem;
    font-weight: 600;
    color: rgba(255,255,255,0.95);
}

.hero__today-time {
    font-family: var(--font-heading);
    font-size: 1.375rem;
    color: #80DEEA;
    font-weight: 400;
}

.hero__today-time--closed {
    color: rgba(255,255,255,0.35);
    font-size: 1rem;
    font-weight: 400;
    font-family: var(--font-body);
}

.hero__hours-link {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.875rem;
    font-weight: 600;
    color: rgba(255,255,255,0.65);
    text-decoration: none;
    transition: color var(--dur-fast) var(--ease);
    letter-spacing: 0.02em;
}

.hero__hours-link:hover { color: #fff; }

.hero__hours-link svg {
    transition: transform var(--dur-fast) var(--ease);
}

.hero__hours-link:hover svg {
    transform: translateX(4px);
}

/* Float animation for hero card */
@keyframes heroFloat {
    0%, 100% { transform: translateY(0px); }
    50%       { transform: translateY(-14px); }
}

.hero__float-wrapper {
    animation: heroFloat 5s ease-in-out infinite;
}

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

/* ============================================================
   18. Wave Dividers
   ============================================================ */
.wave-divider {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    line-height: 0;
    z-index: 3;
    pointer-events: none;
}

.wave-divider svg {
    display: block;
    width: 100%;
    height: 70px;
}

@media (max-width: 768px) {
    .wave-divider svg { height: 44px; }
}

/* ============================================================
   19. Scroll Progress Bar
   ============================================================ */
.scroll-progress {
    position: fixed;
    top: 0;
    left: 0;
    height: 3px;
    width: 0%;
    background: linear-gradient(90deg, var(--clr-accent), #4FC3F7, var(--clr-primary-light));
    z-index: 400;
    pointer-events: none;
    will-change: width;
}

/* ============================================================
   20. Reviews Section
   ============================================================ */
.reviews {
    background: linear-gradient(135deg, var(--clr-primary) 0%, var(--clr-primary-mid) 100%);
    position: relative;
    overflow: hidden;
}

.reviews::before {
    content: '';
    position: absolute;
    top: -20%;
    right: -8%;
    width: 50vw;
    max-width: 560px;
    aspect-ratio: 1;
    background: radial-gradient(circle, rgba(255,255,255,0.06) 0%, transparent 65%);
    border-radius: 50%;
    pointer-events: none;
}

.reviews__eyebrow {
    background: rgba(255,255,255,0.15) !important;
    color: rgba(255,255,255,0.9) !important;
}

.reviews__title {
    color: #fff !important;
}

.reviews__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--sp-lg);
}

.review-card {
    background: rgba(255,255,255,0.1);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: var(--radius-xl);
    padding: var(--sp-xl) var(--sp-xl) var(--sp-lg);
    display: flex;
    flex-direction: column;
    gap: var(--sp-md);
    transition:
        transform var(--dur-med) var(--ease),
        background var(--dur-med) var(--ease);
}

.review-card:hover {
    transform: translateY(-5px);
    background: rgba(255,255,255,0.16);
}

.review-card__stars {
    display: flex;
    gap: 3px;
}

.review-card__text {
    font-size: 1rem;
    color: rgba(255,255,255,0.9);
    line-height: 1.75;
    font-style: italic;
    flex: 1;
    margin: 0;
}

.review-card__footer {
    display: flex;
    align-items: center;
    gap: var(--sp-md);
    padding-top: var(--sp-md);
    border-top: 1px solid rgba(255,255,255,0.12);
}

.review-card__avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: rgba(255,255,255,0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-heading);
    font-size: 1.375rem;
    font-style: italic;
    color: #fff;
    flex-shrink: 0;
}

.review-card__name {
    font-weight: 600;
    color: #fff;
    font-size: 0.9375rem;
}

a.review-card__name--link {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    text-decoration: none;
    color: #fff;
    transition: opacity .15s;
}

a.review-card__name--link:hover {
    opacity: .75;
}

.review-card__recommends {
    display: inline-flex;
    align-items: center;
    gap: .375rem;
    font-size: .875rem;
    font-weight: 600;
    color: rgba(255,255,255,.85);
}

@media (max-width: 1024px) {
    .reviews__grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 600px) {
    .reviews__grid { grid-template-columns: 1fr; }
}

/* ============================================================
   21. Print
   ============================================================ */
@media print {
    .site-header, .hero__visual, .contact__map, .site-footer { display: none; }
    body { color: #000; }
    a { color: #000; text-decoration: underline; }
}
