:root{
    --bg: #ffffff;
    --text: #000000;
    --primary: #3B5998;
    --accent: #006600;
    --accent-2: #007a4d;
    --accent-2-dark: #005c39;
    --muted: #666666;
    --muted-light: #f9f9f9;
    --border-color: #ddd;
    --card-bg: #ffffff;
    --radius: 8px;
    --shadow: 0 4px 8px rgba(0,0,0,0.1);
}

html, body {
    background: linear-gradient(160deg, #f8fbff 0%, #eef6fe 50%, #e6f2fc 100%);
    background-attachment: fixed;
    margin: 0 auto;
    font-family: system-ui, -apple-system, sans-serif;
    color: var(--text);
    width: 100%;
}

/* Headings */
h1, h2, h3, h4, h5, h6 { color: #375494; font-family: Verdana, Geneva, sans-serif }
h1 { font-size: 15px }
h2 { font-size: 14px }
h3 { font-size: 13px }
h4 { font-size: 12px }
h5 { font-size: 11px }
h6 { font-size: 10px }
.mainh1 { font-size:12px; color: var(--muted); text-align:center }
.article h1 { font-size:24px }
.article h1.listing-title { font-size:13px }
.article h3 { font-size:17px }
.article h4 { font-size:15px; color:var(--accent) }

p, ol, ul, li { text-align:left; margin-top:0; font-size:1em }
strong { font-weight:700 }

a { color:#060; text-decoration:none }
a:hover { text-decoration:none; color:#2582A4 }
p a, [itemprop="description"] a { text-decoration:underline }
[itemprop="description"] { font-size:15px }

h1.main-page { color:var(--accent); font-size: 14px; }
.container .main-content strong { color:var(--primary) }
/* Header & Menu */
#header { max-width:980px; width:100%; margin:0 auto; background:rgba(73,108,190,.70); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); border-bottom:none; box-shadow:0 2px 12px rgba(0,0,50,.15); border-radius:0 0 10px 10px; position:relative; z-index:100; box-sizing:border-box; }
#header-inner { max-width:980px; margin:0 auto; display:flex; align-items:center; padding:8px 16px; gap:16px; }
#header-logo { display:flex; align-items:center; gap:9px; text-decoration:none; flex-shrink:0; }
#header-logo img { border-radius:3px; }
#header-logo-text { font-size:14px; font-weight:800; color:#fff; letter-spacing:.3px; font-family:Verdana,sans-serif; }
#header-logo-text span { color:rgba(255,255,255,.75); }
#menuelements { display:flex; list-style:none; margin:0; padding:0 0 0 20px; gap:0; flex:1; justify-content:center; width:auto; height:auto; }
#menuelements > li { display:inline-flex; align-items:center; }
#menuelements > li + li { border-left:1px solid rgba(255,255,255,.22); margin-left:2px; padding-left:2px; }
#menuelements a { display:inline-block; padding:6px 10px; color:rgba(255,255,255,.92); font-size:12px; font-weight:600; font-family:system-ui,sans-serif; border-radius:6px; height:auto; float:none; text-transform:none; transition:background .12s, color .12s; }
#menuelements a:hover { background:rgba(255,255,255,.18); color:#fff; text-decoration:none; }
@media (max-width:954px) { #header { display:none; } }
@media screen and (min-width:955px) and (max-width:1039px) { #menuelements a { padding:6px 7px; font-size:11px; } }
@media screen and (min-width:955px) and (max-width:1039px) { .site-hero { margin-top:15px; } }

#content { width:980px; margin-left:auto; margin-right:auto; }
#colOne { float:left; width:230px }
#colTwo { float:right; width:735px; padding:0 0 5px 0; background-repeat:repeat-y }
#logo { display:none; }


#footer { clear:both; width:100%; margin:0; padding:5px 0; box-sizing:border-box;
    background:url(images/FooterOverlay.webp) center/cover no-repeat;
    position:relative; }
#footer::before { content:''; position:absolute; inset:0;
    background:rgba(54,110,121,.72); }
#footer p { position:relative; margin:0; text-align:center; color:rgba(255,255,255,.88); font-weight:400; font-size:13px; padding:2px 0; }
#footer a { position:relative; color:rgba(255,255,255,.9); }
#footer a:hover { color:#fff; }

#sticker { background:#fff; color:var(--primary); width:206px; font-size:12px; font-weight:700; font-family:system-ui,sans-serif; text-align:center; padding:12px; margin:0 auto 10px; border:1px solid #e2e8f0; border-radius:10px; box-shadow:0 2px 8px rgba(0,0,0,.07); position:sticky; top:10px; }
#sticker p { text-align:center; margin:0; line-height:1.7; }
#sticker a { color:#007a4d; font-weight:700; }

select { color:var(--muted); font-size:10px }


.blog, .main-content { padding:5px 0 5px 17px; border-radius:15px; box-shadow:var(--shadow); background:var(--card-bg); margin:5px; transition:transform 0.3s }
.blog { padding-right:3px }
.horgaszat { padding:20px; background:var(--muted-light); border-radius:10px; box-shadow:var(--shadow) }
img { border-radius:5px }

.header { width:100%; text-align:center; padding:20px; background-color:var(--muted-light); border-bottom:1px solid var(--border-color) }

.listing-row { display:flex; justify-content:center; width:100%; gap:12px; }
.listing-card { box-shadow:0 2px 12px rgba(0,0,0,.12); transition:transform .2s,box-shadow .2s; width:30%; box-sizing:border-box; display:flex; flex-direction:column; background:#fff; border-radius:12px; overflow:hidden; border:1px solid #e5e7eb; }
.listing-card:hover { transform:translateY(-3px); box-shadow:0 8px 24px rgba(0,0,0,.16); }
.listing-card a { text-decoration:none; font-size:12px; color:#060; display:block; text-align:center }
.image-container { height:160px; overflow:hidden; display:flex; align-items:center; justify-content:center }
.listing-card img { max-width:100%; height:100%; object-fit:cover; border-radius:0; }
.listing-card strong { padding:8px 10px 4px; display:block; text-align:center; min-height:38px; font-size:11px; font-weight:600; color:#007a4d; }

/* ─── Full-width site hero (home page, above columns) ───────────────────── */
.site-hero { width:100%; max-width:1176px; margin-top:-52px; margin-left:auto; margin-right:auto; padding:0; display:block; position:relative; z-index:1; overflow:visible; border-radius:16px; }
/* On home page, hide the in-column hero-container (we render it full-width via .site-hero) */
.page-home #colTwo .hero-container { display:none; }
.site-hero .hero-container { width:1176px; max-width:100%; height:200px; border-radius:0; margin-bottom:0; overflow:visible; }
.site-hero .heroimage { width:100%; height:100%; object-fit:cover; display:block; border-radius:16px; }
/* Subpage hero is shorter; home page overrides to full height */
.site-hero .heroimage { height:100%; }

.site-hero .hero-overlay {
    position:absolute;
    top:calc(50% + 10px);
    left:50%;
    transform:translate(-50%,-50%);
    width:auto;
    max-width:min(360px,85vw);
    max-height:45px;
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    background:rgba(52, 216, 177, 0.35);
    backdrop-filter:blur(3px) saturate(0.2);
    -webkit-backdrop-filter:blur(1px) saturate(0.2);
    border:1px solid rgba(255,255,255,.15);
    border-radius:12px;
    padding:8px 10px 8px;
    text-align:center;
    box-shadow:0 4px 20px rgba(0,0,0,.08), inset 0 1px 0 rgba(255,255,255,.10);
}
.site-hero .hero-overlay h2 { color:#fff; margin:0; font-size:12px; font-weight:800; text-shadow:0 1px 4px rgba(0,0,0,.45); white-space:normal; }
.site-hero .hero-overlay p { color:rgba(255,255,255,.80); margin:4px 0 0; font-size:12px; text-shadow:0 1px 3px rgba(0,0,0,.35); white-space:normal; }

/* ─── Hero ───────────────────────────────────────────────────────────────── */
.hero-container { position:relative; width:100%; border-radius:12px; overflow:hidden; margin-bottom:12px; display:block; }
.heroimage { width:100%; height:auto; display:block; border-radius:0; }
.hero-overlay { position:absolute; bottom:0; left:0; right:0; background:linear-gradient(to top,rgba(15,40,100,.7) 0%,rgba(26,63,159,.35) 60%,transparent 100%); padding:24px 20px 16px; text-align:center; text-decoration:none; cursor:pointer; }
.hero-overlay h1, .hero-overlay h2 { color:#fff; margin:0; text-shadow:0 2px 6px rgba(0,0,0,.4); }
.hero-overlay h1 { font-size:12px; font-weight:800; }
.hero-overlay p { color:rgba(255,255,255,.9); margin:5px 0 0; font-size:13px; }
/* ─── Hide sidebar "Szállás kereső" on search/amenity pages ─────────────── */
.page-search #colOne-inner > section { display:none; }
.page-search #colOne-inner { display:none; }

/* ─── Layout boxes ───────────────────────────────────────────────────────── */
#colOne-inner { background:#fff; border-radius:12px; box-shadow:0 2px 10px rgba(0,0,0,.09); overflow:hidden; margin-bottom:12px; }
#content { padding-top:12px; position:relative; z-index:10; }
.page-home #content { padding-top:0; margin-top:-25px; }
/* White content background for specific pages */
.page-horgaszat-a-koroson #colTwo .one,
.page-horgaszat-a-koroson #colTwo .article { background:#fff; }
.one { background:#fff; border-radius:12px; box-shadow:0 2px 10px rgba(0,0,0,.07); padding:14px 16px; margin-bottom:12px; }

/* ─── SEO filter nav: light colored glass tiles ──────────────────────────── */
nav[aria-label^="Szűrés"] a {
    backdrop-filter:blur(4px) !important;
    -webkit-backdrop-filter:blur(4px) !important;
    border-radius:6px !important;
    border:1px solid rgba(255,255,255,.45) !important;
    transition:background .15s, transform .15s, box-shadow .15s !important;
    font-size:9px !important; font-weight:600 !important;
    text-align:center !important; text-decoration:none !important;
    display:flex !important; flex-direction:column !important;
    align-items:center !important; gap:2px !important;
    padding:5px 3px !important; line-height:1.2 !important;
}
nav[aria-label^="Szűrés"] a span[style*="font-size:16px"] { font-size:13px !important; line-height:1 !important; }
nav[aria-label^="Szűrés"] a:nth-child(1) { background:rgba(96,165,250,.14) !important; color:#1e3a5f !important; }
nav[aria-label^="Szűrés"] a:nth-child(1):hover { background:rgba(96,165,250,.38) !important; transform:translateY(-1px) !important; }
nav[aria-label^="Szűrés"] a:nth-child(2) { background:rgba(252,165,165,.14) !important; color:#5f1e1e !important; }
nav[aria-label^="Szűrés"] a:nth-child(2):hover { background:rgba(252,165,165,.38) !important; transform:translateY(-1px) !important; }
nav[aria-label^="Szűrés"] a:nth-child(3) { background:rgba(251,191,36,.12) !important; color:#4a3a00 !important; }
nav[aria-label^="Szűrés"] a:nth-child(3):hover { background:rgba(251,191,36,.34) !important; transform:translateY(-1px) !important; }
nav[aria-label^="Szűrés"] a:nth-child(4) { background:rgba(134,239,172,.14) !important; color:#1a4a2a !important; }
nav[aria-label^="Szűrés"] a:nth-child(4):hover { background:rgba(134,239,172,.38) !important; transform:translateY(-1px) !important; }
nav[aria-label^="Szűrés"] a:nth-child(5) { background:rgba(196,167,124,.14) !important; color:#4a2a0a !important; }
nav[aria-label^="Szűrés"] a:nth-child(5):hover { background:rgba(196,167,124,.38) !important; transform:translateY(-1px) !important; }
nav[aria-label^="Szűrés"] a:nth-child(6) { background:rgba(167,139,250,.14) !important; color:#3a1a5a !important; }
nav[aria-label^="Szűrés"] a:nth-child(6):hover { background:rgba(167,139,250,.38) !important; transform:translateY(-1px) !important; }
nav[aria-label^="Szűrés"] a:nth-child(7) { background:rgba(38,119,115,.12) !important; color:#0a3a38 !important; }
nav[aria-label^="Szűrés"] a:nth-child(7):hover { background:rgba(38,119,115,.34) !important; transform:translateY(-1px) !important; }
nav[aria-label^="Szűrés"] a:nth-child(8) { background:rgba(56,189,248,.12) !important; color:#0a2a4a !important; }
nav[aria-label^="Szűrés"] a:nth-child(8):hover { background:rgba(56,189,248,.34) !important; transform:translateY(-1px) !important; }
nav[aria-label^="Szűrés"] a:last-child {
    background:rgba(38,119,115,1) !important; color:#fff !important;
    border-color:rgba(38,119,115,.6) !important;
    flex-direction:row !important; gap:5px !important;
    padding:5px 10px !important; justify-content:center !important;
    font-size:10px !important; font-weight: 600; white-space:nowrap !important;
}
nav[aria-label^="Szűrés"] a:last-child:hover { background:rgba(38,119,115,.5) !important; transform:translateY(-1px) !important; }

/* ─── Blog links ─────────────────────────────────────────────────────────── */
.blog div[itemscope] {
    display:flex;
    flex-direction:column;
    row-gap:2px;
    padding:8px 0;
    border-bottom:1px solid #e8f0f8;
}
.blog div[itemscope] > a { font-weight:700; font-size:13px; color:#1a3f9f; }
.blog div[itemscope] > p { color:#555; margin:0; line-height:1.45; }

.mobile-search-form { display:none; position:absolute; left:50%; transform:translateX(-50%); top:50px; width:92%; max-width:92%; background:rgba(255,255,255,.95); padding:8px; border-radius:8px; box-shadow:0 2px 6px rgba(0,0,0,.08); font-size:11px; overflow:visible; }

.form-group { display:flex; flex-direction:column; gap:1px; margin-bottom:6px }
.form-group label { font-weight:500; color:#333; font-size:11px }
.form-group input, .form-group textarea, .form-group select { padding:3px; border:1px solid var(--border-color); border-radius:3px; font-size:11px }
.form-group textarea { min-height:50px; resize:vertical }
.form-group input[type="range"] { width:100%; accent-color:var(--primary); height:4px }
.checkbox-group { overflow-y:auto; border:1px solid #eee; padding:3px; border-radius:3px; display:grid; grid-template-columns:1fr 1fr; gap:2px }
.checkbox-item { display:flex; align-items:center; gap:2px; margin:1px 0; min-height:32px }
.submit-btn { background:var(--primary); color:white; border:none; padding:4px 10px; border-radius:3px; cursor:pointer; width:80px; font-size:12px; transition:background-color .2s }
.submit-btn:hover { background:var(--muted) }

.bottom-container { display:flex; flex-direction:row; align-items:center; gap:10px; margin-top:6px }
.slider-container { padding:4px; background:var(--muted-light); border-radius:5px; border:1px solid var(--border-color); margin-right:10px; flex:1 }
.slider-label { display:block; margin-bottom:5px; font-size:11px; color:#333 }

.image-container img { width:100%; height:100%; object-fit:cover }

/* ── Property card: C1-style compact, site colors, loc badge on image ─────── */
.property-card { box-shadow:0 2px 10px rgba(0,0,0,.1); transition:.22s; width:32%; margin:4px; box-sizing:border-box; display:flex; flex-direction:column; background:var(--bg,#fff); border-radius:10px; overflow:hidden }
.property-card:hover { transform:translateY(-2px); box-shadow:0 6px 18px rgba(0,0,0,.16) }
.pc4-img-box { position:relative; height:175px; overflow:hidden; background:#b8d0e8 }
.pc4-img-link { display:block; text-decoration:none }
.pc4-img-box img { width:100%; height:175px; object-fit:cover; display:block }
.pc4-loc-badge { position:absolute; bottom:8px; right:8px; background:rgba(59,89,152,0.5); color:#fff; font-size:10px; font-weight:700; padding:3px 9px; border-radius:20px; line-height:1.4; white-space:nowrap }
.pc4-body { padding:8px 10px 10px; display:flex; flex-direction:column; gap:6px; flex:1 }
.pc4-title { font-size:10px; font-weight:700; line-height:1.35; margin:0; height:40px; overflow:hidden }
.pc4-title a { color:#3B5998; text-decoration:none }
.pc4-title a:hover { text-decoration:underline }
.pc4-stats { display:flex; gap:0; border:1px solid var(--border-color,#ddd); border-radius:7px; overflow:hidden }
.pc4-stat { flex:1; display:flex; flex-direction:column; align-items:center; padding:5px 4px; border-right:1px solid var(--border-color,#ddd); background:#fafafa }
.pc4-stat:last-child { border-right:none }
.pc4-n { font-size:1.05rem; font-weight:800; color:var(--primary,#3B5998); line-height:1 }
.pc4-l { font-size:9px; color:var(--muted,#666); margin-top:2px; text-align:center; text-transform:uppercase; letter-spacing:.03em }
.pc4-tags { display:flex; flex-wrap:wrap; gap:3px; min-height:20px; list-style:none; margin:0; padding:0 }
.pc4-tag { font-size:10px; padding:2px 7px; border-radius:10px; background:#e8f8f0; color:#006600; font-weight:600 }
.pc4-tag.szep { background:#eef1fb; color:var(--primary,#3B5998) }
.pc4-footer { display:flex; align-items:center; justify-content:space-between; border-top:1px solid var(--border-color,#ddd); padding-top:7px; margin-top:auto }
.pc4-footer .nyaralo-link { margin:0; padding:5px 12px }
.pc4-price { font-weight:800; color:var(--primary); font-size:13px }
.pc4-price small { font-size:10px; color:var(--muted,#666); font-weight:400; margin-left:2px }

.nyaralo-link { display:inline-block; padding:4px 8px; margin:8px; color:#fff; background-color:var(--primary); text-align:center; text-decoration:none; border:none; border-radius:4px; font-size:12px; line-height:18px; transition:transform .2s ease; cursor:pointer }
.nyaralo-link:hover { background-color:var(--button-bg-dark, #2D4373); transform:translateY(-2px) }

.holtag-nav { display:flex; flex-wrap:wrap; gap:6px 10px; justify-content:center; align-items:center; padding:14px 20px; background:var(--muted-light); border-radius:10px; box-shadow:var(--shadow) }
.holtag-sep { margin-top:40px; padding-top:32px; border-top:2px solid #ddd }
.holtag-sep h2 { margin-top:4px }
.holtag-stats { display:inline-block; background:#eef3fb; padding:5px 14px; border-radius:6px; font-size:0.88em; margin:6px 0 }
.holtag-fish { display:block; background:#f0f8ee; border-left:3px solid #6aad6a; padding:6px 14px; border-radius:0 6px 6px 0; font-size:0.88em; margin:6px 0 }
.holtag-link, .centered-container a { color:var(--primary); text-decoration:none; margin:0 10px; font-size:16px; min-width:fit-content; white-space:nowrap }
.holtag-table { border-collapse:collapse; width:100%; max-width:800px; margin:20px auto; font-family:system-ui; box-shadow:0 1px 3px rgba(0,0,0,0.1) }
.holtag-table th, .holtag-table td { padding:8px; text-align:left; border:1px solid var(--border-color); font-size:0.7em }
.holtag-table th { background:var(--primary); color:#fff }
.holtag-table tr:nth-child(even) { background:#f7fafc }
.holtag-table a { color:var(--primary); text-decoration:none }
.holtag-header { background:linear-gradient(to right,#f8f9fa,#e9ecef); border-left:5px solid var(--primary); padding:15px; margin:20px 0; border-radius:5px; box-shadow:0 2px 4px rgba(0,0,0,0.1) }
.holtag-info { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:10px; margin-top:10px }
.info-item { padding:5px; font-size:0.9em }
.fish-species { margin-top:10px; padding:8px; background:#f1f8ff; border-radius:4px; font-size:0.9em }
.info-text { margin-top:10px; line-height:1.65 }
.info-list { margin:8px 0 14px 22px; line-height:1.75; font-size:0.95em }
.info-list li { margin-bottom:3px }
.centered-container { text-align:center; padding:20px; background:var(--muted-light); border-radius:10px; box-shadow:var(--shadow) }
.table-container { overflow-x:auto }

.filters { background:rgba(255,255,255,.88); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); padding:12px; border-radius:10px; box-shadow:0 2px 10px rgba(73,108,190,.10); border:1px solid rgba(199,216,240,.5); margin-bottom:12px }
.filter-section { margin-bottom:10px; display:flex; align-items:center; gap:10px }
label, .label { color:#375494; font-size:12px; min-width:100px }
/* Sort controls glass style */
.sort-button { background:#3a5fa8 !important; backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px); border:1px solid rgba(255,255,255,.3) !important; color:#fff !important; border-radius:6px !important; font-size:11px; padding:5px 10px; box-shadow:0 2px 6px rgba(58,95,168,.25); }
.sort-button:hover { background:#2d4f94 !important; transform:translateY(-1px); }
/* ── Concept 8: features-container – stats header + amenity badge row ──────── */
.features-container { width:100%; margin:0 0 16px; border-radius:8px; overflow:hidden; border:1px solid var(--border-color,#ddd); box-shadow:0 2px 6px rgba(0,0,0,.08) }
.fc8-stats { display:flex; background:#fff }
.fc8-stat { flex:1; display:flex; flex-direction:column; align-items:center; padding:10px 6px; border-right:1px solid var(--border-color,#ddd) }
.fc8-stat:last-child { border-right:none }
.fc8-n { font-size:1.4rem; font-weight:800; color:var(--primary,#3B5998); line-height:1 }
.fc8-l { font-size:9px; color:var(--muted,#666); margin-top:4px; text-align:center; text-transform:uppercase; letter-spacing:.04em }
.fc8-amenities { display:flex; flex-wrap:wrap; gap:5px; padding:8px 10px; background:#f9f9f9; border-top:1px solid var(--border-color,#ddd); list-style:none; margin:0 }
.fc8-am { font-size:11px; padding:3px 10px; border-radius:20px; font-weight:600 }
.fc8-am.yes { background:rgba(0,118,70,.22); backdrop-filter:blur(8px) saturate(1.6); -webkit-backdrop-filter:blur(8px) saturate(1.6); border:1px solid rgba(0,180,100,.35); color:#0a4a28; box-shadow:0 2px 8px rgba(0,102,0,.12), inset 0 1px 0 rgba(255,255,255,.35); text-shadow:0 1px 1px rgba(255,255,255,.5); }
.fc8-am.no { background:#eee; color:#666; text-decoration:line-through }
.fc8-am.szep { background:var(--primary,#3B5998); color:#fff }

.slider-container { align-items:center; gap:3px; width:100%; max-width:400px }
.slider-container label { flex:0 0 100px; font-size:12px }
input[type="range"] { flex:1; width:100% }
.slider-container span { flex:0 0 20px; font-size:12px }
.rental-row { display:flex; overflow:hidden; flex-wrap:wrap }
.rental-row p { font-size:0.8em; margin-top:2px }
.sort-button { background:var(--primary); border:1px solid var(--border-color); padding:4px 8px; border-radius:3px; cursor:pointer; margin-right:8px; color:white; font-size:12px; margin-bottom:10px }
.sort-button:hover { transform:translateY(-1px); box-shadow:0 4px 6px rgba(0,0,0,0.15); background:#2d4a8a !important }
.sort-meta { display:inline }
details.checkbox-dropdown { position:relative; display:inline-block; width:100% }
.filter-section.locations { justify-content:flex-start }
summary.dropdown-button { list-style:none; border:1px solid var(--border-color); padding:4px 8px; cursor:pointer; font-size:12px; color:var(--accent); border-radius:5px; display:inline-block }
button.dropdown-button { border:1px solid var(--border-color,#ddd); padding:6px 8px; cursor:pointer; font-size:10px; color:#375494; border-radius:5px; background:#fff; width:100%; box-sizing:border-box; text-align:left; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
summary.dropdown-button::-webkit-details-marker { display:none }
summary.dropdown-button::after { content:' ▼'; font-size:10px }
details[open] > summary.dropdown-button::after { content:' ▲' }
summary.dropdown-button:hover { background:var(--muted-light) }
.desktop_search-form { width:206px; margin:0 auto 12px; padding:0; border:1px solid #ccddf5; border-radius:10px; background:#fff; font-family:system-ui,sans-serif; box-shadow:0 4px 16px rgba(30,70,180,.18); overflow:hidden; }
.dsf-heading { font-size:12px; font-weight:800; color:#1a3f9f; background:transparent; margin:0; padding:6px 8px 4px; font-family:Verdana,sans-serif; }
.desktop_form-group { padding:10px 12px 0; margin-bottom:0; }
.desktop_form-group p { font-size:12px; margin-top:2px; color:var(--primary) }
.dsf-date-group { margin-bottom:8px; }
.dsf-label { display:block; font-size:11px; font-weight:600; color:#475569; margin-bottom:3px; min-width:unset; }
.dsf-sublabel { font-size:11px; font-weight:700; color:#475569; margin:0 0 5px; letter-spacing:.04em; }
.desktop_checkbox-group { display:grid; grid-template-columns:1fr 1fr; gap:1px; }
.desktop_checkbox-item { margin-bottom:0; min-height:28px; display:flex; align-items:center; }
.desktop_checkbox-item label { font-size:11px; color:#334155; font-weight:500; cursor:pointer; display:flex; align-items:center; gap:4px; min-width:unset; }
.desktop_checkbox-item input[type="checkbox"] { accent-color:#007a4d; width:13px; height:13px; }
.desktop_bottom-container { padding:8px 12px 12px; justify-content:space-between; align-items:center; }
.desktop_slider-container { width:100%; margin-bottom:8px; }
.slider-label { font-size:11px; color:#475569; display:block; margin-bottom:4px; }
.desktop_slider-container input[type="range"] { width:100%; height:4px; cursor:pointer; accent-color:#007a4d; }
.desktop_submit-btn { padding:5px 8px; min-height:0; width:100%; background:#3a5fa8; backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); border:1px solid rgba(255,255,255,.35); border-radius:8px; color:#fff; cursor:pointer; display:block; font-size:12px; font-weight:700; transition:background .15s, box-shadow .15s; box-shadow:0 2px 10px rgba(58,95,168,.35), inset 0 1px 0 rgba(255,255,255,.2); text-shadow:0 1px 2px rgba(0,0,0,.2); }
.desktop_submit-btn:hover { background:#2d4f94; box-shadow:0 4px 16px rgba(58,95,168,.45), inset 0 1px 0 rgba(255,255,255,.3); }
.page-search .desktop_search-form { display:none }

/* Listing page layout */
.listing-layout { display:flex; gap:12px; align-items:flex-start }
.listing-gallery-sidebar { width:140px; flex-shrink:0; display:flex; flex-direction:column; gap:6px }
.listing-gallery-sidebar a { display:block }
.listing-gallery-sidebar a img { width:100%; height:90px; object-fit:cover; border-radius:5px; display:block }
.listing-gallery-sidebar .img-caption { font-size:11px; color:#666; margin:2px 0 4px; text-align:center }
.listing-right-col { flex:1; min-width:0; display:flex; flex-direction:column; gap:12px }
.listing-hero img { width:100%; height:auto; max-height:480px; object-fit:cover; border-radius:8px; display:block }
.listing-hero .img-caption { font-size:12px; color:#666; margin:4px 0; text-align:center }
.listing-main-col { width:100% }
.listing-main-col .features-container { margin-top:0 }
.listing-title-row {
    display:flex;
    align-items:baseline;
    gap:0.5rem;
    margin:0 0 6px;
}
.listing-title {
    font-size:clamp(1.8rem,2.8vw,2.4rem);
    line-height:1.15;
    margin:0;
    font-weight:800;
}
.listing-address {
    display:flex;
    align-items:baseline;
    gap:0.4rem;
    margin:0 0 14px;
    font-style:normal;
}
.listing-subtitle {
    font-size:12px;
    font-weight:600;
    color:#475569;
}
.listing-title::after { content:' |'; color:#94a3b8; font-weight:400; font-size:1rem }
.listing-location { font-size:12px; font-weight:600; color:#475569 }
.listing-location:empty ~ .listing-subtitle::before { content:'' }
.listing-subtitle:empty { display:none }
.listing-capacity-msg {
    display:none;
    font-size:12px;
    color:#c0392b;
    margin:4px 0 0;
    padding:4px 8px;
    background:#ffeaea;
    border-radius:4px;
    border-left:3px solid #e74c3c;
}
.listing-booking-note {
    margin:10px 0 0;
    font-size:14px;
    color:#3b5998;
    font-style:italic;
}

/* Ensure contact links meet minimum mobile touch target size */
.kapcsolat-section a[href^="tel:"],
.kapcsolat-section a[href^="mailto:"],
.listing-kapcsolat a[href^="tel:"],
.listing-kapcsolat a[href^="mailto:"] {
    display:block;
    min-height:20px;
    line-height:1.25;
    margin-top:5px;
}

@media (max-width: 768px) {
    .kapcsolat-section a[href^="tel:"],
    .kapcsolat-section a[href^="mailto:"],
    .listing-kapcsolat a[href^="tel:"],
    .listing-kapcsolat a[href^="mailto:"] {
        width:100%;
    }
}

/* Featured listings section */
.featured-section { margin:5px 0 10px }
.featured-section > h2 { margin-bottom:10px }
.featured-section .rental-row { display:flex; flex-wrap:wrap; gap:10px; justify-content:flex-start }

/* Responsive Styles */
@media (max-width: 480px) {
    .filter-section { align-items:flex-start }
    .label label { font-size:13px }
    .sort-button { font-size:11px; padding:3px 6px }
}
@media (max-width: 600px) {
    .holtag-table th, .holtag-table td { padding:4px 5px; font-size:0.62em }
    .rental-row { flex-direction:column; align-items:stretch }
    .listing-row { gap:4px }
    .listing-card { width:calc(33.333% - 4px); margin:0 }
    .image-container { height:auto; aspect-ratio:4/3 }
    .seo-icon-grid { grid-template-columns:repeat(2, 1fr) }

}
@media (max-width: 954px) {
    .site-hero { margin-top:0; }
    #header { width:100%; border-radius:0; background:rgba(73,108,190,.90); }
    #content { margin-top:0; padding-top:8px; }
    .listing-card { width:32%; margin:2px }
    .property-card { width:100% }
    .listing-gallery-sidebar { display:none }
    .listing-title-row { flex-wrap:wrap }
    .listing-title { width:100% }
    .rental-row { flex-wrap:wrap }
.sort-controls { flex-direction:row; align-items:center; flex-wrap:nowrap }
    .sort-button { width:auto; margin-bottom:0 }
    .sort-button .sort-meta { display:block }
    .slider-container label { flex:0 0 80px }
    label { min-width:80px }
    .fc8-n { font-size:1.1rem }
    .fc8-l { font-size:8px }
    .filters label, .filters .label { color: #000 }
    .pc4-title { font-size:13px; height:auto; min-height:38px }
}
@media (min-width:769px) and (max-width:1040px) {
    #colOne { display:none }
}
@media screen and (min-width:1040px) {
    #logo { display:none }
    #content { width:980px; margin-left:auto; margin-right:auto; }
    #colTwo { float:right; width:735px; padding:0 0 10px 0; background-repeat:repeat-y }
    #colOne { float:left; width:230px }
    .container { display:flex }
    .main-content { width:50%; padding-right:20px }
    .blog { width:50% }
    #sticker a { color:#007a4d; text-decoration:none; display:block; padding:3px 0; }
}
@media screen and (max-width:1039px) {
    #footer { padding:14px 10px; }
    .hero-container { display:flex; flex-direction:column; align-items:center; position:relative; width:100%; height:auto; overflow:visible }
    .heroimage { width:100%; object-fit:cover }
    .site-hero .heroimage { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
    .mobile-search-form { display:block !important; position:relative; left:auto; top:auto; transform:none; margin:-3px auto 0 }
    .site-hero .mobile-search-form { display:block !important; z-index:50; background:rgba(255,255,255,.12); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); border-radius:12px; padding:8px; border:1px solid rgba(255,255,255,.25); box-shadow:0 4px 16px rgba(0,0,0,.15); overflow:visible; }
    #colOne { display:none }
    #content { width:100% }
    #colTwo { width:100% }
    .one { margin-top:0; margin-left:5px; margin-right:5px; padding-top:0 }
}

/* ─── Tablet hero (769–1039px): wide desktop image, form overlaid ────────── */
@media screen and (min-width:769px) and (max-width:1039px) {
    .site-hero { max-width:100%; }
    .site-hero .hero-container { width:100%; max-width:100%; height:200px; justify-content:center; gap:0; padding:0; }
    .site-hero .mobile-search-form { position:absolute !important; bottom:10px; left:50%; transform:translateX(-50%) !important; top:auto; width:65%; max-width:580px; margin:0; }
    .page-home .site-hero .hero-container { height:200px; }
    .page-home .site-hero .heroimage { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
    .page-home .site-hero .hero-overlay { position:absolute; top:auto; bottom:130px; left:50%; transform:translateX(-50%); width:65%; max-width:580px; min-height:auto; max-height:none; padding:6px 14px; z-index:1; overflow:visible; }
    .page-home .site-hero .mobile-search-form { position:absolute !important; bottom:50px; left:50%; transform:translateX(-50%) !important; top:auto; width:65%; max-width:580px; margin:0; z-index:1; }
}

/* ─── Mobile hero (≤768px): 390px narrow layout ─────────────────────────── */
@media screen and (max-width:768px) {
    .site-hero { max-width:390px; }
    .site-hero .hero-container { width:390px; max-width:100%; height:280px; justify-content:center; gap:8px; padding:0; }
    .site-hero .mobile-search-form { position:relative !important; left:auto; bottom:auto; transform:none !important; width:82%; max-width:82%; margin:0 auto; }
    .page-home .site-hero .hero-container { width:390px; max-width:100%; height:220px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px; padding:0; }
    .page-home .site-hero .heroimage { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
    .page-home .site-hero .hero-overlay { position:relative; top:auto; left:auto; transform:none; min-height:auto; max-height:80px; width:82%; max-width:82%; margin-top:0; padding:6px 10px 8px; z-index:1; overflow:hidden; }
    .page-home .site-hero .mobile-search-form { position:relative !important; top:auto; bottom:auto; left:auto; transform:none !important; width:82%; max-width:82%; margin:0 auto; z-index:1; overflow:visible; }
}

/* ─── Mobile search form submit button ──────────────────────────────────── */
.msf-submit-btn { display:block; width:30%; margin:0 auto; padding:2px; background:#007849; border:1px solid rgba(255,255,255,.4); border-radius:8px; color:#fff; font-size:13px; font-weight:700; cursor:pointer; box-shadow:0 2px 10px rgba(0,120,73,.3),inset 0 1px 0 rgba(255,255,255,.2); text-shadow:0 1px 2px rgba(0,0,0,.2); }

/* ─── Popup Form ─────────────────────────────────────────────────────────── */
.open-button { background:#007849; color:#fff; padding:11px 16px; border:1px solid rgba(255,255,255,.35); cursor:pointer; position:fixed; bottom:30px; right:30px; width:auto; border-radius:22px; font-family:system-ui,-apple-system,sans-serif; font-size:13px; font-weight:600; transition:background .2s, transform .2s, box-shadow .2s; box-shadow:0 4px 18px rgba(0,120,73,.35), inset 0 1px 0 rgba(255,255,255,.25); line-height:1.2; outline:none !important; z-index:999; text-shadow:0 1px 2px rgba(0,0,0,.2); }
.open-button:hover { background:#005f3c; transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,95,60,.4), inset 0 1px 0 rgba(255,255,255,.3); color:#fff !important }
.open-button:active { transform:translateY(0); color:#fff !important }
dialog.form-popup { display:none; position:fixed; bottom:0; right:15px; top:auto; left:auto; margin:0; border:3px solid #f1f1f1; padding:0; z-index:1000; width:310px; max-width:90vw }
dialog.form-popup[open] { display:block }
dialog.form-popup::backdrop { background:transparent }
.form-container { background:#fff; padding:6px; max-width:300px }
.form-container h3 { font-size:16px; color:#007a4d; margin:2px 0 }
.form-container p { font-size:12px; font-family:Verdana,Geneva,sans-serif; margin-bottom:6px }
.form-container label { display:block; margin-bottom:2px; font-size:14px; color:#444; font-family:Arial,sans-serif }
.form-container input, .form-container textarea { width:100%; padding:3px; margin:3px 0 6px; border:none; background:#f1f1f1; box-sizing:border-box; font-size:13px }
.form-container input:focus, .form-container textarea:focus { background:#ddd; outline:none }
.form-container textarea { resize:vertical }
.date-field { display:flex; align-items:center; gap:4px; margin:3px 0 6px; position:relative }
.date-field input[type="text"] { flex:1; margin:0; width:auto }
.date-field input[type="date"] { position:absolute; right:0; top:0; width:1px; height:100%; opacity:0; pointer-events:none; border:0; padding:0; margin:0 }
.cal-btn { flex-shrink:0; background:#e0e0e0; border:none; border-radius:3px; padding:3px 7px; cursor:pointer; font-size:14px; line-height:1.4 }
.cal-btn:hover { background:#ccc }
.form-container .btn { background:#007a4d; color:white; padding:7px 20px; border:none; cursor:pointer; width:49%; margin-bottom:5px; opacity:0.8; font-size:13px }
.form-container .btn.cancel { background:grey }
.form-container .btn:hover { opacity:1 }

@media(max-width:768px){
    dialog.form-popup { bottom:0; right:0; left:0; width:100%; max-width:none; border-left:none; border-right:none }
}

/* ─── SEO Icon Tile Grid (index page) ───────────────────────────────────── */
.seo-icon-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    margin: 0 0 14px;
}
.seo-icon-tile {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 10px 6px;
    border-radius: 10px;
    border: 2px solid #e2e8f0;
    background: #f8fafc;
    text-decoration: none;
    color: #1e293b;
    gap: 5px;
    transition: border-color .15s, background .15s;
}
.seo-icon-tile:hover { border-color: #667eea; background: #eef2ff; color: #3730a3; }
.seo-icon-tile-icon { font-size: 18px; line-height: 1; }
.seo-icon-tile-label { font-size: 10px; font-weight: 600; text-align: center; line-height: 1.3; }
.seo-icon-tile--all {
    grid-column: 1 / -1;
    width: 80%;
    margin: 0 auto;
    justify-self: center;
    flex-direction: row;
    gap: 8px;
    background: #007a4d;
    border: 2px solid #007a4d;
    color: #fff;
    font-size: 11px;
    font-weight: 600;
    padding: 10px 14px;
    justify-content: center;
}
.seo-icon-tile--all:hover { background: #005f3c; border-color: #005f3c; color: #fff; }
.seo-icon-tile--all .seo-icon-tile-label { font-size: 12px; color: #fff; }

/* ─── SEO Amenity Filter Links ───────────────────────────────────────────── */
.seo-filter-links {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: center;
    margin: 0 0 18px;
}
.seo-filter-links a {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 3px 5px;
    border-radius: 20px;
    font-size: 0.82em;
    font-weight: 600;
    text-decoration: none;
    border: 1px solid;
    white-space: nowrap;
    transition: filter 0.15s, transform 0.15s;
    font-size: 11px;
}
.seo-filter-links a:hover { filter:brightness(0.9); transform:translateY(-1px); text-decoration:none }
.seo-filter-links a:nth-child(1) { background:#e0f2fe; border-color:#7dd3fc; color:#0369a1 }
.seo-filter-links a:nth-child(2) { background:#fce7f3; border-color:#f9a8d4; color:#be185d }
.seo-filter-links a:nth-child(3) { background:#fef3c7; border-color:#fcd34d; color:#b45309 }
.seo-filter-links a:nth-child(4) { background:#d1fae5; border-color:#6ee7b7; color:#065f46 }
.seo-filter-links a:nth-child(5) { background:#f5f3ff; border-color:#c4b5fd; color:#5b21b6 }
.seo-filter-links a:nth-child(6) { background:#dbeafe; border-color:#93c5fd; color:#1d4ed8 }
@media(max-width:600px){
    .seo-filter-links a { font-size:0.68em; padding:3px 7px }
}

.page-h1 { margin-bottom: 5px }

/* Align .one content start with #colTwo top edge */
.one { margin-top: 0; padding-top: 10px }
.one > :first-child { margin-top: 0 }
.one > script:first-child + h1,
.one > script:first-child + .page-h1 { margin-top: 0 }
.one > .article:first-child > h1:first-child { margin-top: 0 }
.one > script:first-child + .article > h1:first-child { margin-top: 0 }

/* ─── Filter area: sidebar nav + filters side by side ───────────────────── */
.filter-area {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    margin-bottom: 14px;
    position: relative;
    z-index: 20;
}
.filter-area > .filters {
    flex: 1;
    margin-bottom: 0;
}
.slider-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 25px;
    margin-bottom: 10px;
    align-items: start;
}
.slider-row .filter-section {
    margin-bottom: 0;
    display: block;
}
.slider-row .slider-container,
.slider-row input[type="range"] {
    width: 100%;
}
.sort-controls {
    display: flex;
    flex-wrap: nowrap;
    gap: 8px;
    margin-top: 8px;
    margin-bottom: 10px;
}
.sort-controls .sort-button {
    margin-right: 0;
    margin-bottom: 0;
}
.seo-filter-sidebar {
    flex-direction: column;
    flex-shrink: 0;
    width: 150px;
    margin: 0;
    padding: 6px;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    align-items: stretch;
    gap: 4px;
}
.seo-filter-sidebar a {
    padding: 3px 7px;
    font-size: 0.68em;
    white-space: normal;
    line-height: 1.2;
    justify-content: center;
    border-radius: 12px;
    text-align: center;
    width: 100%;
    box-sizing: border-box;
}
.seo-filter-sidebar a:hover { transform: none; filter: brightness(0.92) }
@media(max-width:700px){
    .filter-area { flex-direction: column }
    .seo-filter-sidebar { display: none }
    .filters { display: flex; flex-wrap: wrap; gap: 8px }
    .filters .slider-row { flex: 0 0 100% }
    .filters > .filter-section { flex: 0 0 100%; margin-bottom: 0 }
}

/* Divider between amenity buttons and location buttons */
.seo-filter-divider { border: none; border-top: 1px solid #e2e8f0; transform: scaleY(0.3); transform-origin: center; margin: 2px 0; width: 100% }


/* ─── Breadcrumb navigation (listing pages) ──────────────────────────────── */
.breadcrumb-nav { margin-bottom: 10px; margin-top: 10px }
.breadcrumb { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 0 4px; font-size: 0.81em; color: #6b7280 }
.breadcrumb li + li::before { content: '›'; margin-right: 4px; color: #9ca3af }
.breadcrumb a { color: #4b6fd4; text-decoration: none }
.breadcrumb a:hover { text-decoration: underline }

/* ─── Home SEO content blocks (class-based, no inline style dependency) ─── */
.mobile-search-title {
    margin: 0 0 6px;
    font-size: 12px;
    font-weight: 800;
    color: #ffffff;
    text-align: center;
    text-shadow: 0 1px 2px rgba(0,0,0,.25);
}
.featured-home {
    margin: 8px 0 12px;
}
.featured-home > h2 {
    margin: 0 0 8px;
}
.seo-filters {
    margin: 4px 0 14px;
}
.seo-filters > h2 {
    margin: 0 0 4px;
}
.contact-cta {
    margin-top: 10px;
}
.blog article[itemscope] {
    display: flex;
    flex-direction: column;
    row-gap: 2px;
    padding: 8px 0;
    border-bottom: 1px solid #e8f0f8;
}
.blog article[itemscope] > h3 {
    margin: 0;
    font-size: 14px;
}
.blog article[itemscope] > p {
    margin: 0;
    color: #555;
    line-height: 1.45;
}
.breadcrumb li[aria-current="page"] { color: #374151 }

/* ─── Amenity-page intro paragraph ───────────────────────────────────────── */
.amenity-intro { background: #f0f9ff; border-left: 3px solid #7dd3fc; padding: 10px 14px; margin-bottom: 14px; font-size: 0.92em; border-radius: 0 6px 6px 0; line-height: 1.6 }

/* ─── Date Range Picker ──────────────────────────────────────────────────── */
.drp-host { display:block; width:100%; }

/* Trigger button */
.drp-trigger {
  width:100%; box-sizing:border-box; 
  padding:7px 10px; border:1px solid #c7d8f0; border-radius:8px;
  background:rgba(255,255,255,.92); cursor:pointer; font-size:12px;
  color:#334155; text-align:left; overflow:hidden;
  font-family:system-ui,sans-serif; line-height:1.3;
  -webkit-appearance:none; appearance:none;
}
.drp-trigger:hover { border-color:#5779BD; background:#fff; }
.drp-trigger[aria-expanded="true"] { border-color:#5779BD; box-shadow:0 0 0 2px rgba(87,121,189,.2); }
.drp-cal-icon { flex-shrink:0; font-size:14px; line-height:1; }
.drp-display { flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.drp-placeholder { color:#334155 !important; }
.drp-hint { color:#475569; font-style:italic; }
.drp-flex-badge { display:inline-block; background:#dbeafe; color:#1d4ed8; border-radius:10px; padding:1px 6px; font-size:10px; font-weight:600; margin-left:4px; }

/* Desktop search form: match form width exactly */
.desktop_search-form .drp-host { width:100%; }
.desktop_search-form .drp-trigger { font-size:11px; padding:5px 8px; border-color:#ddd; }

/* Mobile form: transparent trigger to blend with glassmorphism */
.mobile-search-form .drp-trigger { background:rgba(255,255,255,.85); border-color:rgba(199,216,240,.8); border-radius:6px; font-size:11px; padding:5px 6px; }

/* Panel — portaled to body, positioned absolutely */
.drp-panel {
  z-index:10000; background:#fff; border:1px solid #c7d8f0;
  border-radius:12px; padding:12px 14px 10px;
  box-shadow:0 8px 32px rgba(59,89,152,.18), 0 2px 8px rgba(0,0,0,.08);
  font-family:system-ui,sans-serif; font-size:13px;
  -webkit-tap-highlight-color:transparent;
}

/* Status bar */
.drp-status {
  text-align:center; font-size:12px; color:#5779BD; font-weight:600;
  padding:4px 0 8px; border-bottom:1px solid #e8f0fb; margin-bottom:8px;
}

/* Header: [prev] [months] [next] */
.drp-hdr { display:flex; align-items:flex-start; gap:6px; }
.drp-nav {
  flex-shrink:0; width:30px; height:30px; margin-top:20px;
  border:1px solid #e2e8f0; border-radius:6px; background:#f8fafc;
  cursor:pointer; font-size:18px; line-height:1; display:flex;
  align-items:center; justify-content:center; color:#5779BD;
  -webkit-appearance:none; appearance:none;
}
.drp-nav:hover { background:#dbeafe; border-color:#5779BD; }

/* Months container */
.drp-months { display:flex; gap:20px; flex:1; min-width:0; }
.drp-month { flex:1; min-width:0; }
.drp-month-title { font-size:13px; font-weight:700; color:#1a3f9f; text-align:center; margin-bottom:6px; height:22px; line-height:22px; }

/* Weekday header row */
.drp-wk-row { display:grid; grid-template-columns:repeat(7,1fr); margin-bottom:2px; }
.drp-wk-cell { text-align:center; font-size:10px; font-weight:700; color:#64748b; padding:3px 0; }

/* Day cells */
.drp-days { display:grid; grid-template-columns:repeat(7,1fr); gap:1px; }
.drp-day {
  text-align:center; padding:6px 1px; border-radius:4px;
  font-size:12px; line-height:1; -webkit-user-select:none; user-select:none;
  cursor:default;
}
.drp-day.drp-past { color:#d1d5db; cursor:default; }
.drp-day.drp-available { color:#334155; cursor:pointer; }
.drp-day.drp-available:hover { background:#e8f0fb; color:#1a3f9f; }
.drp-day.drp-today { font-weight:800; color:#1a3f9f; }
.drp-day.drp-today.drp-available:not(.drp-start):not(.drp-end) { text-decoration:underline; text-underline-offset:2px; }

/* Selected range */
.drp-day.drp-start { background:#5779BD !important; color:#fff !important; border-radius:4px 0 0 4px; font-weight:700; }
.drp-day.drp-end   { background:#5779BD !important; color:#fff !important; border-radius:0 4px 4px 0; font-weight:700; }
.drp-day.drp-start.drp-end { border-radius:4px !important; }
.drp-day.drp-in-range { background:#dbeafe; color:#1d4ed8; border-radius:0; }

/* Hover preview */
.drp-day.drp-end-prev  { background:rgba(87,121,189,.35); color:#1a3f9f; border-radius:0 4px 4px 0; }
.drp-day.drp-start-prev { background:rgba(87,121,189,.35); color:#1a3f9f; border-radius:4px 0 0 4px; }

/* Flexible row */
.drp-flex-row {
  margin-top:10px; padding:7px 10px;
  background:#f0f6ff; border-radius:8px; border:1px solid #dbeafe;
}
.drp-flex-label {
  display:flex; align-items:center; gap:8px; cursor:pointer;
  font-size:12px; color:#334155; line-height:1.4;
}
.drp-flex-cb { accent-color:#5779BD; width:15px; height:15px; cursor:pointer; flex-shrink:0; }
.drp-flex-label strong { color:#1d4ed8; }

/* Footer */
.drp-footer { display:flex; justify-content:space-between; align-items:center; margin-top:10px; }
.drp-clear-btn {
  background:none; border:1px solid #e2e8f0; border-radius:6px;
  padding:5px 12px; font-size:12px; cursor:pointer; color:#475569;
  -webkit-appearance:none; appearance:none;
}
.drp-clear-btn:hover { background:#fef2f2; border-color:#fca5a5; color:#c0392b; }
.drp-done-btn {
  background:#5779BD; border:none; border-radius:6px;
  padding:5px 16px; font-size:12px; cursor:pointer; color:#fff; font-weight:600;
  -webkit-appearance:none; appearance:none;
}
.drp-done-btn:hover { background:#4668a8; }

/* Filter area: full-width trigger */
.filters .drp-trigger { width:100%; }

/* Small screen: single month + narrower panel */
@media (max-width:599px) {
  .drp-panel { padding:10px; min-width:0; max-width:calc(100vw - 20px); }
  .drp-months { flex-direction:column; }
  .drp-month + .drp-month { display:none; } /* hide 2nd month */
  .drp-nav { margin-top:18px; }
  .drp-day { padding:5px 1px; font-size:11px; }
  .drp-flex-label { font-size:11px; }
}

/* End of refactored CSS */

/* ─── Mobile search form (index.php) ────────────────────────────────────────── */
.msf-row { display:flex; gap:4px; align-items:center; margin-bottom:6px; }
.msf-drp-host { flex:1; min-width:0; }
.msf-guests-wrap { display:flex; align-items:center; gap:3px; background:rgba(255,255,255,.85); border:1px solid rgba(199,216,240,.8); border-radius:6px; padding:5px 6px; white-space:nowrap; flex-shrink:0; }
.msf-guests-icon { font-size:11px; }
.msf-guests-input { width:28px; border:none; background:transparent; font-size:11px; outline:none; text-align:center; }
.msf-filter-wrap { position:relative; flex-shrink:0; }
.msf-filter-btn { display:flex; align-items:center; gap:3px; background:rgba(255,255,255,.85); border:1px solid rgba(199,216,240,.8); border-radius:6px; padding:5px 8px; cursor:pointer; font-size:11px; font-weight:500; white-space:nowrap; }
.msf-filter-panel { display:none; position:absolute; background:rgba(255,255,255,.96); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); border:1px solid #c7d8f0; border-radius:10px; padding:8px 12px 10px; z-index:9999; min-width:170px; box-shadow:0 6px 20px rgba(0,0,0,.13); }
.msf-filter-hdr { display:flex; justify-content:space-between; align-items:center; margin-bottom:6px; }
.msf-filter-title { font-size:11px; font-weight:600; color:#1a3f9f; }
.msf-filter-close-btn { background:none; border:none; cursor:pointer; font-size:16px; line-height:1; color:#666; padding:0 2px; }
.msf-amenity-label { display:flex; gap:7px; align-items:center; padding:4px 0; font-size:12px; cursor:pointer; }
.msf-date-error { display:none; color:#c0392b; background:rgba(254,242,242,.95); border:1px solid #fca5a5; border-radius:5px; padding:6px 8px; font-size:11px; margin-top:4px; width:100%; box-sizing:border-box; }

/* ─── Listing availability calendar ─────────────────────────────────────────── */
.listing-availability-calendar { border:1px solid #e5e7eb; border-radius:10px; padding:12px; background:#fafafa; }
.listing-availability-calendar h3 { margin:0 0 10px; color:#1f2937; font-size:18px; }
.listing-cal-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:10px; }
.listing-cal-month.hidden-page { display:none; }
.listing-cal-pager { display:flex; justify-content:space-between; align-items:center; gap:8px; margin:0 0 10px; }
.listing-cal-pager button { border:1px solid #d1d5db; background:#fff; border-radius:6px; padding:6px 10px; cursor:pointer; color:#374151; }
.listing-cal-pager button[disabled] { opacity:.5; cursor:not-allowed; }
.listing-cal-month { background:#fff; border:1px solid #e5e7eb; border-radius:8px; padding:8px; height:216px; box-sizing:border-box; overflow:hidden; display:flex; flex-direction:column; }
.listing-cal-title { font-weight:700; color:#3b5998; text-align:center; margin:4px 0 8px; }
.listing-cal-days { display:grid; grid-template-columns:repeat(7,1fr); gap:2px; }
.listing-cal-dow { font-size:11px; text-align:center; color:#6b7280; font-weight:600; }
.listing-cal-day { height:20px; border-radius:6px; display:flex; align-items:center; justify-content:center; font-size:11px; border:1px solid #e5e7eb; }
.listing-cal-day.selectable { cursor:pointer; }
.listing-cal-day.selected { outline:2px solid #123b91; outline-offset:-2px; }
.listing-cal-day.in-range { box-shadow:inset 0 0 0 9999px rgba(59,89,152,.16); }
.listing-cal-day.empty { background:transparent; border-color:transparent; }
.listing-cal-day.available { background:#ecfdf5; color:#065f46; }
.listing-cal-day.booked { background:#fee2e2; color:#991b1b; }
.listing-cal-day.half-start { color:#7c2d12; background:linear-gradient(135deg,#ecfdf5 0 50%,#fee2e2 50% 100%); }
.listing-cal-day.half-end { color:#7c2d12; background:linear-gradient(135deg,#fee2e2 0 50%,#ecfdf5 50% 100%); }
.listing-cal-legend { display:flex; gap:10px; flex-wrap:wrap; margin-top:10px; font-size:12px; color:#374151; }
.listing-cal-dot { width:14px; height:14px; border-radius:4px; border:1px solid #d1d5db; display:inline-block; vertical-align:middle; margin-right:5px; }
.listing-cal-dot.available { background:#ecfdf5; }
.listing-cal-dot.booked { background:#fee2e2; }
.listing-cal-dot.half { background:linear-gradient(135deg,#ecfdf5 0 50%,#fee2e2 50% 100%); }
.listing-cal-error { padding:10px 12px; border-radius:6px; background:#fff3f3; border:1px solid #fecaca; color:#991b1b; font-size:14px; }
.listing-booking-box { margin-top:12px; background:#fff; border:1px solid #e5e7eb; border-radius:8px; padding:10px; }
.listing-booking-row { display:flex; gap:8px; flex-wrap:wrap; align-items:center; margin-bottom:8px; }
.listing-booking-row-main { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:8px; align-items:end; margin-bottom:8px; }
.listing-guest-field { font-size:13px; color:#374151; display:flex; flex-direction:column; gap:4px; min-width:0; }
.listing-guest-stepper { display:flex; align-items:center; }
.listing-guest-stepper button { width:28px; height:30px; border:1px solid #d1d5db; background:#f8fafc; color:#374151; cursor:pointer; padding:0; line-height:1; display:inline-flex; align-items:center; justify-content:center; }
.listing-guest-stepper button:first-child { border-radius:6px 0 0 6px; border-right:none; }
.listing-guest-stepper button:last-child { border-radius:0 6px 6px 0; border-left:none; }
.listing-guest-stepper input { width:54px; height:30px; text-align:center; border:1px solid #d1d5db; border-radius:0; padding:0; font-size:13px; -webkit-appearance:textfield; -moz-appearance:textfield; appearance:textfield; }
.listing-guest-stepper input::-webkit-outer-spin-button,
.listing-guest-stepper input::-webkit-inner-spin-button { -webkit-appearance:none; margin:0; }
.listing-guest-field-single { max-width:none; }
.listing-child-ages { display:none; gap:8px; flex-wrap:wrap; margin:8px 0; }
.listing-child-age-item { display:flex; flex-direction:column; gap:4px; align-items:center; }
.listing-child-age-item span { font-size:11px; color:#4b5563; }
.listing-age-stepper { display:flex; align-items:center; }
.listing-age-stepper button { width:24px; height:28px; border:1px solid #d1d5db; background:#f8fafc; color:#374151; cursor:pointer; padding:0; line-height:1; }
.listing-age-stepper button:first-child { border-radius:6px 0 0 6px; border-right:none; }
.listing-age-stepper button:last-child { border-radius:0 6px 6px 0; border-left:none; }
.listing-age-stepper input { width:42px; height:28px; text-align:center; border:1px solid #d1d5db; border-radius:0; padding:0; font-size:12px; }
.listing-schema-hidden { display:none; }
.listing-selected-range { font-size:13px; margin-bottom:8px; display:none; }
.listing-selected-range span { margin-right:12px; }
.listing-range-label { color:#3b5998; font-weight:400; }
.listing-range-date { color:#3b5998; font-weight:700; }
.listing-booking-msg { font-size:14px; color:#3b5998; white-space:pre-line; }
.listing-booking-msg.error { color:#991b1b; }
.listing-booking-msg.warn { color:#92400e; background:#fef3c7; border:1px solid #fcd34d; border-radius:6px; padding:8px 10px; }
.listing-booking-msg.ok { color:#065f46; }
.listing-booking-price { font-weight:700; margin-top:6px; color:#3b5998; }
.listing-booking-cta { margin-top:8px; }
.listing-booking-cta button { padding:8px 12px; border:1px solid #3b5998; background:#3b5998; color:#fff; border-radius:6px; cursor:pointer; margin-bottom:3px; }
.listing-booking-cta button.alt { background:#007a4d; border-color:#007a4d; color:#fff; }
.listing-booking-cta button[disabled] { opacity:.5; cursor:not-allowed; }
.listing-intent-modal { position:fixed; inset:0; background:rgba(17,24,39,.55); display:none; z-index:9999; align-items:center; justify-content:center; padding:16px; }
.listing-intent-modal.open { display:flex; }
.listing-intent-dialog { width:min(860px,96vw); height:min(90vh,820px); background:#fff; border-radius:10px; overflow:hidden; position:relative; }
.listing-intent-close { position:absolute; right:8px; top:8px; z-index:2; background:#3b5998; color:#fff; border:0; border-radius:6px; padding:6px 10px; cursor:pointer; }
.listing-intent-iframe { width:100%; height:100%; border:0; }
@media (max-width:768px) {
    .listing-booking-row-main { grid-template-columns:repeat(3,minmax(0,1fr)); gap:6px; align-items:start; }
    .listing-guest-field { font-size:11px; gap:3px; }
    .listing-guest-stepper button { width:22px; height:24px; font-size:12px; }
    .listing-guest-stepper input { width:30px; height:24px; font-size:11px; }
}

/* Template inline CSS migration */
.mobile-nav-brand-logo { border-radius: 3px; }
.search-heading-section { padding: 6px 10px 4px; }
.dsf-label-tight { margin-bottom: 4px; }
.dialog-sr-trap {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
    overflow: hidden;
    pointer-events: none;
}

.date-error-box {
    display: none;
    color: #c0392b;
    background: #fef2f2;
    border: 1px solid #fca5a5;
    border-radius: 5px;
    padding: 7px 10px;
    font-size: 12px;
    margin: 4px 0;
}

.filter-grid-full { grid-column: 1 / -1; }
.filter-slider-max { max-width: 100%; }
.drp-filter-full { width: 100%; }
.filter-dropdown-row {
    display: flex;
    gap: 8px;
    width: 100%;
    box-sizing: border-box;
    align-items: flex-end;
}
.filter-col {
    flex: 1;
    min-width: 0;
    flex-direction: column;
    align-items: stretch;
    gap: 3px;
    overflow: hidden;
}
.filter-label-tight { margin: 0 0 2px 0; }
.checkbox-dropdown-fill {
    min-width: 0;
    width: 100%;
    overflow: hidden;
    position: relative;
}
.checkbox-dropdown-flex {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    position: relative;
}
.dropdown-button-ellipsis {
    width: 100%;
    box-sizing: border-box;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.dropdown-panel {
    display: none;
    position: absolute;
    background: #fff;
    border: 1px solid #c7d8f0;
    border-radius: 8px;
    padding: 8px 12px;
    z-index: 9999;
    min-width: 180px;
    box-shadow: 0 6px 20px rgba(0,0,0,.13);
    font-size: 13px;
}
.dropdown-option {
    display: flex;
    align-items: center;
    margin-bottom: 5px;
}
.dropdown-option-last { margin-bottom: 0; }
.dropdown-checkbox { margin-right: 6px; }
.filter-location-row {
    display: flex;
    gap: 4px;
    align-items: center;
    min-width: 0;
    overflow: hidden;
}
.filter-search-btn {
    flex-shrink: 0;
    padding: 4px 10px;
    background: #3a5fa8;
    color: #fff;
    border: none;
    border-radius: 5px;
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    white-space: nowrap;
}

.availability-checking {
    display: none;
    padding: 12px 0;
    color: #667eea;
    font-size: 14px;
}

.no-availability-section {
    display: none;
    margin-top: 24px;
}
.no-availability-notice {
    background: #f1ffff;
    border: 1px solid #aaccfe;
    border-radius: 10px;
    padding: 20px 24px;
    margin-bottom: 20px;
    color: #3B5998;
    font-size: 15px;
    line-height: 1.6;
}
.inquiry-card {
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    padding: 24px;
    max-width: 520px;
}
.inquiry-title {
    margin: 0 0 16px;
    font-size: 17px;
    color: #3B5998;
}
.inquiry-success {
    display: none;
    background: #f0fdf4;
    border: 1px solid #86efac;
    border-radius: 6px;
    padding: 12px 16px;
    color: #166534;
    font-size: 14px;
    margin-bottom: 12px;
}
.inquiry-error {
    display: none;
    background: #fef2f2;
    border: 1px solid #fca5a5;
    border-radius: 6px;
    padding: 12px 16px;
    color: #3B5998;
    font-size: 14px;
    margin-bottom: 12px;
}
.inquiry-grid-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin-bottom: 10px;
}
.inquiry-label {
    display: block;
    font-size: 12px;
    font-weight: 600;
    color: #555;
    margin-bottom: 3px;
}
.required-star { color: #e53e3e; }
.inquiry-input {
    width: 100%;
    padding: 8px;
    border: 1px solid #ddd;
    border-radius: 5px;
    font-size: 13px;
    box-sizing: border-box;
}
.inquiry-block-10 { margin-bottom: 10px; }
.inquiry-block-14 { margin-bottom: 14px; }
.inquiry-textarea {
    width: 100%;
    padding: 8px;
    border: 1px solid #ddd;
    border-radius: 5px;
    font-size: 13px;
    box-sizing: border-box;
    resize: vertical;
    font-family: inherit;
}
.inquiry-submit-btn {
    width: 100%;
    padding: 10px;
    background: #007a4d;
    color: #fff;
    border: none;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
}

.date-input-wrap { display: flex; align-items: center; gap: 4px; }
.date-text-input { flex: 1; min-width: 0; width: 0; padding: 6px 6px; border: 1px solid #ddd; border-radius: 5px; font-size: 12px; }
.date-text-input-lg { padding: 8px; font-size: 13px; }
.date-native-hidden { position: absolute; inset: 0; width: 100%; height: 100%; opacity: 0; cursor: pointer; pointer-events: all; }
.date-picker-wrap { position: relative; flex-shrink: 0; display: inline-flex; overflow: hidden; }
.date-cal-btn { width: 30px; height: 30px; border: 1px solid #ddd; border-radius: 5px; background: #fff; cursor: pointer; font-size: 14px; line-height: 1; flex-shrink: 0; }

@media (pointer:fine) {
    .date-cal-btn { pointer-events: all; }
    .date-native-hidden { width: 1px; height: 1px; pointer-events: none; }
}

@media (max-width:700px) {
    .filters { background: rgba(255,255,255,.95); border-radius: 8px; box-shadow: 0 2px 6px rgba(0,0,0,.08); font-size: 11px; }
    .filters .label,
    .filters label { font-size: 11px; min-width: unset; color: #333; }
    .filters input[type="range"] { width: 100%; }
}

/* Home FAQ (one-column, schema.org FAQPage content block) */
.home-faq.one-column-faq {
    width: 100%;
    margin: 8px 5px 12px;
    padding: 12px 14px;
    background: #ffffff;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    box-shadow: 0 2px 10px rgba(0,0,0,.07);
    box-sizing: border-box;
}

.home-faq.one-column-faq > h2 {
    margin: 0 0 10px;
    color: #006600;
    font-size: 16px;
    line-height: 1.3;
}

.home-faq.one-column-faq [itemprop="mainEntity"] {
    padding: 9px 0;
    border-bottom: 1px solid #e8f0f8;
}

.home-faq.one-column-faq [itemprop="mainEntity"]:last-child {
    border-bottom: 0;
    padding-bottom: 2px;
}

.home-faq.one-column-faq h3[itemprop="name"] {
    margin: 0 0 6px;
    font-size: 14px;
    line-height: 1.35;
    color: #375494;
    font-weight: 700;
}

.home-faq.one-column-faq [itemprop="text"] {
    margin: 0;
    font-size: 14px;
    line-height: 1.65;
    color: #334155;
}

.home-faq.one-column-faq a {
    color: #006600;
    text-decoration: underline;
}

.home-faq.one-column-faq a:hover {
    color: #2582A4;
}

@media (max-width: 954px) {
    .home-faq.one-column-faq {
        margin: 8px 5px 12px;
        padding: 10px 11px;
        border-radius: 10px;
    }

    .home-faq.one-column-faq > h2 {
        font-size: 15px;
    }

    .home-faq.one-column-faq h3[itemprop="name"] {
        font-size: 13px;
    }

    .home-faq.one-column-faq [itemprop="text"] {
        font-size: 13px;
        line-height: 1.6;
    }
}
