/* Globální zákaz horizontálního scrollbaru */
html { overflow-x: hidden; }

.nav-logo svg {
    height: 50px;
    width: auto;
}

.nav-logo .s0 {
    fill: #005240 !important;
}

.footer-watermark .s0 {
    fill: #ffffff !important;
}

/* Preloader logo icon */
.preloader-logo-icon .s0 {
    fill: #ffffff !important;
}

/* Sekce Pohodlné ubytování – mobil */
@media (max-width: 767px) {
    .ubytovani-box {
        top: 300px;
        bottom: unset !important;
    }
}

/* Footer */
.footer-main {
    background-color: #005240;
}

.footer-hero-inner {
    padding-top: 10rem;
    padding-bottom: 10rem;
}

.footer-bottom-bar {
    border-top: 1px solid rgba(255, 255, 255, 0.15);
}

.footer-heart {
    color: #e53e3e;
}

/* Footer heading */
.footer-heading {
    font-family: Outfit, sans-serif;
    font-size: clamp(2rem, 5vw, 3.5rem);
    font-weight: 600;
    color: #ffffff;
    line-height: 1.5;
}

/* Footer watermark SVG rozměry */
.footer-watermark svg {
    height: 320px;
    width: auto;
    opacity: 0.05;
}

/* Mobile menu – výška 100dvh */
.mobile-menu-full-height {
    height: 100dvh;
}

.mobile-menu-min-height {
    min-height: 100dvh;
}

/* Section s panoramou */
.panorama-section {
    min-height: 350px;
}

@media (min-width: 768px) {
    .panorama-section {
        min-height: 450px;
    }
}

/* Leaf deco – individuální velikosti a pozice */
.leaf-deco-o-nas {
    width: 420px;
    top: -60px;
    left: 42%;
    transform: translateX(-50%) rotate(-15deg);
    opacity: 0;
    z-index: 0;
}

.leaf-deco-ubytovani {
    width: 380px;
    top: -40px;
    right: -60px;
    transform: rotate(20deg) scaleX(-1);
    opacity: 0;
    z-index: 0;
}

.leaf-deco-galerie {
    width: 360px;
    top: 20px;
    right: 120px;
    transform: rotate(-10deg);
    opacity: 0;
    z-index: 0;
}

.leaf-deco-kontakt {
    width: 400px;
    top: -40px;
    right: -80px;
    transform: rotate(15deg) scaleX(-1);
    z-index: 0;
}

@tailwind base;
@tailwind components;
@tailwind utilities;

@layer utilities {
    .text-balance {
        text-wrap: balance;
    }
    /* Alignment for rooms carousel overflow */
    .rooms-container-offset {
        padding-left: clamp(1rem, calc((100vw - 80rem) / 2 + 1rem), 50vw);
    }
}

/* Smooth image reveal on scroll */
.img-overlay-card {
    position: relative;
    overflow: hidden;
    border-radius: 1.5rem;
}
.img-overlay-card img {
    transition: transform 0.7s cubic-bezier(0.4, 0, 0.2, 1);
}
.img-overlay-card:hover img {
    transform: scale(1.05);
}
.img-overlay-scrim {
    background: linear-gradient(to top, rgba(0,0,0,0.8) 0%, rgba(0,0,0,0) 60%);
}

/* Flatpickr Custom Brand Colors */
.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange,
.flatpickr-day.selected.inRange,
.flatpickr-day.startRange.inRange,
.flatpickr-day.endRange.inRange,
.flatpickr-day.selected:focus,
.flatpickr-day.startRange:focus,
.flatpickr-day.endRange:focus,
.flatpickr-day.selected:hover,
.flatpickr-day.startRange:hover,
.flatpickr-day.endRange:hover,
.flatpickr-day.selected.prevMonthDay,
.flatpickr-day.startRange.prevMonthDay,
.flatpickr-day.endRange.prevMonthDay,
.flatpickr-day.selected.nextMonthDay,
.flatpickr-day.startRange.nextMonthDay,
.flatpickr-day.endRange.nextMonthDay {
    background: rgb(0 82 64) !important;
    border-color: rgb(0 82 64) !important;
    color: white !important;
}


/* Trips Grid */
.trips-grid {
    display: grid;
    grid-template-columns: 1fr;
    grid-auto-rows: 220px;
    gap: 12px;
    margin-bottom: 12px;
}
@media (min-width: 640px) {
    .trips-grid {
        grid-template-columns: 2fr 1fr;
        grid-auto-rows: 280px;
    }
}
.trips-grid:nth-of-type(even) { direction: rtl; }
.trip-item {
    position: relative;
    overflow: hidden;
    border-radius: 1.2rem;
    display: block;
    cursor: pointer;
    text-decoration: none;
    direction: ltr;
}
.trip-item.big { grid-row: span 2; }
.trip-item img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.trip-item:hover img { transform: scale(1.05); }
.trip-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.1) 70%, transparent 100%);
}
.trip-tag {
    position: absolute; top: 14px; left: 14px;
    background: rgba(255,255,255,0.92);
    backdrop-filter: blur(6px);
    border-radius: 999px;
    padding: 3px 12px;
    font-size: 10px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.1em; color: #111;
}
.trip-content { position: absolute; bottom: 0; left: 0; right: 0; padding: 16px 20px; color: white; }
.trip-item.big .trip-content { padding: 24px 28px; }
.trip-title {
    font-weight: 700; text-decoration: underline; text-underline-offset: 4px;
    line-height: 1.3; margin-bottom: 6px; font-size: clamp(0.9rem, 1.5vw, 1.1rem);
}
.trip-item.big .trip-title { font-size: clamp(1.1rem, 2vw, 1.4rem); }
.trip-desc {
    font-size: 0.8rem; color: rgba(255,255,255,0.8); line-height: 1.4;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
    overflow: hidden; text-decoration: none !important;
}
.trip-item.big .trip-desc { -webkit-line-clamp: 3; font-size: 0.9rem; }
.trips-batch { display: none; opacity: 0; transition: opacity 0.5s ease; }
.trips-batch.active { display: block; opacity: 1; }

#load-more-trips {
    display: inline-flex; align-items: center; gap: 12px;
    padding: 14px 36px; background: #005240; color: white;
    border: none; border-radius: 999px;
    font-size: 0.95rem; font-weight: 600; cursor: pointer;
    transition: all 0.3s ease; position: relative;
}
#load-more-trips:hover { background: #003d30; transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,0.15); }
#id-spinner { display: none; animation: spin 1s linear infinite; }
@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
#load-more-trips.loading #id-spinner { display: block; }
#load-more-trips.loading #id-text { opacity: 0.7; }
#load-more-trips.loading { pointer-events: none; opacity: 0.8; }


/* ── Alert bar ──────────────────────────────────────────────────────────────── */
#alert-bar {
    background: #005240; color: #fff;
    font-size: .9375rem; font-weight: 500;
    height: 2.5rem; display: flex; align-items: center; overflow: hidden;
}
#alert-content {
    display: flex; align-items: center; justify-content: center;
    width: 100%; overflow: hidden; padding: 0 1rem;
}
#alert-txt { white-space: nowrap; display: inline-block; }
#alert-txt * { display: inline; margin: 0; padding: 0; font-size: inherit; color: inherit; }
@keyframes alertMarquee { 0% { transform: translateX(0); } 100% { transform: translateX(var(--mw, -100%)); } }

/* ── Cookie banner ─────────────────────────────────────────────────────────── */
#cookie-banner {
    position: fixed; bottom: 1.5rem; left: 1.5rem; z-index: 8000;
    width: 360px; max-width: calc(100vw - 3rem);
    background: #005240; border-radius: 1.25rem;
    padding: 1.5rem 1.5rem 1.25rem;
    box-shadow: 0 20px 60px rgba(0,0,0,.28);
    display: none;
}
#cookie-banner.is-visible { display: block; animation: cookieIn .4s ease; }
@keyframes cookieIn { from { opacity:0; transform:translateY(.75rem); } to { opacity:1; transform:none; } }
.ck-header { display:flex; align-items:center; gap:.875rem; margin-bottom:.875rem; }
.ck-icon { width:52px; height:52px; flex-shrink:0; object-fit:contain; }
.ck-title { font-size:1.375rem; font-weight:800; color:#fff; margin:0; line-height:1.2; }
.ck-body { font-size:.875rem; color:rgba(255,255,255,.82); line-height:1.6; margin:0 0 1.125rem; }
.ck-body a { color:#fff; font-weight:700; text-decoration:underline; text-underline-offset:2px; }
.ck-footer { display:flex; align-items:center; gap:1.25rem; padding-top:.875rem; border-top:1px solid rgba(255,255,255,.15); }
.ck-btn-text {
    background:none; border:none; color:rgba(255,255,255,.7);
    font-size:.875rem; font-weight:600; cursor:pointer; font-family:inherit;
    padding:0; text-decoration:underline; text-underline-offset:3px; transition:color .2s;
}
.ck-btn-text:hover { color:#fff; }
.ck-btn-accept {
    margin-left:auto; width:62px; height:62px; border-radius:50%;
    background:#fff; color:#005240; font-size:.8125rem; font-weight:800;
    border:none; cursor:pointer; font-family:inherit;
    transition:transform .2s, box-shadow .2s;
    box-shadow:0 4px 14px rgba(0,0,0,.22); flex-shrink:0; line-height:1.2;
}
.ck-btn-accept:hover { transform:scale(1.06); box-shadow:0 6px 22px rgba(0,0,0,.28); }
@media (max-width:480px) {
    #cookie-banner { bottom:0; left:0; width:100%; max-width:100%; border-radius:1.25rem 1.25rem 0 0; }
}

/* ── Cookie detail / kategorie ─────────────────────────────────────────────── */
#ck-detail { display:none; overflow:hidden; }
#ck-detail.is-open { display:block; animation:ckDetailIn .3s ease; }
@keyframes ckDetailIn { from { opacity:0; transform:translateY(-6px); } to { opacity:1; transform:none; } }
.ck-cat { padding:.55rem 0; border-bottom:1px solid rgba(255,255,255,.1); }
.ck-cat:last-of-type { border-bottom:none; padding-bottom:0; }
.ck-cat-row { display:flex; align-items:center; justify-content:space-between; gap:.75rem; }
.ck-cat-name { font-size:.8125rem; font-weight:700; color:#fff; }
.ck-cat-desc { font-size:.75rem; color:rgba(255,255,255,.55); margin-top:.1rem; line-height:1.4; }
.ck-always { font-size:.6875rem; font-weight:700; color:rgba(255,255,255,.65); background:rgba(255,255,255,.12); border-radius:999px; padding:.2rem .65rem; white-space:nowrap; flex-shrink:0; }
/* Toggle */
.ck-toggle { position:relative; display:inline-block; width:40px; height:22px; flex-shrink:0; cursor:pointer; }
.ck-toggle input { opacity:0; width:0; height:0; position:absolute; }
.ck-slider { position:absolute; inset:0; border-radius:999px; background:rgba(255,255,255,.18); transition:background .2s; }
.ck-slider::before { content:''; position:absolute; width:16px; height:16px; left:3px; top:3px; border-radius:50%; background:rgba(255,255,255,.55); transition:transform .2s, background .2s; }
.ck-toggle input:checked + .ck-slider { background:rgba(255,255,255,.88); }
.ck-toggle input:checked + .ck-slider::before { transform:translateX(18px); background:#005240; }
/* Confirm button */
.ck-btn-confirm { margin-top:.75rem; width:100%; padding:.55rem 1rem; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.2); color:#fff; font-family:inherit; font-size:.8125rem; font-weight:700; border-radius:.75rem; cursor:pointer; transition:background .2s; }
.ck-btn-confirm:hover { background:rgba(255,255,255,.22); }
/* Banner wider when detail open */
#cookie-banner.is-visible:has(#ck-detail.is-open) { width:400px; }
/* Cookie trigger button */
#ck-trigger {
    display: none; position:fixed; bottom:1.5rem; left:1.5rem; z-index:7999;
    width:46px; height:46px; border-radius:50%; background:#005240; border:none;
    cursor:pointer; align-items:center; justify-content:center; padding:10px;
    box-shadow:0 4px 14px rgba(0,0,0,.25); transition:transform .2s, box-shadow .2s;
    color:#fff;
}
#ck-trigger:hover { transform:scale(1.1); box-shadow:0 6px 22px rgba(0,0,0,.35); }
#ck-trigger svg { width:100%; height:100%; display:block; }
@media (max-width:480px) { #ck-trigger { bottom:.75rem; left:.75rem; } }
