/* ═══════════════════════════════════════════
   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; text-align: left;
}
.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; bottom:0; top:auto; 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:#1f522b; 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:#2b703b; 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:#2b703b; }
.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:#2b703b; }
.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:0 0 calc(50% - 15px); /* tačno polovina minus pola gap-a */
  width:calc(50% - 15px);
  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:#1f522b; 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:18px; 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:relative; }
.nav-dropdown-menu {
  display:none; position:absolute; top:calc(100% + 16px); left:0;
  background:#1f522b; 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:-40px; left:0; right:0; height:40px;
  background:transparent;
}
.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: bottom; }
.hero-hotel-title { flex:1; text-align:center; }
.hero-hotel-name {
  color:white; font-family:'Roboto Condensed',sans-serif; font-size: clamp(2.8125rem, 2.2917rem + 2.7778vw, 5.625rem); 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;
}

/* ═══ HERO SLIDER ═══ */
.hero-body--slider { justify-content:flex-start; position:relative; }
.hero-hotel-title--overlay {
  position:absolute; left:0; right:0; top:75%; transform:translateY(-50%);
  text-align:center; pointer-events:none;
}
.hero-slider-nav {
  display:flex; align-items:center; gap:16px; padding-left:60px; position:relative; z-index:1;
}
.hero-slider-nav .hero-arrow { padding:0; }
.hero-slider {
  flex:0 0 380px; display:flex; flex-direction:column; align-items:center; gap:16px;
}
.hero-slide {
  display:none; width:380px; border-radius:20px; overflow:hidden; text-decoration:none;
  background:rgba(0,0,0,0.35); border:2px solid white;
  transition:background 0.2s;
}
.hero-slide:hover { background:rgba(0,0,0,0.5); }
.hero-slide--active { display:block; }
.hero-slide-thumb {
  width:100%; height:180px; background-size:cover; background-position:center;
}
.hero-slide-body {
  padding:18px 22px; display:flex; flex-direction:column; gap:6px;
}
.hero-slide-hotel {
  font-family:'Roboto Condensed',sans-serif; font-size:11px; font-weight:700;
  text-transform:uppercase; letter-spacing:1.8px; color:rgba(255,255,255,0.65);
}
.hero-slide-naziv {
  font-family:'Roboto Condensed',sans-serif; font-size:22px; font-weight:400;
  text-transform:uppercase; color:white; line-height:1.2;
}
.hero-slide-board {
  font-family:'Roboto',sans-serif; font-size:13px; color:rgba(255,255,255,0.75);
}
.hero-slide-opis {
  font-family:'Roboto',sans-serif; font-size:13px; line-height:1.55;
  color:rgba(255,255,255,0.8); margin-top:2px;
}
.hero-slider-dots {
  display:flex; gap:8px; justify-content:center;
}
.hero-slider-dot {
  width:7px; height:7px; border-radius:50%; border:none; cursor:pointer; padding:0;
  background:rgba(255,255,255,0.35); transition:background 0.2s;
}
.hero-slider-dot--active { background:white; }

/* ═══ 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;text-align:center;
}
.btn-saznaj--full { width:100%; padding:16px; }
.btn-rezervisi-soba {
  display:block; background:#2b703b; 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:#2b703b; 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:#2b703b;
}
.restoran-detalj-vrednost {
  font-family:'Roboto',sans-serif; font-size:24px; color:#333;
}
.restoran-naslov {
  font-family:'Roboto Condensed',sans-serif; font-size:32px; font-weight:400;
  text-transform:uppercase; color:#333;
}
.restoran-info-label {
  font-family:'Roboto Condensed',sans-serif; font-size:14px; font-weight:700;
  text-transform:uppercase; letter-spacing:1.2px; color:#888; margin-bottom:8px;
}
.restoran-telefon {
  display:block; font-family:'Roboto Condensed',sans-serif; font-size:42px;
  color:#333; text-decoration:none; margin-bottom:24px; line-height:1;
}
.restoran-telefon:hover { color:#2b703b; }

/* ═══ 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:left;
}
.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:#2b703b; 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-section:nth-of-type(odd) .bazen-wrap { flex-direction: row-reverse; }
.bazen-section:nth-of-type(odd) { padding: 0 0 100px 0; }
.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; }
.bazen-pdf-link {
  display:inline-block; margin-top:auto;
  font-family:'Roboto Condensed',sans-serif; font-size:15px; font-weight:700;
  letter-spacing:1.2px; text-transform:uppercase; color:#333;
  border:1px solid #333; border-radius:4px; padding:12px 28px;
  text-decoration:none; transition:background 0.2s, color 0.2s;
}
.bazen-pdf-link:hover { background:#333; color:white; }

/* ═══ JAVNE NABAVKE STRANICA ═══ */
.jn-uvod { display:flex; align-items:center; justify-content:center; padding:22px 30px; }
.jn-uvod .section-body { max-width:850px; text-align:center; }
.jn-filter-wrap { display:flex; justify-content:flex-end; align-items:center; height:68px; }
.jn-filter { display:flex; flex-direction:column; width:155px; }
.jn-filter-label { font-family:'Roboto Condensed',sans-serif; font-size:14px; color:#333; letter-spacing:1.12px; text-transform:uppercase; line-height:17.3px; }
.jn-filter-val { display:flex; align-items:center; justify-content:space-between; gap:10px; }
.jn-filter-val span { font-family:'Roboto',sans-serif; font-size:24px; color:#333; line-height:50px; }
.jn-lista { display:flex; flex-direction:column; gap:10px; }
.jn-row {
  background:#f0eae8; border-radius:16px;
  padding:22px 30px; display:flex; align-items:center;
  justify-content:space-between; gap:20px;
  text-decoration:none; transition:background 0.15s;
}
.jn-row:hover { background:#e4dbd8; }
.jn-col-broj { display:flex; flex-direction:column; gap:5px; color:#203438; width:180px; flex-shrink:0; }
.jn-col-naziv { display:flex; flex-direction:column; gap:5px; color:#203438; flex:1; }
.jn-label { font-family:'Roboto Condensed',sans-serif; font-size:13px; text-transform:uppercase; letter-spacing:1.2px; line-height:20px; }
.jn-broj { font-family:'Roboto',sans-serif; font-size:21px; line-height:normal; }
.jn-naziv { font-family:'Roboto',sans-serif; font-size:24px; line-height:normal; }
.jn-cta { display:flex; align-items:center; gap:15px; flex-shrink:0; }
.jn-cta-devider { width:1px; height:30px; background:#203438; opacity:0.24; }
.jn-cta-text { font-family:'Roboto',sans-serif; font-weight:700; font-size:13px; letter-spacing:1.8px; text-transform:uppercase; color:#203438; white-space:nowrap; }
.jn-prikazi-jos { display:flex; justify-content:center; padding:22px 30px; }
.btn-prikazi-jos {
  background:#2b703b; color:#fbfbfb; border:none;
  padding:30px 50px; font-size:24px; font-weight:700;
  letter-spacing:2.88px; border-radius:24px; cursor:pointer;
  font-family:'Roboto',sans-serif; text-transform:uppercase;
  width:448px; height:78px; display:flex; align-items:center; justify-content:center;
  transition:background 0.2s ease;
}
.btn-prikazi-jos:hover { background:#239623; }
.soba-galerija-badge svg { flex-shrink:0; display:block; }

/* ═══ JN FILTER DROPDOWN ═══ */
.jn-filter { position:relative; cursor:pointer; user-select:none; }
.jn-filter-dropdown {
  display:none; position:absolute; top:100%; left:0; z-index:100;
  background:white; border-radius:12px; min-width:155px;
  box-shadow:0 8px 24px rgba(0,0,0,0.12); overflow:hidden;
}
.jn-filter-dropdown--open { display:block; }
.jn-filter-option {
  display:block; padding:12px 20px;
  font-family:'Roboto',sans-serif; font-size:18px; color:#333;
  text-decoration:none; border-top:1px solid rgba(0,0,0,0.06);
  transition:background 0.15s;
}
.jn-filter-option:first-child { border-top:none; }
.jn-filter-option:hover { background:#f0eae8; }
.jn-filter-option--active { font-weight:700; color:#1b214f; }

/* ═══ RATE PLAN KARTICA ═══ */
.ponuda-img-wrap--rate {
  background: #1b214f;
  display:flex; align-items:center; justify-content:center;
}
.ponuda-rate-hero {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:12px; padding:30px; text-align:center; flex:1;
}
.ponuda-rate-board {
  font-family:'Roboto Condensed',sans-serif; font-size:48px; font-weight:700;
  color:white; line-height:1; letter-spacing:2px;
}
.ponuda-rate-naziv {
  font-family:'Roboto Condensed',sans-serif; font-size:18px; font-weight:400;
  color:rgba(255,255,255,0.7); text-transform:uppercase; letter-spacing:1px;
}
.ponuda-desc--board {
  font-family:'Roboto Condensed',sans-serif; font-size:16px;
  color:#1b214f; text-transform:uppercase; letter-spacing:0.5px; font-weight:600;
}
.ponuda-cena-info {
  font-family:'Roboto',sans-serif; font-size:16px; color:#2b703b;
  font-weight:700; margin-top:auto; padding-top:10px;
}

/* ═══ STRELICE NA BELOJ POZADINI ═══ */
.section-white .slider-arrow .hero-arrow-img {
  filter: invert(93%) sepia(6%) saturate(300%) hue-rotate(330deg) brightness(95%);
}

/* ═══════════════════════════════════════════════════════════════
   LAPTOP BREAKPOINT — uski desktop ekrani (14")
   ═══════════════════════════════════════════════════════════════ */

@media (max-width: 1400px) {
  .header-nav-bar {
    gap: 30px;
    padding: 21px 24px;
  }
  .header-nav {
    gap: 20px;
  }
  .nav-link {
    font-size: 15px;
    letter-spacing: 0;
  }
}

/* ═══════════════════════════════════════════════════════════════
   MOBILNA VERZIJA — dodati na kraj shared.css
   Breakpoint: 768px (tablet i manji)
   Body klase: .home (naslovna), ostale stranice dodati naknadno
   ═══════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {

  /* ═══ LAYOUT ═══ */
  .container {
    padding: 0 15px;
    gap: 20px;
  }
  .section-white,
  .section-beige {
    padding: 60px 0;
  }
  .section-title {
    font-size: 36px;
    white-space: normal;
  }

  /* ═══ HERO ═══ */
  .hero {
    height: 752px;
  }
  .hero-hotel-name {
    font-size: 46px;
    white-space: normal;
    line-height: 48px;
  }
  /* Hero slika — resetujemo desktop trik */
  .hero-bg-img {
    top: 0;
    bottom: auto;
    height: 100%;
    object-position: center top;
  }
  /* Ograniciavamo bg wrapper na 72% — slika i dim overlay ne prelaze ispod */
  .hero-bg {
    bottom: auto;
    height: 72%;
  }
  /* Pozadina hero sekcije — bela ispod slike */
  .hero {
    background: white;
  }

  /* ═══ HEADER ═══ */
  .header-nav-bar {
    gap: 0;
    padding: 21px 20px;
  }
  .header-nav {
    display: none;
  }
  .btn-lang {
    display: none;
  }

  /* ═══ HERO SLIDER — sakrivamo slider kartice, ostaju strelice i naslov ═══ */
  /* Slider — peek pattern, aktivna kartica 85% + peek 15% */
  .hero-slider-nav {
    display: flex;
    align-items: flex-end;
    padding: 0;
    gap: 0;
    width: 100%;
    overflow: hidden;
  }
  /* Sakrivamo strelice */
  .hero-slider-nav .hero-arrow {
    display: none;
  }
  /* Slider — horizontalni scroll sa peek efektom */
  .hero-slider {
    flex: 1;
    flex-direction: row !important;
    overflow-x: auto;
    overflow-y: visible;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    gap: 10px !important;
    padding: 0 15px 12px;
    align-items: stretch;
    width: 100%;
    flex-wrap: nowrap;
  }
  .hero-slider::-webkit-scrollbar {
    display: none;
  }
  /* Sve kartice vidljive — overridujemo JS display: none */
  /* Kartica: ~50% sirine ekrana — vidi se aktivna + peek sledece */
  .hero-slide {
    display: flex !important;
    flex-direction: column;
    flex: 0 0 calc(50% - 10px);
    min-width: calc(50% - 10px);
    border-radius: 10px;
    border: 1.5px solid rgba(255,255,255,0.7);
    scroll-snap-align: start;
    opacity: 0.5;
    filter: blur(1.5px);
    transition: opacity 0.3s, filter 0.3s;
  }
  /* Aktivna kartica — puna vidljivost */
  .hero-slide--active {
    opacity: 1;
    filter: none;
  }
  /* Thumb */
  .hero-slide-thumb {
    height: 80px;
  }
  /* Tekst kompaktniji */
  .hero-slide-body {
    padding: 8px 10px;
    gap: 3px;
    flex: 1;
  }
  .hero-slide-naziv {
    font-size: 12px;
    line-height: 1.2;
  }
  .hero-slide-hotel {
    font-size: 9px;
  }
  .hero-slide-board,
  .hero-slide-opis {
    display: none;
  }
  /* Jedna kartica — centrirana */
  .hero-slider--single {
    justify-content: center;
  }
  .hero-slider--single .hero-slide {
    flex: 0 0 60%;
    min-width: 60%;
  }
  /* Dots — sakrivamo */
  .hero-slider-dots {
    display: none;
  }
  /* Hero body — vertikalni stack: kartice gore, naslov dole */
  .hero-body {
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    padding-bottom: 20px;
    gap: 16px;
  }
  .hero-body--slider {
    justify-content: flex-start;
    align-items: center;
  }
  /* Slider nav — puna sirina */
  .hero-slider-nav {
    width: 100%;
    align-items: flex-start;
    padding-top: 16px;
  }
  /* Naslov — ispod kartica, centriran */
  .hero-hotel-title--overlay {
    position: relative;
    top: auto;
    left: auto;
    transform: none;
    text-align: center;
    padding: 0 20px;
    width: 100%;
  }
  /* Strelice ostaju ali su manje */
  .hero-arrow-img {
    width: 40px;
    height: 40px;
  }

  /* ═══ BOOKING FORMA ═══ */
  .bf-outer {
    position: relative;
    bottom: auto;
    left: auto;
    right: auto;
    width: 100%;
    box-sizing: border-box;
    padding: 0 15px;
    margin-top: auto;
  }
  .bf-wrap {
    width: 100%;
    box-sizing: border-box;
    position: relative;
  }
  .bf-row {
    flex-direction: column;
    gap: 0;
    padding: 20px 20px 30px;
    border-radius: 24px 24px 0 0;
  }
  /* Hotel selector — puna širina, razdvajač ispod */
  .bf-field--hotel {
    flex: none;
    width: 100%;
    padding: 0 0 12px 0;
    border-right: none;
    border-bottom: 1px solid #c5c5c5;
    margin-bottom: 12px;
  }
  /* Dolazak + Odlazak — dva u redu */
  .bf-field--sep {
    flex: none;
    padding: 0;
    border-right: none;
  }
  /* Wrapper za dolazak i odlazak u redu */
  #bf-ci-wrap,
  #bf-co-wrap {
    flex: 1;
  }
  /* Grupišemo dolazak i odlazak horizontalno */
  #bf-ci-wrap + #bf-co-wrap {
    margin-left: 0;
  }
  /* Promo kod — sakrivamo */
  .bf-field:has(#bf-promo) {
    display: none;
  }
  /* CTA — puna širina */
  .bf-field--cta {
    flex: none;
    width: 100%;
    padding: 12px 0 0 0;
  }
  .btn-rezervisi {
    width: 100%;
  }
  /* Kalendar pozicioniranje — otvara se iznad forme */
  .bf-row {
    position: relative;
  }
  .bf-cal {
    position: absolute;
    bottom: calc(100% + 8px);
    top: auto;
    left: 0;
    right: 0;
    width: 100%;
    box-sizing: border-box;
  }

  /* ═══ STICKY BAR — sakrivamo na mobilnom ═══ */
  .bf-sticky-bar {
    display: none;
  }

  /* ═══ HOME — WELCOME SEKCIJA ═══ */
  .home .index-uvod {
    padding: 22px 0;
  }

  /* ═══ HOME — HOTELS GRID ═══ */
  .home .hotels-grid {
    flex-direction: column;
    height: auto;
  }
  .home .hotels-intro-col {
    flex: none;
    width: 100%;
    padding: 60px 15px;
  }
  .home .hotels-intro-icon {
    width: 120px;
    height: 119px;
  }
  .home .hotels-cards-col {
    flex: none;
    width: 100%;
  }
  .home .hotels-cards-row {
    flex-direction: column;
    height: auto;
  }
  .home .hotels-cards-row--two {
    flex-direction: column;
  }
  .home .hotel-card,
  .home .hotel-card--large {
    flex: none;
    width: 100%;
    height: 234px; /* svaka kartica ~234px da trojka ukupno pravi ~702px sa gapovima */
  }

  /* ═══ HOME — SPECIJALNE PONUDE (horizontalni scroll) ═══ */
  .home .ponude-row {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 16px;
    gap: 15px;
    /* Sakrivamo scrollbar vizuelno ali zadržavamo funkcionalnost */
    scrollbar-width: none;
  }
  .home .ponude-row::-webkit-scrollbar {
    display: none;
  }
  .home .ponuda-card {
    flex: 0 0 286px;
    min-width: 286px;
  }

  /* ═══ HOME — VESTI ═══ */
  .home .vesti-grid {
    flex-direction: column;
    gap: 30px;
  }
  .home .vest-card {
    flex-direction: column;
    padding: 0;
  }
  /* Sakrivamo sliku na mobilnom — Figma dizajn je ne prikazuje */
  .home .vest-img-wrap {
    display: none;
  }
  .home .vest-body {
    align-self: auto;
    width: 100%;
  }

  /* ═══ FOOTER ═══ */
  .footer-section {
    margin-top: 60px;
  }
  .footer-wrap {
    padding: 40px 15px 20px;
    gap: 40px;
    border-radius: 24px 24px 0 0;
  }
  .footer-watermark {
    display: none;
  }
  .footer-top {
    flex-direction: column;
    gap: 40px;
  }
  .footer-logo-col {
    width: 100%;
  }
  /* Sakrivamo nav linkove kolone — nisu u mobilnom dizajnu */
  .footer-links {
    display: none;
  }
  .footer-hotels-col {
    display: flex;
    flex-direction: column;
    gap: 30px;
  }
  .footer-bottom {
    flex-direction: column;
    gap: 16px;
    align-items: flex-start;
  }
  .footer-copyright {
    font-size: 13px;
  }

  /* ═══ BURGER PANEL ═══ */
  #burger-panel {
    width: 100%;
    right: -100%;
  }
  #burger-panel.active {
    right: 0;
  }

} /* kraj @media 768px */


/* ═══ BOOKING FORMA — dolazak+odlazak u redu (poseban breakpoint) ═══
   Moramo ovo da sredimo kroz flex wrapper —
   na mobilnom bf-row je column, ali ci i co treba da budu u redu.
   Rešavamo kroz redosled u DOM-u: ci i co su jedan za drugim,
   pa ih stavljamo u pseudo-row. */
@media (max-width: 768px) {
  #bf-ci-wrap,
  #bf-co-wrap {
    display: flex;
    flex-direction: column;
  }
  /* Wrapper trik: grupišemo ih vizuelno u red */
  .bf-row {
    display: grid;
    grid-template-areas:
      "hotel hotel"
      "checkin checkout"
      "cta    cta";
    grid-template-columns: 1fr 1fr;
    gap: 0;
    column-gap: 30px;
  }
  .bf-field--hotel        { grid-area: hotel; }
  #bf-ci-wrap             { grid-area: checkin; padding-top: 12px; }
  #bf-co-wrap             { grid-area: checkout; padding-top: 12px; }
  .bf-field--cta          { grid-area: cta; }
  /* Promo polje van grida — sakriven */
  .bf-field:has(#bf-promo) { display: none; }
}

/* ═══════════════════════════════════════════════════════════════
   HOTEL OMORIKA — mobilna verzija
   Selektor: .page-template-page-hotel-omorika
   ═══════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {

  /* ═══ DOBRODOŠLI — grid2 → vertikalni stack ═══ */
  .page-template-page-hotel-omorika .container--grid2 {
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding: 0 15px;
    height: auto;
  }
  .page-template-page-hotel-omorika .soba-opis-col {
    min-height: auto;
    padding: 60px 15px;
    width: 100%;
  }
  .page-template-page-hotel-omorika .intro-img-col {
    width: 100%;
    height: 346px;
    min-height: auto;
    border-radius: 24px;
    overflow: hidden;
  }
  .page-template-page-hotel-omorika .intro-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  /* ═══ SOBE SLIDER — horizontalni scroll ═══ */
  .page-template-page-hotel-omorika .slider-row {
    gap: 0;
  }
  .page-template-page-hotel-omorika .slider-arrow {
    display: none;
  }
  .page-template-page-hotel-omorika .slider-viewport {
    width: 100%;
    overflow-x: auto;
    overflow-y: visible;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: 0 15px;
  }
  .page-template-page-hotel-omorika .slider-viewport::-webkit-scrollbar {
    display: none;
  }
  .page-template-page-hotel-omorika .slider-track {
    height: auto;
    gap: 15px;
    /* JS postavlja transform — resetujemo ga na mobilnom */
    transform: none !important;
    width: max-content;
  }

  /* Sobe kartice */
  .page-template-page-hotel-omorika .soba-wrap {
    flex: 0 0 286px !important;
    min-width: 286px !important;
    max-width: 286px !important;
    height: 477px;
  }

  /* Sadrzaji kartice */
  .page-template-page-hotel-omorika .sadrzaj-grid {
    display: flex;
    flex-direction: column-reverse;
    height: 560px;
    min-width: 286px !important;
    max-width: 286px !important;
    gap: 0;
    overflow: hidden;
    border-radius: 16px;
  }
  .page-template-page-hotel-omorika .sadrzaj-beige-col {
    flex: 0 0 auto;
    height: 260px;
    padding: 24px 24px 24px;
    border-radius: 0 0 16px 16px;
    text-align: left;
    align-items: flex-start;
    justify-content: flex-start;
    overflow: hidden;
  }
  .page-template-page-hotel-omorika .sadrzaj-beige-col .section-body {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  .page-template-page-hotel-omorika .sadrzaj-img-col {
    flex: 1;
    min-height: 0;
    border-radius: 16px 16px 0 0;
    overflow: hidden;
  }
  .page-template-page-hotel-omorika .sadrzaj-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  /* Dots — sakrivamo na mobilnom jer imamo scroll */
  .page-template-page-hotel-omorika .slider-dots {
    display: none;
  }

  /* ═══ SPECIJALNE PONUDE — horizontalni scroll ═══ */
  .page-template-page-hotel-omorika .ponude-row {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 16px;
    gap: 15px;
    scrollbar-width: none;
  }
  .page-template-page-hotel-omorika .ponude-row::-webkit-scrollbar {
    display: none;
  }
  .page-template-page-hotel-omorika .ponuda-card {
    flex: 0 0 286px;
    min-width: 286px;
  }

  /* ═══ VESTI — bez slike, vertikalni stack ═══ */
  .page-template-page-hotel-omorika .vesti-grid {
    flex-direction: column;
    gap: 30px;
  }
  .page-template-page-hotel-omorika .vest-card {
    flex-direction: column;
    padding: 0;
  }
  .page-template-page-hotel-omorika .vest-img-wrap {
    display: none;
  }
  .page-template-page-hotel-omorika .vest-body {
    align-self: auto;
    width: 100%;
  }

} /* kraj hotel omorika @media */


/* ═══ BURGER — ubaceni top nav linkovi ═══ */
@media (max-width: 768px) {
  #burger-panel nav a.burger-nav-injected {
    color: white;
    text-decoration: none;
    font-family: 'Roboto', sans-serif;
    font-size: 18px;
    line-height: 17px;
    letter-spacing: -0.18px;
    white-space: nowrap;
    opacity: 0.85;
  }
  #burger-panel nav a.burger-nav-injected:hover {
    opacity: 1;
  }
  /* Uvucene stavke iz padajuceg menija */
  #burger-panel nav a.burger-nav-child {
    padding-left: 20px;
    font-size: 15px;
    opacity: 0.65;
  }
  #burger-panel nav a.burger-nav-child:hover {
    opacity: 0.9;
  }
  .burger-nav-sep {
    width: 100%;
    height: 1px;
    background: rgba(255, 255, 255, 0.15);
    margin: 3px 0;
  }
}


/* ═══════════════════════════════════════════════════════════════
   RESTORAN — mobilna verzija
   Selektor: .page-template-page-restoran
   ═══════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {

  /* ═══ OPIS + INFO — vertikalni stack ═══ */
  .page-template-page-restoran .soba-detalji-grid {
    flex-direction: column;
    min-height: auto;
    gap: 20px;
  }
  .page-template-page-restoran .soba-opis-col {
    min-height: auto;
    padding: 30px 20px;
    width: 100%;
  }
  /* Kompaktniji info box */
  .page-template-page-restoran .soba-cena-col {
    min-height: auto;
    padding: 24px 20px;
    gap: 10px;
    width: 100%;
  }
  .page-template-page-restoran .restoran-telefon {
    font-size: 28px;
    margin-bottom: 10px;
  }
  .page-template-page-restoran .restoran-detalji {
    gap: 10px;
  }
  .page-template-page-restoran .restoran-detalj-item {
    flex-wrap: wrap;
    gap: 4px;
  }
  .page-template-page-restoran .restoran-detalj-label {
    font-size: 18px;
  }
  .page-template-page-restoran .restoran-detalj-vrednost {
    font-size: 18px;
  }

  /* ═══ GALERIJA — stack ═══ */
  .page-template-page-restoran .soba-galerija-grid {
    flex-direction: column;
    height: auto;
    gap: 10px;
  }
  /* Dva thumbnaila idu prvi (order: 1) */
  .page-template-page-restoran .soba-galerija-side {
    order: 1;
    width: 100%;
    gap: 10px;
  }
  .page-template-page-restoran .soba-galerija-row {
    gap: 10px;
    height: 180px;
  }
  .page-template-page-restoran .soba-galerija-thumb {
    height: 180px;
    border-radius: 12px;
    overflow: hidden;
  }
  /* Glavna slika ide ispod kao treca — puna sirina (order: 2) */
  .page-template-page-restoran .soba-galerija-main {
    order: 2;
    flex: none;
    width: 100%;
    height: 180px;
    border-radius: 12px;
    overflow: hidden;
    position: relative;
  }
  .page-template-page-restoran .soba-galerija-main img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  /* Galerija badge — sakrivamo na mobilnom */
  .page-template-page-restoran .soba-galerija-badge {
    display: none;
  }
  /* soba-galerija-bottom ako postoji */
  .page-template-page-restoran .soba-galerija-bottom {
    width: 100%;
    height: 180px;
    border-radius: 12px;
    overflow: hidden;
    flex-shrink: 0;
  }

} /* kraj restoran @media */


/* ═══════════════════════════════════════════════════════════════
   BAZEN — mobilna verzija
   Selektor: .page-template-page-bazen
   ═══════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {

  /* Sekcija padding */
  .page-template-page-bazen .bazen-section {
    padding: 60px 0;
  }
  .page-template-page-bazen .bazen-section:nth-of-type(odd) {
    padding: 0 0 60px 0;
  }

  /* Wrapper — vertikalni stack */
  .page-template-page-bazen .bazen-wrap {
    flex-direction: column;
    gap: 20px;
    padding: 0 15px;
  }

  /* Opis kolona — resetujemo JS inline stilove */
  .page-template-page-bazen .bazen-opis-col {
    flex: none !important;
    width: 100% !important;
    height: auto !important;
    padding: 40px 20px;
    border-radius: 24px;
  }

  /* Foto kolona — puna sirina, resetujemo JS inline stilove */
  .page-template-page-bazen .bazen-foto-col {
    flex: none !important;
    width: 100% !important;
    gap: 10px;
  }

  /* Dva thumbnaila u redu */
  .page-template-page-bazen .bazen-foto-row {
    height: 180px !important;
    gap: 10px;
  }
  .page-template-page-bazen .bazen-foto-thumb {
    height: 180px !important;
    border-radius: 12px;
    overflow: hidden;
  }

  /* Glavna slika — puna sirina ispod */
  .page-template-page-bazen .bazen-foto-main {
    flex: none !important;
    width: 100%;
    height: 180px !important;
    border-radius: 12px;
    overflow: hidden;
    position: relative;
  }
  .page-template-page-bazen .bazen-foto-main img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  /* Badge — sakrivamo */
  .page-template-page-bazen .soba-galerija-badge {
    display: none;
  }

  /* Alternacija layout-a — resetujemo na mobilnom */
  .page-template-page-bazen .bazen-section:nth-of-type(odd) .bazen-wrap {
    flex-direction: column;
  }

} /* kraj bazen @media */


/* ═══════════════════════════════════════════════════════════════
   SPECIJALNE PONUDE — mobilna verzija
   Selektor: .page-template-page-specijalne-ponude
   ═══════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {

  .page-template-page-specijalne-ponude .ponude-grid-wrap {
    padding: 0 15px;
    gap: 30px;
  }

  /* Svaki red — vertikalni stack */
  .page-template-page-specijalne-ponude .ponude-row {
    flex-direction: column;
    gap: 20px;
  }

  /* Kartice — puna sirina */
  .page-template-page-specijalne-ponude .ponuda-card {
    flex: none;
    width: 100%;
    min-width: 0;
  }

} /* kraj specijalne ponude @media */


/* ═══════════════════════════════════════════════════════════════
   SMESTAJ — mobilna verzija
   Selektor: .page-template-page-hotel-omorika-smestaj
   ═══════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {

  .page-template-page-hotel-omorika-smestaj .smestaj-grid-wrap {
    padding: 0 15px;
    gap: 20px;
  }

  /* Svaki red — vertikalni stack */
  .page-template-page-hotel-omorika-smestaj .smestaj-row {
    flex-direction: column;
    height: auto;
    gap: 20px;
  }

  /* Soba kartica — puna sirina, fiksna visina */
  .page-template-page-hotel-omorika-smestaj .soba-wrap {
    flex: none !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: 320px;
  }

} /* kraj smestaj @media */


/* ═══════════════════════════════════════════════════════════════
   SINGLE SOBA — mobilna verzija
   Selektor: .single-phobs_room
   ═══════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {

  /* ═══ OPIS + CENA — vertikalni stack ═══ */
  .single-phobs_room .soba-detalji-grid {
    flex-direction: column;
    min-height: auto;
    gap: 20px;
  }
  .single-phobs_room .soba-opis-col {
    min-height: auto;
    padding: 30px 20px;
    width: 100%;
  }
  .single-phobs_room .soba-cena-col {
    min-height: auto;
    padding: 30px 20px;
    width: 100%;
    gap: 20px;
  }
  .single-phobs_room .soba-cena-box {
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
    padding: 16px 20px;
  }
  .single-phobs_room .soba-cena-iznos {
    font-size: 36px;
  }
  .single-phobs_room .btn-rezervisi-large {
    font-size: 18px;
    padding: 20px 30px;
  }
  .single-phobs_room .soba-info-lista {
    gap: 20px;
    padding: 10px 0;
  }

  /* ═══ GALERIJA — ista logika kao restoran ═══ */
  .single-phobs_room .soba-galerija-grid {
    flex-direction: column;
    height: auto;
    gap: 10px;
  }
  .single-phobs_room .soba-galerija-side {
    order: 1;
    width: 100%;
    gap: 10px;
  }
  .single-phobs_room .soba-galerija-row {
    gap: 10px;
    height: 180px;
  }
  .single-phobs_room .soba-galerija-thumb {
    height: 180px;
    border-radius: 12px;
    overflow: hidden;
  }
  .single-phobs_room .soba-galerija-main {
    order: 2;
    flex: none;
    width: 100%;
    height: 180px;
    border-radius: 12px;
    overflow: hidden;
    position: relative;
  }
  .single-phobs_room .soba-galerija-main img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .single-phobs_room .soba-galerija-badge {
    display: none;
  }
  .single-phobs_room .soba-galerija-bottom {
    flex: none;
    width: 100%;
    height: 180px;
    border-radius: 12px;
    overflow: hidden;
  }

  /* ═══ AMENITIES — sakrivamo na mobilnom ═══ */
  .single-phobs_room .soba-sadrzaji-box {
    display: none;
  }

  /* ═══ OSTALE SOBE SLIDER — horizontalni scroll ═══ */
  .single-phobs_room .slider-arrow {
    display: none;
  }
  .single-phobs_room .slider-viewport {
    width: 100%;
    overflow-x: auto;
    overflow-y: visible;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: 0 15px;
  }
  .single-phobs_room .slider-viewport::-webkit-scrollbar {
    display: none;
  }
  .single-phobs_room .slider-track {
    transform: none !important;
    width: max-content;
    height: auto;
    gap: 15px;
  }
  .single-phobs_room .soba-wrap {
    flex: 0 0 286px !important;
    min-width: 286px !important;
    max-width: 286px !important;
    height: 477px;
  }

} /* kraj single soba @media */


/* ═══════════════════════════════════════════════════════════════
   SINGLE RATE — mobilna verzija
   Selektor: .single-phobs_rate
   ═══════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {

  /* ═══ OPIS + REZERVISI — vertikalni stack ═══ */
  .single-phobs_rate .ponuda-detalji-grid {
    flex-direction: column;
    min-height: auto;
    gap: 20px;
    padding: 0 15px;
  }
  .single-phobs_rate .ponuda-opis-col {
    min-height: auto;
    padding: 30px 20px;
    width: 100%;
  }
	.single-phobs_rate .ponuda-opis-col img {
    border-radius: 24px;
  }
  .single-phobs_rate .ponuda-cena-col {
    min-height: auto;
    padding: 30px 20px;
    width: 100%;
  }
  .single-phobs_rate .btn-rezervisi-large {
    font-size: 18px;
    padding: 20px 30px;
  }

  /* ═══ OSTALI CENOVNICI — vertikalni stack ═══ */
  .single-phobs_rate .ponude-row {
    flex-direction: column;
    gap: 20px;
  }
  .single-phobs_rate .ponuda-card {
    flex: none;
    width: 100%;
    min-width: 0;
  }

} /* kraj single rate @media */


/* ═══════════════════════════════════════════════════════════════
   KONTAKT FORMA — stilizacija CF7
   ═══════════════════════════════════════════════════════════════ */

.kontakt-forma {
  background: #f0eae8;
  border-radius: 24px;
  padding: 60px;
}

.kontakt-forma .wpcf7-form {
  display: flex;
  flex-direction: column;
  gap: 30px;
}

/* Uklanjamo default <p> margin od CF7 */
.kontakt-forma .wpcf7-form p {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* Labele */
.kontakt-forma label {
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 100%;
  font-family: 'Roboto Condensed', sans-serif;
  font-size: 14px;
  font-weight: 400;
  color: #333;
  letter-spacing: 1.12px;
  text-transform: uppercase;
  line-height: 20px;
  cursor: pointer;
}

/* Input i select polja */
.kontakt-forma input[type="text"],
.kontakt-forma input[type="email"],
.kontakt-forma input[type="tel"],
.kontakt-forma select {
  width: 100%;
  height: 50px;
  background: white;
  border: none;
  border-radius: 4px;
  padding: 0 16px;
  font-family: 'Roboto', sans-serif;
  font-size: 16px;
  color: #333;
  outline: none;
  box-sizing: border-box;
  appearance: none;
  -webkit-appearance: none;
}

.kontakt-forma input[type="text"]:focus,
.kontakt-forma input[type="email"]:focus,
.kontakt-forma input[type="tel"]:focus,
.kontakt-forma select:focus {
  box-shadow: 0 0 0 2px rgba(43, 150, 43, 0.3);
}

/* Select — custom strelica */
.kontakt-forma .wpcf7-form-control-wrap:has(select) {
  position: relative;
  display: block;
  width: 100%;
}
.kontakt-forma .wpcf7-form-control-wrap:has(select)::after {
  content: '';
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  width: 10px;
  height: 6px;
  background: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%23333' stroke-width='1.5'/%3E%3C/svg%3E") no-repeat center;
  pointer-events: none;
}

/* Textarea */
.kontakt-forma textarea {
  width: 100%;
  height: 175px;
  background: white;
  border: none;
  border-radius: 4px;
  padding: 14px 16px;
  font-family: 'Roboto', sans-serif;
  font-size: 16px;
  color: #333;
  outline: none;
  resize: vertical;
  box-sizing: border-box;
  line-height: 1.6;
}
.kontakt-forma textarea:focus {
  box-shadow: 0 0 0 2px rgba(43, 150, 43, 0.3);
}

/* Submit dugme */
.kontakt-forma input[type="submit"] {
  height: 50px;
  padding: 0 50px;
  background: #2b703b;
  color: white;
  border: none;
  border-radius: 4px;
  font-family: 'Roboto', sans-serif;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 1.92px;
  text-transform: uppercase;
  cursor: pointer;
  align-self: flex-start;
  transition: background 0.15s;
}
.kontakt-forma input[type="submit"]:hover {
  background: #247a24;
}

/* CF7 span wrapper */
.kontakt-forma .wpcf7-form-control-wrap {
  display: block;
  width: 100%;
}

/* Validacijske greske */
.kontakt-forma .wpcf7-not-valid-tip {
  font-family: 'Roboto', sans-serif;
  font-size: 13px;
  color: #c0392b;
  margin-top: 4px;
}
.kontakt-forma .wpcf7-not-valid {
  box-shadow: 0 0 0 2px rgba(192, 57, 43, 0.4) !important;
}

/* Response poruka */
.kontakt-forma .wpcf7-response-output {
  font-family: 'Roboto', sans-serif;
  font-size: 15px;
  padding: 12px 16px;
  border-radius: 4px;
  border: none !important;
  margin: 0 !important;
}

/* Mobilno */
@media (max-width: 768px) {
  .kontakt-forma {
    padding: 30px 20px;
    border-radius: 16px;
  }
  .kontakt-forma input[type="submit"] {
    width: 100%;
  }
}
.section-white.veljko{
margin: auto important!;
background-color: white !important;
padding: 20px 0 !important;}
.ponuda-thumb img{
border-radius: 24px;}


/* ═══════════════════════════════════════════════════════════════
   KONTAKT STRANICA — mobilna verzija
   ═══════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {

  /* Grid — vertikalni stack */
  .kontakt-grid {
    flex-direction: column;
    gap: 20px;
  }

  /* Info kolone — puna sirina, manji padding */
  .kontakt-info-col {
    flex: none;
    width: 100%;
    padding: 40px 24px;
    border-radius: 16px;
    align-items: flex-start;
    text-align: left;
  }

  .kontakt-info-col .section-title {
    text-align: left;
  }

  /* Kontakt tekst — manji font */
  .kontakt-info-tekst {
    font-size: 16px;
    line-height: 26px;
    width: 100%;
  }

  /* Mapa — manja visina */
  .kontakt-mapa {
    height: 280px;
    border-radius: 16px;
  }

  /* Forma sekcija */
  .kontakt-forma {
    padding: 30px 20px;
    border-radius: 16px;
  }
  .kontakt-forma input[type="submit"] {
    width: 100%;
    padding: 0 20px;
  }

} /* kraj kontakt @media */

.sakriti{
	display: none !important;
}
/* ═══ RESPONSIVE NAV ═══ */
@media (max-width: 1600px) {
  .header-nav-bar { gap:40px; padding:21px 24px; flex-shrink:1; }
  .header-nav     { gap:24px; }
  .header-actions { gap:40px; }
  .nav-link       { font-size:15px; gap:7px; }
  .nav-link--active { font-size:20px; }
}
@media (max-width: 1380px) {
  .header-nav-bar { gap:20px; padding:21px 16px; }
  .header-nav     { gap:14px; }
  .header-actions { gap:20px; }
  .nav-link       { font-size:13px; gap:5px; }
  .nav-link--active { font-size:17px; }
  .nav-icon--sq   { width:20px; height:20px; }
  .nav-icon--hotel { width:22px; height:27px; }
}