/**
 * RESPONSIVE KONCEPT – KLS WebAct (mobile-first)
 * Jedan izvor istine za breakpoints, touch targete i mobilni layout.
 * Učitava se nakon tailwind.css.
 */

/* ========== BREAKPOINTS (usklađeno s Tailwindom) ==========
   xs: 0–639px   (mobil)
   sm: 640px+
   md: 768px+
   lg: 1024px+   (desktop nav)
   xl: 1280px+
   2xl: 1536px+
   3xl: 1920px+  (veliki monitori / ultra-wide)
*/

:root {
  --brand-blue: #0f172a;
  /* Breakpoints (za media queries u custom CSS-u) */
  --bp-sm: 640px;
  --bp-md: 768px;
  --bp-lg: 1024px;
  --bp-xl: 1280px;
  --bp-2xl: 1536px;
  --bp-3xl: 1920px;

  /* Touch & tap (Apple HIG / Material: min 44px) */
  --touch-min: 44px;
  --touch-min-lg: 48px;

  /* Header */
  --header-h-mobile: 64px;
  --header-h-desktop: 72px;

  /* Container padding (safe area na mobitelu) */
  --container-px-mobile: 1rem;
  --container-px-tablet: 1.5rem;
  --container-px-desktop: 2rem;
  --container-max: 1280px;
  /* Fluid proširenje na velikim rezolucijama */
  --container-max-2xl: min(90vw, 1400px);
  --container-max-3xl: min(90vw, 1600px);

  /* Tipografija – mobil first (veće na desktopu preko Tailwinda) */
  --text-base-mobile: 1rem;
  --text-sm-mobile: 0.875rem;
  --line-height-tight: 1.25;
  --line-height-normal: 1.5;

  /* Public theme defaults */
  --public-bg: #08111f;
  --public-bg-soft: #0f1a2e;
  --public-surface: rgba(15, 23, 42, 0.72);
  --public-surface-strong: rgba(8, 15, 29, 0.84);
  --public-surface-soft: rgba(255, 255, 255, 0.08);
  --public-border: rgba(255, 255, 255, 0.12);
  --public-border-strong: rgba(255, 255, 255, 0.2);
  --public-text: #f8fafc;
  --public-text-muted: #cbd5e1;
  --public-title: #ffffff;
  --public-shadow: 0 20px 45px rgba(2, 8, 23, 0.35);
  --public-header-bg: linear-gradient(135deg, rgba(15, 23, 42, 0.68) 0%, rgba(8, 15, 29, 0.62) 100%);
  --public-header-shadow: 0 2px 0 rgba(255, 255, 255, 0.06) inset, 0 8px 32px rgba(2, 8, 23, 0.36), 0 1px 0 rgba(255, 255, 255, 0.08);
  --public-header-border: rgba(255, 255, 255, 0.12);
  --public-menu-bg: linear-gradient(180deg, rgba(8, 15, 29, 0.97) 0%, rgba(15, 23, 42, 0.98) 100%);
  --public-chip-bg: rgba(255, 255, 255, 0.08);
  --public-chip-text: #e2e8f0;
  --public-toggle-bg: rgba(255, 255, 255, 0.08);
  --public-toggle-border: rgba(255, 255, 255, 0.14);
  --public-toggle-icon: #f8fafc;
  --public-toggle-muted: #94a3b8;
  --public-footer-bg: #020817;
  --public-footer-card: rgba(15, 23, 42, 0.72);
  --public-footer-text: #e2e8f0;
  --public-footer-muted: #94a3b8;
  /* Footer glassmorphism efekti */
  --public-footer-glass-bg: rgba(15, 23, 42, 0.6);
  --public-footer-glass-border: rgba(255, 255, 255, 0.1);
  --public-footer-glass-strong: rgba(15, 23, 42, 0.85);
  --public-footer-gradient: linear-gradient(180deg, rgba(8, 15, 29, 0.95) 0%, #020817 100%);
  --public-footer-review-bg: rgba(255, 255, 255, 0.05);
  --public-footer-review-border: rgba(255, 255, 255, 0.08);
  --public-footer-trust-bg: rgba(255, 255, 255, 0.06);
  --public-footer-hover-glow: rgba(59, 130, 246, 0.3);
  --public-cookie-bg: rgba(255, 255, 255, 0.96);
  --public-cookie-text: #475569;
  --public-cookie-border: rgba(148, 163, 184, 0.18);
  --card-bg: rgba(255, 255, 255, 0.04);
  --card-border: rgba(255, 255, 255, 0.08);
  color-scheme: dark;
}

html[data-theme="light"] {
  --public-bg: #eef4ff;
  --public-bg-soft: #f8fbff;
  --public-surface: rgba(255, 255, 255, 0.82);
  --public-surface-strong: rgba(255, 255, 255, 0.94);
  --public-surface-soft: rgba(15, 23, 42, 0.04);
  --public-border: rgba(15, 23, 42, 0.1);
  --public-border-strong: rgba(15, 23, 42, 0.16);
  --public-text: #0f172a;
  --public-text-muted: #475569;
  --public-title: #020617;
  --public-shadow: 0 18px 36px rgba(15, 23, 42, 0.1);
  --public-header-bg: linear-gradient(135deg, rgba(255, 255, 255, 0.72) 0%, rgba(241, 245, 249, 0.68) 100%);
  --public-header-shadow: 0 2px 0 rgba(255, 255, 255, 0.7) inset, 0 8px 28px rgba(15, 23, 42, 0.1), 0 1px 0 rgba(15, 23, 42, 0.06);
  --public-header-border: rgba(15, 23, 42, 0.1);
  --public-menu-bg: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(239, 246, 255, 0.98) 100%);
  --public-chip-bg: rgba(15, 23, 42, 0.05);
  --public-chip-text: #0f172a;
  --public-toggle-bg: rgba(15, 23, 42, 0.05);
  --public-toggle-border: rgba(15, 23, 42, 0.12);
  --public-toggle-icon: #0f172a;
  --public-toggle-muted: #64748b;
  --public-footer-bg: #e2e8f0;
  --public-footer-card: rgba(255, 255, 255, 0.78);
  --public-footer-text: #0f172a;
  --public-footer-muted: #475569;
  /* Footer glassmorphism efekti */
  --public-footer-glass-bg: rgba(255, 255, 255, 0.7);
  --public-footer-glass-border: rgba(15, 23, 42, 0.08);
  --public-footer-glass-strong: rgba(255, 255, 255, 0.9);
  --public-footer-gradient: linear-gradient(180deg, rgba(226, 232, 240, 0.95) 0%, #e2e8f0 100%);
  --public-footer-review-bg: rgba(15, 23, 42, 0.03);
  --public-footer-review-border: rgba(15, 23, 42, 0.06);
  --public-footer-trust-bg: rgba(15, 23, 42, 0.04);
  --public-footer-hover-glow: rgba(59, 130, 246, 0.2);
  --public-cookie-bg: rgba(255, 255, 255, 0.98);
  --public-cookie-text: #334155;
  --public-cookie-border: rgba(15, 23, 42, 0.08);
  --card-bg: rgba(255, 255, 255, 0.85);
  --card-border: rgba(15, 23, 42, 0.08);
  color-scheme: light;
}

/* ========== SKIP LINK (pristupačnost – tipkovnica / screen reader) ========== */
.skip-link {
  position: absolute;
  top: -100%;
  left: 0.5rem;
  z-index: 9999;
  padding: 0.75rem 1rem;
  background: var(--brand-blue);
  color: white;
  font-weight: 600;
  border-radius: 0.5rem;
  text-decoration: none;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
  transition: top 0.2s ease;
}
.skip-link:focus {
  top: 0.5rem;
  outline: 2px solid #f59e0b;
  outline-offset: 2px;
}

/* ========== FOCUS STILOVI (pristupačnost – tipkovnica) ========== */
a:focus-visible,
button:focus-visible,
[tabindex="0"]:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 2px solid #f59e0b;
  outline-offset: 2px;
}
/* Ne mijenjaj izgled na klik (mouse) – samo na keyboard focus */
a:focus:not(:focus-visible),
button:focus:not(:focus-visible),
input:focus:not(:focus-visible),
select:focus:not(:focus-visible),
textarea:focus:not(:focus-visible) {
  outline: none;
}

/* ========== KONTRAST (WCAG AA – min ~4.5:1 za normalni tekst na tamnoj pozadini) ========== */
.text-on-dark {
  color: #e5e7eb; /* gray-200 – siguran na #0f172a / slate-900 */
}
.text-on-dark-muted {
  color: #d1d5db; /* gray-300 – sekundarni tekst na tamnoj pozadini */
}

/* ========== BASE (mobile-first) ========== */
html {
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
}

body {
  font-size: var(--text-base-mobile);
  line-height: var(--line-height-normal);
  min-width: 320px;
  overflow-x: hidden;
}

/* Safe area za notche / zaobljene rubove */
@supports (padding: env(safe-area-inset-left)) {
  body {
    padding-left: env(safe-area-inset-left);
    padding-right: env(safe-area-inset-right);
  }
}

/* ========== CONTAINER ========== */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--container-px-mobile);
  padding-right: var(--container-px-mobile);
}

@media (min-width: 768px) {
  .container {
    padding-left: var(--container-px-tablet);
    padding-right: var(--container-px-tablet);
  }
}

@media (min-width: 1280px) {
  .container {
    padding-left: var(--container-px-desktop);
    padding-right: var(--container-px-desktop);
  }
}

@media (min-width: 1536px) {
  .container {
    max-width: var(--container-max-2xl);
  }
}

@media (min-width: 1920px) {
  .container {
    max-width: var(--container-max-3xl);
  }
}

/* ========== TOUCH TARGETS (min 44px za klikabilne elemente) ========== */
.touch-target {
  min-width: var(--touch-min);
  min-height: var(--touch-min);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

@media (min-width: 1024px) {
  .touch-target {
    min-width: var(--touch-min-lg);
    min-height: var(--touch-min-lg);
  }
}

/* Gumbi i ikone u headeru (mobil) – min 44px tap zona */
#main-header button,
#mobileNavToggle,
#main-header a[href^="tel:"] {
  min-width: var(--touch-min);
  min-height: var(--touch-min);
  padding: 0.5rem;
  box-sizing: border-box;
}

/* Mobilni meni – svi linkovi i gumbi dovoljno veliki za prst */
#mobileMenu a,
#mobileMenu button {
  min-height: var(--touch-min);
  padding: 0.75rem 1rem;
  box-sizing: border-box;
}

/* Footer i forme – dovoljna tap zona na mobilu (min 44px) */
@media (max-width: 1023px) {
  footer a {
    padding: 0.5rem 0.25rem;
    min-height: var(--touch-min);
    display: inline-flex;
    align-items: center;
  }
  footer button,
  form button[type="submit"],
  form button[type="button"],
  .share-btn {
    min-height: var(--touch-min);
    padding: 0.75rem 1rem;
    box-sizing: border-box;
  }
}

/* ========== HEADER MOBIL ========== */
#main-header {
  min-height: var(--header-h-mobile);
}

@media (min-width: 768px) {
  #main-header {
    min-height: var(--header-h-desktop);
  }
}

/* ========== MOBILNI MENI – puni ekran, scroll ========== */
#mobileMenu {
  min-height: 100vh;
  min-height: 100dvh;
  padding-bottom: env(safe-area-inset-bottom, 0);
}

/* ========== UTILITY – sakrivanje po breakpointu ========== */
@media (max-width: 1023px) {
  .desktop-only {
    display: none !important;
  }
}

@media (min-width: 1024px) {
  .mobile-only {
    display: none !important;
  }
}

/* Prostor za sticky CTA na mobilu (da sadržaj ne bude prekriven) */
@media (max-width: 1023px) {
  body.has-sticky-cta main {
    padding-bottom: 5rem;
  }
}

/* ========== PUBLIC THEME SYSTEM ========== */
html,
body {
  background: var(--public-bg);
  color: var(--public-text);
}

body {
  transition: background-color 0.25s ease, color 0.25s ease;
}

.theme-toggle-btn {
  min-height: var(--touch-min);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.625rem;
  border-radius: 999px;
  border: 1px solid var(--public-toggle-border);
  background: var(--public-toggle-bg);
  color: var(--public-text);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
  transition: background-color 0.2s ease, border-color 0.2s ease, transform 0.2s ease, color 0.2s ease;
}

.theme-toggle-btn:hover {
  transform: translateY(-1px);
}

.theme-toggle-btn:active {
  transform: translateY(0);
}

.theme-toggle-icon-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
}

.theme-toggle-icon-wrap i {
  font-size: 0.9rem;
}

.theme-toggle-icon-wrap .fa-sun {
  color: #f59e0b;
}

.theme-toggle-icon-wrap .fa-moon {
  color: var(--public-toggle-muted);
}

html[data-theme="light"] .theme-toggle-icon-wrap .fa-sun {
  color: #f59e0b;
}

html[data-theme="light"] .theme-toggle-icon-wrap .fa-moon {
  color: #1e293b;
}

.theme-toggle-label {
  display: none;
  font-size: 0.875rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}

/* Samo ikona: prikaži onu za akciju (u koju ćeš preći) */
[data-theme-toggle][data-theme-state="dark"] .theme-toggle-icon-wrap .fa-moon {
  display: none;
}

[data-theme-toggle][data-theme-state="light"] .theme-toggle-icon-wrap .fa-sun {
  display: none;
}

.theme-toggle-btn--compact {
  width: var(--touch-min);
  min-width: var(--touch-min);
  padding: 0;
  gap: 0;
}

.theme-toggle-btn--compact .theme-toggle-label {
  display: none;
}

.theme-toggle-btn--mobile {
  width: 100%;
  justify-content: space-between;
  padding: 0.875rem 1rem;
  border-radius: 1rem;
}

#main-header {
  background: var(--public-header-bg) !important;
  border-bottom: 1px solid var(--public-header-border, var(--public-border)) !important;
  box-shadow: var(--public-header-shadow) !important;
  backdrop-filter: blur(16px) saturate(170%) brightness(1.04);
  -webkit-backdrop-filter: blur(16px) saturate(170%) brightness(1.04);
}

#main-header .theme-toggle-btn {
  padding: 0.625rem 0.9rem;
}

#main-header .theme-toggle-btn--compact {
  padding: 0;
}

/* Header brand lockup (test_header varijanta 69): icon + divider + dvoredni tekst */
#main-header .header-brand-lockup {
  min-width: 0;
  max-width: min(58vw, 16rem);
}

#main-header .brand-lockup-icon {
  display: block;
  height: 2.75rem;
  width: 2.75rem;
  flex-shrink: 0;
}

@media (min-width: 768px) {
  #main-header .brand-lockup-icon {
    height: 3.5rem;
    width: 3.5rem;
  }
}

/* Uski mobilni (do ~480px): header ne smije horizontalno „povući“ stranicu — logo + 3 kontrole moraju stati */
@media (max-width: 480px) {
  #main-header .container {
    max-width: 100% !important;
    padding-left: max(0.5rem, env(safe-area-inset-left, 0px));
    padding-right: max(0.5rem, env(safe-area-inset-right, 0px));
    box-sizing: border-box;
  }

  #main-header .header-brand-lockup {
    max-width: min(44vw, 10.5rem);
    flex-shrink: 1 !important;
    min-width: 0 !important;
    overflow: hidden;
  }

  #main-header .header-brand-lockup > span.flex.flex-col {
    min-width: 0;
    overflow: hidden;
  }

  #main-header .container > div:last-child {
    gap: 0.25rem;
    flex-shrink: 0;
  }
}

@media (max-width: 380px) {
  #main-header .header-brand-lockup {
    max-width: min(62vw, 15rem);
    gap: 0.5rem !important;
  }

  #main-header .brand-lockup-icon {
    height: 2.35rem;
    width: 2.35rem;
  }

  #main-header .header-brand-divider {
    height: 2.35rem !important;
  }

  #main-header .brand-lockup-title {
    font-size: 0.8125rem !important;
    line-height: 1.15 !important;
  }

  #main-header .brand-lockup-sub {
    font-size: 0.5625rem !important;
    letter-spacing: 0.14em !important;
  }
}

#main-header .header-brand-divider {
  width: 1px;
  height: 2.75rem;
  flex-shrink: 0;
  background: rgba(255, 255, 255, 0.22);
}

@media (min-width: 768px) {
  #main-header .header-brand-divider {
    height: 3.5rem;
  }
}

/* Podnaslov (Rent a car …): narančasta, nijanse po temi */
#main-header .header-brand-lockup .brand-lockup-sub {
  color: #fb923c !important; /* orange-400 — čitljivo na tamnom headeru */
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.45);
}

#main-header .header-brand-lockup:hover .brand-lockup-sub {
  color: #fdba74 !important; /* orange-300 — blagi hover */
}

html[data-theme="light"] #main-header .header-brand-lockup .brand-lockup-sub {
  color: #c2410c !important; /* orange-700 — kontrast na svijetlom headeru */
  text-shadow: none !important;
}

html[data-theme="light"] #main-header .header-brand-lockup:hover .brand-lockup-sub {
  color: #ea580c !important; /* orange-600 */
}

html[data-theme="light"] #main-header .header-brand-divider {
  background: rgba(15, 23, 42, 0.2) !important;
}

html[data-theme="light"] #main-header a:not(.header-reserve-btn),
html[data-theme="light"] #main-header a:not(.header-reserve-btn) span,
html[data-theme="light"] #main-header a:not(.header-reserve-btn) i,
html[data-theme="light"] #main-header button,
html[data-theme="light"] #main-header span,
html[data-theme="light"] #main-header i,
html[data-theme="light"] #desktop-nav a,
html[data-theme="light"] #desktop-nav button {
  color: #0f172a !important;
  text-shadow: none !important;
}

/* Rezerviraj u light modu: CTA ostaje vidljiv (amber + bijeli tekst) */
html[data-theme="light"] #main-header .header-reserve-btn,
html[data-theme="light"] #main-header .header-reserve-btn span,
html[data-theme="light"] #main-header .header-reserve-btn i {
  color: #fff !important;
  text-shadow: none !important;
}

html[data-theme="light"] #main-header .header-reserve-btn {
  background: linear-gradient(135deg, #d97706 0%, #b45309 100%) !important;
  border: 1px solid rgba(0, 0, 0, 0.08);
}

html[data-theme="light"] #main-header .header-reserve-btn:hover {
  background: linear-gradient(135deg, #ea580c 0%, #c2410c 100%) !important;
}

html[data-theme="light"] #main-header img {
  filter: brightness(0.95);
}

html[data-theme="light"] #main-header .bg-white\/20,
html[data-theme="light"] #main-header .bg-white\/5 {
  background: rgba(15, 23, 42, 0.05) !important;
}

html[data-theme="light"] #main-header .border-white\/20,
html[data-theme="light"] #main-header .border-white\/30 {
  border-color: rgba(15, 23, 42, 0.12) !important;
}

html[data-theme="light"] #mobileMenu {
  background: var(--public-menu-bg) !important;
  color: var(--public-text) !important;
  border-right: 1px solid var(--public-border) !important;
}

html[data-theme="light"] #mobileMenu a,
html[data-theme="light"] #mobileMenu button,
html[data-theme="light"] #mobileMenu p,
html[data-theme="light"] #mobileMenu div,
html[data-theme="light"] #mobileMenu span,
html[data-theme="light"] #mobileMenu i {
  color: var(--public-text) !important;
  text-shadow: none !important;
}

html[data-theme="light"] #mobileMenu .border-white\/20,
html[data-theme="light"] #mobileMenu .border-white\/30 {
  border-color: rgba(15, 23, 42, 0.12) !important;
}

html[data-theme="light"] #mobileMenu .bg-white\/20,
html[data-theme="light"] #mobileMenu .bg-white\/10,
html[data-theme="light"] #mobileMenu .bg-white\/5 {
  background: rgba(15, 23, 42, 0.04) !important;
}

html[data-theme="light"] footer {
  background: var(--public-footer-bg) !important;
  border-top: 1px solid rgba(15, 23, 42, 0.08) !important;
}

html[data-theme="light"] footer,
html[data-theme="light"] footer h2,
html[data-theme="light"] footer h3,
html[data-theme="light"] footer h4,
html[data-theme="light"] footer p,
html[data-theme="light"] footer span,
html[data-theme="light"] footer a,
html[data-theme="light"] footer li,
html[data-theme="light"] footer strong,
html[data-theme="light"] footer i {
  color: var(--public-footer-text) !important;
}

html[data-theme="light"] footer .text-slate-400,
html[data-theme="light"] footer .text-gray-300,
html[data-theme="light"] footer .text-gray-200,
html[data-theme="light"] footer .text-white\/80,
html[data-theme="light"] footer .text-white\/50 {
  color: var(--public-footer-muted) !important;
}

html[data-theme="light"] footer .bg-white\/5,
html[data-theme="light"] footer .bg-white\/10,
html[data-theme="light"] footer .glass-card {
  background: var(--public-footer-card) !important;
}

html[data-theme="light"] footer .border-white\/5,
html[data-theme="light"] footer .border-white\/10,
html[data-theme="light"] footer .border-white\/20 {
  border-color: rgba(15, 23, 42, 0.08) !important;
}

#cookieBanner {
  background: var(--public-cookie-bg) !important;
  border-top-color: var(--public-cookie-border) !important;
}

#cookieBanner,
#cookieBanner * {
  color: var(--public-cookie-text);
}

/* Gumb prihvata: globalno pravilo iznad prepisuje text-white; tamna pozadina zahtijeva svijetli tekst u dark/light temi */
#cookieBanner [data-cookie-accept] {
  color: #ffffff;
}

/* ========== LANG MODAL – usklađen s theme (light/dark) ========== */
.lang-modal-panel {
  background: var(--public-surface-strong);
  color: var(--public-text);
  border: 1px solid var(--public-border);
  box-shadow: var(--public-shadow);
}

.lang-modal-icon-wrap {
  background: var(--public-surface-soft);
  color: #f59e0b;
  border: 1px solid var(--public-border);
}

.lang-modal-title {
  color: var(--public-title);
}

.lang-modal-msg {
  color: var(--public-text-muted);
}

.lang-modal-btn-secondary {
  color: var(--public-text-muted);
  background: var(--public-surface-soft);
  border: 1px solid var(--public-border);
}

.lang-modal-btn-secondary:hover {
  background: var(--public-surface);
  color: var(--public-text);
}

/* ========== MODERNI FOOTER STILOVI (2-Kolonski Split Layout) ========== */

/* Footer Layout Improvements */
.footer-modern .container {
  padding-bottom: 0.75rem;
}

@media (min-width: 768px) {
  .footer-modern .container {
    padding-bottom: 1rem;
  }
}

/* 2-Column Split Grid */
.footer-split-grid {
  align-items: start;
}

/* Mobile column order: Brand first, then Contact */
.footer-col-brand { order: 1; }
.footer-col-contact { order: 2; }

@media (min-width: 1024px) {
  .footer-col-brand,
  .footer-col-contact { order: 0; }

  .footer-modern .footer-col-contact {
    justify-self: center;
    width: min(100%, 28rem);
    margin-left: clamp(1.5rem, 4vw, 5rem);
  }
}

/* Horizontal Navigation in Footer — 2-col grid on small screens, row + separators from md */
.footer-nav-horizontal {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.2rem 0.65rem;
  align-items: center;
}

@media (min-width: 768px) {
  .footer-nav-horizontal {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem 1.25rem;
  }
}

.footer-nav-link {
  font-size: 0.8125rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--public-footer-muted);
  transition: color 0.3s ease;
  white-space: nowrap;
}

@media (min-width: 768px) {
  .footer-nav-link {
    font-size: 0.85rem;
  }
}

@media (min-width: 640px) and (max-width: 767px) {
  .footer-nav-horizontal {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.footer-nav-link:hover {
  color: var(--public-footer-text);
}

.footer-nav-link--ghost {
  color: var(--public-footer-bg);
  transition: color 0.3s ease;
}
.footer-nav-link--ghost:hover {
  color: var(--public-footer-muted);
}

.footer-nav-separator {
  color: var(--public-footer-glass-border);
  font-size: 0.85rem;
  opacity: 0.4;
}

/* Footer Trust Section - Bottom (vertical padding mostly from Tailwind on element) */
.footer-trust-section {
  margin-top: 0.35rem;
}

@media (min-width: 768px) {
  .footer-trust-section {
    margin-top: 0.5rem;
  }

  .footer-modern .trust-row {
    justify-content: center;
    width: 100%;
  }
}

/* Trust Badges - Modern Pills */
.trust-badge {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  min-height: 2.75rem;
  padding: 0.625rem 1rem;
  background: var(--public-footer-trust-bg);
  border: 1px solid var(--public-footer-glass-border);
  border-radius: 9999px;
  box-sizing: border-box;
  line-height: 1;
  white-space: nowrap;
  transition: all 0.3s ease;
}

.trust-badge span {
  line-height: 1;
}

/* Mobile: one row height — horizontal scroll, compact pills */
@media (max-width: 767px) {
  .footer-modern .trust-row {
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x proximity;
    gap: 0.65rem;
    padding-bottom: 0.2rem;
  }

  .footer-modern .trust-row .trust-badge {
    flex-shrink: 0;
    min-height: 2.35rem;
    scroll-snap-align: start;
    padding: 0.4rem 0.7rem;
    gap: 0.35rem;
  }

  .footer-modern .trust-row .trust-badge span {
    font-size: 0.65rem;
    letter-spacing: 0.02em;
  }

  .footer-modern .trust-row .trust-badge i {
    font-size: 0.75rem;
  }
}

/* Trust row: single line on large desktop */
@media (min-width: 1024px) {
  .trust-row {
    flex-wrap: nowrap;
    gap: 2rem;
  }
}

.trust-badge:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px var(--public-footer-hover-glow);
}

.trust-badge i {
  font-size: 0.875rem;
}

/* Trust Badge Colors */
.trust-badge-ssl i {
  color: #10b981; /* Emerald green */
}

.trust-badge-rating i {
  color: #fbbf24; /* Amber/yellow star */
}

.trust-badge-instant i {
  color: #f59e0b; /* Amber/orange bolt */
}

/* Trust badge specific backgrounds on hover */
.trust-badge-ssl:hover {
  background: rgba(16, 185, 129, 0.15);
  border-color: rgba(16, 185, 129, 0.3);
}

.trust-badge-rating:hover {
  background: rgba(251, 191, 36, 0.15);
  border-color: rgba(251, 191, 36, 0.3);
}

.trust-badge-instant:hover {
  background: rgba(245, 158, 11, 0.15);
  border-color: rgba(245, 158, 11, 0.3);
}

/* Light theme adjustments for trust badges */
html[data-theme="light"] .trust-badge-ssl:hover {
  background: rgba(16, 185, 129, 0.1);
}

html[data-theme="light"] .trust-badge-rating:hover {
  background: rgba(251, 191, 36, 0.1);
}

html[data-theme="light"] .trust-badge-instant:hover {
  background: rgba(245, 158, 11, 0.1);
}

/* Social Icons */
.social-icon {
  width: 2.5rem;
  height: 2.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 9999px;
  background: var(--public-footer-glass-bg);
  border: 1px solid var(--public-footer-glass-border);
  color: var(--public-footer-text);
  transition: all 0.3s ease;
}

.social-icon:hover {
  transform: scale(1.1);
  box-shadow: 0 0 20px var(--public-footer-hover-glow);
}

.social-icon.whatsapp:hover {
  background: #22c55e;
  border-color: #22c55e;
  color: white;
}

.social-icon.viber:hover {
  background: #8b5cf6;
  border-color: #8b5cf6;
  color: white;
}

/* Footer Links */
.footer-link {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.25rem 0;
  color: var(--public-footer-muted);
  font-size: 0.875rem;
  transition: all 0.3s ease;
  position: relative;
}

.footer-link:hover {
  color: var(--public-text-muted);
  transform: translateX(4px);
}

.footer-link::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 1.25rem;
  right: 100%;
  height: 1px;
  background: var(--public-text-muted);
  transition: right 0.3s ease;
}

.footer-link:hover::after {
  right: 0;
}

/* Contact Items */
.contact-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.contact-icon-modern {
  font-size: 1rem;
  color: var(--public-footer-muted);
  width: 1.25rem;
  text-align: center;
  opacity: 0.8;
}

.contact-link {
  color: var(--public-footer-muted);
  font-size: 0.875rem;
  transition: all 0.3s ease;
}

.contact-link:hover {
  color: var(--public-text-muted);
}

.contact-text {
  color: var(--public-footer-muted);
  font-size: 0.875rem;
  line-height: 1.5;
}

@media (max-width: 767px) {
  .footer-modern .contact-text {
    font-size: 0.8125rem;
    line-height: 1.4;
  }

  .footer-modern .quick-cta-btn {
    padding: 0.6rem 1.1rem;
    font-size: 0.85rem;
  }
}

/* Quick CTA Button - Modern */
.quick-cta-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.625rem;
  padding: 0.75rem 1.5rem;
  background-color: var(--brand-accent, #f59e0b);
  color: #ffffff !important;
  border-radius: 0.5rem;
  font-size: 0.9rem;
  font-weight: 600;
  transition: all 0.3s ease;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.quick-cta-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(245, 158, 11, 0.4);
  background-color: #d97706; /* blago tamnija narandžasta */
  color: #ffffff !important;
}

/* Footer Scroll Buttons - 44px touch target on mobile, always visible */
.footer-scroll-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 2rem;
  height: 2rem;
  min-width: 44px;
  min-height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--public-footer-glass-strong);
  border: 1px solid var(--public-footer-glass-border);
  border-radius: 9999px;
  color: var(--public-footer-text);
  cursor: pointer;
  opacity: 0;
  transition: all 0.3s ease;
  z-index: 10;
}

/* Tailwind left-0/right-0 nisu uvijek u tailwind.css — eksplicitno da ne prekrivaju prvu karticu */
.footer-modern .footer-scroll-btn#prev-review {
  left: 0.375rem;
}

.footer-modern .footer-scroll-btn#next-review {
  right: 0.375rem;
}

/* Prostor za strelice horizontalnog scrolla – sadržaj ne ulazi ispod gumba */
.footer-modern #reviews-scroll-container {
  padding-left: 3.5rem;
  padding-right: 3.5rem;
  box-sizing: border-box;
}

@media (min-width: 768px) {
  .footer-modern #reviews-scroll-container {
    padding-left: 3.25rem;
    padding-right: 3.25rem;
  }
}

@media (max-width: 767px) {
  .footer-scroll-btn {
    opacity: 1;
    width: 2.75rem;
    height: 2.75rem;
  }

  .footer-modern .footer-reviews-heading {
    flex-direction: column;
    align-items: stretch;
    gap: 0.75rem;
  }

  .footer-modern .footer-reviews-heading > a {
    align-items: flex-start;
  }

  .footer-modern #reviews-scroll-container {
    padding-left: 2.25rem;
    padding-right: 2.25rem;
  }
}

/* Početna (index): hero blok s učitanim Google recenzijama ispod trust stripa — samo mobilno skriven; footer recenzije ne dirati */
@media (max-width: 767px) {
  #home #hero-reviews {
    display: none !important;
  }
}

@media (min-width: 768px) {
  .group\/reviews:hover .footer-scroll-btn {
    opacity: 1;
  }
}

.footer-scroll-btn:hover {
  background: var(--public-text-muted);
  border-color: var(--public-text-muted);
}

.footer-scroll-btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

/*
 * Footer Google recenzije: avatari — dimenzije MORAJU biti ovdje (ne Tailwind arbitrary iz app.js),
 * jer assets/tailwind.css ne uključuje dinamičke klase; inače <img> ostaje u punoj rezoluciji.
 */
.footer-modern #google-reviews-footer .footer-review-avatar {
  width: 22px;
  height: 22px;
  min-width: 22px;
  min-height: 22px;
  max-width: 22px;
  max-height: 22px;
  box-sizing: border-box;
  flex-shrink: 0;
}

.footer-modern #google-reviews-footer img.footer-review-avatar {
  object-fit: cover;
}

.footer-modern #google-reviews-footer div.footer-review-avatar {
  font-size: 14px;
}

@media (min-width: 768px) {
  .footer-modern #google-reviews-footer .footer-review-avatar {
    width: 35px;
    height: 35px;
    min-width: 35px;
    min-height: 35px;
    max-width: 35px;
    max-height: 35px;
  }

  .footer-modern #google-reviews-footer div.footer-review-avatar {
    font-size: 20px;
  }
}

/* Review Cards - footer: desktop = šire, niže (testimonial strip); mobilne širine ispod */
.footer-modern #google-reviews-footer .review-card {
  flex-shrink: 0;
  min-width: 300px;
  width: 300px;
  max-width: 300px;
  padding: 0.5rem 0.75rem;
  background: var(--public-footer-review-bg);
  border: 1px solid var(--public-footer-review-border);
  border-radius: 0.65rem;
  backdrop-filter: blur(10px);
}

/* Ime autora u kartici recenzije: tamna tema bijelo, svijetla tema tamno (čitljivo na svijetloj kartici) */
.footer-modern #google-reviews-footer .footer-review-author-name {
  color: #f8fafc;
}

html[data-theme="light"] .footer-modern #google-reviews-footer .footer-review-author-name {
  color: #0f172a !important;
}

.footer-modern #google-reviews-footer .review-card .review-card-quote {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-top: 0.375rem;
  font-size: 0.8125rem;
  line-height: 1.35;
}

.footer-modern #google-reviews-footer .review-card .footer-review-stars i {
  font-size: 0.65rem;
  line-height: 1;
}

@media (min-width: 768px) {
  .footer-modern #google-reviews-footer .review-card .footer-review-stars i {
    font-size: 0.72rem;
  }
}

@media (min-width: 1024px) {
  .footer-modern #google-reviews-footer .review-card {
    min-width: 320px;
    width: 320px;
    max-width: 320px;
    padding: 0.5rem 0.875rem;
  }
}

@media (min-width: 1280px) {
  .footer-modern #google-reviews-footer .review-card {
    min-width: 340px;
    width: 340px;
    max-width: 340px;
  }
}

@media (max-width: 767px) {
  .footer-modern #google-reviews-footer .review-card {
    min-width: min(340px, calc(100vw - 4.75rem));
    width: min(340px, calc(100vw - 4.75rem));
    max-width: min(340px, calc(100vw - 4.75rem));
    padding: 0.45rem 0.65rem;
    border-radius: 0.65rem;
    min-height: 92px !important;
  }

  .footer-modern #google-reviews-footer .review-card .review-card-quote {
    margin-top: 0.35rem !important;
    font-size: 0.75rem !important;
    line-height: 1.35 !important;
    -webkit-line-clamp: 2;
  }
}

.review-card {
  flex-shrink: 0;
  width: 280px;
  padding: 1rem;
  background: var(--public-footer-review-bg);
  border: 1px solid var(--public-footer-review-border);
  border-radius: 0.75rem;
  backdrop-filter: blur(10px);
}

.review-card-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}

.review-card-avatar {
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 9999px;
  background: var(--public-footer-glass-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  color: var(--public-footer-text);
}

.review-card-stars {
  display: flex;
  gap: 0.125rem;
  color: #fbbf24;
  font-size: 0.75rem;
}

.review-card-text {
  font-size: 0.875rem;
  line-height: 1.5;
  color: var(--public-footer-muted);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Scrollbar Hide */
.scrollbar-hide {
  -ms-overflow-style: none;
  scrollbar-width: none;
}

.scrollbar-hide::-webkit-scrollbar {
  display: none;
}

/* Footer Bottom - Copyright & Legal */
.footer-bottom {
  text-align: center;
}

@media (max-width: 767px) {
  .footer-modern .footer-bottom {
    padding-left: 0;
    padding-right: 0;
  }
}

@media (min-width: 768px) {
  .footer-bottom {
    text-align: left;
  }
}

.footer-copyright-text,
.footer-copyright-text p {
  font-size: 0.6875rem; /* 11px */
}

.footer-copyright-text a {
  color: var(--public-footer-muted);
  transition: color 0.3s ease;
}

.footer-copyright-text a:hover {
  color: var(--public-footer-text);
}

/* Light theme adjustments for footer */
html[data-theme="light"] .trust-badge {
  background: rgba(255, 255, 255, 0.6);
}

html[data-theme="light"] .social-icon {
  background: rgba(255, 255, 255, 0.7);
}

html[data-theme="light"] .review-card {
  background: rgba(255, 255, 255, 0.6);
}

/* Hero landing: fade pri rotaciji Google recenzija */
#hero-reviews {
  transition: opacity 0.25s ease;
}

/* Skip-to-content (Lighthouse/axe: mora biti fokusabilan — ne clip -9999px) */
.skip-to-content {
  position: absolute;
  top: -100%;
  left: 0.5rem;
  z-index: 10000;
  padding: 0.75rem 1rem;
  background: #f59e0b;
  color: #0f172a;
  font-weight: 700;
  border-radius: 0 0 0.5rem 0.5rem;
  text-decoration: none;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
  transition: top 0.2s ease;
}
.skip-to-content:focus {
  top: 0.5rem;
  outline: 3px solid #0f172a;
  outline-offset: 2px;
}

/* Rezervacije — polje telefona (intl-tel-input) i validacija */
.rez-field-error {
  color: #ef4444;
  font-size: 12px;
  margin-top: 4px;
  display: block;
}
html[data-theme="light"] .rez-field-error {
  color: #dc2626;
}
.rez-input-error {
  border-color: #ef4444 !important;
}
.rez-input-valid {
  border-color: #22c55e !important;
}
.rez-input-warn {
  border-color: #f59e0b !important;
  background-color: rgba(245, 158, 11, 0.08) !important;
}
.rez-input-loading {
  border-color: #3b82f6 !important;
  background-color: rgba(59, 130, 246, 0.05) !important;
}
#rez-phone-container.iti,
#rez-phone-container {
  position: relative;
  width: 100%;
}
/* ITI: dugme sa zastavicom (uvijek unutar containera) */
#rez-phone-container .iti__selected-flag {
  color: var(--public-text, #e2e8f0);
}
html[data-theme="light"] #rez-phone-container .iti__selected-flag {
  color: #0f172a;
}

/* ITI dropdown — radi za inline i fullscreen popup (appended to body na mobileu).
   Selektori su namjerno na root nivou, bez #rez-phone-container prefixe. */
html:not([data-theme="light"]) .iti__dropdown-content,
html:not([data-theme="light"]) .iti__country-list {
  background-color: #1e293b;
  border-color: rgba(255, 255, 255, 0.12);
  box-shadow: 0 8px 32px rgba(2, 8, 23, 0.5);
}
html[data-theme="light"] .iti__dropdown-content,
html[data-theme="light"] .iti__country-list {
  background-color: #ffffff;
  border-color: rgba(15, 23, 42, 0.12);
}
html:not([data-theme="light"]) .iti__country-name {
  color: #f8fafc;
}
html:not([data-theme="light"]) .iti__dial-code {
  color: #94a3b8;
}
html[data-theme="light"] .iti__country-name {
  color: #0f172a;
}
html[data-theme="light"] .iti__dial-code {
  color: #475569;
}
html:not([data-theme="light"]) .iti__country.iti__highlight {
  background-color: rgba(255, 255, 255, 0.08);
}
html[data-theme="light"] .iti__country.iti__highlight {
  background-color: rgba(15, 23, 42, 0.06);
}
html:not([data-theme="light"]) .iti__divider {
  border-bottom-color: rgba(255, 255, 255, 0.1);
}
html[data-theme="light"] .iti__divider {
  border-bottom-color: rgba(15, 23, 42, 0.1);
}
html:not([data-theme="light"]) .iti__search-input {
  background-color: #0f172a;
  color: #f8fafc;
  border-color: rgba(255, 255, 255, 0.15);
}
html:not([data-theme="light"]) .iti__search-input::placeholder {
  color: #64748b;
}
html[data-theme="light"] .iti__search-input {
  background-color: #f8fafc;
  color: #0f172a;
  border-color: rgba(15, 23, 42, 0.15);
}

/* Rezervacije — field check icon + error small (Build 431) */
.rez-form-control-wrap {
  position: relative;
}
.rez-phone-control-wrap .iti {
  width: 100%;
}
.rez-phone-control-wrap .iti input {
  width: 100%;
  padding-right: 42px !important;
}
.rez-phone-control-wrap .rez-field-check {
  right: 14px;
  z-index: 3;
}
.rez-form-control-wrap textarea.rez-form-textarea {
  padding-right: 42px;
}
.rez-field-check {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 14px;
  font-weight: 700;
  pointer-events: none;
  line-height: 1;
}
.rez-field-check--ok  { color: #22c55e; }
.rez-field-check--err { color: #ef4444; }
html[data-theme="light"] .rez-field-check--ok  { color: #16a34a; }
html[data-theme="light"] .rez-field-check--err { color: #dc2626; }
small.rez-field-error {
  color: #ef4444;
  font-size: 12px;
  margin-top: 3px;
  display: none;
}
small.rez-field-error:not(:empty) { display: block; }
html[data-theme="light"] small.rez-field-error { color: #dc2626; }
