@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600;700&family=Manrope:wght@300;400;500;600;700;800&display=swap');

@font-face{
  font-family:"Gliker";
  src:url("../font/gliker-regular.woff2") format("woff2");
  font-weight:400;
  font-style:normal;
  font-display:swap;
}

:root{
  --ink:#1b1712;
  --ink-2:#2d261f;
  --muted:#6b6359;
  --cream:#f6f2ea;
  --ivory:#fcfaf6;
  --gold:#b08a4a;
  --gold-2:#d5b67c;
  --line:rgba(27,23,18,.12);
  --shadow:0 18px 40px rgba(27,23,18,.12);
  --shadow-soft:0 12px 24px rgba(27,23,18,.08);
  --radius:18px;
  --maxw:1140px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }

body{
  margin:0;
  color:var(--ink);
  font-family:"Manrope", system-ui, sans-serif;
  line-height:1.6;
  overflow-x:hidden;
  background-color: var(--cream);
  background-image:
    radial-gradient(1200px 800px at 15% -10%, rgba(176,138,74,.18), transparent 60%),
    radial-gradient(1200px 900px at 85% -20%, rgba(27,23,18,.12), transparent 60%),
    linear-gradient(180deg, #fcfaf6 0%, #f4efe6 45%, #efe8dc 100%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240' viewBox='0 0 240 240'%3E%3Cpath d='M0 60c40-14 80-14 120 0s80 14 120 0' fill='none' stroke='rgba(27,23,18,0.05)' stroke-width='1.2'/%3E%3Cpath d='M-20 160c50-18 100-18 150 0s100 18 150 0' fill='none' stroke='rgba(176,138,74,0.08)' stroke-width='1.1'/%3E%3Ccircle cx='34' cy='28' r='1.3' fill='rgba(27,23,18,0.06)'/%3E%3Ccircle cx='170' cy='96' r='1.2' fill='rgba(176,138,74,0.10)'/%3E%3C/svg%3E");
  background-attachment: fixed;
}

img{ max-width:100%; height:auto; display:block; border-radius: 0; }
a{ color:inherit; text-decoration:none; }
p, h1, h2, h3, li, a, button, input, textarea{
  overflow-wrap:anywhere;
  word-break:break-word;
}

h1, h2, h3, h4, h5, h6, .section-title{
  font-family:"Gliker", "Cormorant Garamond", serif;
  letter-spacing:.03em;
  font-weight:600;
}

.container{
  width: min(var(--maxw), calc(100% - 40px));
  margin-inline:auto;
}

.section{ padding: 84px 0; }

#uvod{
  margin-top: 0;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}
#uvod .container{
  width: 100%;
  max-width: none;
  padding: 0;
  margin: 0;
}

.section-title{
  font-size: clamp(28px, 3.2vw, 44px);
  line-height:1.05;
  margin: 0 0 14px;
  text-transform: uppercase;
}

.section-subtitle{
  margin:0;
  color:var(--muted);
  max-width: 70ch;
}

.muted{ color:var(--muted); }

.spot-img{
  width:100%;
  height:180px;
  object-fit:cover;
  border-radius:0;
  background: rgba(27,23,18,.06);
  border: 1px solid rgba(27,23,18,.08);
}

.spot-title{
  margin:12px 0 6px;
  font-size: 1.08rem;
}

.nav{
  position: fixed;
  top:0;
  z-index: 20;
  backdrop-filter: blur(10px);
  background: rgba(252,250,246,.88);
  border-bottom: 1px solid var(--line);
  width:100%;
  transform: translateY(-120%);
  opacity:0;
  pointer-events:none;
  transition: transform .4s ease, opacity .3s ease;
}

.nav.is-visible{
  transform: translateY(0);
  opacity:1;
  pointer-events:auto;
}

.nav-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 16px 140px 16px 0;
  gap: 14px;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  font-weight: 700;
  letter-spacing:.2em;
  text-transform: uppercase;
  font-size: .92rem;
}
.brand-logo{
  width:42px;
  height:42px;
  border-radius:0;
  object-fit:contain;
  display:block;
}

.nav-links{
  display:flex;
  gap: 14px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.lang-switch{
  display:flex;
  align-items:center;
  gap:6px;
}
.lang-float{
  position: fixed;
  top: 16px;
  right: 16px;
  z-index: 30;
  background: rgba(27,23,18,.8);
  border: 1px solid rgba(27,23,18,.35);
  border-radius: 999px;
  padding: 6px;
  box-shadow: 0 10px 24px rgba(18,34,51,.18);
}
.nav .lang-float{
  position: static;
  top: auto;
  right: auto;
  transform: none;
  margin-left: auto;
}
.lang-float-hero{
  position: fixed;
  top: 16px;
  right: 16px;
  z-index: 29;
  display: inline-flex;
  width: auto;
  max-width: none;
}
.nav:not(.is-visible) .lang-float{
  display: none;
}
.nav.is-visible ~ .lang-float-hero{
  display: none;
}
.nav.is-visible ~ .lang-float-hero{
  display: none;
}
@media (max-width: 640px){
  .lang-float-hero{
    display: inline-flex !important;
    position: fixed;
    top: 64px;
    left: 50%;
    right: auto;
    transform: translateX(-50%);
    margin: 0;
    background: rgba(27,23,18,.85);
    border: 1px solid rgba(27,23,18,.35);
    box-shadow: 0 10px 24px rgba(18,34,51,.18);
  }
  .nav:not(.is-visible) .lang-float{
    display: none;
  }
}
.lang-float.is-solid{
  background: rgba(252,250,246,.92);
  border: 1px solid var(--line);
  box-shadow: 0 10px 24px rgba(27,23,18,.12);
}
.lang-btn{
  border: 1px solid var(--line);
  background: rgba(255,255,255,.7);
  color: var(--ink);
  border-radius: 10px;
  padding: 6px 8px;
  font-weight: 700;
  font-size: .82rem;
  cursor:pointer;
  text-transform: uppercase;
  letter-spacing:.08em;
}
.lang-btn.active{
  background: var(--ink);
  color: #fff;
  border-color: rgba(27,23,18,.25);
}

.nav-links a{
  padding: 10px 12px;
  border-radius: 999px;
  color: var(--ink-2);
  border: 1px solid transparent;
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: .78rem;
}

.nav-links a:hover{
  color: var(--ink);
  border-color: var(--line);
  background: rgba(255,255,255,.75);
}

.nav-links a[href="#dostupnost"]{
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
  box-shadow: 0 10px 26px rgba(27,23,18,.22);
}

.nav-links a[href="#dostupnost"]:hover{
  background: #111;
  color: #fff;
  border-color: #111;
}

.nav-toggle{
  display:none;
  width:44px;
  height:44px;
  border-radius:12px;
  border:1px solid rgba(27,23,18,.16);
  background: #fff;
  color: var(--ink);
  align-items:center;
  justify-content:center;
  cursor:pointer;
  box-shadow: 0 8px 18px rgba(27,23,18,.10);
}
.nav-toggle span{
  display:block;
  width:18px;
  height:2px;
  background: currentColor;
  position:relative;
}
.nav-inner{
  align-items: center;
  gap: 10px;
}
.nav-toggle span::before,
.nav-toggle span::after{
  content:"";
  position:absolute;
  left:0;
  width:18px;
  height:2px;
  background: currentColor;
  transition: transform .2s ease, opacity .2s ease;
}
.nav-toggle span::before{ top:-6px; }
.nav-toggle span::after{ top:6px; }

.nav.open .nav-toggle span{ background: transparent; }
.nav.open .nav-toggle span::before{ transform: translateY(6px) rotate(45deg); }
.nav.open .nav-toggle span::after{ transform: translateY(-6px) rotate(-45deg); }

.nav-drawer{
  display:flex;
  gap:14px;
}

.nav-backdrop{
  display:none;
}

.hero{ padding: 72px 0 40px; }

.hero-visual{
  position:relative;
  width:100%;
  height: 100vh;
  min-height: 560px;
  border-radius:0;
  overflow:hidden;
  background:#0d0b09;
  box-shadow: none;
  border: 0;
}
.hero-visual video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  filter: saturate(1.05) contrast(1.05);
}

.hero-overlay{
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(0,0,0,.55) 0%, rgba(0,0,0,.18) 55%, rgba(0,0,0,.55) 100%),
    linear-gradient(180deg, rgba(0,0,0,.12), rgba(0,0,0,.6));
}

.hero-content{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding: 24px;
  color:#fff;
  text-shadow: 0 12px 28px rgba(0,0,0,.45);
}

.hero-logo{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  margin-bottom: 22px;
  transform: translateY(18px);
  letter-spacing:.18em;
  text-transform: uppercase;
  font-size: .72rem;
  color: rgba(255,255,255,.9);
  transition: opacity .3s ease, transform .3s ease;
}
.hero-logo img{
  width:168px;
  height:168px;
  border-radius:0;
  filter: brightness(0) invert(1) drop-shadow(0 8px 18px rgba(0,0,0,.35));
}
.hero-logo-text{
  font-weight: 600;
}

.hero-title{
  margin:0;
  font-size: clamp(36px, 5.6vw, 92px);
  font-weight: 500;
  letter-spacing:.09em;
  text-transform: uppercase;
}
.hero-subtitle{
  margin: 10px 0 0;
  font-size: clamp(14px, 1.6vw, 22px);
  font-weight: 500;
  letter-spacing:.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.9);
}
.hero-actions{
  margin-top: 18px;
}
.hero-actions .btn{
  padding: 16px 26px;
  font-size: .88rem;
  letter-spacing: .2em;
  min-height: 52px;
}
.hero-actions .btn-outline{
  background: var(--ink);
  border-color: var(--ink);
  color: #fff;
  box-shadow: 0 14px 30px rgba(27,23,18,.22);
}
.hero-actions .btn-outline:hover{
  box-shadow: 0 18px 40px rgba(27,23,18,.26);
}
.hero-content.is-scrolled .hero-logo{
  opacity:0;
  transform: translateY(-36px);
  pointer-events:none;
}
.hero-title,
.hero-subtitle{
  transition: opacity .3s ease, transform .3s ease;
}

.hero-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 26px;
  align-items:center;
}

.hero-card{
  background: rgba(252,250,246,.88);
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) + 6px);
  padding: 26px;
  box-shadow: var(--shadow-soft);
}

.hero h1{
  font-size: clamp(34px, 4.2vw, 58px);
  line-height:1.05;
  margin: 0 0 12px;
}

.hero p{
  margin: 0 0 18px;
  color: var(--muted);
  font-size: 1.05rem;
  max-width: 70ch;
}

.hero-actions{
  display:flex;
  gap: 12px;
  flex-wrap:wrap;
  margin-top: 8px;
}

.badges{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top: 16px;
}

.badge{
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.85);
  color: var(--muted);
  font-size: .9rem;
  text-transform: uppercase;
  letter-spacing:.12em;
}

.btn{
  appearance:none;
  border: 1px solid transparent;
  border-radius: 999px;
  padding: 12px 18px;
  font-weight: 700;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  transition: transform .08s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
  user-select:none;
  min-height: 46px;
  white-space: normal;
  text-align:center;
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: .78rem;
}

.btn:active{ transform: translateY(1px); }

.btn-primary{
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
  box-shadow: 0 14px 30px rgba(27,23,18,.22);
}

.btn-primary:hover{
  box-shadow: 0 18px 40px rgba(27,23,18,.26);
}

.btn-outline{
  background: rgba(255,255,255,.75);
  border-color: rgba(176,138,74,.55);
  color: var(--ink);
}

.btn-outline:hover{
  background: rgba(255,255,255,.95);
  border-color: rgba(176,138,74,.75);
}

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

.card{
  background: rgba(255,255,255,.94);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 20px;
  box-shadow: var(--shadow-soft);
}

.card h3{
  margin: 0 0 6px;
  font-size: 1.2rem;
}

.card p{ margin:0; color: var(--muted); }

.card:hover{
  border-color: rgba(176,138,74,.35);
  box-shadow: 0 16px 30px rgba(27,23,18,.12);
}

details.details-clean summary::-webkit-details-marker{ display:none; }
details.details-clean summary{
  margin-inline:auto;
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
  justify-content: left;
}

.details-title{
  justify-content: space-between;
  width: 100%;
}

.gallery-row{
  display:flex;
  gap:10px;
  overflow-x:auto;
  padding:10px 2px;
}

.gallery-row img{
  border: 1px solid rgba(27,23,18,.12);
}

.form-wrap{
  background: rgba(255,255,255,.75);
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) + 6px);
  padding: 22px;
  box-shadow: var(--shadow);
  backdrop-filter: blur(12px);
}

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

.field{
  display:flex;
  flex-direction:column;
  gap: 6px;
}

label{
  font-weight: 700;
  font-size: .9rem;
  color: var(--ink);
  text-transform: uppercase;
  letter-spacing:.12em;
}

input, textarea, select{
  width:100%;
  border-radius: 14px;
  border: 1px solid rgba(27,23,18,.18);
  background: rgba(255,255,255,.96);
  color: var(--ink);
  padding: 12px 12px;
  outline:none;
}

input::placeholder, textarea::placeholder{ color: rgba(91,99,114,.75); }

input:focus, textarea:focus, select:focus{
  border-color: rgba(176,138,74,.75);
  box-shadow: 0 0 0 4px rgba(176,138,74,.18);
}

textarea{ min-height: 120px; resize: vertical; }

.form-actions{
  margin-top: 14px;
  display:flex;
  gap: 12px;
  flex-wrap:wrap;
  align-items:center;
}
.stay-toggle{
  width:100%;
  text-align:left;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid rgba(27,23,18,.18);
  background: rgba(255,255,255,.95);
  font-weight: 700;
  color: var(--ink);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  cursor:pointer;
  transition: box-shadow .2s ease, border-color .2s ease, transform .1s ease;
}
.stay-toggle::after{
  content:"▾";
  font-size: 14px;
  opacity:.7;
  transition: transform .2s ease;
}
.stay-toggle[aria-expanded="true"]{
  border-color: rgba(176,138,74,.45);
  box-shadow: 0 0 0 4px rgba(176,138,74,.18);
}
.stay-toggle[aria-expanded="true"]::after{
  transform: rotate(180deg);
}
.stay-picker{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 16px;
  background: rgba(255,255,255,.7);
  border: 1px solid rgba(27,23,18,.12);
  border-radius: 16px;
  padding: 14px;
  backdrop-filter: blur(10px);
}
.stay-picker[hidden]{
  display:none !important;
}
.stay-col-title{
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing:.14em;
  font-size: .78rem;
  margin-bottom: 10px;
  color: var(--ink-2);
}
.stay-option{
  display:flex;
  align-items:center;
  gap:10px;
  width:100%;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(27,23,18,.1);
  background: rgba(255,255,255,.6);
  cursor:pointer;
  transition: background .2s ease, border-color .2s ease, transform .1s ease;
}
.stay-option input{
  appearance:none;
  width:18px;
  height:18px;
  border-radius: 50%;
  border: 2px solid rgba(27,23,18,.35);
  display:inline-grid;
  place-items:center;
}
.stay-option input::before{
  content:"";
  width:8px;
  height:8px;
  border-radius:50%;
  background: var(--ink);
  transform: scale(0);
  transition: transform .15s ease;
}
.stay-option input:checked{
  border-color: var(--ink);
}
.stay-option input:checked::before{
  transform: scale(1);
}
.stay-option input:checked + span{
  color: var(--ink);
}
.stay-option:has(input:checked){
  background: rgba(255,255,255,.95);
  border-color: rgba(176,138,74,.35);
  box-shadow: 0 6px 16px rgba(18,34,51,.08);
}
.stay-option:hover{
  background: rgba(255,255,255,.9);
  border-color: rgba(27,23,18,.18);
}
.stay-option:active{
  transform: translateY(1px);
}
.stay-option span{
  font-weight: 600;
}
.extras-row{
  padding: 10px 12px;
  border: 1px dashed rgba(18,34,51,.2);
  border-radius: 12px;
  background: rgba(255,255,255,.75);
}
.extras-row .stay-option{
  background: rgba(255,255,255,.95);
  border-color: rgba(27,23,18,.18);
}
.stay-preview{
  margin-top: 12px;
  padding: 12px;
  border: 1px solid rgba(27,23,18,.12);
  border-radius: 14px;
  background: rgba(255,255,255,.9);
}
.stay-preview-title{
  font-weight: 800;
  margin-bottom: 8px;
  color: var(--ink);
}
.stay-preview-viewport{
  overflow: hidden;
}
.stay-preview-track{
  display: flex;
  gap: 8px;
  transition: transform .6s ease;
  will-change: transform;
}
.stay-preview img{
  border-radius: 10px;
  height: 180px;
  object-fit: cover;
  flex: 0 0 calc((100% - 16px) / 3);
}
@media (max-width: 720px){
  .stay-picker{
    grid-template-columns: 1fr;
  }
}
.actions-row,
.form-actions{
  align-items: stretch;
}
@media (max-width: 640px){
  .form-wrap{ padding: 16px; }
  .field{ gap: 8px; }
  label{ font-size: .78rem; letter-spacing:.1em; }
  input, textarea, select{ padding: 12px 12px; border-radius: 12px; }
  .stay-toggle{ padding: 12px 12px; font-size: .92rem; }
  .stay-picker{ padding: 10px; gap: 12px; }
  .stay-option{ padding: 10px; }
  .extras-row{ padding: 10px; }
  .price-inline{ font-size: .68rem; }
  .form-actions .btn{ width: 100%; justify-content:center; }
  .stay-preview{ padding: 10px; }
  .stay-preview img{ height: 120px; }
  .gallery-row{
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }
  .gallery-row img{
    flex: 0 0 100%;
    max-width: 100%;
    scroll-snap-align: start;
  }
  .lang-float{
    position: static;
    transform: none;
    margin-left: auto;
    background: rgba(27,23,18,.85);
    border: 1px solid rgba(27,23,18,.35);
    box-shadow: 0 10px 24px rgba(18,34,51,.18);
  }
  .lang-btn{
    font-size: .76rem;
    padding: 6px 8px;
  }
  .benefits-grid{
    grid-auto-flow: row;
    grid-template-columns: 1fr;
  }
}
.price-inline{
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: .72rem;
  color: var(--ink-2);
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.9);
  display:inline-flex;
  align-items:center;
  max-width: 100%;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
  line-height: 1.35;
}
.price-modal{
  position: fixed;
  inset: 0;
  display: none;
  z-index: 10000;
}
.price-modal.is-open{
  display: block;
}
.price-backdrop{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.6);
}
.price-dialog{
  position: relative;
  width: min(980px, calc(100% - 32px));
  max-height: calc(100vh - 40px);
  margin: 20px auto;
  background: #1f1f1f;
  color: #f5f1ea;
  border-radius: 18px;
  padding: 20px 22px 24px;
  overflow: auto;
  box-shadow: 0 20px 50px rgba(0,0,0,.4);
}
.price-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
}
.price-eyebrow{
  text-transform: uppercase;
  letter-spacing: .2em;
  font-size: .7rem;
  color: rgba(245,241,234,.7);
}
.price-close{
  border: 1px solid rgba(255,255,255,.25);
  background: transparent;
  color: #fff;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  font-size: 22px;
  cursor:pointer;
}
.price-meta{
  margin-top: 6px;
  color: rgba(245,241,234,.8);
  font-size: .92rem;
}
.price-notes{
  margin-top: 6px;
  display:flex;
  flex-direction:column;
  gap:4px;
  font-size: .82rem;
  color: rgba(245,241,234,.75);
}
.price-controls{
  margin-top: 14px;
  display:flex;
  align-items:center;
  gap: 10px;
}
.price-controls label{
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: .78rem;
  color: rgba(245,241,234,.8);
}
.price-controls select{
  background: #2a2a2a;
  color: #fff;
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 12px;
  padding: 8px 10px;
}
.price-legend{
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
  margin-top: 16px;
  font-size: .82rem;
}
.legend-item{
  display:flex;
  align-items:center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  background: #2a2a2a;
  border: 1px solid rgba(255,255,255,.1);
}
.legend-swatch{
  width: 10px;
  height: 10px;
  border-radius: 50%;
}
.price-calendar{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 16px;
  margin-top: 16px;
}
.month{
  background: #262626;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  padding: 12px;
}
.month h4{
  margin: 0 0 10px;
  font-size: 1rem;
  color: #f5f1ea;
}
.weekdays,
.days{
  display:grid;
  grid-template-columns: repeat(7, minmax(0,1fr));
  gap: 6px;
}
.weekdays div{
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: rgba(245,241,234,.6);
  text-align:center;
}
.day{
  min-height: 48px;
  border-radius: 10px;
  background: #1f1f1f;
  border: 1px solid rgba(255,255,255,.05);
  padding: 6px 6px 4px;
  font-size: .72rem;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.day .num{
  font-weight: 700;
  color: #fff;
}
.day .price{
  font-size: .64rem;
  color: rgba(255,255,255,.8);
}
.day.outside{
  opacity: .35;
}
.day.season-year{ background: rgba(176,138,74,.16); border-color: rgba(176,138,74,.35); }
.day.season-summer{ background: rgba(15,89,59,.22); border-color: rgba(15,89,59,.45); }
.day.season-easter{ background: rgba(90,70,140,.22); border-color: rgba(90,70,140,.45); }
.day.season-xmas{ background: rgba(140,35,35,.24); border-color: rgba(140,35,35,.45); }
.day.season-nye{ background: rgba(30,30,30,.65); border-color: rgba(255,255,255,.35); }
.day.season-none{ background: rgba(255,255,255,.06); }
@media (max-width: 980px){
  .price-calendar{ grid-template-columns: 1fr; }
}

@media (max-width: 860px){
  .lang-float{
    position: static;
    transform: none;
    margin-left: auto;
    background: rgba(27,23,18,.85);
    border-color: rgba(27,23,18,.35);
  }
}

.form-note{
  margin: 10px 0 0;
  color: var(--muted);
  font-size: .92rem;
}
.form-success{
  margin-top: 10px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(46, 125, 50, 0.35);
  background: rgba(76, 175, 80, 0.08);
  color: #1b5e20;
  font-weight: 700;
}

.contact{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  align-items:start;
}

.kv{ display:grid; gap: 10px; }

.kv a{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.88);
  color: var(--ink);
}

.kv a:hover{
  background: rgba(255,255,255,.98);
  border-color: rgba(176,138,74,.35);
}

.map{
  border-radius: var(--radius);
  overflow:hidden;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.88);
  min-height: 320px;
  box-shadow: var(--shadow-soft);
}

.footer{
  padding: 28px 0 50px;
  border-top: 1px solid var(--line);
  color: var(--muted);
  text-align:center;
  text-transform: uppercase;
  letter-spacing:.12em;
  font-size:.8rem;
}

.hr{
  height:1px;
  background: var(--line);
  margin: 28px 0;
  border:0;
}

:target{ scroll-margin-top: 90px; }

@media (max-width: 980px){
  .hero-grid{ grid-template-columns: 1fr; }
  .grid-3{ grid-template-columns: 1fr; }
  .grid-2{ grid-template-columns: 1fr; }
  .contact{ grid-template-columns: 1fr; }
  #uvod{
    padding-top: 0 !important;
    margin-top: 0 !important;
  }
}

@media (max-width: 640px){
  .section{ padding: 58px 0; }
  .hero{ padding: 60px 0 30px; }
  .hero-card{ padding: 18px; }
  .form-grid{ grid-template-columns: 1fr; }
}

@media (max-width: 860px){
  .nav-inner{ gap:10px; }
  .nav-inner{ padding-right: 120px; }
  .nav-drawer{
    position:absolute;
    top:100%;
    left:0;
    right:0;
    display:flex;
    flex-direction:column;
    background: rgba(252,250,246,.98);
    border-bottom: 1px solid var(--line);
    padding: 12px 16px 16px;
    box-shadow: 0 14px 30px rgba(27,23,18,.12);
    transform: translateY(-12px);
    opacity:0;
    pointer-events:none;
    transition: opacity .18s ease;
  }
  .nav.open .nav-drawer{
    opacity:1;
    pointer-events:auto;
    transform: translateY(0);
  }
  .nav-links{
    flex-direction:column;
    align-items:flex-start;
    gap:10px;
  }
  .nav-links a{
    width:100%;
    padding: 12px 14px;
    background: rgba(255,255,255,.98);
    border:1px solid var(--line);
    border-radius: 14px;
  }
  .nav-links a[href="#dostupnost"]{
    text-align:center;
  }
  .nav-toggle{ display:inline-flex; }
  .nav-backdrop{
    display:block;
    position:fixed;
    inset:0;
    background: rgba(0,0,0,0.25);
    opacity:0;
    pointer-events:none;
    transition: opacity .18s ease;
  }
  .nav.open .nav-backdrop{
    opacity:1;
    pointer-events:auto;
  }
  .nav{ position:fixed; top:0; }
  .nav-inner{ position:relative; }
}

@media (max-width: 720px){
  .benefits-grid{
    grid-auto-flow: column;
    grid-auto-columns: minmax(240px, 70%);
    grid-template-columns: unset;
    overflow-x: auto;
    padding-bottom: 6px;
    scroll-snap-type: x mandatory;
  }
  .benefits-grid .card{
    scroll-snap-align: start;
    min-height: 150px;
  }
}

.reviews{
  background: rgba(255,255,255,.95);
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) + 6px);
  box-shadow: var(--shadow);
  padding: 24px;
}
.pricing{
  background: #1f1f1f;
  color: #f5f1ea;
}
.pricing .section-title{
  color: #f5f1ea;
}
.pricing-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 22px;
  margin-top: 22px;
}
.pricing-card{
  background: #262626;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  padding: 22px;
  box-shadow: 0 16px 32px rgba(0,0,0,.2);
}
.pricing-card h3{
  margin: 0 0 12px;
  font-size: 1.2rem;
  color: #f5f1ea;
}
.pricing-block{
  margin-top: 14px;
}
.pricing-block h4{
  margin: 0 0 8px;
  font-weight: 600;
  font-size: .98rem;
  color: #f0e7d6;
}
.pricing-block ul{
  margin: 0;
  padding-left: 18px;
  color: #e5ded2;
}
.pricing-block li{
  margin: 6px 0;
}
@media (max-width: 980px){
  .pricing-grid{
    grid-template-columns: 1fr;
  }
}
.reviews h2{
  margin-top:0;
  margin-bottom:8px;
  text-transform: uppercase;
}
.reviews-sub{
  margin:0 0 18px;
  color: var(--muted);
}
.reviews-window{
  overflow:hidden;
}
.reviews-track{
  display:flex;
  gap:14px;
  transition: transform .5s ease;
}
.review-slide{
  flex: 0 0 340px;
}
.review-card{
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 18px;
  box-shadow: var(--shadow-soft);
  height: 100%;
}
.review-rating{
  color: #d19a2f;
  letter-spacing: 1px;
  font-weight: 800;
}
.review-author{
  margin: 10px 0 0;
  font-weight: 800;
  color: var(--ink);
}
.review-meta{
  color: var(--muted);
  font-size: .9rem;
  margin: 4px 0 0;
}
.review-dots{
  display:flex;
  gap:8px;
  margin-top:12px;
  justify-content:center;
}
.review-dot{
  width:10px;
  height:10px;
  border-radius:50%;
  background: rgba(27,23,18,.18);
  border:0;
  cursor:pointer;
}
.review-dot.active{
  background: var(--gold);
}

.review-nav{
  display:flex;
  justify-content:space-between;
  gap:10px;
  margin: 10px 0 0;
}
.review-btn{
  border:1px solid rgba(27,23,18,.16);
  background:#fff;
  color: var(--ink);
  border-radius:12px;
  padding:8px 12px;
  cursor:pointer;
  box-shadow: 0 8px 18px rgba(27,23,18,.08);
}

.season-switch{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top: 16px;
}
.season-btn{
  border: 1px solid var(--line);
  background: rgba(255,255,255,.9);
  color: var(--ink);
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 700;
  font-size: .78rem;
  letter-spacing:.12em;
  text-transform: uppercase;
  cursor:pointer;
}
.season-btn.active{
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
  box-shadow: 0 10px 24px rgba(27,23,18,.18);
}

@media (max-width: 720px){
  .container{
    width: 100%;
    max-width: none;
    padding: 0 12px;
  }

  #uvod{
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    margin: 0 !important;
  }
  #uvod .container{
    width:100%;
    max-width:none;
    padding:0;
    margin:0;
  }

  .reviews-window{
    overflow:hidden;
    padding-inline: 8px;
  }
  .reviews-track{
    gap:10px;
  }
  .review-slide{
    flex: 0 0 90%;
  }
  .review-nav{
    justify-content:center;
  }

  .hero-visual{
    height:82vh;
    min-height: 0;
    border-radius: 0 !important;
    overflow: hidden !important;
  }
  .hero-visual video{
    object-fit: cover;
  }

  .call-cta{
    width:60px !important;
    height:60px !important;
  }
  .call-cta img{
    width:32px !important;
    height:32px !important;
  }
}

/* Lightbox */
.lightbox{
  position: fixed;
  inset: 0;
  padding: 20px;
  background: rgba(0, 0, 0, 0.8);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  transition: opacity 0.2s ease;
}
.lightbox.is-hidden{
  opacity: 0;
  pointer-events: none;
}
.lightbox__backdrop{
  position: absolute;
  inset: 0;
}
.lightbox__img{
  max-width: 92vw;
  max-height: 92vh;
  border-radius: 16px;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.35);
  background: #0b2a3a;
  object-fit: contain;
}
.lightbox__btn{
  position: absolute;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.35);
  background: rgba(0, 0, 0, 0.55);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 22px;
  transition: background 0.2s ease, transform 0.1s ease;
}
.lightbox__btn:hover{ background: rgba(0, 0, 0, 0.75); }
.lightbox__btn:active{ transform: translateY(1px); }
.lightbox__btn--close{ top: 22px; right: 22px; font-size: 26px; }
.lightbox__btn--prev{ left: 18px; }
.lightbox__btn--next{ right: 18px; }

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

.hero-visual,
.section-title,
.card,
.form-wrap,
.reviews{
  animation: fadeUp .7s ease both;
}

@media (prefers-reduced-motion: reduce){
  *{ scroll-behavior:auto; }
  .hero-visual,
  .section-title,
  .card,
  .form-wrap,
  .reviews{
    animation: none;
  }
}
