/* =====================================================
   THEME – CHATA / PŘÍRODA (Bootstrap override)
   ===================================================== */
:root {
    /* Bootstrap */
    --bs-primary: #1f5f4a;            /* borovicová */
    --bs-primary-rgb: 31, 95, 74;

    --bs-link-color: #1f5f4a;
    --bs-link-hover-color: #153f31;

    --bs-body-bg: #fbf7f0;            /* teplý „linen“ */
    --bs-body-color: #1d2321;

    --bs-secondary-color: #50625b;
    --bs-border-color: rgba(29, 35, 33, 0.12);

    --bs-warning: #d4a24c;            /* teplý akcent */
    --bs-warning-rgb: 212, 162, 76;
}

/* =====================================================
   VLASTNÍ PALETA
   ===================================================== */
:root {
    --vn-primary: #1f5f4a;
    --vn-primary-dark: #153f31;
    --vn-primary-soft: #e7f1ec;

    --vn-accent: #d4a24c;             /* měď/písek */
    --vn-accent-dark: #b48332;

    --vn-ink: #1d2321;
    --vn-muted: #50625b;

    --vn-surface: #ffffff;
    --vn-surface-2: #fffaf1;

    --vn-shadow: 0 10px 28px rgba(21, 63, 49, 0.18);
    --vn-shadow-soft: 0 6px 18px rgba(21, 63, 49, 0.12);

    --vn-radius: 1rem;
    --vn-radius-lg: 1.25rem;
}

/* =====================================================
   ZÁKLAD
   ===================================================== */
body {
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI",
        Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif,
        "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol",
        "Noto Color Emoji";
    background: radial-gradient(
            1200px 600px at 15% 0%,
            rgba(31, 95, 74, 0.10),
            transparent 60%
        ),
        radial-gradient(
            900px 500px at 95% 10%,
            rgba(212, 162, 76, 0.12),
            transparent 55%
        ),
        var(--bs-body-bg);
    color: var(--bs-body-color);
}

/* drobnosti */
a { text-underline-offset: 3px; }
a:hover { text-decoration-thickness: 2px; }

::selection { background: rgba(212, 162, 76, 0.35); }

/* =====================================================
   HEADER / FOOTER – „dřevěný“ panel v containeru
   ===================================================== */
.site-header,
.site-footer {
    background-color: transparent;
}

.site-header .container,
#site-header .container {
    background: linear-gradient(135deg, #123428 0%, var(--vn-primary-dark) 40%, #0f2c22 100%);
    border-radius: 0 0 var(--vn-radius-lg) var(--vn-radius-lg);
    box-shadow: 0 10px 24px rgba(15, 44, 34, 0.35);
    border: 1px solid rgba(255, 255, 255, 0.10);
}

.site-footer .container,
#site-footer .container {
    background: linear-gradient(135deg, #0f2c22 0%, var(--vn-primary-dark) 60%, #123428 100%);
    border-radius: var(--vn-radius-lg) var(--vn-radius-lg) 0 0;
    box-shadow: 0 -10px 24px rgba(15, 44, 34, 0.35);
    border: 1px solid rgba(255, 255, 255, 0.10);
}

.site-footer .row,
#site-footer .row {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}

/* =====================================================
   NAVBAR
   ===================================================== */
.site-header .navbar,
#site-header .navbar {
    padding: 0.65rem 0.9rem;
}

.site-header .navbar-brand,
#site-header .navbar-brand {
    font-size: 1.05rem;
    letter-spacing: 0.2px;
    color: #ffffff !important;
    display: inline-flex;
    gap: 0.55rem;
    align-items: center;
}

.brand-badge {
    width: 34px;
    height: 34px;
    border-radius: 12px;
    display: grid;
    place-items: center;
    background: rgba(212, 162, 76, 0.16);
    border: 1px solid rgba(212, 162, 76, 0.35);
    color: #fff;
}

.navbar-dark .navbar-toggler {
    border-color: rgba(255, 255, 255, 0.35);
}

.site-header .navbar-nav .nav-link,
#site-header .navbar-nav .nav-link {
    font-weight: 600;
    color: rgba(255, 255, 255, 0.88);
    padding: 0.4rem 0.7rem;
    border-radius: 999px;
}

.site-header .navbar-nav .nav-link:hover,
#site-header .navbar-nav .nav-link:hover {
    color: #fff;
    background: rgba(255, 255, 255, 0.10);
}

.site-header .navbar-nav .nav-link.active,
#site-header .navbar-nav .nav-link.active {
    color: #fff;
    background: rgba(212, 162, 76, 0.18);
    border: 1px solid rgba(212, 162, 76, 0.25);
}

/* =====================================================
   MAIN PANEL
   ===================================================== */
.main-panel {
    background: rgba(255, 255, 255, 0.85);
    backdrop-filter: blur(8px);
    border-radius: var(--vn-radius-lg);
    box-shadow: var(--vn-shadow);
    padding: 1.25rem 1.15rem;
    border: 1px solid rgba(29, 35, 33, 0.10);
}

@media (min-width: 768px) {
    .main-panel { padding: 1.7rem 1.7rem; }
}

/* =====================================================
   HERO
   ===================================================== */
.hero {
    border-radius: var(--vn-radius-lg);
    overflow: hidden;
    position: relative;
    box-shadow: var(--vn-shadow-soft);
    border: 1px solid rgba(29, 35, 33, 0.10);
    background: #0f2c22;
}

/* výchozí */
.hero { min-height: 320px; }

.hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(15, 44, 34, 0.92) 0%, rgba(15, 44, 34, 0.55) 55%, rgba(15, 44, 34, 0.15) 100%),
        url("img/hero.jpg") center/cover no-repeat;
    filter: saturate(1.05);
}

.hero-content {
    position: relative;
    z-index: 1;
    padding: 1.25rem;
}

/* kompaktní */
.hero.hero-compact { min-height: 240px; }
.hero.hero-compact .hero-content { padding: 1rem; }

@media (min-width: 768px) {
    .hero { min-height: 360px; }
    .hero-content { padding: 1.7rem; }

    .hero.hero-compact { min-height: 270px; }
    .hero.hero-compact .hero-content { padding: 1.2rem 1.35rem; }
}

.hero-kicker {
    display: inline-flex;
    gap: 0.5rem;
    align-items: center;
    font-weight: 700;
    letter-spacing: 0.2px;
    color: rgba(255, 255, 255, 0.92);
}

.hero h1 {
    color: #fff;
    margin-top: 0.35rem;
    margin-bottom: 0.25rem;
}

.hero.hero-compact .lead {
    line-height: 1.28;
    margin-bottom: 0.9rem !important;
}

.hero p {
    color: rgba(255, 255, 255, 0.86);
    max-width: 46rem;
}

/* =====================================================
   KARTY
   ===================================================== */
.card {
    border-radius: var(--vn-radius);
    border: 1px solid rgba(29, 35, 33, 0.10);
}

.card .card-body,
.card .card-header,
.card .card-footer {
    padding-left: 1rem;
    padding-right: 1rem;
}

.card .card-header {
    border-bottom: 1px solid rgba(29, 35, 33, 0.10);
}

.compact-card-body {
    padding-top: 0.85rem !important;
    padding-bottom: 0.85rem !important;
}

.card-highlight {
    background: linear-gradient(135deg, var(--vn-surface-2) 0%, var(--vn-primary-soft) 100%);
    border-left: 5px solid rgba(212, 162, 76, 0.85);
}

.card:hover {
    transform: translateY(-1px);
    transition: 160ms ease;
    box-shadow: var(--vn-shadow-soft);
}

/* =====================================================
   BUTTONS
   ===================================================== */
.btn-primary {
    background: linear-gradient(135deg, var(--vn-primary), var(--vn-primary-dark));
    border-color: rgba(255, 255, 255, 0.15);
    box-shadow: 0 8px 18px rgba(31, 95, 74, 0.22);
}

.btn-primary:hover {
    background: linear-gradient(135deg, var(--vn-primary-dark), var(--vn-primary));
    border-color: rgba(255, 255, 255, 0.15);
}

.btn-outline-light { border-color: rgba(255, 255, 255, 0.55); }

.btn-accent {
    background: linear-gradient(135deg, var(--vn-accent), var(--vn-accent-dark));
    border: none;
    color: #1a140a;
    font-weight: 800;
    box-shadow: 0 10px 22px rgba(212, 162, 76, 0.22);
}

.btn-accent:hover { filter: brightness(0.98); }

/* =====================================================
   TEXT
   ===================================================== */
.text-muted { color: var(--vn-muted) !important; }

.lead { line-height: 1.35; }

.section-title {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
}

.section-title i { color: var(--vn-accent-dark); }

/* =====================================================
   INFO LIST
   ===================================================== */
.info-list {
    display: grid;
    gap: 0.55rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.info-list li {
    display: flex;
    gap: 0.55rem;
    align-items: flex-start;
}

.info-icon {
    width: 34px;
    height: 34px;
    border-radius: 12px;
    display: grid;
    place-items: center;
    background: rgba(31, 95, 74, 0.10);
    border: 1px solid rgba(31, 95, 74, 0.18);
    color: var(--vn-primary-dark);
    flex: 0 0 auto;
}

/* =====================================================
   GALLERY (Bootstrap grid) – 4 sloupce na lg
   miniatury stejné výšky, bez deformace, bez ořezu
   ===================================================== */

.gallery-item{
  appearance:none;
  border:0;
  padding:0;
  background:transparent;
  cursor:pointer;

  border-radius:0.9rem;
  overflow:hidden;
  border:1px solid rgba(29,35,33,0.10);
  box-shadow:0 6px 14px rgba(21,63,49,0.10);
  transition:transform 160ms ease, box-shadow 160ms ease;
}

.gallery-item img{
  display:block;
  width:100%;

  /* ✅ stejné výšky miniatur v řádku */
  aspect-ratio: 4 / 3;

  /* ✅ bez deformace, zobraz celou fotku */
  object-fit: contain;
  object-position: center;

  /* jemné pozadí když vzniknou pruhy */
  background: rgba(15,44,34,0.06);
}

.gallery-item:hover{
  transform: translateY(-1px);
  box-shadow: var(--vn-shadow-soft);
}

.gallery-item:focus-visible{
  outline:3px solid rgba(212,162,76,0.5);
  outline-offset:3px;
}


/* =====================================================
   LIGHTBOX – plátno se přizpůsobí fotce (má max velikost),
   fotka je vždy celá (bez ořezu), zachová poměr stran
   ===================================================== */
.vn-lightbox {
    position: fixed;
    inset: 0;
    z-index: 1055;
    display: none;
}
.vn-lightbox.is-open { display: block; }

.vn-lightbox-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 44, 34, 0.78);
    backdrop-filter: blur(3px);
}

.vn-lightbox-dialog {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    padding: 1rem;
}

.vn-lightbox-figure {
    position: relative;
    margin: 0;

    max-width: min(1100px, 96vw);
    max-height: 82vh;
    width: fit-content;

    background: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(255, 255, 255, 0.25);
    border-radius: 1.1rem;
    box-shadow: 0 18px 60px rgba(0,0,0,0.35);
    overflow: hidden;

    display: grid;
    grid-template-rows: auto auto;
}

.vn-lightbox-media {
    padding: 0.85rem;
    background: rgba(15, 44, 34, 0.06);
}

.vn-lightbox-img {
    display: block;
    width: auto;
    height: auto;

    max-width: min(1100px, 96vw);
    max-height: 74vh;

    object-fit: contain;
    object-position: center;
}

.vn-lightbox-caption {
    padding: 0.6rem 0.85rem;
    font-size: 0.95rem;
    color: var(--vn-muted);
    border-top: 1px solid rgba(29, 35, 33, 0.10);
    background: rgba(255, 255, 255, 0.95);
}

.vn-lightbox-close {
    position: absolute;
    top: 1.1rem;
    right: 1.1rem;
    width: 42px;
    height: 42px;
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.25);
    background: rgba(15, 44, 34, 0.55);
    color: #fff;
    display: grid;
    place-items: center;
    cursor: pointer;
}

.vn-lightbox-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    border-radius: 16px;
    border: 1px solid rgba(255, 255, 255, 0.25);
    background: rgba(15, 44, 34, 0.55);
    color: #fff;
    display: grid;
    place-items: center;
    cursor: pointer;
}

.vn-lightbox-prev { left: 1.1rem; }
.vn-lightbox-next { right: 1.1rem; }

.vn-lightbox-close:hover,
.vn-lightbox-nav:hover {
    background: rgba(15, 44, 34, 0.68);
}

@media (max-width: 575.98px) {
    .vn-lightbox-media { padding: 0.65rem; }

    .vn-lightbox-img {
        max-width: 96vw;
        max-height: 72vh;
    }

    .vn-lightbox-prev { left: 0.65rem; }
    .vn-lightbox-next { right: 0.65rem; }
    .vn-lightbox-close { top: 0.65rem; right: 0.65rem; }
}

/* =====================================================
   KONTAKT – QR + MAPA
   ===================================================== */
.qr-code { width: 84px; height: 84px; }
.map-embed { height: 320px; }

/* =====================================================
   FOOTER LINKS
   ===================================================== */
.footer-link {
    color: rgba(255, 255, 255, 0.88);
    text-decoration: none;
}

.footer-link:hover {
    color: #fff;
    text-decoration: underline;
}

/* =====================================================
   MOBIL
   ===================================================== */
@media (max-width: 575.98px) {
    .main-panel { padding: 1.05rem 0.95rem; }
    .qr-code { width: 74px; height: 74px; }
    .map-embed { height: 210px; }
    .hero { min-height: 310px; }
    .hero.hero-compact { min-height: 220px; }
    .hero.hero-compact .hero-content { padding: 0.95rem; }
}

/* =====================================================
   CENÍK – tabulky, odznaky, callouty
   ===================================================== */
.vn-table thead th {
    font-size: 0.86rem;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    color: var(--vn-muted);
    border-bottom: 1px solid rgba(29, 35, 33, 0.12);
}

.vn-table tbody td {
    padding-top: 0.55rem;
    padding-bottom: 0.55rem;
    border-bottom: 1px solid rgba(29, 35, 33, 0.10);
}

.vn-table tbody tr:hover { background: rgba(31, 95, 74, 0.06); }

.vn-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.28rem 0.55rem;
    border-radius: 999px;
    font-weight: 700;
    font-size: 0.78rem;
    background: rgba(212, 162, 76, 0.16);
    border: 1px solid rgba(212, 162, 76, 0.28);
    color: var(--vn-ink);
}

.vn-badge {
    display: inline-block;
    padding: 0.15rem 0.5rem;
    border-radius: 999px;
    font-weight: 800;
    font-size: 0.78rem;
    background: rgba(31, 95, 74, 0.10);
    border: 1px solid rgba(31, 95, 74, 0.18);
    color: var(--vn-primary-dark);
    vertical-align: middle;
}

.vn-note {
    padding: 0.75rem 0.9rem;
    border-radius: 0.9rem;
    background: rgba(31, 95, 74, 0.08);
    border: 1px solid rgba(31, 95, 74, 0.16);
    color: var(--vn-ink);
}

.vn-checklist {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 0.55rem;
}

.vn-checklist li {
    display: flex;
    gap: 0.55rem;
    align-items: flex-start;
}

.vn-checklist i.fa-check { color: var(--vn-primary-dark); margin-top: 0.18rem; }
.vn-checklist i.fa-xmark { color: #8a2e2e; margin-top: 0.18rem; }

.vn-callout {
    border-radius: 1rem;
    padding: 0.9rem 1rem;
    background: linear-gradient(135deg, rgba(212, 162, 76, 0.16), rgba(31, 95, 74, 0.08));
    border: 1px solid rgba(29, 35, 33, 0.12);
}

.vn-callout-title {
    font-weight: 900;
    margin-bottom: 0.4rem;
    color: var(--vn-primary-dark);
}

.price-teaser {
    border-radius: 1rem;
    border: 1px solid rgba(29, 35, 33, 0.10);
    background: linear-gradient(135deg, rgba(255, 250, 241, 0.9), rgba(231, 241, 236, 0.9));
}
