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

/* ═══ RESET + BASE ═══ */
* { margin:0; padding:0; box-sizing:border-box; }
html { overflow-x:hidden; overflow-y:scroll; }
body { font-family:'Roboto',sans-serif; color:#333; background:white; overflow-x:hidden; }
html.burger-open body { overflow:hidden; height:100%; }
h1,h2,h3,h4,h5,h6 { font-family:'Roboto Condensed',sans-serif; font-weight:400; }

/* ═══ LAYOUT ═══ */
.container {
  width:1440px; max-width:100%; flex-shrink:1;
  display:flex; flex-direction:column; gap:30px; overflow:hidden;
}
.container--center { align-items:center; }
.section-white { background:white; padding:100px 0; display:flex; flex-direction:column; align-items:center; }
.section-beige { background:#f0eae8; padding:100px 0; display:flex; flex-direction:column; align-items:center; }

/* ═══ SECTION HEADER ═══ */
.section-header { display:flex; flex-direction:column; gap:20px; align-items:center; }
.section-title {
  font-family:'Roboto Condensed',sans-serif; font-size:42px; font-weight:400;
  text-transform:uppercase; color:#333; text-align:center;
  line-height:normal; white-space:nowrap;
}
.section-body {
  font-family:'Roboto',sans-serif; font-size:18px; line-height:28px; color:#333;
}
.section-divider { width:1px; height:68px; background:#c5c5c5; }

/* ═══ HERO ═══ */
.hero {
  position:relative; height:900px;
  display:flex; flex-direction:column; align-items:flex-start; justify-content:center; gap:30px;
}
.hero-bg { position:absolute; inset:0; pointer-events:none; z-index:0; overflow:hidden; }
.hero-bg-img {
  position:absolute; left:0; top:-0.12%; width:100%; height:141.07%; object-fit:cover;
}
.hero-bg-dim { position:absolute; inset:0; background:rgba(0,0,0,0.2); }

/* ═══ HEADER ═══ */
.header {
  position:relative; z-index:100;
  display:flex; align-items:flex-start; justify-content:space-between;
  width:100%; flex-shrink:0;
}
.header-logo {
  display:flex; align-items:center; gap:6.989px; text-decoration:none;
  background:white; padding:8px 36px; flex-shrink:0; border-bottom-right-radius:24px;
}
.header-logo-img { width:67.228px; height:66.427px; flex-shrink:0; display:block; }
.header-logo-text {
  font-family:'Roboto Condensed',sans-serif; font-size:17.471px; line-height:20.092px;
  text-transform:uppercase; color:#1a1a18; white-space:nowrap; font-weight:400;
}
.header-nav-bar {
  background:#1b214f; display:flex; align-items:center; gap:80px;
  padding:21px 40px; border-bottom-left-radius:24px; flex-shrink:0;
  position:relative;
}
.header-nav { display:flex; align-items:center; gap:40px; height:40px; }
.nav-link {
  color:white; text-decoration:none; font-family:'Roboto Condensed',sans-serif;
  font-size:17px; font-weight:400; letter-spacing:-0.17px; display:flex; align-items:center; gap:10px;
  text-transform:uppercase; white-space:nowrap;
}
.nav-icon          { display:block; flex-shrink:0; }
.nav-icon--hotel   { width:28px; height:34px; }
.nav-icon--rest    { width:23.966px; height:17.534px; }
.nav-icon--offer   { width:23.978px; height:22.998px; }
.nav-icon--contact { width:23.979px; height:23.995px; }
.nav-arrow         { display:block; flex-shrink:0; width:9.78px; height:5.192px; }
.header-actions { display:flex; align-items:center; gap:80px; }
.btn-lang {
  background:transparent; border:1px solid white; color:white;
  width:24px; height:24px; border-radius:3px; font-size:13px; font-weight:600;
  cursor:pointer; font-family:'Roboto Condensed',sans-serif;
  display:flex; align-items:center; justify-content:center;
}
.burger-btn { display:flex; flex-direction:column; align-items:flex-end; gap:5px; cursor:pointer; }
.burger-line { width:24px; height:1px; background:white; }
.burger-line--short { width:20px; }
.burger-label {
  font-size:10px; color:white; font-family:'Roboto',sans-serif; font-weight:700;
  text-transform:uppercase; letter-spacing:0.2px; text-align:center; width:25px;
}

/* ═══ HERO BODY ═══ */
.hero-body {
  flex:1; display:flex; align-items:center; justify-content:space-between;
  width:100%; position:relative; z-index:1; padding-bottom:120px;
}
.hero-arrow { padding:0 30px; flex-shrink:0; }
.hero-arrow-img { width:72px; height:72px; cursor:pointer; display:block; }
.hero-arrow-img--next { transform:rotate(180deg); }
.hero-title {
  color:white; font-family:'Roboto Condensed',sans-serif; font-size:72px; font-weight:400;
  text-align:center; text-shadow:0 0 20px rgba(0,0,0,0.5); line-height:50px;
  flex:1; white-space:nowrap;
}

/* ═══ BOOKING FORMA ═══ */
.bf-outer {
  position:absolute; bottom:0; left:0; right:0; z-index:10; display:flex; justify-content:center;
}
.bf-wrap { position:relative; width:min(1440px, 96%); }
.bf-row {
  border-radius:24px 24px 0 0; background:white; padding:20px 24px;
  display:flex; align-items:center;
}
.bf-field { min-width:0; display:flex; flex-direction:column; }
.bf-field--hotel { flex:3; padding:0 20px 0 0; border-right:1px solid #c5c5c5; cursor:pointer; user-select:none; }
.bf-field--sep   { flex:2; padding:0 20px; border-right:1px solid #c5c5c5; cursor:pointer; user-select:none; }
.bf-field--cta   { flex:2; padding:0 0 0 20px; }
.bf-field-inner  { display:flex; align-items:center; justify-content:space-between; }
.bf-value        { font-family:'Roboto',sans-serif; font-size:24px; color:#333; line-height:50px; white-space:nowrap; }
.bf-date-display { display:flex; align-items:flex-end; gap:4px; }
.bf-chevron      { width:17px; height:9px; flex-shrink:0; content:url('bf-arrow-down.svg'); }
.bf-promo-input  {
  font-family:'Roboto',sans-serif; font-size:22px; color:#333; line-height:50px;
  border:none; outline:none; background:transparent; width:100%; padding:0;
}
.btn-rezervisi {
  background:#2b962b; color:#fbfbfb; border:none; padding:16px 20px;
  font-size:16px; font-weight:700; letter-spacing:1.92px; border-radius:4px;
  cursor:pointer; font-family:'Roboto',sans-serif; text-transform:uppercase;
  width:100%; white-space:nowrap;
}
.bf-change-link {
  display:block; text-align:center; margin-top:6px; font-size:11px;
  color:rgba(51,51,51,0.5); text-decoration:none; font-family:'Roboto',sans-serif; white-space:nowrap;
}
.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; }

/* ═══ WELCOME SEKCIJA ═══ */
.welcome-text {
  display:flex; flex-direction:column; gap:35px; align-items:center;
  text-align:center; padding:22px 30px; color:#333;
}
.welcome-text .section-body { max-width:850px; }

/* ═══ HOTELI GRID ═══ */
.hotels-grid { display:flex; gap:30px; align-items:stretch; height:702px; overflow:hidden; }
.hotels-intro-col {
  flex:1; background:#f0eae8; border-radius:24px; padding:60px 70px;
  display:flex; flex-direction:column; gap:30px;
  align-items:center; justify-content:center; text-align:center;
}
.hotels-intro-icon { width:196px; height:194px; transform:rotate(180deg) scaleY(-1); }
.hotels-intro-title {
  font-family:'Roboto Condensed',sans-serif; font-size:42px; font-weight:400;
  text-transform:uppercase; color:#333; line-height:normal; white-space:nowrap;
}
.hotels-cards-col { flex:1; display:flex; flex-direction:column; gap:30px; }
.hotels-cards-row { display:flex; gap:30px; flex:1; }
.hotel-card {
  position:relative; border-radius:24px; overflow:hidden; display:block; text-decoration:none; flex:1;
}
.hotel-card--large { flex:1.3; }
.hotel-card-img {
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  transition:transform 0.5s ease;
}
.hotel-card:hover .hotel-card-img {
  transform:scale(1.05);
}
.hotel-card-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0) 50%);
  display:flex; flex-direction:column; justify-content:flex-end; padding:20px;
  transition:background 0.4s ease;
}
.hotel-card:hover .hotel-card-overlay {
  background:linear-gradient(to top, rgba(0,0,0,0.65) 0%, rgba(0,0,0,0.15) 100%);
}
.hotel-card-name {
  color:white; font-family:'Roboto Condensed',sans-serif;
  font-size:30px; font-weight:700; text-transform:uppercase;
  transform:translateY(0); transition:transform 0.4s ease;
}
.hotel-card-location {
  color:white; font-family:'Roboto Condensed',sans-serif;
  font-size:22px; font-weight:400; text-transform:uppercase; line-height:22px;
  opacity:1; transform:translateY(0); transition:transform 0.4s ease, opacity 0.4s ease;
}
/* Strelica koja se pojavljuje na hover */
.hotel-card-overlay::after {
  content:'→';
  position:absolute; right:24px; bottom:24px;
  color:white; font-size:28px;
  opacity:0; transform:translateX(-8px);
  transition:opacity 0.4s ease, transform 0.4s ease;
}
.hotel-card:hover .hotel-card-overlay::after {
  opacity:1; transform:translateX(0);
}

/* ═══ SPECIJALNE PONUDE ═══ */
.ponude-grid { display:flex; gap:30px; width:100%; align-items:flex-start; }
.ponuda-card {
  flex:1; display:flex; flex-direction:column; gap:20px; text-decoration:none;
  color:inherit; transition:transform 0.3s ease;
}
.ponuda-card:hover { transform:translateY(-6px); }
.ponuda-img {
  width:100%; height:100%; object-fit:cover; display:block;
  transition:transform 0.5s ease;
}
.ponuda-card:hover .ponuda-img { transform:scale(1.04); }
.ponuda-img-wrap { height:300px; border-radius:16px; overflow:hidden; position:relative; flex-shrink:0; }
.ponuda-img { width:100%; height:100%; object-fit:cover; display:block; }
.ponuda-badge {
  position:absolute; top:0; right:0; height:38px;
  display:flex; align-items:center; gap:5px; padding:0 20px;
  border-radius:0 16px 0 16px;
  color:white; font-family:'Roboto Condensed',sans-serif; white-space:nowrap;
}
.ponuda-badge--navy  { background:#1b214f; }
.ponuda-badge--green { background:#2b962b; }
.ponuda-badge-text       { font-size:16px; text-transform:uppercase; letter-spacing:0.5px; }
.ponuda-badge-pct        { font-size:24px; }
.ponuda-badge-pct-label  { font-size:14px; text-transform:uppercase; }
.ponuda-body { background:white; border-radius:16px; padding:30px 30px 50px; display:flex; flex-direction:column; gap:20px; }
.ponuda-title { font-family:'Roboto Condensed',sans-serif; font-size:32px; font-weight:400; color:#333; margin:0; line-height:normal; }
.ponuda-divider { width:30px; height:1px; background:#333; opacity:0.24; }
.ponuda-desc { font-family:'Roboto',sans-serif; font-size:18px; line-height:28px; color:#333; margin:0; }

/* ═══ VESTI ═══ */
.vesti-grid { display:flex; gap:60px; align-items:stretch; width:100%; }
.vest-card {
  flex:1; display:flex; gap:20px; align-items:center;
  padding:20px 0; text-decoration:none; color:inherit;
  transition:transform 0.3s ease;
}
.vest-card:hover { transform:translateY(-4px); }
.vest-img-wrap { width:166px; height:166px; border-radius:16px; overflow:hidden; flex-shrink:0; }
.vest-img {
  width:100%; height:100%; object-fit:cover;
  transition:transform 0.5s ease;
}
.vest-card:hover .vest-img { transform:scale(1.06); }
.vest-body {
  flex:1; background:#f0eae8; border-radius:16px; padding:20px;
  display:flex; flex-direction:column; gap:5px; color:#333; align-self:stretch;
  transition:background 0.3s ease;
}
.vest-card:hover .vest-body { background:#e8e0dc; }
.vest-date  { font-family:'Roboto',sans-serif; font-size:18px; line-height:28px; margin:0; }
.vest-title { font-family:'Roboto Condensed',sans-serif; font-size:26px; font-weight:400; line-height:normal; margin:0; }
.vest-more  { font-family:'Roboto',sans-serif; font-size:18px; line-height:28px; margin:0; }

/* ═══ 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; left:774px; top:47px;
  width:643px; height:636px; pointer-events:none; object-fit:contain; z-index:0;
}
.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; display:block; }
.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 { display:flex; align-items:center; gap:16px; }
.social-link { display:flex; align-items:center; opacity:0.85; transition:opacity 0.15s; }
.social-link:hover { opacity:1; }
.social-icon { width:24px; height:24px; display:block; }
.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-link { text-decoration:none; }
.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; }
.footer-grb { display:flex; align-items:center; flex-shrink:0; }
.footer-grb-img { width:60px; height:60px; object-fit:contain; display:block; }

/* ═══ SOBE (hotel stranice) ═══ */
.soba-wrap {
  position:relative;
  flex:1 0 0;
  min-width:0;
  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;
}
#burger-social .social-icon { filter:brightness(0) invert(1); }

/* ═══ NAV DROPDOWN ═══ */
.nav-dropdown { position:static; }
.nav-dropdown-menu {
  display:none; position:absolute; top:100%; left:0;
  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:-24px; left:0; right:0; height:24px;
  background:#1b214f;
}
.nav-dropdown-menu.is-open { display:block; }
.nav-dropdown-menu--wide { min-width:300px; }
.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); }
.footer-social-img { width:63.73px; height:21.303px; object-fit:contain; }

/* ═══ HERO — hotel varijanta ═══ */
.hero-bg-img--top { object-position: center top; }
.hero-hotel-title { flex:1; text-align:center; }
.hero-hotel-name {
  color:white; font-family:'Roboto Condensed',sans-serif; font-size:116px; font-weight:400;
  text-shadow:0 0 20px rgba(0,0,0,0.5); line-height:normal; white-space:nowrap;
}
.hero-hotel-subtitle {
  color:white; font-family:'Roboto Condensed',sans-serif; font-size:36px; font-weight:400;
  text-transform:uppercase; text-shadow:0 0 20px rgba(0,0,0,0.5); line-height:normal;
}

/* ═══ NAV — aktivni link ═══ */
.nav-link--active { font-size:26px; font-weight:700; }
.nav-icon--sq { width:24px; height:24px; }

/* ═══ INTRO SEKCIJA (hotel dobrodošli) ═══ */
.container--grid2 {
  display:grid; grid-template-columns:1fr 1fr; gap:30px;
  width:1440px; max-width:100%; flex-shrink:1; overflow:hidden;
}
.container--grid2--fixed { height:680px; }
.intro-beige-col {
  background:#f0eae8; border-radius:24px; padding:60px 70px;
  display:flex; flex-direction:column; gap:30px;
  align-items:center; justify-content:center; text-align:center;
  min-height:680px;
}
.intro-img-col { border-radius:24px; overflow:hidden; min-height:680px; }
.intro-img { width:100%; height:100%; object-fit:cover; display:block; }

/* ═══ SLIDER ═══ */
.slider-section { display:flex; flex-direction:column; gap:20px; align-items:center; width:100%; }
.slider-row {
  display:flex; align-items:center; justify-content:center; width:100%;
}
.slider-arrow {
  display:flex; align-items:center; justify-content:center;
  padding:0 24px; flex-shrink:0;
}
.slider-viewport {
  width:1440px; max-width:1440px; flex-shrink:1; overflow:hidden;
}
.slider-track {
  display:flex; gap:30px; height:680px;
  transition:transform 0.4s ease;
}
.slider-dots { display:flex; justify-content:center; gap:10px; margin-top:30px; }
.slider-dot { width:10px; height:10px; border-radius:50%; cursor:pointer; transition:background 0.3s; background:#ccc; }
.slider-dot--active { background:#333; }

/* ═══ SOBA KARTICE ═══ */
.soba-img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.soba-price-badge {
  position:absolute; top:0; right:0; background:#1b214f; color:white;
  font-family:'Roboto Condensed',sans-serif; padding:0 20px; height:38px;
  display:flex; align-items:center; gap:5px;
  border-radius:0 24px 0 24px; white-space:nowrap; z-index:10;
}
.soba-price-label { font-size:14px; text-transform:uppercase; }
.soba-price-val   { font-size:24px; }
.soba-naziv {
  color:white; font-family:'Roboto Condensed',sans-serif;
  font-size:36px; font-weight:400; text-transform:uppercase;
}
.soba-meta { display:flex; gap:20px; align-items:center; }
.soba-meta--mb { margin-bottom:8px; }
.soba-meta-item { display:flex; align-items:center; gap:8px; }
.soba-meta-icon         { flex-shrink:0; object-fit:contain; }
.soba-meta-icon--osobe  { width:24px; height:18.9px; }
.soba-meta-icon--lezaj  { width:23.6px; height:17.7px; }
.soba-meta-icon--povrs  { width:20.2px; height:20.2px; }
.soba-meta-text { color:white; font-family:'Roboto',sans-serif; font-size:16px; white-space:nowrap; }
.btn-saznaj {
  background:white; color:#333; border:none; padding:16px 50px;
  font-size:16px; font-weight:700; letter-spacing:1.92px; border-radius:4px;
  cursor:pointer; font-family:'Roboto',sans-serif; text-transform:uppercase;
  width:190px; display:inline-flex; align-items:center; justify-content:center;
  text-decoration:none; box-sizing:border-box;
}
.btn-saznaj--full { width:100%; padding:16px; }
.btn-rezervisi-soba {
  display:block; background:#2b962b; color:white; padding:16px;
  font-size:16px; font-weight:700; letter-spacing:1.92px; border-radius:4px;
  font-family:'Roboto',sans-serif; text-transform:uppercase;
  text-align:center; text-decoration:none;
}

/* ═══ SADRŽAJI ═══ */
.sadrzaj-grid { display:grid; grid-template-columns:1fr 1fr; gap:30px; width:100%; height:680px; overflow:hidden; }
.sadrzaj-beige-col {
  background:#f0eae8; border-radius:24px; padding:60px 70px;
  display:flex; flex-direction:column; gap:30px; justify-content:center;
  align-items:flex-start; text-align:left;
  position:relative; overflow:hidden;
}
.sadrzaj-watermark {
  position:absolute; right:0; bottom:0;
  width:196px; height:194px; object-fit:contain; pointer-events:none; opacity:0.35;
}
.sadrzaj-title {
  font-family:'Roboto Condensed',sans-serif; font-size:36px; font-weight:400;
  text-transform:uppercase; color:#333;
}
.sadrzaj-img-col { border-radius:24px; overflow:hidden; position:relative; }
.sadrzaj-img-link { display:block; text-decoration:none; cursor:pointer; border-radius:24px; overflow:hidden; position:relative; }
.sadrzaj-img-link .sadrzaj-img { transition:transform 0.5s ease; }
.sadrzaj-img-link:hover .sadrzaj-img { transform:scale(1.05); }
.sadrzaj-img-link .sadrzaj-img-dim { transition:background 0.4s ease; }
.sadrzaj-img-link:hover .sadrzaj-img-dim { background:rgba(0,0,0,0.45); }
.sadrzaj-img { width:100%; height:100%; object-fit:cover; display:block; }
.sadrzaj-img-dim { position:absolute; inset:0; background:rgba(0,0,0,0.28); }
.sadrzaj-img-hover {
  position:absolute; inset:0; display:flex;
  align-items:center; justify-content:center;
  opacity:0; transition:opacity 0.4s ease;
}
.sadrzaj-img-link:hover .sadrzaj-img-hover { opacity:1; }
.sadrzaj-img-hover-text {
  color:white; font-family:'Roboto Condensed',sans-serif;
  font-size:24px; font-weight:700; text-transform:uppercase; letter-spacing:1px;
  border:2px solid white; padding:14px 32px; border-radius:4px;
  transform:translateY(8px); transition:transform 0.4s ease;
}
.sadrzaj-img-link:hover .sadrzaj-img-hover-text { transform:translateY(0); }
.container--no-pad { padding:0; }

/* ═══ STICKY BOOKING BAR ═══ */
.bf-sticky-bar {
  position:fixed; top:-100px; left:0; right:0; z-index:149;
  background:white; box-shadow:0 4px 20px rgba(0,0,0,0.12);
  display:flex; justify-content:center;
  transition:top 0.35s cubic-bezier(0.4,0,0.2,1);
}
.bf-sticky-bar--visible { top:0; }
.bf-sticky-inner {
  width:min(1440px, 96%); display:flex; align-items:center; padding:12px 24px;
}

/* ═══ SMESTAJ STRANICA ═══ */
.section-white--no-top-pad { padding-top:0; }
.smestaj-intro {
  width:1440px; max-width:100%; flex-shrink:1;
  display:flex; flex-direction:column; gap:20px;
  align-items:center; text-align:center;
}
.smestaj-intro .section-body { max-width:850px; }
.smestaj-grid-wrap {
  width:1440px; max-width:100%; flex-shrink:1;
  display:flex; flex-direction:column; gap:30px; padding:0 30px;
}
.smestaj-row {
  display:flex; gap:30px; height:680px;
}
.smestaj-row .soba-wrap { flex:1; }
.bf-field--clickable { cursor:pointer; }

/* ═══ SOBA DETALJI STRANICA ═══ */
.soba-detalji-grid { display:flex; gap:30px; min-height:594px; }
.soba-opis-col {
  flex:1; background:#f0eae8; border-radius:24px; padding:60px 70px;
  display:flex; flex-direction:column; gap:30px;
  align-items:center; justify-content:center; text-align:center;
}
.soba-cena-col {
  flex:1; background:#f0eae8; border-radius:24px; padding:60px;
  display:flex; flex-direction:column; gap:20px; justify-content:center;
}
.soba-cena-box {
  background:white; border-radius:16px; padding:20px 40px;
  display:flex; align-items:center; justify-content:center; gap:10px; white-space:nowrap;
}
.soba-cena-label { font-family:'Roboto Condensed',sans-serif; font-size:28px; text-transform:uppercase; color:#333; }
.soba-cena-iznos { font-family:'Roboto Condensed',sans-serif; font-size:48px; color:#333; }
.btn-rezervisi-large {
  display:block; background:#2b962b; color:white;
  padding:30px 50px; font-size:24px; font-weight:700; letter-spacing:2.88px;
  border-radius:16px; font-family:'Roboto',sans-serif; text-transform:uppercase;
  text-align:center; text-decoration:none;
  position:relative; overflow:hidden;
  transition:background 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease;
}
.btn-rezervisi-large::before {
  content:'';
  position:absolute; top:0; left:-100%;
  width:60%; height:100%;
  background:linear-gradient(120deg, transparent 0%, rgba(255,255,255,0.28) 50%, transparent 100%);
  animation:shimmer 2.4s infinite;
}
@keyframes shimmer {
  0%   { left:-100%; }
  100% { left:160%; }
}
.btn-rezervisi-large:hover {
  background:#239623;
  transform:translateY(-3px);
  box-shadow:0 12px 32px rgba(43,150,43,0.35);
}
.soba-info-lista { padding:20px 0; display:flex; flex-direction:column; gap:40px; }
.soba-info-item { display:flex; align-items:center; gap:24px; }
.soba-info-ikona { width:72px; height:56.7px; object-fit:contain; flex-shrink:0; }
.soba-info-tekst { font-family:'Roboto',sans-serif; font-size:24px; color:#333; white-space:nowrap; }

.soba-galerija-grid { display:flex; gap:30px; height:702px; }
.soba-galerija-main { flex:1; position:relative; border-radius:24px; overflow:hidden; }
.soba-galerija-main img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.soba-galerija-badge {
  position:absolute; bottom:12px; left:12px;
  background:rgba(51,51,51,0.63); border-radius:16px; padding:12px;
  display:flex; align-items:center; gap:10px;
}
.soba-galerija-badge img { width:24px; height:24px; flex-shrink:0; object-fit:contain; display:block; }
.soba-galerija-badge span { font-family:'Roboto',sans-serif; font-size:18px; color:white; line-height:28px; }
.soba-galerija-side { flex:1; display:flex; flex-direction:column; gap:30px; }
.soba-galerija-row { display:flex; gap:30px; flex:1; }
.soba-galerija-thumb { flex:1; position:relative; border-radius:24px; overflow:hidden; }
.soba-galerija-thumb img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.soba-galerija-bottom { flex:1; position:relative; border-radius:24px; overflow:hidden; }
.soba-galerija-bottom img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }

.soba-sadrzaji-box {
  background:#f0eae8; border-radius:24px; padding:60px 70px;
  display:flex; flex-direction:column; gap:30px;
}
.soba-sadrzaji-title {
  font-family:'Roboto Condensed',sans-serif; font-size:36px; font-weight:400;
  text-transform:uppercase; color:#333;
}
.soba-sadrzaji-grid {
  display:flex; flex-wrap:wrap; justify-content:space-between;
  align-items:flex-start; gap:11px 0;
}
.soba-sadrzaj-item {
  display:flex; flex-direction:column; align-items:center;
  gap:10px; width:119px; flex-shrink:0;
}
.soba-sadrzaj-ikona { width:64px; height:70px; display:flex; align-items:center; justify-content:center; }
.soba-sadrzaj-ikona img { width:100%; height:100%; object-fit:contain; }
.soba-sadrzaj-naziv { font-family:'Roboto',sans-serif; font-size:20px; color:#333; text-align:center; }

/* Ostale sobe slider na soba stranici */
.ostale-sobe-section { padding-bottom:0; }

/* Lightbox */
#lightbox {
  display:none; position:fixed; inset:0; z-index:1000;
  background:rgba(0,0,0,0.92); align-items:center; justify-content:center;
}
#lightbox.open { display:flex; }
#lightbox-img {
  max-width:90vw; max-height:85vh; border-radius:12px;
  object-fit:contain; user-select:none; transition:opacity 0.2s ease;
}
#lightbox-close {
  position:fixed; top:24px; right:32px; width:40px; height:40px;
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  opacity:0.8; transition:opacity 0.15s;
}
#lightbox-close:hover { opacity:1; }
#lightbox-close::before, #lightbox-close::after {
  content:''; position:absolute; width:32px; height:2px; background:white;
}
#lightbox-close::before { transform:rotate(45deg); }
#lightbox-close::after  { transform:rotate(-45deg); }
.lightbox-arrow {
  position:fixed; top:50%; transform:translateY(-50%);
  width:56px; height:56px; background:rgba(255,255,255,0.12);
  border:none; border-radius:50%; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  opacity:0.8; transition:opacity 0.15s, background 0.15s;
}
.lightbox-arrow:hover { opacity:1; background:rgba(255,255,255,0.22); }
#lightbox-prev { left:24px; }
#lightbox-next { right:24px; }
.lightbox-arrow svg { width:20px; height:20px; fill:none; stroke:white; stroke-width:2.5; stroke-linecap:round; stroke-linejoin:round; }
#lightbox-counter {
  position:fixed; bottom:28px; left:50%; transform:translateX(-50%);
  color:rgba(255,255,255,0.6); font-family:'Roboto',sans-serif; font-size:14px;
}
.lb-clickable { cursor:zoom-in; }

/* ═══ RAZMAK PRE FOOTERA ═══ */
.footer-section { margin-top:100px; }

/* ═══ HOVER EFEKTI — GALERIJA SOBE ═══ */
.soba-galerija-main,
.soba-galerija-thumb,
.soba-galerija-bottom { overflow:hidden; }

.soba-galerija-main img,
.soba-galerija-thumb img,
.soba-galerija-bottom img {
  transition:transform 0.5s ease, filter 0.4s ease;
}
.soba-galerija-main:hover img,
.soba-galerija-thumb:hover img,
.soba-galerija-bottom:hover img {
  transform:scale(1.05);
  filter:brightness(1.08);
}

/* ═══ SPECIJALNE PONUDE GRID ═══ */
.ponude-grid-wrap {
  width:1440px; max-width:100%; flex-shrink:1;
  display:flex; flex-direction:column; gap:60px; padding:0 30px;
}
.ponude-row { display:flex; gap:30px; align-items:flex-start; }

/* ═══ PONUDA DETALJI STRANICA ═══ */
.ponuda-detalji-grid {
  width:1440px; max-width:100%; flex-shrink:1;
  display:flex; gap:30px; min-height:594px; padding:0 30px;
}
.ponuda-opis-col {
  flex:1; background:#f0eae8; border-radius:24px; padding:60px 70px;
  display:flex; flex-direction:column; gap:30px; justify-content:center;
}
.ponuda-cena-col {
  flex:1; background:#f0eae8; border-radius:24px; padding:60px;
  display:flex; flex-direction:column; gap:20px; justify-content:center;
}
.ponuda-lista {
  font-family:'Roboto',sans-serif; font-size:18px; line-height:28px;
  color:#333; padding-left:24px; display:flex; flex-direction:column; gap:6px; margin:0;
}
.ponuda-napomene {
  padding:20px 0; font-family:'Roboto',sans-serif;
  font-size:18px; line-height:28px; color:#333;
  display:flex; flex-direction:column; gap:8px;
}
.ponuda-napomene p { margin:0; }
.ponuda-link { color:#333; }
.ponuda-body--white { background:white; }

/* ═══ RESTORAN STRANICA ═══ */
.restoran-kontakt-box {
  background:white; border-radius:16px; padding:20px 40px;
  display:flex; align-items:center; gap:10px; white-space:nowrap;
}
.restoran-kontakt-label {
  font-family:'Roboto Condensed',sans-serif; font-size:28px;
  text-transform:uppercase; color:#333;
}
.restoran-kontakt-broj {
  font-family:'Roboto Condensed',sans-serif; font-size:48px; color:#333;
}
.restoran-detalji { display:flex; flex-direction:column; gap:30px; }
.restoran-detalj-item { display:flex; align-items:baseline; gap:6px; flex-wrap:wrap; }
.restoran-detalj-label {
  font-family:'Roboto Condensed',sans-serif; font-size:23px; color:#2b962b;
}
.restoran-detalj-vrednost {
  font-family:'Roboto',sans-serif; font-size:24px; color:#333;
}

/* ═══ KONTAKT STRANICA ═══ */
.kontakt-grid {
  display:flex; gap:30px; align-items:stretch;
}
.kontakt-info-col {
  flex:1; background:#f0eae8; border-radius:24px; padding:60px 70px;
  display:flex; flex-direction:column; gap:24px;
  align-items:center; justify-content:center; text-align:center;
}
.kontakt-info-tekst {
  font-family:'Roboto',sans-serif; font-size:18px; line-height:28px; color:#333;
  display:flex; flex-direction:column; gap:2px;
}
.kontakt-naziv { font-size:22px; }
.kontakt-link { color:#333; }
.kontakt-forma-col {
  flex:1; background:#f0eae8; border-radius:24px; padding:60px;
  display:flex; flex-direction:column; gap:30px; justify-content:center;
}
.kontakt-forma { display:flex; flex-direction:column; gap:30px; }
.forma-red { display:flex; gap:30px; }
.forma-polje { flex:1; display:flex; flex-direction:column; }
.forma-label {
  font-family:'Roboto Condensed',sans-serif; font-size:14px;
  color:#333; letter-spacing:1.12px; text-transform:uppercase;
  line-height:20px; display:block; margin-bottom:10px;
}
.forma-input {
  width:100%; height:50px; border:none; border-radius:4px;
  background:white; font-family:'Roboto',sans-serif; font-size:16px;
  color:#333; padding:0 16px; outline:none;
}
.forma-input:focus { box-shadow:0 0 0 2px #1b214f; }
.forma-textarea {
  width:100%; height:175px; border:none; border-radius:4px;
  background:white; font-family:'Roboto',sans-serif; font-size:16px;
  color:#333; padding:16px; outline:none; resize:none;
}
.forma-textarea:focus { box-shadow:0 0 0 2px #1b214f; }
.btn-posalji {
  background:#2b962b; color:white; border:none;
  padding:16px 50px; font-size:16px; font-weight:700;
  letter-spacing:1.92px; border-radius:4px; cursor:pointer;
  font-family:'Roboto',sans-serif; text-transform:uppercase;
  width:177px; transition:background 0.2s ease;
}
.btn-posalji:hover { background:#239623; }
.kontakt-mapa {
  border-radius:24px; overflow:hidden; height:409px; width:100%;
}
.kontakt-mapa iframe { border:0; display:block; width:100%; height:100%; }



/* ═══ BAZEN STRANICA ═══ */
.bazen-section { background:white; padding:100px 0; display:flex; justify-content:center; }
.bazen-wrap { width:100%; max-width:1440px; padding:0 30px; box-sizing:border-box; display:flex; gap:30px; }
.bazen-opis-col {
  flex:1; min-width:0; box-sizing:border-box;
  background:#f0eae8; border-radius:24px; padding:60px 70px;
  display:flex; flex-direction:column; gap:30px;
  align-items:center; justify-content:center; text-align:center;
}
.bazen-opis-col .section-title { white-space:normal; }
.bazen-foto-col { flex:1; min-width:0; box-sizing:border-box; display:flex; flex-direction:column; gap:30px; }
.bazen-foto-row { display:flex; gap:30px; }
.bazen-foto-thumb { flex:1; position:relative; border-radius:24px; overflow:hidden; }
.bazen-foto-thumb img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.bazen-foto-main { flex:1; position:relative; border-radius:24px; overflow:hidden; }
.bazen-foto-main img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }

/* ═══ WORDPRESS SPECIFICS ═══ */
.wp-block-image img, .entry-content img { max-width:100%; height:auto; }
.aligncenter { display:block; margin:0 auto; }
.alignleft { float:left; margin:0 1em 1em 0; }
.alignright { float:right; margin:0 0 1em 1em; }
.wp-caption { max-width:100%; }
.screen-reader-text { clip:rect(1px,1px,1px,1px); position:absolute; height:1px; width:1px; overflow:hidden; }
.admin-bar .header { top:32px; }

/* ═══ SOBA LISTING — PHOBS INTEGRATION ═══ */
.smestaj-grid-wrap { display:flex; flex-direction:column; gap:30px; }
.smestaj-row { display:flex; gap:30px; }
.smestaj-row .soba-wrap { flex:1; }

/* Soba detalj amenities sa ikonama */
.soba-sadrzaj-item { display:flex; flex-direction:column; align-items:center; gap:8px; }
.soba-sadrzaj-ikona { width:64px; height:70px; display:flex; align-items:center; justify-content:center; }
.soba-sadrzaj-ikona img { width:100%; height:100%; object-fit:contain; }
.soba-sadrzaj-naziv { font-family:'Roboto',sans-serif; font-size:20px; color:#333; text-align:center; }

/* ═══ SPECIJALNA PONUDA ═══ */
.ponuda-detalji-grid { display:flex; gap:30px; }
.ponuda-opis-col { flex:1; display:flex; flex-direction:column; gap:30px; }
.ponuda-cena-col { width:360px; flex-shrink:0; display:flex; flex-direction:column; gap:20px; }
.ponuda-include-lista { display:flex; flex-direction:column; gap:12px; padding:0; margin:0; list-style:none; }
.ponuda-include-lista li { font-family:'Roboto',sans-serif; font-size:18px; color:#333; padding-left:20px; position:relative; }
.ponuda-include-lista li::before { content:'·'; position:absolute; left:0; color:#2b962b; font-weight:700; }
.ponuda-napomene { background:#f0eae8; border-radius:16px; padding:30px; display:flex; flex-direction:column; gap:12px; }
.ponuda-napomene-title { font-family:'Roboto Condensed',sans-serif; font-size:20px; text-transform:uppercase; color:#333; }
.ponuda-napomene p { font-size:15px; color:#555; line-height:1.6; }
.ponuda-cena-box { background:#1b214f; border-radius:16px; padding:30px; display:flex; flex-direction:column; gap:16px; }
.ponuda-cena-label { font-family:'Roboto Condensed',sans-serif; font-size:20px; color:rgba(255,255,255,0.7); text-transform:uppercase; }
.ponuda-cena-iznos { font-family:'Roboto Condensed',sans-serif; font-size:48px; color:white; }
.btn-rezervisi-ponuda { background:#2b962b; color:white; border:none; padding:18px 24px; font-size:16px; font-weight:700; letter-spacing:2px; border-radius:4px; cursor:pointer; font-family:'Roboto',sans-serif; text-transform:uppercase; width:100%; text-align:center; text-decoration:none; display:block; }

/* ═══ SPECIJALNE PONUDE LISTING ═══ */
.ponude-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
@media (max-width:1024px) { .ponude-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:640px) { .ponude-grid { grid-template-columns:1fr; } }

/* ═══ MOBILE ═══ */
@media (max-width:1200px) {
  .soba-detalji-grid { flex-direction:column; }
  .ponuda-detalji-grid { flex-direction:column; }
  .ponuda-cena-col { width:100%; }
  .container { width:100%; padding:0 20px; }
  .hero { height:600px; }
  .hero-title { font-size:42px; }
  .smestaj-row { flex-wrap:wrap; }
}
@media (max-width:768px) {
  .section-white, .section-beige { padding:60px 0; }
  .header-nav { display:none; }
  .soba-galerija-grid { flex-direction:column; height:auto; }
  .soba-sadrzaji-grid { grid-template-columns:repeat(3,1fr); }
}
