/* =========================================================
   VILLA NATALI - MASTER CSS
   1 file for: index, apartmani, apartman A1-A7, blog,
   podaca, faq, privacy, rules, uvjeti rezervacije
========================================================= */

/* =========================
   1. RESET / BASE
========================= */
*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

:root{
    --primary:#3498db;
    --primary-dark:#217dbb;
    --secondary:#1e293b;
    --accent:#e67e22;
    --accent-dark:#d35400;
    --whatsapp:#25D366;
    --bg:#f7f8fb;
    --card:#ffffff;
    --text:#2d3748;
    --muted:#64748b;
    --border:#e2e8f0;
    --light:#f8fafc;
    --shadow:0 10px 34px rgba(15,23,42,0.06);
    --shadow-hover:0 16px 40px rgba(15,23,42,0.12);
    --radius:24px;
    --radius-sm:16px;
    --container:1240px;
}

html{
    scroll-behavior:smooth;
    overflow-x:hidden;
}

body{
    font-family:'Poppins',sans-serif;
    color:var(--text);
    background:var(--bg);
    line-height:1.7;
    overflow-x:hidden;
    width:100%;
}

img{
    max-width:100%;
    display:block;
    height:auto;
}

a{
    text-decoration:none;
    color:inherit;
}

ul{
    list-style:none;
}

button,
input,
textarea,
select{
    font:inherit;
}

.container{
    width:100%;
    max-width:var(--container);
    margin:0 auto;
    padding:0 20px;
}

main{
    padding:42px 0 0;
}

/* =========================
   2. HEADER / NAVIGATION
========================= */
header{
    position:fixed;
    top:0;
    left:0;
    width:100%;
    background:rgba(255,255,255,0.97);
    backdrop-filter:blur(8px);
    box-shadow:0 2px 18px rgba(0,0,0,0.06);
    z-index:1000;
}

.header-container,
nav.nav-container{
    width:100%;
    max-width:var(--container);
    margin:0 auto;
    min-height:78px;
    padding:14px 20px;
    display:flex;
    align-items:center;
    gap:20px;
    position:relative;
}

.logo{
    display:flex;
    align-items:center;
    flex:0 0 auto;
    min-width:0;
    z-index:1002;
    font-size:1.5rem;
    font-weight:700;
    color:var(--secondary);
    white-space:nowrap;
}

.logo img{
    height:60px;
    width:auto;
    max-width:100%;
    object-fit:contain;
}

nav{
    margin-left:auto;
}

.main-nav,
.desktop-menu{
    display:flex;
    align-items:center;
    gap:24px;
}

.main-nav > li > a,
.desktop-menu a,
.lang-toggle,
.lang-btn{
    font-size:0.97rem;
    font-weight:600;
    color:#334155;
    transition:0.25s ease;
}

.main-nav > li > a:hover,
.main-nav > li > a.active,
.desktop-menu a:hover,
.desktop-menu a.active,
.lang-toggle:hover,
.lang-btn:hover,
nav a:hover,
nav a.active{
    color:var(--accent-dark);
}

.nav-group{
    display:flex;
    align-items:center;
    gap:18px;
    margin-left:auto;
}

.nav-cta,
.header-cta,
.mobile-cta{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:11px 18px;
    background:linear-gradient(135deg,var(--accent),var(--accent-dark));
    color:#fff !important;
    border-radius:999px;
    font-weight:700;
    box-shadow:0 8px 18px rgba(211,84,0,0.18);
    transition:0.3s ease;
    text-align:center;
}

.nav-cta:hover,
.header-cta:hover,
.mobile-cta:hover{
    transform:translateY(-1px);
    color:#fff !important;
}

.language-dropdown{
    position:relative;
}

.lang-toggle,
.lang-btn{
    border:none;
    background:transparent;
    display:inline-flex;
    align-items:center;
    gap:8px;
    cursor:pointer;
    padding:0;
}

.lang-btn{
    background:var(--primary);
    color:#fff;
    border-radius:999px;
    padding:10px 16px;
}

.language-menu,
.lang-options{
    display:none;
    position:absolute;
    top:100%;
    right:0;
    min-width:140px;
    background:#fff;
    border-radius:16px;
    box-shadow:0 12px 30px rgba(0,0,0,0.12);
    padding:10px 0;
    z-index:1002;
}

.language-menu li a,
.lang-options a{
    display:block;
    padding:10px 16px;
    color:#334155;
}

.language-menu li a:hover,
.lang-options a:hover{
    background:#f8fafc;
    color:var(--accent-dark);
}

.language-dropdown:hover .language-menu,
.language-dropdown:focus-within .language-menu,
.language-dropdown.active .lang-options,
.language-dropdown:hover .lang-options,
.language-dropdown:focus-within .lang-options{
    display:block;
}

.hamburger{
    display:none;
    width:44px;
    height:44px;
    border:none;
    background:transparent;
    cursor:pointer;
    padding:0;
    align-items:center;
    justify-content:center;
    flex-direction:column;
    gap:5px;
    z-index:1002;
    margin-left:auto;
}

.hamburger span,
.hamburger div{
    display:block;
    width:26px;
    height:3px;
    border-radius:3px;
    background:#1f2d3d;
    transition:0.3s ease;
}

.hamburger.active span:nth-child(1),
.hamburger.active div:nth-child(1){
    transform:translateY(8px) rotate(45deg);
}

.hamburger.active span:nth-child(2),
.hamburger.active div:nth-child(2){
    opacity:0;
}

.hamburger.active span:nth-child(3),
.hamburger.active div:nth-child(3){
    transform:translateY(-8px) rotate(-45deg);
}

/* NAV FIX – da ne bude rašireno */
.nav-container {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

/* GLAVNI MENU */
#menu {
    display: flex;
    align-items: center;
    gap: 14px; /* KLJUČNO – smanjuje razmak */
}

/* LINKOVI */
#menu a {
    padding: 8px 10px;
    font-weight: 500;
    white-space: nowrap;
}

/* =========================
   3. BUTTONS
========================= */
.btn-primary,
.btn-secondary,
.cta-btn,
.cta-btn-secondary,
.cta-button,
.booking-button,
.home-button,
.cta-mobile{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    padding:14px 22px;
    border-radius:999px;
    font-weight:700;
    transition:0.3s ease;
    text-align:center;
}

.btn-primary,
.cta-btn,
.cta-button,
.booking-button,
.cta-mobile{
    background:linear-gradient(135deg,var(--accent),var(--accent-dark));
    color:#fff;
    box-shadow:0 10px 24px rgba(211,84,0,0.22);
}

.btn-primary:hover,
.cta-btn:hover,
.cta-button:hover,
.booking-button:hover,
.cta-mobile:hover,
.btn-secondary:hover,
.cta-btn-secondary:hover,
.home-button:hover{
    transform:translateY(-2px);
}

.btn-secondary,
.cta-btn-secondary,
.home-button,
.cta-secondary{
    background:#fff;
    color:var(--secondary);
    border:1px solid var(--border);
}

/* =========================
   4. HERO SECTIONS
========================= */
.hero{
    margin-top:86px;
    background:linear-gradient(135deg,#fff7ed 0%,#ffffff 55%,#f8fafc 100%);
    padding:48px 0 38px;
}

.hero-grid{
    display:grid;
    grid-template-columns:minmax(0,1.2fr) minmax(0,0.8fr);
    gap:34px;
    align-items:center;
}

.hero-text h1,
.hero-content h1,
.hero-card h1,
.blog-article h1,
header h1{
    font-size:clamp(2rem,4vw,3rem);
    line-height:1.2;
    color:var(--secondary);
    margin-bottom:18px;
}

.hero-text p,
.hero-content p,
.hero-card p,
header p,
.intro-text,
.faq-lead{
    color:#475569;
    font-size:1.02rem;
}

.hero-badges{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin:24px 0;
}

.hero-badges span,
.trust-line,
.score-line{
    background:#ffffff;
    border:1px solid var(--border);
    padding:10px 14px;
    border-radius:999px;
    font-size:0.92rem;
    font-weight:500;
    color:#334155;
}

.hero-buttons,
.hero-actions,
.header-actions,
.cta-button-wrap{
    display:flex;
    flex-wrap:wrap;
    gap:14px;
    margin-top:16px;
}

.hero-image-card,
.hero-card,
.seo-box,
.content-box,
.card,
.intro-box,
.media-card,
.highlight-box,
.white-box,
.bottom-cta-box{
    background:#fff;
    border-radius:var(--radius);
    box-shadow:var(--shadow);
}

.hero-image-card{
    overflow:hidden;
    position:relative;
}

.hero-image-card img{
    width:100%;
    height:100%;
    min-height:420px;
    object-fit:cover;
}

.hero-image-label{
    position:absolute;
    left:18px;
    bottom:18px;
    background:rgba(255,255,255,0.95);
    padding:10px 14px;
    border-radius:14px;
    font-size:0.92rem;
    font-weight:600;
    color:var(--secondary);
    box-shadow:0 10px 22px rgba(0,0,0,0.08);
}

/* swiper hero */
.swiper{
    width:100%;
    height:68vh;
    min-height:460px;
    margin-top:92px;
    position:relative;
}

.swiper-slide{
    position:relative;
}

.swiper-slide img{
    width:100%;
    height:100%;
    object-fit:cover;
}

.hero-overlay{
    position:absolute;
    inset:0;
    background:linear-gradient(to bottom, rgba(0,0,0,.24), rgba(0,0,0,.5));
    z-index:2;
    pointer-events:none;
}

.hero-content,
.hero-intro{
    position:absolute;
    z-index:3;
    left:50%;
    top:50%;
    transform:translate(-50%, -50%);
    width:100%;
    max-width:920px;
    padding:0 20px;
    text-align:center;
    color:#fff;
}

.hero-content h1,
.hero-content p,
.hero-intro h1,
.hero-intro p{
    color:#fff;
    text-shadow:0 2px 10px rgba(0,0,0,.35);
}

.hero-content p{
    max-width:760px;
    margin:0 auto 1.5rem;
}

.hero-card{
    padding:34px;
    max-width:900px;
    margin:0 auto;
    text-align:center;
}

/* =========================
   5. COMMON LAYOUT / CARDS
========================= */
.main-grid{
    display:grid;
    grid-template-columns:minmax(0,1fr) 360px;
    gap:28px;
    align-items:start;
}

.content-left{
    min-width:0;
}

.card,
.content-box,
.blog-content,
.blog-article,
.intro-box,
.media-card,
.white-box{
    padding:28px;
    margin-bottom:24px;
    width:100%;
}

.card h2,
.content-box h2,
.section-title,
.mapa-title,
.apartments-heading,
.other-apartments h2,
.bottom-cta-box h2,
.blog-article h2,
.blog-section h2,
.features h2,
.reviews-section h2,
.location-section h2,
.croatia-section h2,
.house-rules-section h2,
.faq-section h2{
    font-size:clamp(1.7rem,3vw,2rem);
    color:var(--secondary);
    margin-bottom:16px;
}

.card h3,
.content-box h3,
.blog-article h3,
.apartment-card h3,
.post-preview h3,
.blog-card h3,
.feature-card h3,
.benefit-card h3,
.review-card h3{
    font-size:1.2rem;
    color:var(--secondary);
    margin-bottom:12px;
}

.card p,
.content-box p,
.blog-article p,
.post-preview p,
.blog-card p,
.feature-card p,
.benefit-card p,
.review-card p,
.apartment-card p,
.apartments-subtext,
.section-subtitle,
.cta-note,
.location-box,
.map-section p,
.blog-section p,
.reviews-section p{
    color:#475569;
    margin-bottom:14px;
}

.section-title,
.section-subtitle,
.apartments-heading,
.apartments-subtext,
.hero-card,
.intro-box,
.bottom-cta-box,
.location-section,
.reviews-section,
.blog-section,
.features,
.section-center{
    text-align:center;
}

.card p a,
.blog-article p a,
.seo-links a,
.content-box a,
.intro-box a,
.privacy-content a{
    color:var(--accent-dark);
    font-weight:600;
    transition:0.25s ease;
}

.card p a:hover,
.blog-article p a:hover,
.seo-links a:hover,
.content-box a:hover,
.intro-box a:hover,
.privacy-content a:hover{
    text-decoration:underline;
    color:var(--accent);
}

.intro-text strong{
    color:var(--accent-dark);
    font-weight:600;
}

.highlight-box,
.side-note,
.location-box,
.review-card,
.benefit-card,
.feature-card,
.blog-card{
    padding:20px;
}

.highlight-box,
.side-note,
.location-box{
    background:#fff7ed;
    border:1px solid #fed7aa;
    color:#9a3412;
    border-radius:18px;
}

/* =========================
   6. INDEX / HOME PAGE
========================= */
.seo-intro,
.features,
.apartments,
.content-section,
.mapa,
.page-section,
.blog-section,
.location-section,
.reviews-section,
.croatia-section,
.house-rules-section,
.faq-section,
.bottom-cta,
.map-section{
    max-width:var(--container);
    margin:42px auto;
    padding:0 20px;
}

.seo-box{
    padding:32px;
    text-align:center;
}

.seo-links,
.banner-links{
    margin-top:20px;
    display:flex;
    gap:14px;
    flex-wrap:wrap;
    justify-content:center;
    align-items:center;
}

.features-grid,
.benefits-grid,
.reviews-grid,
.blog-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(220px,1fr));
    gap:20px;
}

.feature-card,
.benefit-card,
.review-card,
.blog-card{
    background:#fff;
    border-radius:20px;
    box-shadow:var(--shadow);
}

.feature-card i,
.benefit-card i{
    font-size:2rem;
    color:var(--primary);
    margin-bottom:12px;
}

/* =========================
   7. APARTMENTS OVERVIEW
========================= */
.apartments-grid,
.apartment-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:24px;
}

.apartment-card{
    background:#fff;
    border-radius:22px;
    overflow:hidden;
    box-shadow:0 12px 34px rgba(15,23,42,0.08);
    transition:0.3s ease;
    min-width:0;
    display:flex;
    flex-direction:column;
}

.apartment-card:hover{
    transform:translateY(-5px);
    box-shadow:var(--shadow-hover);
}

.apartment-card img{
    width:100%;
    height:220px;
    object-fit:cover;
}

.apartment-card-content{
    padding:18px;
}

.card-buttons{
    display:flex;
    flex-direction:column;
    gap:10px;
    padding:0 18px 20px;
    margin-top:auto;
}

.card-buttons a,
.details-btn,
.booking-btn{
    display:inline-flex;
    justify-content:center;
    align-items:center;
    width:100%;
    padding:12px 16px;
    border-radius:12px;
    text-align:center;
    font-weight:700;
    transition:0.25s ease;
}

.details-btn{
    background:var(--primary);
    color:#fff;
}

.details-btn:hover{
    background:var(--primary-dark);
}

.booking-btn{
    background:linear-gradient(135deg,var(--accent),var(--accent-dark));
    color:#fff;
}

.booking-btn:hover{
    transform:scale(1.02);
}

/* =========================
   8. SINGLE APARTMENT PAGES
========================= */
.feature-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:14px;
    margin-top:18px;
}

.feature-box{
    background:var(--light);
    border:1px solid var(--border);
    border-radius:18px;
    padding:16px;
    font-size:0.95rem;
    color:#334155;
    display:flex;
    align-items:center;
    gap:12px;
    min-width:0;
}

.feature-box i,
.booking-list i{
    color:var(--accent-dark);
    min-width:18px;
}

.gallery-main img{
    width:100%;
    border-radius:20px;
    box-shadow:0 12px 30px rgba(0,0,0,0.08);
}

.gallery-thumbnails{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:14px;
    margin-top:16px;
}

.gallery-thumbnails img{
    width:100%;
    aspect-ratio:1 / 0.8;
    object-fit:cover;
    border-radius:16px;
    border:2px solid transparent;
    transition:0.3s ease;
    cursor:pointer;
}

.gallery-thumbnails img:hover{
    border-color:var(--accent);
    transform:translateY(-2px);
}

.sidebar{
    position:sticky;
    top:108px;
}

.booking-card .price{
    font-size:2rem;
    font-weight:700;
    color:var(--accent-dark);
    margin-bottom:10px;
}

.booking-card small{
    display:block;
    color:var(--muted);
    margin-bottom:20px;
}

.booking-list{
    display:grid;
    gap:12px;
    margin:18px 0 22px;
}

.booking-list div{
    display:flex;
    align-items:center;
    gap:12px;
    color:#334155;
    font-size:0.96rem;
}

/* =========================
   9. BLOG LIST / BLOG PAGES
========================= */
.page-blog .container{
    max-width:1200px;
    margin:0 auto;
    padding:0 20px;
}

.page-blog{
    padding-bottom:100px;
}

/* =========================
   BLOG HEADER
========================= */
.blog-header{
    padding:24px 0 12px;
    background:#f8fafc;
    border-bottom:1px solid #e2e8f0;
}

.blog-header h1{
    font-size:clamp(1.6rem, 2.5vw, 2.2rem);
    line-height:1.15;
    margin-bottom:8px;
}

.blog-header p{
    font-size:1rem;
    line-height:1.6;
    color:#64748b;
    max-width:900px;
    margin-bottom:16px;
}

/* =========================
   HEADER BUTTONS
========================= */
.header-actions{
    display:flex;
    gap:16px;
    flex-wrap:wrap;
    align-items:center;
}

.home-button,
.booking-button,
.cta-button{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:48px;
    padding:0 20px;
    border-radius:999px;
    font-weight:600;
    text-decoration:none;
    transition:0.25s ease;
}

/* home */
.home-button{
    background:#fff;
    color:#1e293b;
    border:1px solid #e2e8f0;
}

/* booking + CTA */
.booking-button,
.cta-button{
    background:linear-gradient(135deg,#e67e22,#d35400);
    color:#fff;
    box-shadow:0 8px 20px rgba(211,84,0,0.2);
}

.home-button:hover,
.booking-button:hover,
.cta-button:hover{
    transform:translateY(-2px);
}

/* =========================================================
   BLOG HARD FIX
   - intro box ispod headera
   - blog header nije fixed
========================================================= */
.page-blog header.blog-header{
    position:static !important;
    top:auto !important;
    left:auto !important;
    width:100% !important;
    z-index:auto !important;
    box-shadow:none !important;
    backdrop-filter:none !important;
    background:#f8fafc !important;
    border-bottom:1px solid #e2e8f0;
    padding:24px 0 12px;
}

.page-blog main.blog-main{
    padding:20px 0 0 !important;
    margin-top:0 !important;
}

.page-blog .intro-box{
    display:block !important;
    visibility:visible !important;
    opacity:1 !important;
    position:relative !important;
    z-index:2 !important;
    background:#ffffff !important;
    border:1px solid #e5e7eb !important;
    border-radius:20px !important;
    box-shadow:0 10px 25px rgba(0,0,0,0.06) !important;
    padding:26px !important;
    margin:20px 0 28px !important;
}

.page-blog .intro-box h2{
    display:block !important;
    color:#1e293b !important;
    font-size:1.3rem !important;
    margin:0 0 12px !important;
}

.page-blog .intro-box p{
    display:block !important;
    color:#64748b !important;
    font-size:0.98rem !important;
    line-height:1.6 !important;
    margin:0 !important;
}

@media (max-width:768px){
    .page-blog header.blog-header{
        padding:18px 0 10px !important;
    }

    .page-blog .intro-box{
        padding:18px !important;
        margin:16px 0 22px !important;
    }
}

/* =========================
   MAIN
========================= */
.blog-main{
    padding:14px 0 0;
}

/* =========================
   INTRO BOX FIX
========================= */
.intro-box{
    background:#ffffff;
    border-radius:20px;
    box-shadow:0 10px 25px rgba(0,0,0,0.06);
    padding:26px;
    margin:20px 0 28px;
    border:1px solid #e5e7eb;
}

.intro-box h2{
    font-size:1.3rem;
    margin-bottom:12px;
    color:#1e293b;
}

.intro-box p{
    color:#64748b;
    font-size:0.98rem;
    line-height:1.6;
}

/* =========================
   POSTS GRID
========================= */
.posts-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(280px,1fr));
    gap:24px;
    margin-bottom:24px;
}

/* CARD */
.post-preview{
    background:#fff;
    border-radius:20px;
    box-shadow:var(--shadow);
    padding:20px;
    display:flex;
    flex-direction:column;
    height:100%;
}

/* title */
.post-preview h2{
    font-size:1.1rem;
    line-height:1.4;
    margin-bottom:12px;
}

.post-preview h2 a{
    color:#1e293b;
    text-decoration:none;
}

/* text */
.post-preview p{
    color:#64748b;
    font-size:0.95rem;
    margin-bottom:14px;
}

/* image */
.post-preview img{
    width:100%;
    height:200px;
    object-fit:cover;
    border-radius:14px;
    margin-bottom:14px;
}

/* CTA button */
.post-preview .cta-button{
    margin-top:auto;
    align-self:flex-start;
}

/* =========================
   MEDIA BLOCK
========================= */
.media-block{
    max-width:1200px;
    margin:0 auto 30px;
    padding:0 20px;
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(280px,1fr));
    gap:24px;
}

.media-card{
    background:#fff;
    border-radius:20px;
    box-shadow:var(--shadow);
    padding:20px;
}

.media-card h2{
    margin-bottom:12px;
    color:#1e293b;
}

.media-card p{
    color:#475569;
    margin-bottom:14px;
}

.media-card img{
    width:100%;
    border-radius:14px;
}

/* video */
.iframe-wrap{
    position:relative;
    padding-bottom:56.25%;
    height:0;
    overflow:hidden;
    border-radius:16px;
}

.iframe-wrap iframe{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    border:0;
}

/* =========================
   BLOG ARTICLE TEMPLATE
   master article page for all languages
========================= */
.page-article{
    padding-bottom:100px;
}

.page-article main{
    padding-top:0;
}

.page-article .article-topbar{
    position:static;
    background:#f8fafc;
    box-shadow:none;
    border-bottom:1px solid var(--border);
}

.page-article .article-topbar .container{
    max-width:1200px;
    min-height:auto;
    padding-top:18px;
    padding-bottom:18px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
}

.page-article .article-topbar .logo img{
    height:56px;
}

.article-back-link{
    font-weight:600;
    color:#334155;
    transition:0.25s ease;
}

.article-back-link:hover{
    color:var(--accent-dark);
}

.article-hero{
    margin-top:0;
    position:relative;
    min-height:420px;
    display:flex;
    align-items:center;
    justify-content:center;
    text-align:center;
    overflow:hidden;
    color:#fff;
    padding:60px 20px;
    background-color:#475569;
    background-size:cover;
    background-position:center 35%;
    background-repeat:no-repeat;
}
@media (max-width: 768px){
    .article-hero{
        min-height:300px;
        padding:40px 15px;
        background-position:center center;
    }

    .article-hero h1{
        font-size:28px;
        line-height:1.3;
    }

    .article-hero p{
        font-size:16px;
    }
}
.article-hero::before{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(180deg, rgba(0,0,0,0.18) 0%, rgba(0,0,0,0.42) 100%);
    z-index:1;
}

.article-hero .container{
    position:relative;
    z-index:2;
    max-width:900px;
    padding-top:70px;
    padding-bottom:70px;
}

.article-hero h1{
    font-size:clamp(2rem,4vw,3rem);
    line-height:1.2;
    color:#fff;
    margin-bottom:16px;
    text-shadow:0 2px 14px rgba(0,0,0,0.28);
}

.article-hero p{
    max-width:760px;
    margin:0 auto;
    font-size:1.05rem;
    color:#f8fafc;
    text-shadow:0 2px 12px rgba(0,0,0,0.25);
}

.article-wrap{
    max-width:900px;
    margin:0 auto;
    padding:34px 20px 0;
}

.article-card{
    background:#fff;
    border-radius:24px;
    box-shadow:var(--shadow);
    padding:34px;
}

.article-card h2{
    font-size:clamp(1.6rem,3vw,2rem);
    color:var(--secondary);
    margin:28px 0 14px;
    line-height:1.28;
}

.article-card h3{
    font-size:1.18rem;
    color:var(--secondary);
    margin:22px 0 12px;
    line-height:1.35;
}

.article-card p{
    color:#475569;
    margin-bottom:16px;
}

.article-card ul,
.article-card ol{
    margin:0 0 18px 22px;
    color:#475569;
}

.article-card li{
    margin-bottom:8px;
}

.article-card strong{
    color:var(--secondary);
}

.article-card a{
    color:var(--accent-dark);
    font-weight:600;
    transition:0.25s ease;
}

.article-card a:hover{
    color:var(--accent);
    text-decoration:underline;
}

.article-card img{
    width:100%;
    border-radius:20px;
    margin:18px 0 22px;
    box-shadow:0 10px 28px rgba(15,23,42,0.10);
}

.article-meta{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin-bottom:18px;
}

.article-meta span{
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:9px 14px;
    border-radius:999px;
    background:#f8fafc;
    border:1px solid var(--border);
    color:#475569;
    font-size:0.92rem;
    font-weight:500;
}

.article-intro{
    font-size:1.04rem;
    color:#334155;
}

.article-cta-box{
    margin:30px 0;
    padding:24px;
    background:#f0f7fd;
    border:1px solid #dbeafe;
    border-left:5px solid var(--primary);
    border-radius:20px;
}

.article-cta-box h3{
    margin-top:0;
    margin-bottom:10px;
}

.article-cta-box p{
    margin-bottom:12px;
}

.article-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    padding:14px 22px;
    border-radius:999px;
    background:linear-gradient(135deg,var(--accent),var(--accent-dark));
    color:#fff !important;
    font-weight:700;
    box-shadow:0 10px 24px rgba(211,84,0,0.22);
    transition:0.3s ease;
}

.article-btn:hover{
    transform:translateY(-2px);
    color:#fff !important;
    text-decoration:none !important;
}

.article-related{
    margin-top:34px;
    padding-top:22px;
    border-top:1px solid var(--border);
}

.article-related h3{
    margin-top:0;
    margin-bottom:14px;
}

.article-related a{
    display:block;
    margin-bottom:10px;
}

.article-image-hidden{
    display:none;
}

.article-sticky-cta{
    position:fixed;
    left:16px;
    right:16px;
    bottom:16px;
    z-index:999;
    display:none;
    text-align:center;
    background:linear-gradient(135deg,var(--accent),var(--accent-dark));
    color:#ffffff !important;
    padding:14px 16px;
    border-radius:999px;
    font-weight:700;
    font-size:15px;
    box-shadow:0 10px 25px rgba(0,0,0,0.25);
}

/* =========================
   STICKY BOOKING
========================= */
.sticky-booking{
    position:fixed;
    left:16px;
    right:16px;
    bottom:16px;
    z-index:999;
    display:block;
    text-align:center;
    background:#0ED8E6;
    color:#ffffff;
    padding:14px 16px;
    border-radius:8px;
    font-weight:600;
    font-size:15px;
    text-decoration:none;
    box-shadow:0 10px 25px rgba(0,0,0,0.25);
    opacity:0;
    pointer-events:none;
    transform:translateY(30px);
    transition:all 0.3s ease;
}

.sticky-booking.show{
    opacity:1;
    transform:translateY(0);
    pointer-events:auto;
}

/* sakrij na desktopu */
@media (min-width:769px){
    .sticky-booking{
        display:none;
    }
}

/* =========================
   MOBILE
========================= */
@media (max-width:768px){
    .page-blog .container{
        padding:0 15px;
    }

    .blog-header{
        padding:18px 0 10px;
    }

    .blog-header h1{
        font-size:1.5rem;
    }

    .blog-header p{
        font-size:0.95rem;
    }

    .header-actions{
        flex-direction:column;
        align-items:stretch;
    }

    .home-button,
    .booking-button,
    .cta-button{
        width:100%;
        text-align:center;
    }

    .posts-grid{
        grid-template-columns:1fr;
        gap:20px;
    }

    .media-block{
        grid-template-columns:1fr;
        padding:0 15px;
    }

    .post-preview,
    .media-card,
    .intro-box{
        padding:18px;
    }

    .post-preview h2{
        font-size:1rem;
    }

    .page-article .article-topbar .container{
        padding-top:14px;
        padding-bottom:14px;
        flex-direction:row;
        gap:12px;
    }

    .page-article .article-topbar .logo img{
        height:46px;
    }

    .article-hero{
        min-height:330px;
    }

    .article-hero .container{
        padding-top:52px;
        padding-bottom:52px;
    }

    .article-hero h1{
        font-size:1.8rem;
    }

    .article-hero p{
        font-size:0.98rem;
    }

    .article-wrap{
        padding:22px 15px 0;
    }

    .article-card{
        padding:22px 18px;
        border-radius:20px;
    }

    .article-card h2{
        font-size:1.45rem;
    }

    .article-card h3{
        font-size:1.08rem;
    }

    .article-meta{
        flex-direction:column;
        align-items:flex-start;
    }

    .article-cta-box{
        padding:18px;
    }

    .article-btn{
        width:100%;
    }

    .article-sticky-cta{
        display:block;
    }
}

/* =========================
   10. FAQ / RULES / PRIVACY / LEGAL
========================= */
.faq-item{
    background:#fff;
    border:1px solid var(--border);
    border-radius:18px;
    padding:20px;
    margin-bottom:16px;
    box-shadow:var(--shadow);
}

.faq-item h3{
    margin-bottom:10px;
}

.faq-note,
.cta-note{
    text-align:center;
    color:var(--muted);
}

.page-legal .card,
.page-faq .card,
.privacy-content{
    max-width:1000px;
    margin-left:auto;
    margin-right:auto;
}

.privacy-content{
    background:#fff;
    border-radius:24px;
    box-shadow:var(--shadow);
    padding:32px;
    margin:120px auto 40px;
}

.privacy-content h1,
.privacy-content h2{
    color:var(--secondary);
    margin-bottom:14px;
}

.privacy-content h1{
    font-size:2rem;
}

.privacy-content h2{
    font-size:1.3rem;
    margin-top:24px;
}

/* =========================
   11. ADVERTISEMENT / MAP / CTA
========================= */
.advertisement{
    margin:42px 0 0;
    background:linear-gradient(135deg,#fff,#f8fafc);
    border-top:1px solid var(--border);
    border-bottom:1px solid var(--border);
    padding:20px;
    text-align:center;
}

.ad-row{
    display:flex;
    justify-content:center;
    align-items:center;
    gap:20px;
    flex-wrap:nowrap;
}

.ad-row a{
    display:block;
    flex:0 0 auto;
}

.ad-row img,
.borea-banner img{
    display:block;
    width:auto;
    height:80px;
    max-width:none;
    object-fit:contain;
    margin:0;
    padding:0;
    border:none;
    box-shadow:none;
    border-radius:0;
}

.borea-banner{
    width:100%;
    background:#f4f4f4;
    padding:20px;
    text-align:center;
    display:flex;
    justify-content:center;
    align-items:center;
    gap:20px;
    flex-wrap:nowrap;
    border-top:1px solid var(--border);
    border-bottom:1px solid var(--border);
}

.borea-banner a{
    display:block;
    flex:0 0 auto;
    margin:0;
    padding:0;
}

.map,
.mapa,
.map-section,
.map-container{
    width:100%;
}

.map iframe,
.mapa iframe,
.map-container iframe{
    width:100%;
    height:420px;
    border:0;
    display:block;
    border-radius:18px;
    box-shadow:var(--shadow);
}

.bottom-cta{
    padding:56px 20px;
    background:linear-gradient(135deg,#fff7ed 0%,#ffffff 100%);
}

.bottom-cta-box{
    max-width:var(--container);
    margin:0 auto;
    padding:36px;
}

/* =========================
   12. FOOTER
========================= */
footer{
    background:var(--secondary);
    color:#fff;
    padding:48px 0 18px;
    margin-top:40px;
}

.footer-content{
    max-width:var(--container);
    margin:0 auto;
    padding:0 20px;
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:28px;
}

.footer-column h3{
    font-size:1.1rem;
    margin-bottom:16px;
}

.footer-column p,
.footer-column a,
.footer-links a{
    color:#cbd5e1;
    display:block;
    margin-bottom:10px;
    transition:0.25s ease;
}

.footer-column a:hover,
.footer-links a:hover{
    color:#fff;
}

.social-icons{
    display:flex;
    flex-direction:column;
    gap:10px;
}

.social-icons a{
    display:flex;
    align-items:center;
    gap:10px;
    margin:0;
    transition:0.25s ease;
}

.social-icons a:hover{
    color:#ffffff;
    transform:translateX(4px);
}

.footer-links{
    display:flex;
    justify-content:center;
    flex-wrap:wrap;
    gap:14px;
    max-width:var(--container);
    margin:0 auto 18px;
    padding:0 20px;
}

.copyright{
    text-align:center;
    color:#94a3b8;
    font-size:0.92rem;
    margin-top:22px;
    padding-top:16px;
    border-top:1px solid rgba(255,255,255,0.08);
    max-width:var(--container);
    margin-left:auto;
    margin-right:auto;
}

/* =========================
   13. FLOATING BUTTONS / LIGHTBOX
========================= */
.whatsapp-float{
    position:fixed;
    right:20px;
    bottom:20px;
    width:56px;
    height:56px;
    border-radius:50%;
    background:var(--whatsapp);
    color:#fff;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:26px;
    box-shadow:0 12px 24px rgba(0,0,0,0.18);
    z-index:999;
}

.lightbox{
    display:none;
    position:fixed;
    inset:0;
    background:rgba(0,0,0,0.82);
    z-index:3000;
    justify-content:center;
    align-items:center;
    padding:20px;
}

.lightbox-content{
    position:relative;
    max-width:1100px;
    width:100%;
}

.lightbox-content img{
    width:100%;
    max-height:82vh;
    object-fit:contain;
    border-radius:18px;
    background:#000;
}

.close-lightbox{
    position:absolute;
    top:-44px;
    right:0;
    color:#fff;
    font-size:2rem;
    cursor:pointer;
}

.lightbox-nav{
    position:absolute;
    top:50%;
    left:0;
    width:100%;
    display:flex;
    justify-content:space-between;
    transform:translateY(-50%);
    pointer-events:none;
}

.lightbox-nav button{
    pointer-events:auto;
    background:rgba(255,255,255,0.85);
    border:none;
    color:var(--secondary);
    width:48px;
    height:48px;
    border-radius:50%;
    font-size:1.2rem;
    cursor:pointer;
    margin:0 12px;
}

/* =========================
   14. RESPONSIVE
========================= */
@media (max-width:1024px){
    .hero-grid,
    .main-grid{
        grid-template-columns:1fr;
    }

    .sidebar{
        position:static;
    }

    .hero-image-card img{
        min-height:340px;
    }

    .apartment-grid,
    .apartments-grid{
        grid-template-columns:repeat(2,1fr);
    }

    .footer-content{
        grid-template-columns:1fr 1fr;
    }
}

@media (max-width:768px){
    .header-container,
    nav.nav-container{
        padding:14px 16px;
        min-height:74px;
    }

    .logo img{
        height:46px;
    }

    .hamburger{
        display:inline-flex;
    }

    nav,
    .desktop-menu{
        position:fixed;
        top:74px;
        left:0;
        width:100%;
        background:#fff;
        box-shadow:0 16px 40px rgba(0,0,0,0.10);
        display:none;
        padding:18px 0 24px;
        max-height:calc(100vh - 74px);
        overflow-y:auto;
        margin-left:0;
    }

    nav.active,
    .desktop-menu.active{
        display:flex;
    }

    .main-nav,
    .desktop-menu{
        flex-direction:column;
        align-items:stretch;
        gap:0;
        padding:0 22px;
    }

    .main-nav > li,
    .desktop-menu a{
        width:100%;
        padding:10px 0;
    }

    .main-nav > li > a,
    .lang-toggle,
    .desktop-menu a{
        display:flex;
        width:100%;
        justify-content:space-between;
        align-items:center;
        text-align:center;
    }

    .desktop-menu .mobile-cta{
        width:100%;
        margin-top:10px;
    }

    .header-cta{
        display:none;
    }

    .language-menu,
    .lang-options{
        position:static;
        min-width:100%;
        box-shadow:none;
        border-radius:0;
        padding:8px 0 0 12px;
        background:transparent;
    }

    .language-dropdown.open .language-menu,
    .language-dropdown.active .lang-options{
        display:block;
    }

    .swiper{
        height:76vh;
        min-height:520px;
        margin-top:82px;
    }

    .hero{
        padding:32px 0 28px;
    }

    .hero-content,
    .hero-intro{
        max-width:100%;
        padding:0 16px;
    }

    .hero-text h1,
    .hero-content h1,
    .hero-card h1,
    header h1,
    .blog-article h1{
        font-size:2rem;
    }

    .hero-buttons,
    .hero-actions,
    .header-actions,
    .cta-button-wrap{
        flex-direction:column;
        align-items:stretch;
    }

    .btn-primary,
    .btn-secondary,
    .cta-btn,
    .cta-btn-secondary,
    .cta-button,
    .booking-button,
    .home-button{
        width:100%;
    }

    .card,
    .blog-content,
    .blog-article,
    .content-box,
    .seo-box,
    .hero-card,
    .intro-box,
    .media-card,
    .bottom-cta-box,
    .privacy-content{
        padding:22px;
    }

    .feature-grid,
    .gallery-thumbnails,
    .features-grid,
    .benefits-grid,
    .reviews-grid,
    .blog-grid,
    .posts-grid,
    .media-block,
    .apartments-grid,
    .apartment-grid,
    .footer-content{
        grid-template-columns:1fr;
    }

    .gallery-thumbnails{
        gap:10px;
    }

    .borea-banner,
    .ad-row{
        flex-wrap:wrap;
        gap:12px;
    }

    .borea-banner img,
    .ad-row img{
        height:64px;
    }

    .map iframe,
    .mapa iframe,
    .map-container iframe{
        height:340px;
    }

    .social-icons{
        align-items:center;
    }

    .social-icons a:hover{
        transform:none;
    }

    .footer-content,
    .footer-links,
    .copyright{
        text-align:center;
    }

    .sticky-booking,
    .cta-mobile{
        left:16px;
        right:16px;
        transform:none;
        width:auto;
        bottom:14px;
    }
}

@media (max-width:480px){
    .container,
    .seo-intro,
    .features,
    .apartments,
    .content-section,
    .mapa,
    .page-section,
    .blog-section,
    .location-section,
    .reviews-section,
    .croatia-section,
    .house-rules-section,
    .faq-section,
    .bottom-cta,
    .map-section{
        padding-left:16px;
        padding-right:16px;
    }

    .hero-text h1,
    .hero-content h1,
    .hero-card h1,
    header h1,
    .blog-article h1,
    .privacy-content h1{
        font-size:1.75rem;
    }

    .hero-badges{
        gap:8px;
    }

    .hero-badges span,
    .trust-line,
    .score-line{
        font-size:0.86rem;
        padding:8px 12px;
    }

    .logo img{
        height:42px;
    }

    .swiper{
        min-height:500px;
    }

    .apartment-card img,
    .post-preview img{
        height:200px;
    }

    .article-hero h1{
        font-size:1.65rem;
    }

    .article-card{
        padding:20px 16px;
    }
}

/* =========================================================
   FINAL OVERRIDES - APRIL 2026
   Homepage from index-en.html
   Content/legal pages from podaca / rules / faq / privacy / terms
========================================================= */

/* =========================
   A. HEADER / NAV FIX
========================= */

/* homepage header */
header{
    display:flex;
    align-items:center;
    justify-content:center;
    padding:0;
}

header > nav.nav-container{
    width:100%;
    max-width:1200px;
    margin:auto;
    display:flex;
    justify-content:space-between;
    align-items:center;
    padding:1rem;
    position:relative;
    gap:1rem;
    min-height:auto;
}

/* content/legal pages header */
header > .logo{
    display:flex;
    align-items:center;
    flex:0 0 auto;
}

header > .logo img{
    height:45px;
    max-width:170px;
    width:auto;
    object-fit:contain;
}

header > .nav-container{
    display:flex;
    align-items:center;
    gap:20px;
    position:relative;
    margin-left:auto;
}

header > .nav-container nav{
    display:flex;
    gap:1rem;
    transition:.3s ease;
    margin-left:0;
}

header > .nav-container nav a{
    text-decoration:none;
    color:#333;
    font-weight:600;
    padding:.3rem .5rem;
    font-size:1.06rem;
    transition:color .2s;
}

header > .nav-container nav a:hover,
header > .nav-container nav a.active{
    color:#3498db;
}

header > .nav-container .lang-btn{
    background:#3498db;
    color:#fff;
    border:none;
    padding:.5rem 1rem;
    cursor:pointer;
    border-radius:5px;
    font-size:1rem;
    font-weight:600;
    white-space:nowrap;
}

header > .nav-container .lang-options{
    display:none;
    position:absolute;
    background:#fff;
    box-shadow:0 2px 5px rgba(0,0,0,.2);
    top:40px;
    right:0;
    z-index:1200;
    border-radius:6px;
    min-width:85px;
    padding:0;
}

header > .nav-container .lang-options a{
    display:block;
    padding:.5rem 1rem;
    text-decoration:none;
    color:#333;
    transition:background .2s;
}

header > .nav-container .lang-options a:hover{
    background:#f2f2f2;
    color:#333;
}

header > .nav-container .language-dropdown.active .lang-options{
    display:block;
}

header > .nav-container .hamburger{
    display:none;
    flex-direction:column;
    cursor:pointer;
    margin-left:12px;
    padding:.15rem;
    z-index:1300;
    width:auto;
    height:auto;
    gap:0;
    background:transparent;
    border:none;
}

header > .nav-container .hamburger div{
    width:27px;
    height:3px;
    background:#333;
    margin:4px 0;
    border-radius:2px;
    transition:all .3s;
}

header > .nav-container .hamburger.active div:nth-child(1){
    transform:rotate(45deg) translate(4px,5px);
}

header > .nav-container .hamburger.active div:nth-child(2){
    opacity:0;
}

header > .nav-container .hamburger.active div:nth-child(3){
    transform:rotate(-45deg) translate(5px,-6px);
}

/* homepage nav */
nav.nav-container{
    margin-left:0;
}

nav.nav-container .logo{
    display:flex;
    align-items:center;
    justify-content:flex-start;
    width:300px;
    min-width:300px;
    overflow:hidden;
    max-width:none;
}

nav.nav-container .logo img{
    display:block;
    width:100%;
    height:auto;
    max-height:60px;
    object-fit:contain;
}

nav.nav-container .nav-group{
    display:flex;
    align-items:center;
    gap:12px;
    min-width:0;
    margin-left:auto;
}

nav.nav-container .desktop-menu{
    display:flex;
    align-items:center;
    gap:22px;
}

nav.nav-container .desktop-menu a{
    text-decoration:none;
    color:#333;
    font-weight:600;
    transition:color .3s ease;
    white-space:nowrap;
    padding:0;
}


nav.nav-container .desktop-menu a:hover,
nav.nav-container .desktop-menu a.active{
    color:#3498db;
}

nav.nav-container .language-dropdown{
    position:relative;
    flex:0 0 auto;
}

nav.nav-container .lang-btn{
    background:#3498db;
    color:#fff;
    border:none;
    padding:.5rem 1rem;
    cursor:pointer;
    border-radius:5px;
    font-weight:600;
    white-space:nowrap;
}

nav.nav-container .lang-options{
    display:none;
    position:absolute;
    background:#fff;
    box-shadow:0 2px 5px rgba(0,0,0,.2);
    right:0;
    margin-top:5px;
    z-index:1001;
    min-width:90px;
    border-radius:0;
    padding:0;
}

nav.nav-container .lang-options a{
    display:block;
    padding:.5rem 1rem;
    text-decoration:none;
    color:#333;
}

nav.nav-container .lang-options a:hover{
    background:#f2f2f2;
    color:#333;
}

nav.nav-container .language-dropdown.active .lang-options{
    display:block;
}

nav.nav-container .hamburger{
    display:none;
    background:none;
    border:none;
    cursor:pointer;
    color:#333;
    width:auto;
    height:auto;
}

nav.nav-container .hamburger i{
    font-size:24px;
}

/* =========================
   B. HOMEPAGE / INDEX
========================= */

.swiper{
    width:100%;
    height:64vh;
    min-height:0;
    margin-top:100px;
    position:relative;
}

.swiper-slide img{
    width:100%;
    height:100%;
    object-fit:cover;
}

.hero-overlay{
    position:absolute;
    inset:0;
    background:linear-gradient(to bottom, rgba(0,0,0,.24), rgba(0,0,0,.5));
    z-index:2;
    pointer-events:none;
}

.hero-content{
    position:absolute;
    z-index:3;
    left:50%;
    top:50%;
    transform:translate(-50%, -50%);
    width:100%;
    max-width:920px;
    padding:0 20px;
    text-align:center;
    color:#fff;
}

.hero-content h1,
.hero-content p{
    color:#fff;
    text-shadow:0 2px 10px rgba(0,0,0,.35);
}

.hero-content p{
    max-width:760px;
    margin:0 auto 1.5rem;
}

/* normal intro under slider for content pages */
.hero-intro{
    max-width:1000px;
    margin:0 auto 2rem;
    padding:0 1rem;
    position:static;
    z-index:auto;
    left:auto;
    top:auto;
    transform:none;
    text-align:initial;
    color:inherit;
}

.hero-copy{
    max-width:1000px;
    margin:3rem auto 2rem;
    padding:0 1rem;
    text-align:center;
}

.hero-copy h1{
    font-size:2.2rem;
    line-height:1.3;
    color:#1f2d3d;
    margin-bottom:1rem;
}

.hero-copy p{
    max-width:860px;
    margin:0 auto 1rem;
    color:#444;
    font-size:1.05rem;
}

.hero-actions{
    display:flex;
    gap:1rem;
    justify-content:center;
    flex-wrap:wrap;
    margin-top:2rem;
}

/* homepage buttons */
.hero-actions .cta-button,
.section-center .cta-button,
.apartments .cta-button,
.cta-mobile{
    display:inline-block;
    padding:.9rem 2rem;
    font-weight:bold;
    text-decoration:none;
    border-radius:8px;
    font-size:1rem;
    transition:background-color .3s ease, transform .2s ease, color .3s ease;
    background-color:#e74c3c;
    color:#fff;
    border:none;
    box-shadow:none;
}

.hero-actions .cta-button:hover,
.section-center .cta-button:hover,
.apartments .cta-button:hover,
.cta-mobile:hover{
    background-color:#c0392b;
    transform:scale(1.05);
}

.hero-actions .cta-secondary,
.section-center .cta-secondary{
    display:inline-block;
    padding:.9rem 2rem;
    font-weight:bold;
    text-decoration:none;
    border-radius:8px;
    font-size:1rem;
    transition:background-color .3s ease, transform .2s ease, color .3s ease;
    background:#fff;
    color:#3498db;
    border:2px solid #3498db;
}

.hero-actions .cta-secondary:hover,
.section-center .cta-secondary:hover{
    background:#3498db;
    color:#fff;
    transform:scale(1.05);
}

.trust-line{
    text-align:center;
    font-weight:bold;
    color:#1f2d3d;
    margin-top:1rem;
    background:none;
    border:none;
    padding:0;
    border-radius:0;
    font-size:inherit;
}

.benefits,
.reviews-section,
.blog-section,
.faq-section,
.location-section,
.croatia-section,
.content-section,
.map-section,
.apartments{
    max-width:1100px;
    margin:3rem auto;
    padding:0 1rem;
}

.location-box,
.white-box,
.review-card,
.blog-card,
.benefit-card,
.apartment-card,
.faq-item,
.content-box{
    background:#fff;
    border-radius:12px;
    box-shadow:0 4px 16px rgba(0,0,0,.08);
    border:1px solid #e8e8e8;
}

.benefits-grid,
.reviews-grid,
.blog-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
    gap:1.5rem;
}

.apartments-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));
    gap:2rem;
}

.apartment-card{
    padding:1.5rem;
    text-align:center;
    transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;
    overflow:visible;
}

.apartment-card img{
    max-width:100%;
    border-radius:10px;
    margin-bottom:1rem;
    display:block;
    width:100%;
    height:auto;
    object-fit:cover;
}

.apartment-card:hover{
    transform:translateY(-5px);
    box-shadow:0 6px 20px rgba(0,0,0,.18);
    border-color:#3498db;
}

.apartment-card a,
.blog-card a{
    display:inline-block;
    margin-top:1rem;
    padding:.5rem 1.2rem;
    background-color:#3498db;
    color:#fff;
    border-radius:5px;
    text-decoration:none;
    font-weight:bold;
    transition:background-color .3s ease, transform .2s ease;
}

.apartment-card a:hover,
.blog-card a:hover{
    background-color:#217dbb;
    transform:scale(1.05);
}

.benefit-card i{
    font-size:2rem;
    color:#3498db;
    margin-bottom:1rem;
}

.benefit-card,
.review-card,
.blog-card,
.faq-item,
.white-box,
.location-box{
    padding:1.5rem;
}

.mapa{
    max-width:1100px;
    margin:3rem auto;
    padding:0 1rem;
}

.mapa iframe{
    width:100%;
    height:400px;
    border:0;
    display:block;
    border-radius:10px;
}

.borea-banner{
    width:100%;
    background-color:#f4f4f4;
    padding:2rem 1rem;
    text-align:center;
    display:flex;
    justify-content:center;
    gap:2rem;
    flex-wrap:wrap;
}

.borea-banner img{
    width:280px;
    max-width:90vw;
    height:80px;
    object-fit:contain;
}

.whatsapp-float{
    display:flex;
    position:fixed;
    bottom:20px;
    right:20px;
    background-color:#25D366;
    color:#fff;
    border-radius:50%;
    width:50px;
    height:50px;
    align-items:center;
    justify-content:center;
    font-size:24px;
    box-shadow:0 2px 8px rgba(0,0,0,.2);
    z-index:1001;
    text-decoration:none;
}

.cta-mobile{
    display:none;
    position:fixed;
    bottom:0;
    left:0;
    width:100%;
    text-align:center;
    padding:1rem;
    font-weight:bold;
    font-size:1.1rem;
    text-decoration:none;
    z-index:999;
    box-shadow:0 -2px 10px rgba(0,0,0,.2);
}

/* =========================
   C. CONTENT / LEGAL PAGES
========================= */

.page-section{
    max-width:980px;
    margin:0 auto 3rem;
    padding:0 1rem;
}

.content-box{
    padding:2.2rem;
    border-radius:14px;
}

.content-box h1{
    font-size:2rem;
    color:#2c3e50;
    margin-top:0;
    margin-bottom:.8rem;
    text-align:center;
}

.content-box h2{
    color:#2c3e50;
    font-size:1.3rem;
    margin-top:2rem;
    margin-bottom:.7rem;
    padding-bottom:.4rem;
    border-bottom:2px solid #eaf2f8;
}

.content-box p{
    margin:0 0 1rem;
}

.content-box ul{
    margin:0 0 1rem 1.2rem;
    padding:0;
    list-style:disc;
}

.content-box li{
    margin-bottom:.45rem;
}

.intro-text{
    text-align:center;
    color:#5f6b76;
    margin-bottom:2rem;
    font-size:1.02rem;
}

.highlight-box{
    background:#f3f9fe;
    border-left:4px solid #3498db;
    border-radius:8px;
    padding:1rem 1.1rem;
    margin:1.2rem 0 1.5rem;
    color:inherit;
    box-shadow:none;
}

.cta-note{
    background:#f8fafc;
    border:1px solid #e5edf5;
    border-radius:10px;
    padding:1rem 1.2rem;
    margin-top:2rem;
}

.cta-button-wrap{
    text-align:center;
    margin-top:2rem;
    display:block;
}

.cta-button-wrap .cta-button,
.content-box .cta-button{
    display:inline-block;
    background:#3498db;
    color:#fff;
    text-decoration:none;
    padding:.9rem 1.6rem;
    border-radius:8px;
    font-weight:600;
    border:none;
    transition:background .2s ease, transform .2s ease;
    box-shadow:none;
}

.cta-button-wrap .cta-button:hover,
.content-box .cta-button:hover{
    background:#217dbb;
    transform:translateY(-1px);
}

/* FAQ + rules page */
.hero-card{
    background:#fff;
    border-radius:14px;
    box-shadow:0 4px 16px rgba(0,0,0,.08);
    padding:2rem;
    margin-top:-.5rem;
    max-width:none;
    text-align:center;
}

.hero-card h1{
    margin:0 0 1rem;
    color:#2c3e50;
    line-height:1.2;
    font-size:clamp(1.8rem, 3.5vw, 2.5rem);
    text-align:center;
}

.hero-card p{
    margin:0 auto 1rem;
    max-width:850px;
    text-align:center;
    color:#475569;
    text-shadow:none;
}

.hero-card .hero-actions{
    display:flex;
    flex-wrap:wrap;
    gap:1rem;
    justify-content:center;
    margin-top:1.5rem;
}

.cta-btn,
.cta-btn-secondary{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:.5rem;
    padding:.85rem 1.35rem;
    border-radius:8px;
    text-decoration:none;
    font-weight:700;
    transition:transform .2s ease, background .2s ease;
}

.cta-btn{
    background:#3498db;
    color:#fff;
}

.cta-btn:hover{
    background:#217dbb;
    transform:translateY(-1px);
}

.cta-btn-secondary{
    background:#eef6fc;
    color:#217dbb;
}

.cta-btn-secondary:hover{
    transform:translateY(-1px);
}

.faq-section{
    max-width:900px;
    margin:2rem auto 3rem;
    padding:2rem;
    background:#fff;
    border-radius:12px;
    box-shadow:0 4px 16px rgba(0,0,0,.08);
}

.faq-section h2{
    text-align:center;
    color:#2c3e50;
    margin:0 0 .75rem;
    font-size:clamp(1.45rem, 3vw, 2rem);
}

.faq-lead{
    text-align:center;
    max-width:760px;
    margin:0 auto 2rem;
    color:#64748b;
}

.faq-section details{
    border:1px solid #e6edf5;
    border-radius:10px;
    padding:.95rem 1rem;
    margin-bottom:.9rem;
    background:#fff;
}

.faq-section details[open]{
    background:#fbfdff;
    border-color:#cde4f6;
}

.faq-section summary{
    font-weight:600;
    cursor:pointer;
    color:#2c3e50;
    list-style:none;
    padding-right:1.2rem;
    position:relative;
}

.faq-section summary::-webkit-details-marker{
    display:none;
}

.faq-section summary::after{
    content:"+";
    position:absolute;
    right:0;
    top:0;
    color:#3498db;
    font-size:1.15rem;
    font-weight:700;
}

.faq-section details[open] summary::after{
    content:"−";
}

.faq-section details p{
    margin:.8rem 0 0;
    color:#4b5563;
}

.faq-note{
    margin-top:2rem;
    padding-top:1.4rem;
    border-top:1px solid #e5e7eb;
    text-align:center;
    color:#64748b;
    font-style:italic;
}

/* =========================
   D. MOBILE / TABLET FIXES
========================= */

@media (max-width:992px){
    .hero-copy h1{
        font-size:1.9rem;
        line-height:1.35;
    }

    .hero-copy p{
        font-size:1rem;
    }

    .apartments-grid,
    .benefits-grid,
    .reviews-grid,
    .blog-grid,
    .footer-content{
        grid-template-columns:1fr !important;
    }
}

@media (max-width:900px){
    header{
        padding:.75rem 1rem;
        justify-content:space-between;
    }

    header > .logo img{
        max-width:150px;
        height:auto;
    }

    header > .nav-container{
        position:static;
        gap:12px;
    }

    header > .nav-container nav{
        position:absolute;
        right:10px;
        top:60px;
        flex-direction:column;
        background:#fff;
        width:220px;
        padding:1rem .7rem;
        box-shadow:0 2px 10px rgba(0,0,0,.13);
        border-radius:8px;
        display:none;
        z-index:1100;
    }

    header > .nav-container nav.active{
        display:flex;
    }

    header > .nav-container .hamburger{
        display:flex;
    }

    .swiper{
        height:350px;
        margin-top:86px;
    }
}

@media (max-width:768px){
    header{
        padding:.6rem 1rem;
    }

    header > nav.nav-container{
        padding:.6rem 1rem;
        gap:.6rem;
    }

    nav.nav-container .logo{
        width:170px !important;
        min-width:170px !important;
    }

    nav.nav-container .logo img{
        max-height:42px !important;
        width:100% !important;
        object-fit:contain;
    }

    nav.nav-container .nav-group{
        gap:.6rem;
    }

    nav.nav-container .desktop-menu{
        display:none;
        flex-direction:column;
        position:absolute;
        top:68px;
        right:10px;
        width:min(260px, calc(100vw - 20px));
        background:#fff;
        border-radius:10px;
        padding:1rem;
        box-shadow:0 8px 24px rgba(0,0,0,.16);
        z-index:1002;
    }

    nav.nav-container .desktop-menu.active{
        display:flex;
    }

    nav.nav-container .desktop-menu a{
        padding:.65rem 0;
        border-bottom:1px solid #eee;
    }

    nav.nav-container .desktop-menu a:last-child{
        border-bottom:none;
    }

    nav.nav-container .hamburger{
        display:block !important;
    }

    nav.nav-container .lang-btn{
        padding:.45rem .8rem;
        font-size:.9rem;
    }

    .swiper{
        height:42vh !important;
        margin-top:78px !important;
    }

    .hero-copy,
    .hero-intro,
    .benefits,
    .reviews-section,
    .blog-section,
    .faq-section,
    .location-section,
    .croatia-section,
    .content-section,
    .mapa,
    .page-section,
    .apartments,
    .map-section{
        padding-left:1rem !important;
        padding-right:1rem !important;
    }

    .hero-copy h1,
    .hero-card h1,
    .content-box h1{
        font-size:1.55rem !important;
        line-height:1.35 !important;
        margin-bottom:.9rem;
    }

    .hero-copy p,
    .hero-card p,
    .content-box p,
    .intro-text{
        font-size:.96rem !important;
        line-height:1.7 !important;
    }

    .hero-actions{
        flex-direction:column;
        align-items:stretch;
        gap:.8rem;
    }

    .hero-actions .cta-button,
    .hero-actions .cta-secondary,
    .cta-button-wrap .cta-button,
    .cta-btn,
    .cta-btn-secondary{
        width:100%;
        text-align:center;
    }

    .benefits h2,
    .apartments h2,
    .reviews-section h2,
    .blog-section h2,
    .faq-section h2,
    .location-section h2,
    .croatia-section h2,
    .content-section h2,
    .page-section h2,
    .mapa h2,
    .content-box h2{
        font-size:1.45rem !important;
        line-height:1.35;
        margin-bottom:1.2rem;
    }

    .benefit-card,
    .review-card,
    .blog-card,
    .faq-item,
    .white-box,
    .content-box,
    .location-box,
    .apartment-card,
    .hero-card{
        padding:1.1rem !important;
        border-radius:10px;
    }

    .apartment-card h3,
    .blog-card h3,
    .benefit-card h3,
    .review-card h3{
        font-size:1.1rem;
    }

    .apartment-card p,
    .blog-card p,
    .benefit-card p,
    .review-card p,
    .faq-item p{
        font-size:.95rem;
    }

    .mapa iframe{
        height:300px !important;
    }

    footer{
        padding:2rem 1rem 5rem;
    }

    .whatsapp-float{
        width:52px;
        height:52px;
        font-size:24px;
        bottom:78px;
        right:14px;
    }

    .cta-mobile{
        display:block !important;
    }

    body{
        padding-bottom:72px;
    }
}

@media (max-width:540px){
    header{
        padding:.55rem .5rem;
    }

    header > .logo img{
        max-width:145px;
    }

    header > .nav-container .lang-btn{
        padding:.27rem .7rem;
        font-size:.95rem;
    }

    header > .nav-container .hamburger div{
        width:18px;
        height:2px;
        margin:2px 0;
    }

    .borea-banner{
        padding:1rem .1rem;
    }

    .borea-banner img{
        width:120px;
        height:auto;
    }

    .swiper{
        height:300px !important;
    }

    .faq-section{
        padding:1.25rem;
    }

    .mapa iframe{
        height:220px !important;
    }

    .hero-actions{
        flex-direction:column;
    }
}

@media (max-width:480px){
    nav.nav-container .logo{
        width:145px !important;
        min-width:145px !important;
    }

    nav.nav-container .logo img{
        max-height:38px !important;
    }

    .swiper{
        height:36vh !important;
    }

    .hero-copy h1{
        font-size:1.35rem !important;
    }
}
/* ===== FIX ZA CONTENT SEKCIJE (SVI JEZICI) ===== */

.hero-copy{
    max-width:1000px;
    margin:3rem auto 2rem;
    padding:0 1rem;
    text-align:center;
}

/* glavna content sekcija */
.content-section{
    max-width:1100px;
    margin:3rem auto;
    padding:0 1rem;
}

/* bijeli box */
.content-box{
    background:#fff;
    border-radius:12px;
    padding:2rem;
    box-shadow:0 4px 16px rgba(0,0,0,0.08);
    border:1px solid #e8e8e8;
}

/* benefits sekcija */
.benefits{
    max-width:1100px;
    margin:3rem auto;
    padding:0 1rem;
}

.benefits h2{
    text-align:center;
    margin-bottom:2rem;
}

/* grid */
.benefits-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(240px,1fr));
    gap:1.5rem;
}

/* kartice */
.benefit-card{
    background:#fff;
    border-radius:12px;
    padding:1.5rem;
    box-shadow:0 4px 16px rgba(0,0,0,0.08);
    border:1px solid #e8e8e8;
}
/* ========================================
   INDEX LANGUAGE SECTION FIX
   HR / EN / DE / PL / CS
======================================== */

.benefits,
.reviews-section,
.en-section,
.croatia-section,
.cs-section,
.germany-section,
.poland-section,
.blog-section,
.faq-section,
.content-section,
.location-section,
.apartments,
.mapa,
.map-section{
    max-width:1100px;
    margin:3rem auto;
    padding:0 1rem;
}

.benefits h2,
.apartments h2,
.reviews-section h2,
.en-section h2,
.croatia-section h2,
.cs-section h2,
.germany-section h2,
.poland-section h2,
.blog-section h2,
.faq-section h2,
.content-section h2,
.location-section h2,
.mapa h2,
.map-section h2{
    text-align:center;
    margin-bottom:2rem;
    color:#1f2d3d;
    font-size:1.9rem;
}

.content-box,
.location-box,
.white-box{
    max-width:900px;
    margin:0 auto;
    background:#fff;
    border-radius:12px;
    padding:2rem;
    box-shadow:0 4px 16px rgba(0,0,0,0.08);
    border:1px solid #e8e8e8;
}

.content-box p,
.location-box p,
.white-box p,
.review-card p,
.blog-card p,
.faq-item p{
    color:#444;
    margin-top:0;
}

.benefits-grid,
.reviews-grid,
.blog-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
    gap:1.5rem;
}

.benefit-card,
.review-card,
.blog-card,
.faq-item,
.white-box{
    background:#fff;
    border-radius:12px;
    box-shadow:0 4px 16px rgba(0,0,0,0.08);
    padding:1.5rem;
    border:1px solid #e8e8e8;
}

.benefit-card i{
    font-size:2rem;
    color:#3498db;
    margin-bottom:1rem;
}

.benefit-card h3,
.review-card h3,
.blog-card h3{
    margin-top:0;
    margin-bottom:0.7rem;
    color:#1f2d3d;
    font-size:1.15rem;
}

.apartments-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));
    gap:2rem;
}

.apartment-card{
    padding:1.5rem;
    box-shadow:0 4px 16px rgba(0,0,0,0.12);
    border:1px solid #ccc;
    border-radius:12px;
    background:#fff;
    transition:transform 0.3s ease, box-shadow 0.3s ease;
    text-align:center;
}

.apartment-card img{
    max-width:100%;
    border-radius:10px;
    margin-bottom:1rem;
    display:block;
}

.apartment-card:hover{
    transform:translateY(-5px);
    box-shadow:0 6px 20px rgba(0,0,0,0.18);
    border-color:#3498db;
}

.apartment-card a,
.blog-card a{
    display:inline-block;
    margin-top:1rem;
    padding:0.5rem 1.2rem;
    background-color:#3498db;
    color:#fff;
    border-radius:5px;
    text-decoration:none;
    font-weight:bold;
    transition:background-color 0.3s ease, transform 0.2s ease;
}

.apartment-card a:hover,
.blog-card a:hover{
    background-color:#217dbb;
    transform:scale(1.05);
}

.cs-section ul,
.germany-section ul,
.poland-section ul,
.croatia-section ul,
.en-section ul{
    line-height:1.9;
    color:#444;
    padding-left:1.2rem;
}

.mapa iframe,
.map-section iframe{
    width:100%;
    height:400px;
    border:0;
    display:block;
    border-radius:10px;
}

.section-center{
    text-align:center;
    margin-top:2rem;
}

/* ========================================
   MOBILE FIX
======================================== */
@media (max-width: 992px){
    .apartments-grid,
    .benefits-grid,
    .reviews-grid,
    .blog-grid,
    .footer-content{
        grid-template-columns:1fr !important;
    }
}

@media (max-width: 768px){
    .hero-copy,
    .benefits,
    .reviews-section,
    .blog-section,
    .faq-section,
    .en-section,
    .croatia-section,
    .cs-section,
    .germany-section,
    .poland-section,
    .content-section,
    .location-section,
    .mapa,
    .map-section,
    .apartments{
        padding-left:1rem !important;
        padding-right:1rem !important;
    }

    .benefits h2,
    .apartments h2,
    .reviews-section h2,
    .blog-section h2,
    .faq-section h2,
    .en-section h2,
    .croatia-section h2,
    .cs-section h2,
    .germany-section h2,
    .poland-section h2,
    .content-section h2,
    .location-section h2,
    .mapa h2,
    .map-section h2{
        font-size:1.45rem !important;
        line-height:1.35;
        margin-bottom:1.2rem;
    }

    .benefit-card,
    .review-card,
    .blog-card,
    .faq-item,
    .white-box,
    .apartment-card,
    .content-box,
    .location-box{
        padding:1.1rem !important;
        border-radius:10px;
    }

    .apartment-card h3,
    .blog-card h3,
    .benefit-card h3,
    .review-card h3{
        font-size:1.1rem;
    }

    .apartment-card p,
    .blog-card p,
    .benefit-card p,
    .review-card p,
    .faq-item p,
    .content-box p,
    .location-box p,
    .white-box p{
        font-size:0.95rem;
    }

    .mapa iframe,
    .map-section iframe{
        height:300px !important;
    }
}
/* === HEADER FIX – logo padding === */

nav.nav-container{
    max-width:1200px;
    margin:0 auto;
    padding:0 24px;
}

nav.nav-container .logo{
    margin-left:8px;
}
/* === CONTENT / LEGAL PAGES HEADER FIX === */

header{
    padding-left:20px !important;
    padding-right:20px !important;
}

header > .logo{
    flex:0 0 auto !important;
    padding-left:14px !important;
    margin-right:24px !important;
}

header > .logo img{
    display:block;
    height:45px !important;
    max-width:170px !important;
    width:auto !important;
    object-fit:contain;
}

header > .nav-container{
    flex:1 1 auto !important;
    justify-content:flex-end !important;
}

header > .nav-container nav{
    gap:.8rem !important;
}

/* =========================================================
   FINAL HEADER MATCH FIX
   content/legal pages should visually match homepage header
========================================================= */

header{
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    padding:0 !important;
}

header > .logo{
    display:flex !important;
    align-items:center !important;
    justify-content:flex-start !important;
    width:300px !important;
    min-width:300px !important;
    margin:0 !important;
    padding:0 !important;
    overflow:hidden !important;
    flex:0 0 auto !important;
}

header > .logo img{
    display:block !important;
    width:100% !important;
    height:auto !important;
    max-height:60px !important;
    max-width:none !important;
    object-fit:contain !important;
}

header > .nav-container{
    width:100% !important;
    max-width:900px !important;
    margin:0 !important;
    min-height:78px !important;
    padding:14px 24px 14px 20px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:flex-end !important;
    gap:20px !important;
    position:relative !important;
    flex:1 1 auto !important;
}

header > .nav-container nav{
    display:flex !important;
    align-items:center !important;
    gap:22px !important;
    margin-left:0 !important;
}

header > .nav-container nav a{
    text-decoration:none !important;
    color:#333 !important;
    font-weight:600 !important;
    font-size:1rem !important;
    white-space:nowrap !important;
    padding:0 !important;
}

header > .nav-container nav a:hover,
header > .nav-container nav a.active{
    color:#3498db !important;
}

header > .nav-container .language-dropdown{
    position:relative !important;
    flex:0 0 auto !important;
}

header > .nav-container .lang-btn{
    background:#3498db !important;
    color:#fff !important;
    border:none !important;
    padding:.5rem 1rem !important;
    border-radius:8px !important;
    font-weight:600 !important;
    white-space:nowrap !important;
}

header > .nav-container .lang-options{
    display:none;
    position:absolute;
    top:100%;
    right:0;
    margin-top:5px;
    min-width:90px;
    background:#fff;
    box-shadow:0 2px 5px rgba(0,0,0,.2);
    padding:0;
    border-radius:0;
    z-index:1001;
}

header > .nav-container .lang-options a{
    display:block;
    padding:.5rem 1rem !important;
    color:#333 !important;
}

header > .nav-container .lang-options a:hover{
    background:#f2f2f2;
    color:#333 !important;
}

header > .nav-container .language-dropdown.active .lang-options{
    display:block;
}

@media (max-width:900px){
    header > .logo{
        width:220px !important;
        min-width:220px !important;
    }

    header > .logo img{
        max-height:48px !important;
    }

    header > .nav-container{
        max-width:none !important;
        padding:14px 16px !important;
        gap:12px !important;
    }

    header > .nav-container nav{
        position:absolute !important;
        right:10px !important;
        top:60px !important;
        flex-direction:column !important;
        align-items:stretch !important;
        gap:0 !important;
        background:#fff !important;
        width:220px !important;
        padding:1rem .7rem !important;
        box-shadow:0 2px 10px rgba(0,0,0,.13) !important;
        border-radius:8px !important;
        display:none !important;
        z-index:1100 !important;
    }

    header > .nav-container nav.active{
        display:flex !important;
    }

    header > .nav-container nav a{
        padding:.65rem 0 !important;
    }

    header > .nav-container .hamburger{
        display:flex !important;
    }
}

@media (max-width:768px){
    header > .logo{
        width:170px !important;
        min-width:170px !important;
    }

    header > .logo img{
        max-height:42px !important;
    }

    header > .nav-container{
        min-height:74px !important;
        padding:.6rem 1rem !important;
    }

    header > .nav-container .lang-btn{
        padding:.45rem .8rem !important;
        font-size:.9rem !important;
    }
}

@media (max-width:480px){
    header > .logo{
        width:145px !important;
        min-width:145px !important;
    }

    header > .logo img{
        max-height:38px !important;
    }
}



/* =========================================================
   FINAL HARD FIX - LEGAL / RULES / TERMS / PRIVACY NAV
   OVAJ BLOK MORA BITI ZADNJI U FILEU
========================================================= */

/* desktop legal nav fix */
@media (min-width: 901px){

    nav.nav-container{
        width:100% !important;
        max-width:1240px !important;
        margin:0 auto !important;
        padding:14px 20px !important;
        display:grid !important;
        grid-template-columns:auto 1fr auto !important;
        align-items:center !important;
        gap:22px !important;
        min-height:78px !important;
    }

    nav.nav-container .logo{
        justify-self:start !important;
        display:flex !important;
        align-items:center !important;
        width:auto !important;
        min-width:0 !important;
        max-width:260px !important;
        overflow:visible !important;
        margin:0 !important;
        padding:0 !important;
    }

    nav.nav-container .logo img{
        display:block !important;
        width:auto !important;
        height:60px !important;
        max-width:260px !important;
        object-fit:contain !important;
        margin:0 !important;
    }

    nav.nav-container .desktop-menu{
        justify-self:center !important;
        display:flex !important;
        align-items:center !important;
        justify-content:center !important;
        gap:18px !important;
        min-width:0 !important;
        flex-wrap:nowrap !important;
        margin:0 !important;
        padding:0 !important;
    }

    nav.nav-container .desktop-menu a{
        display:inline-flex !important;
        align-items:center !important;
        justify-content:center !important;
        padding:0 !important;
        margin:0 !important;
        white-space:nowrap !important;
        font-size:1rem !important;
        line-height:1.2 !important;
    }

    nav.nav-container .nav-right{
        justify-self:end !important;
        display:flex !important;
        align-items:center !important;
        gap:12px !important;
        margin:0 !important;
        min-width:auto !important;
        padding:0 !important;
    }

    nav.nav-container .language-dropdown{
        position:relative !important;
        display:flex !important;
        align-items:center !important;
        margin:0 !important;
    }

    nav.nav-container .lang-btn{
        display:inline-flex !important;
        align-items:center !important;
        justify-content:center !important;
        margin:0 !important;
        padding:.75rem 1.1rem !important;
        line-height:1 !important;
        white-space:nowrap !important;
        border-radius:12px !important;
    }

    nav.nav-container .lang-options{
        top:calc(100% + 8px) !important;
        right:0 !important;
        left:auto !important;
        min-width:110px !important;
        margin-top:0 !important;
        z-index:2000 !important;
        border-radius:10px !important;
    }
}

/* legal pages spacing + hero block */
main.page-section{
    max-width:980px !important;
    width:100% !important;
    margin:0 auto 3rem !important;
    padding:128px 20px 0 !important;
}

main.page-section > .hero-card{
    max-width:1100px !important;
    width:100% !important;
    margin:0 auto 38px !important;
    padding:34px 25px !important;
    text-align:center !important;
}

main.page-section > .hero-card .hero-intro{
    position:static !important;
    left:auto !important;
    top:auto !important;
    transform:none !important;
    max-width:920px !important;
    margin:0 auto !important;
    padding:0 !important;
    text-align:center !important;
    color:inherit !important;
}

main.page-section > .hero-card .hero-actions{
    display:flex !important;
    justify-content:center !important;
    align-items:center !important;
    gap:18px !important;
    flex-wrap:wrap !important;
    margin-top:22px !important;
}

main.page-section > .hero-card .cta-note{
    display:block !important;
    max-width:780px !important;
    margin:28px auto 0 !important;
    padding:18px 22px !important;
    text-align:center !important;
    color:var(--muted) !important;
    font-size:0.96rem !important;
    background:#f8fafc !important;
    border:1px solid var(--border) !important;
    border-radius:16px !important;
    box-shadow:none !important;
}

main.page-section > .hero-card .cta-note a{
    color:var(--accent-dark) !important;
    font-weight:600 !important;
}

main.page-section > .content-box{
    width:100% !important;
    margin:0 auto !important;
    border-radius:18px !important;
}

main.page-section > .highlight{
    display:block !important;
    max-width:980px !important;
    width:100% !important;
    margin:34px auto 42px !important;
    padding:20px 24px !important;
    border-radius:18px !important;
    background:#fff7ed !important;
    border:1px solid #fed7aa !important;
    color:#9a3412 !important;
    text-align:center !important;
    font-weight:600 !important;
    box-shadow:0 10px 25px rgba(0,0,0,0.05) !important;
}

main.page-section > .faq-section{
    max-width:900px !important;
    width:100% !important;
    margin:42px auto 3rem !important;
    padding:2rem !important;
    background:#fff !important;
    border-radius:18px !important;
    box-shadow:var(--shadow) !important;
}

main.page-section > .faq-section .faq-grid{
    display:grid !important;
    gap:16px !important;
}

main.page-section > .faq-section .faq-item{
    margin-bottom:0 !important;
}

/* mobile */
@media (max-width: 900px){
    nav.nav-container{
        display:flex !important;
        align-items:center !important;
        justify-content:space-between !important;
        gap:12px !important;
    }

    nav.nav-container .logo{
        width:auto !important;
        max-width:180px !important;
        min-width:0 !important;
    }

    nav.nav-container .logo img{
        height:46px !important;
        width:auto !important;
        max-width:180px !important;
    }

    nav.nav-container .nav-right{
        display:flex !important;
        align-items:center !important;
        gap:10px !important;
    }
}

@media (max-width:768px){
    main.page-section{
        padding:96px 16px 0 !important;
    }

    main.page-section > .hero-card{
        padding:22px !important;
        margin:0 auto 28px !important;
    }

    main.page-section > .hero-card .hero-actions{
        flex-direction:column !important;
        align-items:stretch !important;
        gap:12px !important;
    }

    main.page-section > .hero-card .cta-button,
    main.page-section > .hero-card .cta-secondary{
        width:100% !important;
    }

    main.page-section > .hero-card .cta-note{
        margin:20px auto 0 !important;
        padding:16px !important;
    }

    main.page-section > .highlight{
        margin:26px auto 30px !important;
        padding:18px !important;
    }

    main.page-section > .faq-section{
        margin:30px auto 3rem !important;
        padding:1.25rem !important;
    }
}

/* fix slider/header overlap on pages with hero slider */
.swiper{
    margin-top:92px !important;
}

@media (max-width:768px){
    .swiper{
        margin-top:78px !important;
    }
}
/* =========================================
   FINAL FIX - OSTALI APARTMANI KARTICE
   zalijepi na SAM KRAJ style.css
========================================= */

.other-apartments{
    padding:40px 0 0 !important;
}

.other-apartments h2{
    font-size:clamp(1.9rem, 3vw, 2.6rem) !important;
    color:var(--secondary) !important;
    margin-bottom:28px !important;
    text-align:left !important;
}

.other-apartments .apartment-grid{
    display:grid !important;
    grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
    gap:28px !important;
}

.other-apartments .apartment-card{
    background:#ffffff !important;
    border:1px solid var(--border) !important;
    border-radius:20px !important;
    overflow:hidden !important;
    box-shadow:0 10px 25px rgba(0,0,0,0.08) !important;
    transition:all 0.25s ease !important;
    display:flex !important;
    flex-direction:column !important;
}

.other-apartments .apartment-card:hover{
    transform:translateY(-6px) !important;
    box-shadow:0 18px 40px rgba(0,0,0,0.12) !important;
}

.other-apartments .apartment-card a{
    display:block !important;
    color:inherit !important;
    text-decoration:none !important;
}

.other-apartments .apartment-card img{
    width:100% !important;
    height:230px !important;
    object-fit:cover !important;
    display:block !important;
    border-radius:0 !important;
    margin:0 !important;
}

.other-apartments .apartment-card-content{
    background:#ffffff !important;
    padding:22px 20px 24px !important;
    text-align:center !important;
}

.other-apartments .apartment-card-content h3{
    font-size:1.9rem !important;
    line-height:1.25 !important;
    color:var(--secondary) !important;
    margin:0 0 12px !important;
}

.other-apartments .apartment-card-content p{
    font-size:1rem !important;
    line-height:1.7 !important;
    color:var(--muted) !important;
    margin:0 !important;
}

@media (max-width:1024px){
    .other-apartments .apartment-grid{
        grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width:768px){
    .other-apartments{
        padding:28px 0 0 !important;
    }

    .other-apartments h2{
        font-size:2rem !important;
        margin-bottom:20px !important;
        text-align:center !important;
    }

    .other-apartments .apartment-grid{
        grid-template-columns:1fr !important;
        gap:20px !important;
    }

    .other-apartments .apartment-card img{
        height:220px !important;
    }

    .other-apartments .apartment-card-content{
        padding:18px 16px 20px !important;
    }

    .other-apartments .apartment-card-content h3{
        font-size:1.6rem !important;
    }

    .other-apartments .apartment-card-content p{
        font-size:0.96rem !important;
    }
}
/* =========================================
   FINAL FIX - UKLANJANJE PLAVE POZADINE
========================================= */

/* makni sve plave pozadine i obrube */
.apartment-card *{
    background:transparent !important;
}

/* glavna kartica */
.apartment-card{
    background:#ffffff !important;
    border-radius:18px !important;
    overflow:hidden !important;
    box-shadow:0 10px 25px rgba(0,0,0,0.08) !important;
}

/* unutarnji wrapper (gdje je plava boja) */
.apartment-card > div{
    background:#ffffff !important;
    border:none !important;
    box-shadow:none !important;
}

/* slika */
.apartment-card img{
    width:100% !important;
    height:230px !important;
    object-fit:cover !important;
    border-radius:0 !important;
}

/* sadržaj */
.apartment-card-content{
    background:#ffffff !important;
    padding:20px !important;
    text-align:center !important;
}

/* tekst */
.apartment-card-content h3{
    color:#1f2937 !important;
}

.apartment-card-content p{
    color:#6b7280 !important;
}
/* ===============================
   VILLA NATALI MASTER STYLE.CSS
   FINAL CLEAN VERSION
=============================== */

/* RESET */
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'Poppins',sans-serif;background:#f5f7fa;color:#1f2937;}

/* NAV */
.nav-container{
    max-width:1200px;
    margin:0 auto;
    padding:14px 20px;
    display:flex;
    align-items:center;
    justify-content:space-between;
}

.logo img{height:60px}

/* GRID APARTMENTS */
.apartments-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:25px;
    padding:40px 0;
}

/* CARD */
.apartment-card{
    background:#fff;
    border-radius:18px;
    overflow:hidden;
    box-shadow:0 10px 25px rgba(0,0,0,0.08);
    display:flex;
    flex-direction:column;
}

.apartment-card img{
    width:100%;
    height:230px;
    object-fit:cover;
}

.apartment-card h3{
    font-size:1.5rem;
    text-align:center;
    margin:15px 0 5px;
}

.apartment-card p{
    text-align:center;
    color:#6b7280;
    padding:0 15px;
}

/* BUTTONS */
.card-buttons{
    display:flex;
    flex-direction:column;
    gap:10px;
    padding:15px;
}

.details-btn{
    background:#3498db;
    color:#fff;
    padding:12px;
    border-radius:10px;
    text-align:center;
    text-decoration:none;
    font-weight:600;
}

.booking-btn{
    background:linear-gradient(135deg,#e67e22,#d35400);
    color:#fff;
    padding:12px;
    border-radius:10px;
    text-align:center;
    text-decoration:none;
    font-weight:700;
}

.details-btn:hover{background:#217dbb;}
.booking-btn:hover{transform:translateY(-2px);}

/* REMOVE BLUE BUG */
.apartment-card *{
    background:unset;
}

/* RESPONSIVE */
@media(max-width:900px){
    .apartments-grid{grid-template-columns:1fr 1fr;}
}

@media(max-width:600px){
    .apartments-grid{grid-template-columns:1fr;}
}



/* =========================================================
   FINAL HARD FIX - MOBILE APARTMENTS + HEADER
   added after user review
========================================================= */

/* apartment card buttons must always be visible */
.apartments-grid .card-buttons,
.apartment-grid .card-buttons{
    display:flex !important;
    flex-direction:column !important;
    gap:10px !important;
    padding:0 18px 20px !important;
    margin-top:auto !important;
    background:#ffffff !important;
}

.apartments-grid .details-btn,
.apartment-grid .details-btn{
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    width:100% !important;
    padding:12px 16px !important;
    border-radius:12px !important;
    background:#3498db !important;
    color:#ffffff !important;
    font-weight:700 !important;
    text-align:center !important;
    text-decoration:none !important;
    border:none !important;
    box-shadow:none !important;
    opacity:1 !important;
    visibility:visible !important;
}

.apartments-grid .booking-btn,
.apartment-grid .booking-btn{
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    width:100% !important;
    padding:12px 16px !important;
    border-radius:12px !important;
    background:linear-gradient(135deg,#e67e22,#d35400) !important;
    color:#ffffff !important;
    font-weight:700 !important;
    text-align:center !important;
    text-decoration:none !important;
    border:none !important;
    box-shadow:0 8px 18px rgba(211,84,0,0.20) !important;
    opacity:1 !important;
    visibility:visible !important;
}

.apartments-grid .details-btn:hover,
.apartment-grid .details-btn:hover{
    background:#217dbb !important;
    color:#ffffff !important;
}

.apartments-grid .booking-btn:hover,
.apartment-grid .booking-btn:hover{
    transform:translateY(-1px) !important;
    color:#ffffff !important;
}

/* remove any old hard reset that killed card colors */
.apartments-grid .apartment-card *,
.apartment-grid .apartment-card *{
    background:unset;
}

.apartments-grid .details-btn,
.apartments-grid .booking-btn,
.apartment-grid .details-btn,
.apartment-grid .booking-btn{
    background-clip:padding-box !important;
}

/* keep cards white */
.apartments-grid .apartment-card,
.apartment-grid .apartment-card{
    background:#ffffff !important;
}

.apartments-grid .apartment-card h3,
.apartment-grid .apartment-card h3{
    margin:14px 0 10px !important;
}

.apartments-grid .apartment-card p,
.apartment-grid .apartment-card p{
    margin:0 18px 12px !important;
}

/* stronger mobile header for apartment pages */
@media (max-width:768px){
    header{
        padding:0 !important;
    }

    nav.nav-container{
        width:100% !important;
        max-width:100% !important;
        min-height:72px !important;
        padding:10px 12px !important;
        display:grid !important;
        grid-template-columns:minmax(0,1fr) auto auto !important;
        align-items:center !important;
        gap:10px !important;
    }

    nav.nav-container .logo{
        width:auto !important;
        min-width:0 !important;
        max-width:155px !important;
        overflow:visible !important;
        margin:0 !important;
    }

    nav.nav-container .logo img{
        width:auto !important;
        height:38px !important;
        max-width:155px !important;
        object-fit:contain !important;
    }

    nav.nav-container .nav-group{
        margin-left:0 !important;
        gap:8px !important;
        align-items:center !important;
    }

    nav.nav-container .language-dropdown{
        position:relative !important;
        order:2 !important;
    }

    nav.nav-container .lang-btn{
        padding:8px 10px !important;
        font-size:0.82rem !important;
        border-radius:10px !important;
        line-height:1 !important;
        min-height:38px !important;
    }

    nav.nav-container .hamburger{
        display:inline-flex !important;
        align-items:center !important;
        justify-content:center !important;
        width:38px !important;
        height:38px !important;
        margin-left:0 !important;
        order:3 !important;
    }

    nav.nav-container .hamburger i{
        font-size:22px !important;
    }

    nav.nav-container .desktop-menu{
        position:absolute !important;
        top:72px !important;
        right:12px !important;
        left:auto !important;
        width:min(270px, calc(100vw - 24px)) !important;
        background:#ffffff !important;
        border-radius:12px !important;
        padding:12px 14px !important;
        box-shadow:0 12px 30px rgba(0,0,0,.16) !important;
        display:none !important;
        flex-direction:column !important;
        align-items:stretch !important;
        gap:0 !important;
        z-index:2000 !important;
    }

    nav.nav-container .desktop-menu.active{
        display:flex !important;
    }

    nav.nav-container .desktop-menu a{
        display:block !important;
        width:100% !important;
        padding:10px 0 !important;
        border-bottom:1px solid #edf2f7 !important;
        text-align:left !important;
    }

    nav.nav-container .desktop-menu a:last-child{
        border-bottom:none !important;
    }

    nav.nav-container .desktop-menu .mobile-cta{
        display:inline-flex !important;
        justify-content:center !important;
        margin-top:10px !important;
        border-bottom:none !important;
        padding:12px 14px !important;
        background:linear-gradient(135deg,#e67e22,#d35400) !important;
        color:#ffffff !important;
        border-radius:10px !important;
    }

    nav.nav-container .lang-options{
        position:absolute !important;
        top:calc(100% + 8px) !important;
        right:0 !important;
        min-width:90px !important;
        background:#ffffff !important;
        border-radius:10px !important;
        box-shadow:0 12px 24px rgba(0,0,0,.14) !important;
        padding:6px 0 !important;
        z-index:2100 !important;
    }

    .swiper{
        margin-top:72px !important;
    }

    .whatsapp-float{
        bottom:20px !important;
    }

    body{
        padding-bottom:0 !important;
    }
}

/* small phones */
@media (max-width:480px){
    nav.nav-container{
        padding:9px 10px !important;
        gap:8px !important;
    }

    nav.nav-container .logo{
        max-width:135px !important;
    }

    nav.nav-container .logo img{
        height:34px !important;
        max-width:135px !important;
    }

    nav.nav-container .lang-btn{
        padding:7px 8px !important;
        font-size:0.78rem !important;
        min-height:34px !important;
    }

    nav.nav-container .hamburger{
        width:34px !important;
        height:34px !important;
    }

    nav.nav-container .desktop-menu{
        top:66px !important;
        right:10px !important;
        width:min(255px, calc(100vw - 20px)) !important;
    }

    .swiper{
        margin-top:66px !important;
    }
}
/* =========================================================
   FINAL HARD FIX - MOBILE FULL WIDTH HOMEPAGE / APARTMENTS
   OVAJ BLOK MORA BITI ZADNJI
========================================================= */

@media (max-width: 768px){

    html,
    body{
        width:100% !important;
        max-width:100% !important;
        overflow-x:hidden !important;
    }

    header{
        width:100% !important;
        max-width:100% !important;
        left:0 !important;
        right:0 !important;
        padding:0 !important;
        justify-content:stretch !important;
    }

    nav.nav-container{
        width:100% !important;
        max-width:100% !important;
        margin:0 !important;
        padding:10px 12px !important;
        min-height:72px !important;
        display:grid !important;
        grid-template-columns:minmax(0,1fr) auto auto !important;
        align-items:center !important;
        gap:10px !important;
        box-sizing:border-box !important;
    }

    nav.nav-container .logo{
        width:auto !important;
        min-width:0 !important;
        max-width:150px !important;
        margin:0 !important;
        overflow:visible !important;
    }

    nav.nav-container .logo img{
        width:auto !important;
        max-width:150px !important;
        height:36px !important;
        object-fit:contain !important;
        margin:0 !important;
    }

    nav.nav-container .nav-group{
        display:flex !important;
        align-items:center !important;
        justify-content:flex-end !important;
        gap:8px !important;
        margin:0 !important;
        min-width:0 !important;
    }

    nav.nav-container .language-dropdown{
        position:relative !important;
        margin:0 !important;
    }

    nav.nav-container .lang-btn{
        display:inline-flex !important;
        align-items:center !important;
        justify-content:center !important;
        min-height:36px !important;
        padding:7px 9px !important;
        font-size:0.8rem !important;
        line-height:1 !important;
        border-radius:10px !important;
        white-space:nowrap !important;
    }

    nav.nav-container .hamburger{
        display:inline-flex !important;
        align-items:center !important;
        justify-content:center !important;
        width:36px !important;
        height:36px !important;
        margin:0 !important;
        padding:0 !important;
    }

    nav.nav-container .hamburger i{
        font-size:20px !important;
    }

    nav.nav-container .desktop-menu{
        position:absolute !important;
        top:72px !important;
        right:12px !important;
        left:auto !important;
        width:min(270px, calc(100vw - 24px)) !important;
        max-width:calc(100vw - 24px) !important;
        background:#ffffff !important;
        border-radius:12px !important;
        padding:12px 14px !important;
        box-shadow:0 12px 30px rgba(0,0,0,.16) !important;
        display:none !important;
        flex-direction:column !important;
        align-items:stretch !important;
        gap:0 !important;
        z-index:3000 !important;
    }

    nav.nav-container .desktop-menu.active{
        display:flex !important;
    }

    nav.nav-container .desktop-menu a{
        display:block !important;
        width:100% !important;
        padding:10px 0 !important;
        text-align:left !important;
        border-bottom:1px solid #edf2f7 !important;
    }

    nav.nav-container .desktop-menu a:last-child{
        border-bottom:none !important;
    }

    nav.nav-container .desktop-menu .mobile-cta{
        display:inline-flex !important;
        justify-content:center !important;
        align-items:center !important;
        margin-top:10px !important;
        padding:12px 14px !important;
        background:linear-gradient(135deg,#e67e22,#d35400) !important;
        color:#ffffff !important;
        border-radius:10px !important;
        border-bottom:none !important;
    }

    nav.nav-container .lang-options{
        position:absolute !important;
        top:calc(100% + 8px) !important;
        right:0 !important;
        left:auto !important;
        min-width:90px !important;
        background:#ffffff !important;
        border-radius:10px !important;
        box-shadow:0 12px 24px rgba(0,0,0,.14) !important;
        padding:6px 0 !important;
        z-index:3100 !important;
    }

    .swiper,
    .seo-intro,
    .features,
    .apartments,
    .content-section,
    .mapa,
    .map-section,
    .bottom-cta,
    .page-section{
        width:100% !important;
        max-width:100% !important;
        margin-left:0 !important;
        margin-right:0 !important;
        box-sizing:border-box !important;
    }

    .swiper{
        margin-top:72px !important;
        height:44vh !important;
        min-height:300px !important;
    }

    .hero-content{
        width:100% !important;
        max-width:100% !important;
        padding:0 16px !important;
        left:50% !important;
        transform:translate(-50%, -50%) !important;
        box-sizing:border-box !important;
    }

    .container{
        width:100% !important;
        max-width:100% !important;
        margin:0 auto !important;
        padding:0 16px !important;
        box-sizing:border-box !important;
    }

    .seo-box,
    .content-box,
    .hero-card,
    .bottom-cta-box,
    .apartment-card{
        width:100% !important;
        max-width:100% !important;
        box-sizing:border-box !important;
    }

    .apartments-grid,
    .apartment-grid{
        grid-template-columns:1fr !important;
        gap:20px !important;
    }

    .whatsapp-float{
        bottom:18px !important;
        right:14px !important;
    }

    body{
        padding-bottom:0 !important;
    }
}

@media (max-width: 480px){
    nav.nav-container{
        padding:9px 10px !important;
        min-height:66px !important;
    }

    nav.nav-container .logo{
        max-width:130px !important;
    }

    nav.nav-container .logo img{
        max-width:130px !important;
        height:32px !important;
    }

    nav.nav-container .lang-btn{
        min-height:34px !important;
        padding:6px 8px !important;
        font-size:0.76rem !important;
    }

    nav.nav-container .hamburger{
        width:34px !important;
        height:34px !important;
    }

    nav.nav-container .desktop-menu{
        top:66px !important;
        right:10px !important;
        width:min(255px, calc(100vw - 20px)) !important;
        max-width:calc(100vw - 20px) !important;
    }

    .swiper{
        margin-top:66px !important;
        min-height:260px !important;
    }
}