/* ═══════════════════════════════════════════
   shared.css — VU Tara
   Zajednički stilovi za sve stranice
   ═══════════════════════════════════════════ */

/* ═══ RESET + BASE ═══ */
* { margin:0; padding:0; box-sizing:border-box; }
body { font-family:'Roboto',sans-serif; color:#333; background:white; }
h1,h2,h3,h4,h5,h6 { font-family:'Roboto Condensed',sans-serif; font-weight:400; }

/* ═══ NAV DROPDOWN ═══ */
.nav-dropdown { position:relative; }
.nav-dropdown-menu {
  display:none; position:fixed; top:82px;
  background:#1b214f; border-radius:0 0 12px 12px;
  min-width:220px; z-index:200; box-shadow:0 8px 24px rgba(0,0,0,0.2);
}
.nav-dropdown-menu::before {
  content:''; position:absolute; top:-20px; left:0; right:0; height:20px; background:#1b214f;
}
.nav-dropdown-menu a {
  display:block; padding:16px 24px; color:white; text-decoration:none;
  font-family:'Roboto Condensed',sans-serif; font-size:20px; font-weight:700;
  text-transform:uppercase; letter-spacing:0.5px;
  border-top:1px solid rgba(255,255,255,0.1); transition:background 0.15s; white-space:nowrap;
}
.nav-dropdown-menu a:first-child { border-top:none; }
.nav-dropdown-menu a:hover { background:rgba(255,255,255,0.1); }
.nav-dropdown-menu a.active { background:rgba(255,255,255,0.15); position:relative; }
.nav-dropdown-menu a.active::before { content:''; position:absolute; left:0; top:0; bottom:0; width:3px; background:white; }

/* ═══ BOOKING FORMA ═══ */
.bf-label {
  font-family:'Roboto Condensed',sans-serif; font-size:14px; color:#333;
  letter-spacing:1.12px; text-transform:uppercase; line-height:17.3px; display:block;
}
.bf-hotel-menu {
  display:none; position:absolute; bottom:calc(100% + 8px); left:0;
  background:white; border-radius:16px; z-index:500;
  box-shadow:0 -4px 24px rgba(0,0,0,0.12); overflow:hidden; border:1px solid #e0e0e0;
}
.bf-hotel-menu a {
  display:block; padding:14px 20px; color:#333; text-decoration:none;
  font-family:'Roboto',sans-serif; font-size:22px; line-height:normal;
  border-top:1px solid #ebebeb; transition:background 0.15s; white-space:nowrap; cursor:pointer;
}
.bf-hotel-menu a:first-child {
  border-top:none; color:#aaa; font-size:15px;
  font-family:'Roboto Condensed',sans-serif; text-transform:uppercase; letter-spacing:1px;
}
.bf-hotel-menu a:hover { background:#f7f7f7; }
.bf-cal {
  display:none; position:absolute; bottom:calc(100% + 8px);
  background:white; border-radius:16px; z-index:500;
  box-shadow:0 -4px 24px rgba(0,0,0,0.12); padding:20px; width:300px;
  font-family:'Roboto',sans-serif; border:1px solid #e0e0e0;
}
.bf-cal.open { display:block; }
.bf-cal-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.bf-cal-title {
  font-family:'Roboto Condensed',sans-serif; font-size:16px;
  text-transform:uppercase; color:#333; letter-spacing:0.5px;
}
.bf-cal-nav {
  background:none; border:none; cursor:pointer; font-size:18px; color:#1b214f;
  width:30px; height:30px; display:flex; align-items:center; justify-content:center;
  border-radius:50%; transition:background 0.15s;
}
.bf-cal-nav:hover { background:#f0eae8; }
.bf-cal-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:2px; }
.bf-cal-day-name {
  font-family:'Roboto Condensed',sans-serif; font-size:11px;
  text-transform:uppercase; color:#aaa; text-align:center; padding:4px 0;
}
.bf-cal-day {
  aspect-ratio:1; display:flex; align-items:center; justify-content:center;
  border-radius:50%; cursor:pointer; font-size:14px; color:#333; transition:background 0.15s;
}
.bf-cal-day:hover:not(.bf-cal-empty):not(.bf-cal-disabled) { background:#f0eae8; }
.bf-cal-day.bf-cal-selected { background:#1b214f; color:white; }
.bf-cal-day.bf-cal-today:not(.bf-cal-selected) { font-weight:700; color:#2b962b; }
.bf-cal-day.bf-cal-empty, .bf-cal-day.bf-cal-disabled { pointer-events:none; color:#ddd; }

/* ═══ FOOTER ═══ */
.footer-section { background:white; display:flex; flex-direction:column; align-items:center; overflow:hidden; }
.footer-wrap { position:relative; background:#f0eae8; border-radius:24px 24px 0 0; width:1440px; max-width:100%; padding:70px 70px 20px; display:flex; flex-direction:column; gap:70px; overflow:hidden; }
.footer-watermark { position:absolute; right:0; top:47px; width:643px; height:636px; pointer-events:none; object-fit:contain; }
.footer-top { display:flex; align-items:center; justify-content:space-between; position:relative; z-index:1; }
.footer-logo-col { display:flex; flex-direction:column; gap:30px; width:509px; flex-shrink:0; }
.footer-logo { display:flex; align-items:center; gap:10.835px; width:236px; height:101.58px; }
.footer-logo img { width:104.231px; height:102.991px; flex-shrink:0; }
.footer-logo-text { font-family:'Roboto Condensed',sans-serif; font-size:27.088px; line-height:31.151px; text-transform:uppercase; color:#1a1a18; white-space:nowrap; font-weight:400; }
.footer-contact { font-family:'Roboto',sans-serif; font-size:18px; line-height:32px; color:#333; }
.footer-contact a { color:#333; text-decoration:underline; }
.footer-social { width:63.73px; height:21.303px; }
.footer-social img { width:100%; height:100%; object-fit:contain; }
.footer-links { display:flex; gap:120px; align-items:flex-start; padding:10px; flex-shrink:0; }
.footer-links-col { display:flex; flex-direction:column; gap:28px; font-family:'Roboto',sans-serif; font-size:18px; line-height:17px; color:#333; white-space:nowrap; letter-spacing:-0.18px; }
.footer-links-col a { color:#333; text-decoration:none; }
.footer-links-col a:hover { text-decoration:underline; }
.footer-hotels-col { display:flex; flex-direction:column; gap:30px; text-transform:uppercase; white-space:nowrap; }
.footer-hotel-name { font-family:'Roboto Condensed',sans-serif; font-size:26px; font-weight:700; line-height:30px; color:#333; }
.footer-hotel-location { font-family:'Roboto Condensed',sans-serif; font-size:18px; font-weight:400; line-height:20px; color:#333; }
.footer-bottom { display:flex; align-items:center; justify-content:space-between; position:relative; z-index:1; }
.footer-copyright { font-family:'Roboto',sans-serif; font-size:15px; line-height:32px; color:#333; margin:0; }
.soba-wrap {
  position:relative; flex:0 0 calc(50% - 15px);
  min-width:calc(50% - 15px); height:680px;
  border-radius:24px; overflow:hidden; cursor:pointer;
}
.soba-default-info {
  position:absolute; bottom:0; left:0; right:0; height:200px;
  background:linear-gradient(to top, rgba(0,0,0,0.5), transparent);
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:20px; gap:12px; z-index:5;
  opacity:1; visibility:visible;
  transition:opacity 0.35s ease, visibility 0.35s ease;
}
.soba-hover-info {
  position:absolute; inset:0; background:rgba(0,0,0,0.6);
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:20px; gap:12px; z-index:6; border-radius:24px;
  opacity:0; visibility:hidden;
  transition:opacity 0.35s ease, visibility 0.35s ease;
}
.soba-wrap:hover .soba-hover-info   { opacity:1; visibility:visible; }
.soba-wrap:hover .soba-default-info { opacity:0; visibility:hidden; }

/* ═══ BURGER MENI ═══ */
#burger-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,0.3); z-index:300;
  opacity:0; pointer-events:none; transition:opacity 0.35s ease;
}
#burger-overlay.active { opacity:1; pointer-events:auto; }
#burger-panel {
  position:fixed; top:var(--header-h, 82px); right:-320px;
  width:320px; height:calc(100vh - var(--header-h, 82px));
  background:rgba(27,33,79,0.95); z-index:400;
  display:flex; flex-direction:column; justify-content:center;
  padding:40px; gap:10px;
  transition:right 0.35s cubic-bezier(0.4,0,0.2,1);
}
#burger-panel.active { right:0; }
#burger-close {
  position:absolute; top:22px; right:22px;
  width:24px; height:24px; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
}
#burger-close::before, #burger-close::after {
  content:''; position:absolute; width:24px; height:1px; background:white;
}
#burger-close::before { transform:rotate(45deg); }
#burger-close::after  { transform:rotate(-45deg); }
#burger-panel nav {
  display:flex; flex-direction:column; gap:40px; flex:1; justify-content:center;
}
#burger-panel nav a {
  color:white; text-decoration:none; font-family:'Roboto',sans-serif;
  font-size:18px; line-height:17px; letter-spacing:-0.18px;
  white-space:nowrap; transition:opacity 0.15s;
}
#burger-panel nav a:hover { opacity:0.7; }
#burger-social { display:flex; flex-direction:column; gap:15px; flex-shrink:0; }
#burger-social span {
  font-family:'Roboto Condensed',sans-serif; font-size:14px;
  color:white; text-transform:uppercase; letter-spacing:1.12px;
}
