/* ═══════════════════════════════════════════════════════════════════════════
   PRO-ESTATE ELITE — Complete Stylesheet
   ═══════════════════════════════════════════════════════════════════════════ */

* { box-sizing: border-box; margin: 0; padding: 0; font-family: system-ui, -apple-system, "Segoe UI", sans-serif; }

/* ─── 1. Classic ─────────────────────────────────────────────────────────── */
body[data-theme="light"],
body[data-theme="classic"] {
    --bg:       #f0f2f7;
    --bg2:      #ffffff;
    --bg3:      #f8fafc;
    --border:   #e2e8f0;
    --text:     #1a202c;
    --text2:    #4a5568;
    --text3:    #718096;
    --accent:   #1d4ed8;
    --accent2:  #1e40af;
    --green:    #16a34a;
    --red:      #dc2626;
    --shadow:   rgba(0,0,0,0.08);
    --shadow2:  rgba(0,0,0,0.15);
    --sidebar-bg: #1e3a8a;
    --sidebar-text: #ffffff;
    --sidebar-text2: rgba(255,255,255,0.65);
    --sidebar-active: rgba(255,255,255,0.15);
    --sidebar-border: rgba(255,255,255,0.1);
    --topbar-bg: #ffffff;
    --catbar-bg: #1e293b;
    --footer-bg: #1e293b;
    --footer-border: #2d3a50;
    --footer-text: #94a3b8;
    --footer-text2: #64748b;
    --footer-heading: #ffffff;
    --footer-social-bg: #2d3a50;
    --footer-bottom-border: #2d3a50;
}

/* ─── 2. Dark Pro ────────────────────────────────────────────────────────── */
body[data-theme="dark"] {
    --bg:       #0f1117;
    --bg2:      #1a1d27;
    --bg3:      #141720;
    --border:   #2d3148;
    --text:     #f1f5f9;
    --text2:    #94a3b8;
    --text3:    #64748b;
    --accent:   #3b82f6;
    --accent2:  #2563eb;
    --green:    #22c55e;
    --red:      #ef4444;
    --shadow:   rgba(0,0,0,0.4);
    --shadow2:  rgba(0,0,0,0.6);
    --sidebar-bg: #0a0c14;
    --sidebar-text: #f1f5f9;
    --sidebar-text2: rgba(241,245,249,0.5);
    --sidebar-active: rgba(59,130,246,0.2);
    --sidebar-border: rgba(255,255,255,0.06);
    --topbar-bg: #1a1d27;
    --catbar-bg: #0a0c14;
    --footer-bg: #0a0c14;
    --footer-border: #1a1d27;
    --footer-text: #64748b;
    --footer-text2: #475569;
    --footer-heading: #94a3b8;
    --footer-social-bg: #1a1d27;
    --footer-bottom-border: #1a1d27;
}

/* ─── 3. Luxury ──────────────────────────────────────────────────────────── */
body[data-theme="luxury"] {
    --bg:       #0d0d0d;
    --bg2:      #161616;
    --bg3:      #1e1e1e;
    --border:   #2a2a2a;
    --text:     #f5e6c8;
    --text2:    #c9a96e;
    --text3:    #8a7355;
    --accent:   #c9a96e;
    --accent2:  #a8843a;
    --green:    #4caf7d;
    --red:      #e05555;
    --shadow:   rgba(0,0,0,0.5);
    --shadow2:  rgba(0,0,0,0.7);
    --sidebar-bg: #0a0a0a;
    --sidebar-text: #f5e6c8;
    --sidebar-text2: rgba(245,230,200,0.5);
    --sidebar-active: rgba(201,169,110,0.15);
    --sidebar-border: rgba(201,169,110,0.15);
    --topbar-bg: #111111;
    --catbar-bg: #080808;
    --footer-bg: #080808;
    --footer-border: #1a1a1a;
    --footer-text: #8a7355;
    --footer-text2: #5a4a35;
    --footer-heading: #c9a96e;
    --footer-social-bg: #1a1a1a;
    --footer-bottom-border: #1a1a1a;
}

/* ─── 4. Nature ──────────────────────────────────────────────────────────── */
body[data-theme="nature"] {
    --bg:       #f0f7f0;
    --bg2:      #ffffff;
    --bg3:      #f4faf4;
    --border:   #d4e8d4;
    --text:     #1a2e1a;
    --text2:    #3d5c3d;
    --text3:    #6b8f6b;
    --accent:   #2d7a2d;
    --accent2:  #1e5c1e;
    --green:    #16a34a;
    --red:      #dc2626;
    --shadow:   rgba(0,60,0,0.08);
    --shadow2:  rgba(0,60,0,0.15);
    --sidebar-bg: #1a3d1a;
    --sidebar-text: #ffffff;
    --sidebar-text2: rgba(255,255,255,0.6);
    --sidebar-active: rgba(255,255,255,0.12);
    --sidebar-border: rgba(255,255,255,0.08);
    --topbar-bg: #ffffff;
    --catbar-bg: #1a2236;
    --footer-bg: #1a3d1a;
    --footer-border: #1e4d1e;
    --footer-text: #7aad7a;
    --footer-text2: #558055;
    --footer-heading: #ffffff;
    --footer-social-bg: #1e4d1e;
    --footer-bottom-border: #1e4d1e;
}

/* ─── 5. Minimal ─────────────────────────────────────────────────────────── */
body[data-theme="minimal"] {
    --bg:       #fafafa;
    --bg2:      #ffffff;
    --bg3:      #f5f5f5;
    --border:   #ebebeb;
    --text:     #111111;
    --text2:    #444444;
    --text3:    #888888;
    --accent:   #111111;
    --accent2:  #333333;
    --green:    #22a06b;
    --red:      #e03434;
    --shadow:   rgba(0,0,0,0.05);
    --shadow2:  rgba(0,0,0,0.1);
    --sidebar-bg: #111111;
    --sidebar-text: #ffffff;
    --sidebar-text2: rgba(255,255,255,0.5);
    --sidebar-active: rgba(255,255,255,0.1);
    --sidebar-border: rgba(255,255,255,0.08);
    --topbar-bg: #ffffff;
    --catbar-bg: #222222;
    --footer-bg: #111111;
    --footer-border: #222222;
    --footer-text: #888888;
    --footer-text2: #555555;
    --footer-heading: #ffffff;
    --footer-social-bg: #222222;
    --footer-bottom-border: #222222;
}

/* ─── 6. Sunset ──────────────────────────────────────────────────────────── */
body[data-theme="sunset"] {
    --bg:       #fff7f3;
    --bg2:      #ffffff;
    --bg3:      #fff3ee;
    --border:   #fde8de;
    --text:     #2d1810;
    --text2:    #7c3a28;
    --text3:    #b06a52;
    --accent:   #c94a1a;
    --accent2:  #a33a10;
    --green:    #16a34a;
    --red:      #dc2626;
    --shadow:   rgba(150,50,0,0.08);
    --shadow2:  rgba(150,50,0,0.15);
    --sidebar-bg: #7c1d0a;
    --sidebar-text: #fff7f3;
    --sidebar-text2: rgba(255,247,243,0.6);
    --sidebar-active: rgba(255,247,243,0.12);
    --sidebar-border: rgba(255,247,243,0.1);
    --topbar-bg: #ffffff;
    --catbar-bg: #5c1508;
    --footer-bg: #5c1508;
    --footer-border: #7c1d0a;
    --footer-text: #c9826a;
    --footer-text2: #a05540;
    --footer-heading: #fff7f3;
    --footer-social-bg: #7c1d0a;
    --footer-bottom-border: #7c1d0a;
}

/* ─── 7. Glass ───────────────────────────────────────────────────────────── */
body[data-theme="glass"] {
    --bg:       transparent;
    --bg2:      rgba(255,255,255,0.08);
    --bg3:      rgba(255,255,255,0.05);
    --border:   rgba(255,255,255,0.12);
    --text:     #ffffff;
    --text2:    rgba(255,255,255,0.75);
    --text3:    rgba(255,255,255,0.45);
    --accent:   #a78bfa;
    --accent2:  #7c3aed;
    --green:    #22c55e;
    --red:      #ef4444;
    --shadow:   rgba(0,0,0,0.3);
    --shadow2:  rgba(0,0,0,0.5);
    --sidebar-bg: rgba(255,255,255,0.07);
    --sidebar-text: #ffffff;
    --sidebar-text2: rgba(255,255,255,0.5);
    --sidebar-active: rgba(255,255,255,0.12);
    --sidebar-border: rgba(255,255,255,0.08);
    --topbar-bg: rgba(255,255,255,0.06);
    --catbar-bg: rgba(0,0,0,0.3);
    --footer-bg: rgba(0,0,0,0.3);
    --footer-border: rgba(255,255,255,0.08);
    --footer-text: rgba(255,255,255,0.5);
    --footer-text2: rgba(255,255,255,0.3);
    --footer-heading: #ffffff;
    --footer-social-bg: rgba(255,255,255,0.1);
    --footer-bottom-border: rgba(255,255,255,0.08);
}

/* Glass — background on html so it covers everything */
body[data-theme="glass"],
html:has(body[data-theme="glass"]) {
    background: linear-gradient(135deg, #0f0c29 0%, #302b63 50%, #24243e 100%) fixed;
    min-height: 100vh;
}

body[data-theme="glass"] .sidebar { backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); }
body[data-theme="glass"] .topbar { backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); }
body[data-theme="glass"] .prop-sidebar { backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); }
body[data-theme="glass"] .modal-content { background: rgba(15,12,41,0.92); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); border: 1px solid rgba(255,255,255,0.15); }
body[data-theme="glass"] .property-list-card { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.12); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); }
body[data-theme="glass"] .property-list-card:hover { background: rgba(255,255,255,0.13); border-color: rgba(255,255,255,0.22); }
body[data-theme="glass"] .cat-nav-tab { color: rgba(255,255,255,0.6); }
body[data-theme="glass"] .cat-nav-tab.active { color: #fff; border-bottom-color: #a78bfa; }
body[data-theme="glass"] .cat-nav-tab:hover { background: rgba(255,255,255,0.08); color: #fff; }
body[data-theme="glass"] .acc-block { border-bottom-color: rgba(255,255,255,0.08); }
body[data-theme="glass"] .acc-header:hover { background: rgba(255,255,255,0.05); }
body[data-theme="glass"] .prop-filter-input,
body[data-theme="glass"] .prop-filter-select,
body[data-theme="glass"] .prop-filter-range-input { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.15); color: #fff; }
body[data-theme="glass"] input::placeholder,
body[data-theme="glass"] textarea::placeholder { color: rgba(255,255,255,0.3); }
body[data-theme="glass"] .btn { background: rgba(167,139,250,0.25); border: 1px solid rgba(167,139,250,0.4); color: #fff; }
body[data-theme="glass"] .btn:hover { background: rgba(167,139,250,0.4); }
body[data-theme="glass"] .btn-outline { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.2); color: rgba(255,255,255,0.8); }
body[data-theme="glass"] .btn-danger { background: rgba(239,68,68,0.6); border-color: rgba(239,68,68,0.8); }
body[data-theme="glass"] .dashboard-panel,
body[data-theme="glass"] .stats > div { background: rgba(255,255,255,0.07); border-color: rgba(255,255,255,0.1); }
body[data-theme="glass"] .filter-search-btn { background: rgba(167,139,250,0.5); }
body[data-theme="glass"] .filter-search-btn:hover { background: rgba(167,139,250,0.7); }
body[data-theme="glass"] .main { background: transparent; }
body[data-theme="glass"] .sidebar-footer select { background: rgba(255,255,255,0.1); border-color: rgba(255,255,255,0.2); color: #fff; }

/* ─── PORTAL BLUE THEME ──────────────────────────────────────────────────── */
body[data-theme="portal"] {
    --bg:       #f0f4ff;
    --bg2:      #ffffff;
    --bg3:      #e8eef8;
    --border:   #c8d8f0;
    --text:     #1a2744;
    --text2:    #3a5080;
    --text3:    #7090b8;
    --accent:   #1d4ed8;
    --accent2:  #1e40af;
    --green:    #16a34a;
    --red:      #dc2626;
    --shadow:   rgba(29,78,216,0.10);
    --shadow2:  rgba(29,78,216,0.18);
    --sidebar-bg: #1d3a7a;
    --sidebar-text: #ffffff;
    --sidebar-text2: rgba(255,255,255,0.55);
    --sidebar-active: rgba(255,255,255,0.15);
    --sidebar-border: rgba(255,255,255,0.1);
    --topbar-bg: #ffffff;
    --catbar-bg: #1a2f6e;
    --footer-bg: #1a2744;
    --footer-border: rgba(255,255,255,0.1);
    --footer-text: rgba(255,255,255,0.6);
    --footer-text2: rgba(255,255,255,0.35);
    --footer-heading: #ffffff;
    --footer-social-bg: rgba(255,255,255,0.1);
    --footer-bottom-border: rgba(255,255,255,0.08);
}
body[data-theme="portal"] .property-list-card {
    background: #ffffff;
    border-color: #dce8f8;
    box-shadow: 0 2px 8px rgba(29,78,216,0.06);
}
body[data-theme="portal"] .property-list-card:hover {
    border-color: #1d4ed8;
    box-shadow: 0 4px 16px rgba(29,78,216,0.15);
}
body[data-theme="portal"] .cat-grid-item {
    background: #ffffff;
    border-color: #dce8f8;
}
body[data-theme="portal"] .cat-grid-item:hover,
body[data-theme="portal"] .cat-grid-item--active {
    background: #1d4ed8;
    border-color: #1d4ed8;
}
body[data-theme="portal"] .prop-sidebar {
    background: #f8faff;
    border-right-color: #dce8f8;
}
body[data-theme="portal"] .modal-content {
    background: #ffffff;
    border-color: #dce8f8;
}
body[data-theme="portal"] .topbar {
    border-bottom: 1px solid #dce8f8;
    box-shadow: 0 2px 8px rgba(29,78,216,0.08);
}
body[data-theme="portal"] .acc-block {
    border-bottom-color: #dce8f8;
}
body[data-theme="portal"] .filter-search-btn {
    background: #1d4ed8;
}
body[data-theme="portal"] .filter-search-btn:hover {
    background: #1e40af;
}
body[data-theme="portal"] .btn-primary {
    background: #1d4ed8;
    border-color: #1d4ed8;
}

/* ─── BODY & ROOT LAYOUT ────────────────────────────────────────────────── */
body {
    height: 100vh;
    display: flex;
    flex-direction: row;
    overflow: hidden;
    background: var(--bg);
    color: var(--text);
}
@media (min-width: 769px) {
    body {
        height: auto;
        min-height: 100vh;
        overflow-x: hidden;
        overflow-y: auto;
    }
    .main {
        height: auto !important;
        min-height: 100vh !important;
        overflow-y: visible !important;
    }
    .sidebar {
        position: sticky !important;
        top: 0 !important;
        height: 100vh !important;
        align-self: flex-start !important;
    }
    .prop-sidebar {
        position: sticky !important;
        top: 0 !important;
        max-height: 100vh !important;
        height: auto !important;
        min-height: 100% !important;
        overflow-y: auto !important;
        align-self: stretch !important;
    }
    .properties-layout.active {
        overflow: visible !important;
        height: auto !important;
    }
}
.app-footer { margin-top: auto; }

/* ─── ADMIN VISIBILITY ───────────────────────────────────────────────────── */
.admin-only { display: none !important; }
body.admin .admin-only { display: inline-flex !important; }
body.admin div.admin-only, body.admin h2.admin-only, body.admin hr.admin-only { display: block !important; }
body.admin button.admin-only { display: inline-flex !important; }
body.admin .nav-item.admin-only { display: flex !important; }

/* ─── SIDEBAR ────────────────────────────────────────────────────────────── */
.sidebar { width:210px; min-width:210px; background:var(--sidebar-bg,#1e3a8a); border-right:1px solid var(--sidebar-border,rgba(255,255,255,0.1)); display:flex; flex-direction:column; height:100%; overflow-y:auto; flex-shrink:0; }
.sidebar-logo { padding:20px 18px 14px; border-bottom:1px solid var(--sidebar-border,rgba(255,255,255,0.1)); }
.sidebar-logo-text { font-size:17px; font-weight:800; color:var(--sidebar-text,#fff); letter-spacing:0.03em; line-height:1.2; }
.sidebar-logo-sub { font-size:10px; color:var(--sidebar-text2,rgba(255,255,255,0.5)); text-transform:uppercase; letter-spacing:0.12em; margin-top:2px; }
.nav { padding:10px; display:flex; flex-direction:column; gap:2px; }
.nav-item { padding:9px 12px; border-radius:8px; cursor:pointer; font-size:13.5px; font-weight:500; color:var(--sidebar-text2,rgba(255,255,255,0.65)); transition:background 0.15s,color 0.15s; user-select:none; display:flex; align-items:center; gap:8px; }
.nav-item:hover { background:var(--sidebar-active,rgba(255,255,255,0.1)); color:var(--sidebar-text,#fff); }
.nav-item.active { background:var(--sidebar-active,rgba(255,255,255,0.15)); color:var(--sidebar-text,#fff); font-weight:700; }
.nav-item--admin { margin-top:8px; border-top:1px solid var(--sidebar-border,rgba(255,255,255,0.1)); padding-top:12px; }
.nav-item--admin:hover { background:#fef3c7; color:#d97706; }
body.admin .nav-item--admin { background:#fef3c7; color:#d97706; font-weight:600; }
body[data-theme="dark"] .nav-item--admin:hover, body[data-theme="dark"].admin .nav-item--admin { background:#451a03; color:#fcd34d; }
.sidebar-footer { margin-top:auto; padding:14px 14px 18px; border-top:1px solid var(--border); display:flex; flex-direction:column; gap:10px; }
.sidebar-footer label { font-size:10px; font-weight:600; text-transform:uppercase; letter-spacing:0.1em; color:var(--text3); margin-bottom:2px; display:block; }
.sidebar-footer select { width:100%; padding:7px 10px; border-radius:8px; border:1px solid rgba(255,255,255,0.2); font-size:13px; background:rgba(255,255,255,0.1); color:#ffffff; cursor:pointer; outline:none; }
.sidebar-footer select option { background:#1e2535; color:#ffffff; }

/* ─── MAIN ───────────────────────────────────────────────────────────────── */
.main { flex:1; display:flex; flex-direction:column; min-width:0; height:100vh; overflow-y:auto; background:var(--bg); }

/* ─── TOPBAR ─────────────────────────────────────────────────────────────── */
.topbar { height:58px; min-height:58px; display:flex; align-items:center; padding:0 20px; gap:12px; background:var(--topbar-bg,var(--bg2)); border-bottom:1px solid var(--border); flex-shrink:0; position:sticky; top:0; z-index:1000; overflow:visible; }
.topbar-brand { display:flex; align-items:center; gap:8px; flex-shrink:0; }
.topbar-appname { font-weight:700; font-size:14px; color:var(--accent); white-space:nowrap; margin-right:4px; }
.topbar-search { flex:1; max-width:380px; padding:8px 14px 8px 36px; border-radius:999px; border:1px solid var(--border); font-size:13px; background:var(--bg3); color:var(--text); outline:none; transition:border-color 0.15s; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23718096' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:12px center; }
.topbar-search:focus { border-color:var(--accent); }
.topbar-spacer { flex:1; }
.topbar-menu { display:flex; align-items:center; gap:2px; margin:0 8px; flex-shrink:0; }
.topbar-menu-item { padding:5px 12px; border-radius:6px; font-size:13px; font-weight:500; color:var(--text2); cursor:pointer; white-space:nowrap; border:none; background:transparent; transition:background 0.15s,color 0.15s; }
.topbar-menu-item:hover { background:var(--bg3); color:var(--accent); }

/* ─── CATEGORY NAV BAR ───────────────────────────────────────────────────── */
.cat-nav-bar { background:var(--catbar-bg,#1a2236); flex-shrink:0; width:100%; position:sticky; top:58px; z-index:19; }
.cat-nav-inner { display:flex; align-items:stretch; justify-content:space-between; height:42px; padding:0 8px; }
.cat-nav-tabs { display:flex; align-items:stretch; overflow-x:auto; scrollbar-width:none; }
.cat-nav-tabs::-webkit-scrollbar { display:none; }
.cat-nav-tab { padding:0 16px; border:none; background:transparent; color:rgba(255,255,255,0.75); font-size:13px; font-weight:500; cursor:pointer; white-space:nowrap; border-bottom:3px solid transparent; transition:color 0.15s,border-color 0.15s,background 0.15s; display:flex; align-items:center; user-select:none; }
.cat-nav-tab:hover { color:#fff; background:rgba(255,255,255,0.08); }
.cat-nav-tab.active { color:#fff; border-bottom-color:#3b82f6; background:rgba(255,255,255,0.05); }
.cat-nav-actions { display:flex; align-items:center; gap:8px; flex-shrink:0; padding:6px 0; }
.cat-nav-btn { padding:5px 14px; border-radius:6px; border:1px solid rgba(255,255,255,0.3); background:transparent; color:#fff; font-size:12.5px; font-weight:600; cursor:pointer; transition:background 0.15s; white-space:nowrap; }
.cat-nav-btn:hover { background:rgba(255,255,255,0.15); }
.cat-nav-sep { width:1px; background:rgba(255,255,255,0.15); margin:8px 4px; flex-shrink:0; }

/* ─── BUTTONS ────────────────────────────────────────────────────────────── */
.btn { padding:7px 14px; border-radius:8px; border:none; background:var(--accent); color:#fff; font-size:13px; font-weight:500; cursor:pointer; display:inline-flex; align-items:center; gap:6px; white-space:nowrap; flex-shrink:0; transition:background 0.15s,transform 0.1s; user-select:none; }
.btn:hover { background:var(--accent2); }
.btn:active { transform:scale(0.97); }
.btn-danger { background:var(--red); }
.btn-danger:hover { background:#b91c1c; }
.btn-outline { background:transparent; border:1px solid var(--border); color:var(--text2); }
.btn-outline:hover { background:var(--bg3); color:var(--accent); border-color:var(--accent); }
.btn-ghost { background:transparent; border:none; color:var(--text3); cursor:pointer; font-size:13px; padding:7px 8px; transition:color 0.15s; }
.btn-ghost:hover { color:var(--text); }
.btn-sm { padding:4px 8px; font-size:11px; }
.badge { background:var(--red); color:#fff; border-radius:999px; padding:1px 6px; font-size:11px; font-weight:600; line-height:1.5; }

/* ─── PAGE SECTIONS ──────────────────────────────────────────────────────── */
.page-section { display:none; padding:20px 22px; flex-shrink:0; }
.page-section.active { display:block; }
.properties-layout.active { display:flex; padding:0 !important; overflow:hidden; height:calc(100vh - 58px - 42px); }
.page-section h1 { font-size:20px; font-weight:700; color:var(--text); margin-bottom:16px; }
.page-section h2 { font-size:14px; font-weight:600; color:var(--text2); margin:14px 0 8px; text-transform:uppercase; letter-spacing:0.06em; }

/* ─── DASHBOARD ──────────────────────────────────────────────────────────── */
.stats { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:20px; }
.stats > div { background:var(--bg2); border-radius:12px; padding:16px 18px; box-shadow:0 2px 8px var(--shadow); border:1px solid var(--border); font-size:12px; color:var(--text3); font-weight:500; text-transform:uppercase; letter-spacing:0.05em; }
.stats span { display:block; margin-top:6px; font-size:22px; font-weight:700; color:var(--text); letter-spacing:0; text-transform:none; }
.dashboard-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.dashboard-panel { background:var(--bg2); border-radius:12px; padding:16px 18px; box-shadow:0 2px 8px var(--shadow); border:1px solid var(--border); overflow-y:auto; }
.dashboard-panel h2 { margin-top:0; }
.activity-empty { font-size:13px; color:var(--text3); padding:8px 0; }
.activity-row { display:flex; flex-wrap:wrap; gap:6px; align-items:baseline; padding:7px 0; border-bottom:1px solid var(--border); font-size:12px; }
.activity-row:last-child { border-bottom:none; }
.activity-ts { color:var(--text3); font-size:11px; }
.activity-user { background:#dbeafe; color:var(--accent); border-radius:999px; padding:1px 7px; font-size:11px; font-weight:600; }
body[data-theme="dark"] .activity-user { background:#1e3a8a; color:#93c5fd; }
.activity-action { font-weight:600; color:var(--text); }
.activity-details { color:var(--text3); font-style:italic; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:180px; }
.cat-stat-row { margin-bottom:14px; }
.cat-stat-name { font-size:13px; font-weight:600; color:var(--text); margin-bottom:4px; }
.cat-stat-bar-wrap { height:6px; background:var(--bg3); border-radius:999px; overflow:hidden; margin-bottom:5px; }
.cat-stat-bar { height:100%; background:linear-gradient(90deg,var(--accent),var(--green)); border-radius:999px; min-width:4px; }
.cat-stat-nums { display:flex; gap:10px; font-size:11px; flex-wrap:wrap; }
.cat-stat-total { font-weight:700; color:var(--text); }
.cat-stat-active { color:var(--green); }
.cat-stat-sold { color:var(--red); }
.cat-stat-rev { color:var(--text3); margin-left:auto; }

/* ─── PROP SIDEBAR FILTER ────────────────────────────────────────────────── */
.properties-layout { flex-direction:row !important; gap:0; padding:0 !important; min-height:calc(100vh - 58px - 42px); align-items:stretch; }
.prop-sidebar { width:230px; min-width:230px; background:var(--bg2); border-right:1px solid var(--border); padding:12px 0; overflow-y:auto; flex-shrink:0; display:flex; flex-direction:column; position:sticky; top:0; align-self:flex-start; max-height:100vh; }
.acc-block { border-bottom:1px solid var(--border); }
.acc-header { display:flex; align-items:center; justify-content:space-between; padding:12px 16px; cursor:pointer; font-size:11.5px; font-weight:800; text-transform:uppercase; letter-spacing:0.08em; color:var(--text2); user-select:none; transition:background 0.12s, color 0.12s; }
.acc-header:hover { background:var(--bg3); color:var(--accent); }
.acc-arrow { font-size:9px; color:var(--text3); transition:transform 0.2s; }
.acc-arrow.open { transform:rotate(180deg); }
.acc-body { padding:4px 16px 12px; display:flex; flex-direction:column; gap:4px; }
.filter-search-btn { width:calc(100% - 24px); margin:12px 12px 6px; padding:13px 14px; border-radius:10px; border:none; background:linear-gradient(135deg,#1d4ed8,#7c3aed); color:#fff; font-size:14px; font-weight:800; cursor:pointer; display:flex; align-items:center; justify-content:center; gap:8px; transition:transform 0.15s, box-shadow 0.15s; box-shadow:0 4px 14px rgba(29,78,216,0.35); letter-spacing:0.02em; }
.filter-search-btn:hover { transform:translateY(-2px); box-shadow:0 6px 20px rgba(29,78,216,0.45); }
.filter-search-btn:active { transform:translateY(0); }
.filter-results-badge { background:rgba(255,255,255,0.25); color:#fff; border-radius:999px; padding:1px 8px; font-size:11px; font-weight:700; }
.prop-filter-input, .prop-filter-select { width:100%; padding:9px 12px; border-radius:9px; border:1px solid var(--border); font-size:13px; background:var(--bg3); color:var(--text); outline:none; transition:border-color 0.15s, box-shadow 0.15s; box-sizing:border-box; }
.prop-filter-input:focus, .prop-filter-select:focus { border-color:var(--accent); box-shadow: 0 0 0 3px rgba(29,78,216,0.1); }
.prop-filter-range { display:flex; align-items:center; gap:6px; }
.prop-filter-range span { color:var(--text3); font-size:12px; flex-shrink:0; }
.prop-filter-range-input { flex:1; padding:6px 8px; border-radius:8px; border:1px solid var(--border); font-size:12px; background:var(--bg3); color:var(--text); outline:none; min-width:0; }
.prop-filter-range-input:focus { border-color:var(--accent); }
.prop-filter-radio { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--text2); cursor:pointer; user-select:none; padding:5px 0; }
.prop-filter-radio input[type="radio"] { accent-color:var(--accent); width:14px; height:14px; cursor:pointer; }
.prop-filter-radio:has(input:checked) { color:var(--text); font-weight:600; }
.prop-filter-check { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--text2); cursor:pointer; user-select:none; padding:5px 0; }
.prop-filter-check input[type="checkbox"] { accent-color:var(--accent); width:13px; height:13px; cursor:pointer; }
.city-check-item, .country-check-item { display:flex; align-items:center; gap:8px; font-size:12px; color:var(--text2); cursor:pointer; padding:3px 0; }
#resetFiltersBtn { width:calc(100% - 24px); margin:4px 12px 12px; padding:9px 14px; border-radius:9px; border:1px solid var(--border); background:transparent; color:var(--text3); font-size:12px; font-weight:600; cursor:pointer; transition:all 0.15s; }
#resetFiltersBtn:hover { background:var(--red); color:#fff; border-color:var(--red); }
.prop-filter-block { padding:10px 0; border-bottom:1px solid var(--border); }
.prop-filter-title { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.07em; color:var(--text3); margin-bottom:8px; }

/* ─── PROP MAIN ──────────────────────────────────────────────────────────── */
.prop-main { flex:1; display:flex; flex-direction:column; padding:16px 18px; min-width:0; }
.prop-results-bar { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; flex-shrink:0; }
.prop-results-count { font-size:14px; color:var(--text2); font-weight:600; }
.prop-results-count { font-size:13px; color:var(--text3); font-weight:500; }

/* ─── PROPERTY CARDS ─────────────────────────────────────────────────────── */
.property-list { display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:16px; }
.property-list-card { background:var(--bg2); border:1px solid var(--border); border-radius:12px; display:flex; flex-direction:column; overflow:hidden; box-shadow:0 2px 6px var(--shadow); transition:box-shadow 0.2s,transform 0.2s; position:relative; }
.property-list-card:hover { box-shadow:0 6px 20px var(--shadow2); transform:translateY(-2px); }
.property-list-img { width:100%; height:200px; background-size:cover; background-position:center; background-color:var(--bg3); cursor:pointer; position:relative; flex-shrink:0; }
.property-list-placeholder { width:100%; height:100%; display:flex; align-items:center; justify-content:center; font-size:40px; color:var(--text3); }
.property-list-badge { position:absolute; top:10px; left:10px; padding:3px 10px; border-radius:6px; font-size:10px; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; z-index:2; }
.property-list-badge--active { background:var(--green); color:#fff; }
.property-list-badge--sold { background:var(--red); color:#fff; }
.property-list-badge--pending { background:#f59e0b; color:#fff; }
.property-list-badge--expired { background:#6b7280; color:#fff; }
.property-list-info { flex:1; padding:14px 16px; display:flex; flex-direction:column; min-width:0; }
.property-list-title { font-size:16px; font-weight:700; color:var(--text); margin-bottom:4px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.property-list-location { font-size:13px; color:var(--text3); margin-bottom:8px; }
.property-list-meta { display:flex; gap:14px; font-size:13px; color:var(--text2); margin-bottom:8px; flex-wrap:wrap; }
.property-list-desc { font-size:13px; color:var(--text3); line-height:1.5; flex:1; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.property-list-footer { display:flex; align-items:flex-start; justify-content:space-between; margin-top:10px; padding-top:10px; border-top:1px solid var(--border); gap:8px; flex-wrap:wrap; }
.property-list-price { font-size:20px; font-weight:800; color:var(--accent); }
.property-list-actions { display:flex; gap:4px; align-items:center; flex-shrink:0; flex-wrap:wrap; max-width:100%; }
.property-list-type { font-size:11px; font-weight:600; padding:2px 8px; border-radius:999px; text-transform:uppercase; letter-spacing:0.05em; }
.property-list-type.sale { background:#dbeafe; color:#1d4ed8; }
.property-list-type.rent { background:#dcfce7; color:#16a34a; }
body[data-theme="dark"] .property-list-type.sale { background:#1e3a8a; color:#93c5fd; }
body[data-theme="dark"] .property-list-type.rent { background:#14532d; color:#86efac; }
.property-plan-badge { position:absolute; top:10px; right:10px; padding:3px 10px; border-radius:6px; font-size:10px; font-weight:800; letter-spacing:0.08em; z-index:3; text-transform:uppercase; }
.property-plan-badge--premium { background:#f59e0b; color:#fff; }
.property-plan-badge--standard { background:#3b82f6; color:#fff; }
.property-list-card--premium { border-color:#f59e0b; box-shadow:0 4px 16px rgba(245,158,11,0.2); }
.property-list-card--standard { border-color:#3b82f6; }
.no-results { text-align:center; padding:60px 20px; color:var(--text3); font-size:15px; }
.no-results-icon { font-size:48px; margin-bottom:12px; }

/* ─── CATEGORIES ─────────────────────────────────────────────────────────── */
.category-input-row { display:flex; align-items:center; gap:10px; margin-top:16px; }
#newCategoryName { flex:1; max-width:320px; padding:8px 12px; border-radius:8px; border:1px solid var(--border); font-size:13px; outline:none; background:var(--bg2); color:var(--text); }
.category-row { display:flex; align-items:center; padding:9px 12px; border-radius:8px; border:1px solid var(--border); margin-bottom:6px; background:var(--bg2); gap:10px; }
.category-row.dragging { opacity:0.4; }
.category-row.drag-over { background:#dbeafe; box-shadow:0 0 0 2px var(--accent); }
body[data-theme="dark"] .category-row.drag-over { background:#1e3a8a; }
.drag-handle { cursor:grab; font-size:16px; color:var(--text3); user-select:none; }
.category-label { flex:1; font-size:14px; color:var(--text); }

/* ─── SETTINGS ───────────────────────────────────────────────────────────── */
#settings label { display:block; font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:0.07em; color:var(--text3); margin:14px 0 4px; }
#settings input, #settings select { width:100%; max-width:360px; padding:8px 12px; border-radius:8px; border:1px solid var(--border); font-size:13px; background:var(--bg2); color:var(--text); outline:none; }
#settings .btn { width:auto; margin-top:12px; margin-right:8px; display:inline-flex; }
.settings-divider { border:none; border-top:1px solid var(--border); margin:24px 0 8px; }
#settings h2 { font-size:14px; font-weight:700; margin:8px 0 12px; color:var(--text2); }
.footer-settings-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; max-width:720px; margin-top:8px; }
.footer-settings-grid > div { display:flex; flex-direction:column; }
.footer-settings-grid label { font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:0.07em; color:var(--text3); margin-bottom:4px; }
.footer-settings-grid input { padding:8px 12px; border-radius:8px; border:1px solid var(--border); font-size:13px; background:var(--bg2); color:var(--text); outline:none; }

/* ─── MODALS ─────────────────────────────────────────────────────────────── */
.modal { position:fixed; inset:0; background:rgba(0,0,0,0.5); display:none; align-items:center; justify-content:center; z-index:3000; padding:16px; }
.modal-content { background:#ffffff; border-radius:14px; padding:20px 22px; width:400px; max-width:100%; max-height:90vh; overflow-y:auto; box-shadow:0 20px 50px rgba(0,0,0,0.3); border:1px solid var(--border); }
.modal-content--wide { width:540px; }
.modal-content h2 { font-size:17px; font-weight:700; margin-bottom:14px; color:var(--text); }
.modal-content label { display:block; font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:0.07em; color:var(--text3); margin:10px 0 3px; }
.modal-content input, .modal-content select, .modal-content textarea { width:100%; margin-bottom:4px; padding:8px 10px; border-radius:8px; border:1px solid var(--border); font-size:13px; background:var(--bg3); color:var(--text); outline:none; font-family:inherit; }
.modal-content textarea { resize:vertical; }
.modal-row { display:flex; gap:10px; margin-bottom:2px; }
.modal-col { flex:1; min-width:0; }
.modal-actions { display:flex; gap:10px; align-items:center; margin-top:14px; }
.modal-close { background:transparent; border:none; color:var(--text3); cursor:pointer; font-size:13px; padding:6px 4px; }
.modal-close:hover { color:var(--text); }
.image-preview-row { display:flex; flex-wrap:wrap; gap:8px; margin:8px 0 12px; }
.image-thumb-preview { width:72px; height:72px; object-fit:cover; border-radius:8px; border:2px solid var(--border); display:block; }
.existing-images-label { font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:0.06em; color:var(--text3); margin-bottom:6px; }
.existing-images-row { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:4px; }
.existing-img-wrap { position:relative; display:inline-block; }
.existing-img-del { position:absolute; top:-6px; right:-6px; width:20px; height:20px; border-radius:999px; border:none; background:var(--red); color:#fff; font-size:10px; cursor:pointer; display:flex; align-items:center; justify-content:center; padding:0; }

/* ─── FULLSCREEN ─────────────────────────────────────────────────────────── */
.fullscreen { position:fixed; inset:0; background:rgba(0,0,0,0.96); display:none; align-items:center; justify-content:center; flex-direction:column; z-index:4000; }
.fullscreen.active { display:flex; }
.fullscreen img { max-width:100vw; max-height:80vh; object-fit:contain; }
#fsImage { max-width:90%; max-height:80vh; border-radius:12px; box-shadow:0 25px 60px rgba(0,0,0,0.7); transition:transform 0.25s ease; object-fit:contain; }
#fsImage.zoomed { transform:scale(1.6); cursor:zoom-out; }
#fsCaption { margin-top:12px; color:#e2e8f0; font-size:14px; text-align:center; }
#fsCounter { margin-top:4px; color:#94a3b8; font-size:12px; }
.fs-btn { position:absolute; top:50%; transform:translateY(-50%); background:rgba(255,255,255,0.12); border:none; color:#fff; padding:10px 14px; border-radius:999px; cursor:pointer; font-size:18px; transition:background 0.15s; }
.fs-btn:hover { background:rgba(255,255,255,0.22); }
#fsPrev { left:24px; }
#fsNext { right:24px; }
#fsClose { top:20px; right:22px; transform:none; font-size:14px; padding:8px 14px; }
#fsDelete, #fsAdd { bottom:24px; top:auto; transform:none; font-size:14px; padding:8px 14px; }
#fsDelete { left:24px; background:rgba(220,38,38,0.7); }
#fsAdd { right:24px; }
.stat-label { display:block; font-size:12px; color:var(--text3); font-weight:500; text-transform:uppercase; letter-spacing:0.05em; margin-bottom:4px; }
.notif-row { display:flex; align-items:flex-start; justify-content:space-between; gap:10px; padding:8px 0; border-bottom:1px solid var(--border); font-size:13px; }
.notif-text { flex:1; color:var(--text2); line-height:1.5; }
.notif-del-btn { background:transparent; border:none; color:var(--text3); cursor:pointer; font-size:12px; padding:2px 6px; border-radius:4px; }
.notif-del-btn:hover { background:var(--red); color:#fff; }
.pagination-bar { display:flex; align-items:center; gap:6px; padding:16px 0 8px; flex-wrap:wrap; }
.pagination-info { font-size:13px; color:var(--text3); margin-right:8px; }

/* ─── USERS & ADMIN ROWS ─────────────────────────────────────────────────── */
.pending-row { display:flex; align-items:flex-start; justify-content:space-between; gap:14px; padding:12px 14px; border:1px solid #f59e0b; border-left:4px solid #f59e0b; border-radius:10px; background:var(--bg2); margin-bottom:10px; }
.pending-info { flex:1; min-width:0; }
.pending-title { font-size:14px; font-weight:700; color:var(--text); margin-bottom:4px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pending-meta { font-size:12px; color:var(--text3); margin-bottom:6px; }
.pending-tags { display:flex; gap:6px; flex-wrap:wrap; }
.pending-plan { padding:2px 8px; border-radius:999px; font-size:11px; font-weight:700; color:#fff; }
.pending-ref { font-size:11px; color:var(--text3); background:var(--bg3); padding:2px 8px; border-radius:999px; }
.pending-actions { display:flex; gap:6px; flex-shrink:0; flex-wrap:wrap; }
.user-admin-row { display:flex; align-items:flex-start; justify-content:space-between; gap:14px; padding:12px 14px; border:1px solid var(--border); border-radius:10px; background:var(--bg2); margin-bottom:8px; }
.user-admin-info { flex:1; min-width:0; }
.user-admin-name { display:flex; align-items:center; gap:6px; font-size:14px; margin-bottom:4px; }
.user-admin-meta { font-size:12px; color:var(--text3); margin-bottom:4px; }
.user-admin-stats { display:flex; gap:10px; font-size:12px; flex-wrap:wrap; }

/* ─── FAVORITES ──────────────────────────────────────────────────────────── */
.fav-active { border-color:#ef4444 !important; color:#ef4444 !important; }
.fav-row { display:flex; align-items:center; gap:12px; padding:10px; border:1px solid var(--border); border-radius:10px; background:var(--bg2); }
.fav-img { width:80px; height:60px; border-radius:8px; background-size:cover; background-position:center; background-color:var(--bg3); flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:24px; }
.fav-title { font-size:14px; font-weight:700; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; margin-bottom:2px; }
.fav-location { font-size:12px; color:var(--text3); margin-bottom:4px; }
.fav-price { font-size:15px; font-weight:800; color:var(--accent); }
.fav-actions { display:flex; flex-direction:column; gap:6px; }

/* ─── USER AUTH ──────────────────────────────────────────────────────────── */
.user-auth-btns { display:flex; gap:6px; align-items:center; }
.user-logged-in { display:flex; align-items:center; gap:8px; }
.user-name { font-size:13px; font-weight:600; color:var(--text); white-space:nowrap; }
.user-dropdown-wrap { position:relative; }
.user-dropdown-btn { display:flex; align-items:center; gap:6px; padding:6px 12px; border-radius:8px; border:1px solid var(--border); background:var(--bg3); color:var(--text); font-size:13px; font-weight:600; cursor:pointer; white-space:nowrap; }
.user-dropdown-menu { display:none; position:fixed; background:var(--bg2); border:1px solid var(--border); border-radius:10px; box-shadow:0 8px 24px var(--shadow2); min-width:200px; z-index:999999; padding:4px 0; }
.user-dropdown-wrap.open .user-dropdown-menu { display:block; }
.user-dropdown-item { padding:10px 16px; font-size:13px; color:var(--text2); cursor:pointer; transition:background 0.12s; display:flex; align-items:center; gap:8px; }
.user-dropdown-item:hover { background:var(--bg3); color:var(--text); }
.user-dropdown-item--danger { color:var(--red); }
.user-dropdown-divider { height:1px; background:var(--border); margin:4px 0; }
.pwd-toggle { position:absolute; right:8px; top:50%; transform:translateY(-50%); background:none; border:none; cursor:pointer; font-size:16px; padding:2px; opacity:0.6; }
.pwd-toggle:hover { opacity:1; }

/* ─── MY LISTINGS TABS ───────────────────────────────────────────────────── */
.my-listings-tab { padding:6px 14px; border-radius:8px; border:1px solid var(--border); background:var(--bg2); color:var(--text2); font-size:13px; font-weight:500; cursor:pointer; transition:all 0.15s; }
.my-listings-tab:hover { background:var(--bg3); color:var(--accent); }
.my-listings-tab.active { background:var(--accent); color:#fff; border-color:var(--accent); }

/* ─── REGISTER TYPE ──────────────────────────────────────────────────────── */
.reg-type-row { display:flex; gap:10px; margin-bottom:4px; }
.reg-type-option { flex:1; display:flex; align-items:center; gap:8px; padding:8px 12px; border:2px solid var(--border); border-radius:8px; cursor:pointer; font-size:13px; font-weight:500; color:var(--text2); }
.reg-type-option:has(input:checked) { border-color:var(--accent); background:#dbeafe; color:var(--accent); }
body[data-theme="dark"] .reg-type-option:has(input:checked) { background:#1e3a8a; color:#93c5fd; }
.reg-type-option input[type="radio"] { display:none; }
.my-ad-row { display:flex; align-items:center; justify-content:space-between; padding:10px 0; border-bottom:1px solid var(--border); gap:12px; }
.my-ad-info { display:flex; flex-direction:column; gap:3px; flex:1; }
.my-ad-status { display:inline-block; padding:2px 8px; border-radius:999px; font-size:11px; font-weight:600; }
.my-ad-status--active { background:#dcfce7; color:#16a34a; }
.my-ad-status--pending { background:#fef3c7; color:#d97706; }
.my-ad-status--sold { background:#fee2e2; color:#dc2626; }
.my-ad-status--expired { background:#e5e7eb; color:#6b7280; }
body[data-theme="dark"] .my-ad-status--active { background:#14532d; color:#86efac; }
body[data-theme="dark"] .my-ad-status--pending { background:#451a03; color:#fcd34d; }

/* ─── PLANS ──────────────────────────────────────────────────────────────── */
.plans-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-bottom:8px; }
.plan-card { border:2px solid var(--border); border-radius:14px; overflow:hidden; transition:transform 0.2s,box-shadow 0.2s; background:var(--bg2); }
.plan-card:hover { transform:translateY(-4px); box-shadow:0 12px 30px var(--shadow2); }
.plan-card-header { padding:16px; display:flex; align-items:center; justify-content:space-between; color:#fff; }
.plan-card-name { font-size:16px; font-weight:800; }
.plan-card-badge { background:rgba(255,255,255,0.25); padding:2px 8px; border-radius:999px; font-size:11px; font-weight:700; }
.plan-card-price { font-size:28px; font-weight:800; color:var(--text); padding:16px 16px 4px; }
.plan-card-duration { font-size:12px; color:var(--text3); padding:0 16px 12px; }
.plan-card-benefits { list-style:none; padding:12px 16px; margin:0; border-top:1px solid var(--border); }
.plan-card-benefits li { font-size:13px; color:var(--text2); padding:3px 0; }
.plan-card-btn { width:calc(100% - 32px); margin:0 16px 16px; justify-content:center; font-size:13px; font-weight:700; border-radius:8px; }
.payment-amount { display:flex; align-items:center; justify-content:space-between; padding:12px 14px; background:var(--bg3); border-radius:10px; margin-bottom:14px; font-size:14px; color:var(--text2); }
.payment-ref { font-size:13px; color:var(--text3); margin-bottom:14px; padding:8px 12px; background:var(--bg3); border-radius:8px; border-left:3px solid var(--accent); }
.payment-method { border:1px solid var(--border); border-radius:10px; overflow:hidden; margin-bottom:10px; }
.payment-method-title { background:var(--bg3); padding:10px 14px; font-size:13px; font-weight:700; color:var(--text); border-bottom:1px solid var(--border); }
.payment-method-body { padding:12px 14px; display:flex; flex-direction:column; gap:6px; font-size:13px; color:var(--text2); }
.plan-editor-row { border:1px solid var(--border); border-radius:10px; padding:14px; margin-bottom:12px; background:var(--bg3); }
.plan-editor-header { display:flex; align-items:center; justify-content:space-between; padding-left:10px; margin-bottom:10px; font-size:14px; }
.plan-editor-fields { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-bottom:8px; }
.plan-editor-field label { display:block; font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:0.06em; color:var(--text3); margin-bottom:4px; }
.plan-field-input { width:100%; padding:7px 9px; border-radius:7px; border:1px solid var(--border); font-size:13px; background:var(--bg2); color:var(--text); outline:none; font-family:inherit; }
.prop-feature-tag { display:inline-flex; align-items:center; gap:3px; padding:2px 8px; border-radius:999px; font-size:11px; font-weight:600; background:var(--bg3); border:1px solid var(--border); color:var(--text2); white-space:nowrap; }

/* ─── FLAG SELECT ────────────────────────────────────────────────────────── */
.flag-select { position:relative; width:100%; }
.flag-select-btn { display:flex; align-items:center; gap:8px; padding:7px 10px; background:rgba(255,255,255,0.1); border:1px solid rgba(255,255,255,0.2); border-radius:8px; cursor:pointer; color:#ffffff; font-size:13px; user-select:none; width:100%; }
.flag-select-flag { font-size:18px; line-height:1; flex-shrink:0; }
.flag-select-text { flex:1; font-weight:500; }
.flag-select-arrow { font-size:10px; opacity:0.6; transition:transform 0.2s; }
.flag-select.open .flag-select-arrow { transform:rotate(180deg); }
.flag-select-dropdown { display:none; position:absolute; bottom:calc(100% + 4px); left:0; right:0; background:#1e2535; border:1px solid rgba(255,255,255,0.12); border-radius:10px; box-shadow:0 8px 24px rgba(0,0,0,0.4); z-index:100; max-height:260px; overflow-y:auto; }
.flag-select.open .flag-select-dropdown { display:block; }
.flag-option { display:flex; align-items:center; gap:10px; padding:8px 12px; font-size:13px; color:rgba(255,255,255,0.8); cursor:pointer; }
.flag-option:hover { background:rgba(255,255,255,0.1); }
.flag-option.selected { background:rgba(59,130,246,0.3); color:#fff; font-weight:600; }
.flag-option span { font-size:18px; flex-shrink:0; }

/* ─── CONTACT FORM ───────────────────────────────────────────────────────── */
.contact-form { max-width:560px; margin:20px 0; padding:24px; background:var(--bg2); border-radius:12px; border:1px solid var(--border); box-shadow:0 2px 8px var(--shadow); }
.cf-field { display:flex; flex-direction:column; margin-bottom:14px; }
.cf-label { font-size:12px; font-weight:600; text-transform:uppercase; letter-spacing:0.06em; color:var(--text3); margin-bottom:5px; }
.cf-input { padding:9px 12px; border-radius:8px; border:1px solid var(--border); font-size:13px; background:var(--bg3); color:var(--text); outline:none; font-family:inherit; }
.cf-input:focus { border-color:var(--accent); }
.cf-textarea { resize:vertical; min-height:100px; }

/* ─── CUSTOM PAGES ───────────────────────────────────────────────────────── */
.custom-page-header { display:flex; align-items:center; gap:12px; margin-bottom:20px; }
.custom-page-body { font-size:15px; line-height:1.8; color:var(--text2); max-width:800px; }
.custom-page-body h2 { font-size:22px; font-weight:700; color:var(--text); margin:24px 0 10px; text-transform:none; letter-spacing:0; }
.custom-page-body h3 { font-size:17px; font-weight:600; color:var(--text); margin:18px 0 8px; }
.custom-page-body p { margin-bottom:14px; }
.custom-page-body ul { padding-left:20px; margin-bottom:14px; }
.custom-page-body hr { border:none; border-top:1px solid var(--border); margin:20px 0; }
.custom-page-body a { color:var(--accent); text-decoration:underline; }
.custom-page-nav-item { display:flex; align-items:center; gap:10px; padding:8px 12px; background:var(--bg3); border-radius:8px; border:1px solid var(--border); }
.page-card { display:inline-flex; flex-direction:column; width:260px; border-radius:12px; border:1px solid var(--border); background:var(--bg2); box-shadow:0 2px 8px var(--shadow); overflow:hidden; margin:8px; vertical-align:top; transition:transform 0.2s,box-shadow 0.2s; }
.page-card:hover { transform:translateY(-3px); box-shadow:0 8px 24px var(--shadow2); }
.page-card-img-wrap { position:relative; width:100%; height:180px; flex-shrink:0; }
.page-card-img { width:100%; height:100%; background-size:cover; background-position:center; background-color:var(--bg3); }
.page-card-badge { position:absolute; top:10px; left:10px; padding:3px 10px; border-radius:6px; font-size:10px; font-weight:700; text-transform:uppercase; color:#fff; }
.page-card-info { padding:12px 14px 14px; display:flex; flex-direction:column; gap:6px; }
.page-card-title { font-size:15px; font-weight:700; color:var(--text); }
.page-card-extra { font-size:12px; color:var(--text3); }
.page-card-desc { font-size:13px; color:var(--text2); line-height:1.5; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }

/* ─── BANNERS ────────────────────────────────────────────────────────────── */
.ad-package-card { padding:14px; border-radius:10px; background:var(--bg2); cursor:pointer; text-align:center; transition:all 0.15s; }
.ad-package-card.selected { border-color:var(--accent) !important; background:var(--bg3); }
.banner-top { width:100%; border-radius:10px; overflow:hidden; cursor:pointer; position:relative; margin-bottom:10px; }
.banner-top-inner { height:72px; background:linear-gradient(90deg,#0f172a,#1e3a8a,#7c3aed); display:flex; align-items:center; padding:0 20px; gap:16px; }
.banner-top-img { width:48px; height:48px; border-radius:10px; object-fit:contain; background:rgba(255,255,255,0.15); flex-shrink:0; }
.banner-top-logo-placeholder { width:48px; height:48px; border-radius:10px; background:rgba(255,255,255,0.15); display:flex; align-items:center; justify-content:center; font-size:18px; font-weight:800; color:#fff; flex-shrink:0; }
.banner-top-name { font-size:15px; font-weight:700; color:#fff; }
.banner-top-desc { font-size:12px; color:rgba(255,255,255,0.65); margin-top:2px; }
.banner-top-cta { background:#fff; color:#1e3a8a; border:none; border-radius:8px; padding:8px 20px; font-size:13px; font-weight:700; cursor:pointer; flex-shrink:0; }
.banner-top-info { flex:1; }
.banner-sponsored { position:absolute; top:7px; right:110px; font-size:9px; font-weight:700; text-transform:uppercase; color:rgba(255,255,255,0.35); }
.banner-sidebar { border-radius:10px; border:1px solid var(--border); background:var(--bg2); overflow:hidden; cursor:pointer; }
.banner-sidebar-img { width:100%; height:80px; object-fit:cover; }
.banner-sidebar-body { padding:10px 12px; }
.banner-sidebar-name { font-size:13px; font-weight:700; color:var(--text); margin-bottom:3px; }
.banner-sidebar-desc { font-size:11px; color:var(--text3); }
.banner-inline { border-radius:10px; border:1px dashed var(--border); background:var(--bg2); padding:12px 16px; display:flex; align-items:center; gap:12px; cursor:pointer; }
.banner-inline-img { width:60px; height:40px; object-fit:contain; border-radius:6px; flex-shrink:0; }
.footer-newsletter-btn { margin-bottom:14px; padding:6px 14px; border-radius:8px; border:1px solid rgba(255,255,255,0.3); background:transparent; color:var(--footer-text,#94a3b8); font-size:12px; font-weight:600; cursor:pointer; transition:all 0.15s; }
.footer-newsletter-btn:hover { background:rgba(255,255,255,0.1); color:#fff; }

/* ─── FOOTER ─────────────────────────────────────────────────────────────── */
.app-footer { background:var(--footer-bg,#1e293b); color:var(--footer-text,#94a3b8); flex-shrink:0; border-top:1px solid var(--footer-border,#2d3a50); }
.footer-inner { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:32px; padding:32px 36px 24px; }
.footer-logo { font-size:16px; font-weight:800; color:var(--footer-heading,#fff); letter-spacing:0.03em; margin-bottom:6px; }
.footer-tagline { font-size:12px; color:var(--footer-text2,#64748b); margin-bottom:14px; }
.footer-social { display:flex; gap:8px; }
.footer-social-btn { width:32px; height:32px; border-radius:8px; background:var(--footer-social-bg,#2d3a50); color:var(--footer-text,#94a3b8); display:flex; align-items:center; justify-content:center; text-decoration:none; font-size:13px; font-weight:700; }
.footer-social-btn:hover { background:var(--accent); color:#fff; }
.footer-col-title { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.1em; color:var(--footer-heading,#fff); margin-bottom:12px; }
.footer-links { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px; }
.footer-links li, .footer-links a { font-size:13px; color:var(--footer-text2,#64748b); text-decoration:none; cursor:pointer; }
.footer-links a:hover { color:var(--footer-heading,#fff); }
.footer-bottom { border-top:1px solid var(--footer-bottom-border,#2d3a50); padding:14px 36px; display:flex; align-items:center; justify-content:space-between; font-size:12px; color:var(--footer-text2,#475569); flex-wrap:wrap; gap:8px; }
.footer-bottom-links { display:flex; gap:16px; }
.footer-bottom-links a { color:var(--footer-text2,#475569); text-decoration:none; }
.footer-payment { margin-top:16px; }
.footer-payment-title { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:0.1em; color:var(--footer-text2,#475569); margin-bottom:8px; }
.footer-payment-icons { display:flex; flex-wrap:wrap; gap:6px; }
.footer-payment-badge { display:inline-flex; align-items:center; gap:5px; background:#1e2535; border:1px solid #2d3a52; border-radius:6px; padding:4px 10px; font-size:12px; font-weight:700; color:#94a3b8; white-space:nowrap; }

@keyframes pop { 0% { transform:scale(0.5); opacity:0; } 70% { transform:scale(1.2); } 100% { transform:scale(1); opacity:1; } }
@keyframes slideInRight { from { transform:translateX(120%); opacity:0; } to { transform:translateX(0); opacity:1; } }
@keyframes slideInUp { from { transform:translateY(40px); opacity:0; } to { transform:translateY(0); opacity:1; } }

/* ─── TRIAL BANNER ───────────────────────────────────────────────────────── */
#trialBanner { animation: slideInRight 0.35s ease; }

/* ─── AGENT CARD ─────────────────────────────────────────────────────────── */
.agent-card {
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 14px;
    display: flex;
    align-items: center;
    gap: 12px;
    transition: box-shadow 0.15s;
}
.agent-card:hover { box-shadow: 0 4px 16px var(--shadow); }
.agent-avatar {
    width: 44px; height: 44px; border-radius: 999px;
    display: flex; align-items: center; justify-content: center;
    font-size: 18px; font-weight: 800; color: #fff; flex-shrink: 0;
}

/* ─── RESPONSIVE — MOBILE ────────────────────────────────────────────────── */
@media (max-width:1100px) { .stats { grid-template-columns:repeat(2,1fr); } .dashboard-grid { grid-template-columns:1fr; } }

@media (max-width:768px) {
    /* Topbar compact */
    .topbar { padding:0 10px; gap:8px; height:52px; min-height:52px; }
    .topbar-search { max-width:160px; font-size:12px; }
    .topbar-menu { display:none; }
    #notifBtn span[data-i18n] { display:none; }

    /* Cat nav compact */
    .cat-nav-bar { top:52px; }
    .cat-nav-tab { padding:0 10px; font-size:12px; }
    .cat-nav-btn { padding:4px 10px; font-size:11px; }

    /* Properties layout — stack vertically */
    .properties-layout.active {
        flex-direction: column !important;
        height: auto !important;
        overflow: visible !important;
    }
    .prop-sidebar {
        display: none !important;
    }
    .prop-sidebar.open {
        display: flex !important;
        width: 100% !important;
        min-width: unset !important;
        max-height: none !important;
        position: static !important;
        border-right: none;
        border-bottom: 1px solid var(--border);
    }
    .prop-main { padding: 12px; }

    /* Grid — single column on small screens */
    .property-list { grid-template-columns: 1fr !important; }

    /* Stats — 2 col */
    .stats { grid-template-columns: repeat(2,1fr); gap:10px; }

    /* Dashboard */
    .dashboard-grid { grid-template-columns: 1fr; }

    /* Plans */
    .plans-grid { grid-template-columns: 1fr !important; }

    /* Footer compact */
    .footer-inner { grid-template-columns: 1fr 1fr; gap:20px; padding:20px; }
    .footer-bottom { padding:12px 20px; }

    /* Modal full-width */
    .modal-content { width: 95vw !important; max-width: 95vw !important; padding: 16px !important; }
    .modal-content--wide { width: 95vw !important; }

    /* My listings grid */
    #myListingsGrid { grid-template-columns: 1fr !important; }
}

@media (max-width:480px) {
    .sidebar { width:100%; min-width:unset; height:auto; flex-direction:row; overflow-x:auto; border-right:none; border-bottom:1px solid var(--border); padding:8px; }
    .sidebar-logo, .sidebar-footer { display:none; }
    .nav { flex-direction:row; gap:2px; padding:0; }
    .nav-item { white-space:nowrap; font-size:11px; padding:6px 8px; border-radius:6px; }
    .nav-item-icon { display:none; }
    body { flex-direction:column; overflow:auto; height:auto; }
    .main { height:auto; overflow-y:visible; }
    .topbar-appname { display:none; }
    .stats { grid-template-columns: 1fr 1fr; }
    .user-name { max-width: 80px; overflow: hidden; text-overflow: ellipsis; }
    #favoritesBtn span, #myAdsBtn span { display:none; }
    .property-list-card { border-radius:10px; }
    .cat-nav-tab { font-size:11px; padding:0 8px; }
    .footer-inner { grid-template-columns: 1fr; }
}
/* ═══════════════════════════════════════════════════════════════════════════
   MOBILNA OPTIMIZACIJA — poboljšana verzija
   ═══════════════════════════════════════════════════════════════════════════ */

/* ─── Velika CTA dugmad ──────────────────────────────────────────────────── */
.btn-cta-large {
    padding: 14px 28px !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    border-radius: 12px !important;
    min-height: 50px;
}

/* Add listing button — velika CTA */
.cat-nav-btn {
    background: var(--accent) !important;
    color: #fff !important;
    font-weight: 700 !important;
    border-radius: 8px !important;
    padding: 8px 18px !important;
    font-size: 13px !important;
    transition: transform 0.15s, box-shadow 0.15s !important;
}
.cat-nav-btn:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(29,78,216,0.3) !important;
}

/* Filter search button — velika CTA */
.filter-search-btn {
    background: var(--accent) !important;
    color: #fff !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    padding: 12px !important;
    border-radius: 10px !important;
    min-height: 46px !important;
    transition: transform 0.15s, box-shadow 0.15s !important;
}
.filter-search-btn:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(29,78,216,0.3) !important;
}

/* ─── Touch-friendly targets (min 44px) ─────────────────────────────────── */
@media (max-width: 768px) {
    /* Sve dugmadi touch-friendly */
    .btn, button {
        min-height: 40px;
        touch-action: manipulation;
    }

    /* Sidebar sakrij na mobilnom — hamburger menu */
    .sidebar {
        position: fixed !important;
        left: -280px !important;
        top: 0 !important;
        height: 100vh !important;
        z-index: 200 !important;
        transition: left 0.3s ease !important;
        box-shadow: none !important;
        width: 280px !important;
        min-width: 0 !important;
        flex: 0 0 0px !important;
    }
    .sidebar.open {
        left: 0 !important;
        box-shadow: 4px 0 20px rgba(0,0,0,0.3) !important;
    }
    .main {
        margin-left: 0 !important;
        width: 100vw !important;
        max-width: 100vw !important;
        flex: 1 1 auto !important;
        overflow-x: hidden !important;
    }

    /* Hamburger dugme */
    #hamburgerBtn {
        display: flex !important;
        align-items: center;
        justify-content: center;
        width: 40px;
        height: 40px;
        background: none;
        border: none;
        cursor: pointer;
        font-size: 22px;
        color: var(--text);
        flex-shrink: 0;
    }

    /* Topbar search — širi */
    .topbar-search {
        flex: 1 !important;
        max-width: 100% !important;
    }

    /* Skloni nebitne topbar elemente */
    .topbar-brand { display: none !important; }
    #favoritesBtn { display: none !important; }
    #myAdsBtn { display: none !important; }
    #topbarClock { display: none !important; }
    #alertsBtn { display: none !important; }
    #topbarMenu { display: none !important; }
    .topbar-spacer { display: none !important; }
    #inboxBtn { display: none !important; }
    .topbar-search { max-width: 140px !important; flex: 1 !important; }
    .topbar { flex-wrap: nowrap !important; gap: 4px !important; padding: 0 8px !important; }
    #userAuthBtns { display: flex !important; gap: 4px !important; }
    #userAuthBtns .btn { padding: 6px 8px !important; font-size: 11px !important; white-space: nowrap !important; }

    /* Property cards — full width, veći touch target */
    .property-list-card {
        width: 100% !important;
    }
    .property-list-img {
        height: 200px !important;
    }

    /* Prop sidebar — collapsible */
    .prop-sidebar {
        display: none;
    }
    .prop-sidebar.open {
        display: flex !important;
    }

    /* Filter toggle dugme */
    #filterToggleBtn {
        display: flex !important;
        align-items: center;
        gap: 8px;
        background: var(--bg2);
        border: 1px solid var(--border);
        border-radius: 8px;
        padding: 8px 14px;
        font-size: 13px;
        font-weight: 600;
        cursor: pointer;
        color: var(--text);
        margin-bottom: 10px;
    }

    /* Modal — full screen na mobilnom */
    .modal-content {
        width: 100vw !important;
        max-width: 100vw !important;
        max-height: 95vh !important;
        border-radius: 16px 16px 0 0 !important;
        position: fixed !important;
        bottom: 0 !important;
        left: 0 !important;
        margin: 0 !important;
        overflow-y: auto !important;
    }
    .modal {
        align-items: flex-end !important;
    }

    /* Plans grid — single column */
    .plans-grid { grid-template-columns: 1fr !important; }

    /* Footer — single column */
    .footer-inner { grid-template-columns: 1fr !important; }

    /* Admin panel buttons — wrap */
    #adminPanel > div[style*="flex-wrap"] {
        gap: 6px !important;
    }
    #adminPanel .btn {
        font-size: 12px !important;
        padding: 8px 12px !important;
    }

    /* Property detail modal images */
    #pdImages { height: 200px !important; }

    /* Pending row — stack vertically */
    .pending-row {
        flex-direction: column !important;
        gap: 10px !important;
    }
    .pending-actions {
        width: 100% !important;
        justify-content: stretch !important;
    }
    .pending-actions .btn {
        flex: 1 !important;
    }
}

/* ─── Extra small phones (< 380px) ─────────────────────────────────────── */
@media (max-width: 380px) {
    .topbar { padding: 0 8px !important; gap: 6px !important; }
    .cat-nav-tab { font-size: 11px !important; padding: 0 6px !important; }
    .property-list-price { font-size: 16px !important; }
    .stats { grid-template-columns: 1fr !important; }
}

/* ─── Dark mode auto poboljšanja ────────────────────────────────────────── */
#darkModeToggle {
    padding: 6px 10px !important;
    font-size: 18px !important;
    line-height: 1 !important;
}

/* ─── Hamburger fix ──────────────────────────────────────────────────────── */
#hamburgerBtn {
    display: none;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    min-width: 40px;
    background: none;
    border: 1px solid var(--border);
    border-radius: 8px;
    cursor: pointer;
    font-size: 20px;
    color: var(--text);
    flex-shrink: 0;
    padding: 0;
    line-height: 1;
}

@media (max-width: 768px) {
    #hamburgerBtn {
        display: flex !important;
    }

    /* Sidebar fix — ne prekriva topbar */
    .sidebar {
        top: 0 !important;
        padding-top: 60px !important;
    }

    /* Filter toggle dugme uvijek vidljiv na mobilnom */
    #filterToggleBtn {
        display: flex !important;
        width: 100%;
        justify-content: center;
        margin-bottom: 12px;
        background: var(--accent);
        color: #fff;
        border: none;
        font-weight: 700;
    }

    /* Prop sidebar sakriven po defaultu */
    .prop-sidebar {
        display: none !important;
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        z-index: 150 !important;
        overflow-y: auto !important;
        background: var(--bg2) !important;
        padding: 60px 16px 16px !important;
    }
    .prop-sidebar.open {
        display: flex !important;
    }
}

/* ═══════════════════════════════════════════════════════════════════════════
   VELIKA CTA DUGMAD
   ═══════════════════════════════════════════════════════════════════════════ */

/* ─── + Post listing dugme ───────────────────────────────────────────────── */
.cat-nav-btn {
    background: linear-gradient(135deg, #1d4ed8, #7c3aed) !important;
    color: #fff !important;
    font-weight: 800 !important;
    font-size: 14px !important;
    padding: 10px 20px !important;
    border-radius: 10px !important;
    border: none !important;
    box-shadow: 0 4px 12px rgba(29,78,216,0.3) !important;
    transition: transform 0.15s, box-shadow 0.15s !important;
    white-space: nowrap;
}
.cat-nav-btn:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 18px rgba(29,78,216,0.4) !important;
}
.cat-nav-btn:active {
    transform: translateY(0) !important;
}

/* ─── Register / Sign in dugmad ─────────────────────────────────────────── */
#registerBtn {
    background: linear-gradient(135deg, #7c3aed, #1d4ed8) !important;
    color: #fff !important;
    border: none !important;
    font-weight: 700 !important;
    padding: 8px 16px !important;
    border-radius: 8px !important;
    box-shadow: 0 2px 8px rgba(124,58,237,0.3) !important;
    transition: transform 0.15s, box-shadow 0.15s !important;
}
#registerBtn:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(124,58,237,0.4) !important;
}

#userLoginBtn {
    border: 2px solid var(--accent) !important;
    color: var(--accent) !important;
    font-weight: 700 !important;
    background: transparent !important;
    padding: 7px 16px !important;
    border-radius: 8px !important;
    transition: all 0.15s !important;
}
#userLoginBtn:hover {
    background: var(--accent) !important;
    color: #fff !important;
}

/* ─── Viber / WhatsApp dugmad ───────────────────────────────────────────── */
.btn[title="Viber"],
button[title="Viber"] {
    background: linear-gradient(135deg, #7f4ccc, #9b59d0) !important;
    color: #fff !important;
    border: none !important;
    font-weight: 700 !important;
    min-width: 44px !important;
}

.btn[title="WhatsApp"],
button[title="WhatsApp"] {
    background: linear-gradient(135deg, #25d366, #128c7e) !important;
    color: #fff !important;
    border: none !important;
    font-weight: 700 !important;
    min-width: 44px !important;
}

/* ─── Mobilna poboljšanja za CTA ────────────────────────────────────────── */
@media (max-width: 768px) {
    /* Post listing — puna širina na mobilnom */
    .cat-nav-btn {
        padding: 12px 16px !important;
        font-size: 13px !important;
    }

    /* Register/Login — veća touch area */
    #registerBtn, #userLoginBtn {
        padding: 10px 14px !important;
        font-size: 13px !important;
        min-height: 42px !important;
    }

    /* Viber/WhatsApp — veći na mobilnom */
    .btn[title="Viber"],
    .btn[title="WhatsApp"] {
        padding: 10px 14px !important;
        font-size: 14px !important;
        min-height: 44px !important;
    }

    /* Property card footer akcije — wrap na mobilnom */
    .property-list-actions {
        flex-wrap: wrap !important;
        gap: 6px !important;
    }
    .property-list-actions .btn {
        flex: 1 !important;
        min-width: 44px !important;
        justify-content: center !important;
    }
}

/* ─── Admin users list fix ───────────────────────────────────────────────── */
.user-admin-stats {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    margin-top: 4px !important;
}
.user-admin-stats span {
    font-size: 12px !important;
    padding: 2px 8px !important;
    background: var(--bg) !important;
    border-radius: 6px !important;
    border: 1px solid var(--border) !important;
}
.user-admin-row {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 12px !important;
    background: var(--bg3) !important;
    border-radius: 10px !important;
    border: 1px solid var(--border) !important;
    margin-bottom: 8px !important;
}
.user-admin-info {
    flex: 1 !important;
}
.user-admin-name {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    margin-bottom: 4px !important;
}
.user-admin-meta {
    font-size: 12px !important;
    color: var(--text3) !important;
    margin-bottom: 4px !important;
}

/* ─── TOP INFO BAR ─────────────────────────────────────────────────────────── */
.top-info-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: #111827;
    color: rgba(255,255,255,0.75);
    font-size: 12px;
    padding: 6px 20px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    flex-wrap: wrap;
    gap: 8px;
    min-height: 32px;
}

.top-info-left {
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
}

.top-info-item {
    display: flex;
    align-items: center;
    gap: 5px;
    color: rgba(255,255,255,0.75);
    font-size: 12px;
    white-space: nowrap;
}

.top-info-item:hover {
    color: #fff;
}

.top-info-right {
    display: flex;
    align-items: center;
    gap: 10px;
}

.top-info-social {
    color: rgba(255,255,255,0.6);
    text-decoration: none;
    font-size: 15px;
    transition: all 0.2s;
    width: 26px;
    height: 26px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 6px;
}

.top-info-social:hover {
    color: #fff;
    background: rgba(255,255,255,0.1);
}

@media (max-width: 768px) {
    .top-info-bar {
        display: none !important;
    }
    .top-info-item span:last-child {
        max-width: 120px;
        overflow: hidden;
        text-overflow: ellipsis;
    }
}

/* ─── HERO SLIDER ──────────────────────────────────────────────────────────── */
.hero-slider {
    position: relative;
    width: 100%;
    height: 480px;
    min-height: 480px;
    overflow: hidden;
    background: transparent;
}

.hero-slides {
    display: flex;
    width: 100%;
    height: 100%;
    transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.hero-slide {
    min-width: 100%;
    height: 100%;
    position: relative;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    display: flex;
    align-items: center;
    justify-content: center;
}

.hero-slide::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, rgba(0,0,0,0.2) 0%, rgba(0,0,0,0.5) 60%, rgba(0,0,0,0.75) 100%);
}

.hero-slide-content {
    position: relative;
    z-index: 2;
    text-align: center;
    color: #fff;
    padding: 0 40px;
    max-width: 800px;
}

.hero-slide-title {
    font-size: clamp(28px, 5vw, 64px);
    font-weight: 900;
    line-height: 1.1;
    margin-bottom: 16px;
    text-shadow: 0 2px 20px rgba(0,0,0,0.5);
    letter-spacing: -0.02em;
}

.hero-slide-subtitle {
    font-size: clamp(15px, 2vw, 22px);
    opacity: 0.92;
    margin-bottom: 32px;
    text-shadow: 0 1px 8px rgba(0,0,0,0.4);
    font-weight: 400;
}

.hero-slide-btn {
    display: inline-block;
    padding: 16px 44px;
    background: linear-gradient(135deg, #1d4ed8, #7c3aed);
    color: #fff;
    border: none;
    border-radius: 12px;
    font-size: 18px;
    font-weight: 800;
    cursor: pointer;
    text-decoration: none;
    transition: transform 0.2s, box-shadow 0.2s;
    box-shadow: 0 6px 24px rgba(29,78,216,0.5);
    letter-spacing: 0.01em;
}

.hero-slide-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 28px rgba(0,0,0,0.4);
}

.hero-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(255,255,255,0.15);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,0.3);
    color: #fff;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    font-size: 18px;
    cursor: pointer;
    z-index: 10;
    transition: background 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
}

.hero-arrow:hover { background: rgba(255,255,255,0.3); }
.hero-prev { left: 16px; }
.hero-next { right: 16px; }

.hero-dots {
    position: absolute;
    bottom: 16px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 8px;
    z-index: 10;
}

.hero-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: rgba(255,255,255,0.5);
    cursor: pointer;
    transition: all 0.3s;
    border: none;
}

.hero-dot.active {
    background: #fff;
    width: 28px;
    border-radius: 5px;
}

/* Slide editor */
.slide-editor-row {
    background: var(--bg3);
    border-radius: 10px;
    border: 1px solid var(--border);
    padding: 14px;
}

@media (max-width: 768px) {
    .hero-slider { height: 340px; min-height: 340px; }
    .hero-slide-title { font-size: 26px; }
    .hero-slide-subtitle { font-size: 14px; }
    .hero-slide-btn { padding: 13px 28px; font-size: 15px; }
}

/* ─── FEATURED LISTINGS ────────────────────────────────────────────────────── */
.featured-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 14px;
    padding-bottom: 10px;
    border-bottom: 2px solid #f59e0b;
}

.featured-badge-title {
    font-size: 16px;
    font-weight: 800;
    color: #f59e0b;
    letter-spacing: 0.03em;
}

.featured-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    gap: 20px;
}

/* Premium card — larger, golden border */
.property-list-card--premium {
    border: 2px solid #f59e0b !important;
    box-shadow: 0 4px 20px rgba(245, 158, 11, 0.25) !important;
    position: relative;
}

.property-list-card--premium::after {
    content: "⭐ PREMIUM";
    position: absolute;
    top: 10px;
    right: 10px;
    background: linear-gradient(135deg, #f59e0b, #d97706);
    color: #fff;
    font-size: 10px;
    font-weight: 800;
    padding: 3px 10px;
    border-radius: 999px;
    letter-spacing: 0.08em;
    z-index: 5;
}

/* Standard card — blue border */
.property-list-card--standard {
    border: 2px solid #3b82f6 !important;
    box-shadow: 0 4px 16px rgba(59, 130, 246, 0.2) !important;
}

.property-list-card--standard::after {
    content: "✦ STANDARD";
    position: absolute;
    top: 10px;
    right: 10px;
    background: linear-gradient(135deg, #3b82f6, #1d4ed8);
    color: #fff;
    font-size: 10px;
    font-weight: 800;
    padding: 3px 10px;
    border-radius: 999px;
    letter-spacing: 0.08em;
    z-index: 5;
}

/* Pinned badge */
.property-pinned-badge {
    position: absolute;
    top: -1px;
    left: 12px;
    background: #dc2626;
    color: #fff;
    font-size: 10px;
    font-weight: 800;
    padding: 3px 10px;
    border-radius: 0 0 8px 8px;
    letter-spacing: 0.05em;
    z-index: 5;
}

/* ─── MORTGAGE CALCULATOR ──────────────────────────────────────────────────── */
.mortgage-calc {
    background: var(--bg3);
    border-radius: 12px;
    padding: 18px;
    border: 1px solid var(--border);
}

.mortgage-title {
    font-size: 15px;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 14px;
}

.mortgage-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin-bottom: 14px;
}

.mortgage-field label {
    font-size: 11px;
    font-weight: 600;
    color: var(--text3);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    display: block;
    margin-bottom: 4px;
}

.mortgage-field input {
    width: 100%;
    padding: 8px 10px;
    border-radius: 8px;
    border: 1px solid var(--border);
    background: var(--bg2);
    color: var(--text);
    font-size: 14px;
    font-weight: 600;
}

.mortgage-price {
    font-size: 16px;
    font-weight: 800;
    color: var(--accent);
    padding: 8px 0;
}

.mortgage-result {
    background: var(--bg2);
    border-radius: 10px;
    padding: 14px;
    border: 1px solid var(--border);
}

.mortgage-result-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}

.mortgage-result-item {
    text-align: center;
}

.mortgage-result-item--main {
    grid-column: 1 / -1;
    background: var(--accent);
    border-radius: 10px;
    padding: 12px;
    color: #fff;
}

.mortgage-result-label {
    font-size: 11px;
    color: var(--text3);
    margin-bottom: 4px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.mortgage-result-item--main .mortgage-result-label {
    color: rgba(255,255,255,0.8);
}

.mortgage-result-value {
    font-size: 15px;
    font-weight: 700;
    color: var(--text);
}

.mortgage-result-monthly {
    font-size: 24px;
    font-weight: 900;
    color: #fff;
}

/* ─── PROPERTY MAP ─────────────────────────────────────────────────────────── */
.map-filter-btn {
    padding: 5px 12px;
    border-radius: 999px;
    border: 2px solid var(--border);
    background: var(--bg3);
    color: var(--text2);
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
    display: flex;
    align-items: center;
    gap: 5px;
}

.map-filter-btn:hover {
    border-color: var(--accent);
    color: var(--accent);
}

.map-filter-btn.active {
    background: var(--accent);
    border-color: var(--accent);
    color: #fff;
}

.leaflet-popup-content {
    font-family: system-ui, sans-serif;
    font-size: 13px;
}



/* ─── QUICK SEARCH BAR ─────────────────────────────────────────────────────── */
.quick-search-bar {
    background: rgba(0,0,0,0.55);
    border-bottom: none;
    padding: 12px 20px;
    flex-shrink: 0;
    box-shadow: none;
    position: relative;
    margin-top: -60px;
    z-index: 20;
    backdrop-filter: blur(6px);
}

.quick-search-inner {
    display: flex;
    align-items: center;
    gap: 10px;
    max-width: 1200px;
    margin: 0 auto;
    flex-wrap: wrap;
}

.quick-search-field {
    position: relative;
    display: flex;
    align-items: center;
    background: var(--bg3);
    border: 2px solid var(--border);
    border-radius: 10px;
    padding: 0 12px;
    height: 48px;
    flex: 1;
    min-width: 140px;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.quick-search-field:focus-within {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(29,78,216,0.1);
}

.quick-search-field--wide {
    flex: 2;
    min-width: 220px;
}

.quick-search-icon {
    font-size: 16px;
    margin-right: 8px;
    flex-shrink: 0;
    opacity: 0.6;
}

.quick-search-input {
    flex: 1;
    border: none;
    background: transparent;
    font-size: 14px;
    color: var(--text);
    outline: none;
    font-weight: 500;
}

.quick-search-input::placeholder {
    color: var(--text3);
}

.quick-search-select {
    flex: 1;
    border: none;
    background: transparent;
    font-size: 14px;
    color: var(--text);
    outline: none;
    cursor: pointer;
    font-weight: 500;
    appearance: none;
    -webkit-appearance: none;
}
.quick-search-select option {
    background: var(--bg2, #1e293b);
    color: var(--text, #f1f5f9);
}

.quick-search-btn {
    height: 48px;
    padding: 0 28px;
    background: linear-gradient(135deg, #1d4ed8, #7c3aed);
    color: #fff;
    border: none;
    border-radius: 10px;
    font-size: 15px;
    font-weight: 800;
    cursor: pointer;
    white-space: nowrap;
    flex-shrink: 0;
    transition: transform 0.15s, box-shadow 0.15s;
    box-shadow: 0 4px 14px rgba(29,78,216,0.35);
    display: flex;
    align-items: center;
    gap: 8px;
}

.quick-search-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(29,78,216,0.45);
}

.quick-search-btn:active {
    transform: translateY(0);
}

@media (max-width: 768px) {
    .quick-search-bar { padding: 12px; }
    .quick-search-inner { gap: 8px; }
    .quick-search-field { min-width: calc(50% - 8px); flex: 1 1 calc(50% - 8px); }
    .quick-search-field--wide { min-width: 100%; flex: 1 1 100%; }
    .quick-search-btn { width: 100%; justify-content: center; }
}

/* ─── RIGHT SIDEBAR ────────────────────────────────────────────────────────── */
.prop-right-sidebar {
    width: 220px;
    min-width: 220px;
    background: var(--bg2);
    border-left: 1px solid var(--border);
    padding: 16px 12px;
    overflow-y: auto;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    gap: 20px;
    position: sticky;
    top: 0;
    max-height: calc(100vh - 58px - 42px);
    box-shadow: -2px 0 12px var(--shadow);
}

.rsb-section {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.rsb-title {
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--text3);
    padding-bottom: 8px;
    border-bottom: 2px solid var(--border);
    margin-bottom: 4px;
}

.rsb-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

/* Mini property card */
.rsb-card {
    display: flex;
    gap: 10px;
    padding: 8px;
    border-radius: 10px;
    border: 1px solid var(--border);
    background: var(--bg3);
    cursor: pointer;
    transition: all 0.2s;
    align-items: center;
}

.rsb-card:hover {
    border-color: var(--accent);
    background: var(--bg2);
    transform: translateX(2px);
    box-shadow: 0 2px 10px var(--shadow);
}

.rsb-card-img {
    width: 56px;
    height: 56px;
    border-radius: 8px;
    background-size: cover;
    background-position: center;
    background-color: var(--bg3);
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    border: 1px solid var(--border);
}

.rsb-card-info {
    flex: 1;
    min-width: 0;
}

.rsb-card-title {
    font-size: 12px;
    font-weight: 700;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-bottom: 2px;
}

.rsb-card-location {
    font-size: 11px;
    color: var(--text3);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-bottom: 4px;
}

.rsb-card-price {
    font-size: 13px;
    font-weight: 800;
    color: var(--accent);
}

.rsb-card-badge {
    font-size: 9px;
    font-weight: 800;
    padding: 2px 6px;
    border-radius: 999px;
    color: #fff;
    background: #f59e0b;
    display: inline-block;
    margin-bottom: 3px;
    letter-spacing: 0.06em;
}

.rsb-card-badge--new {
    background: var(--green);
}

.rsb-empty {
    font-size: 12px;
    color: var(--text3);
    text-align: center;
    padding: 12px 0;
}

/* Right sidebar banner */
.rsb-banner {
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid var(--border);
    cursor: pointer;
    transition: box-shadow 0.2s;
}

.rsb-banner:hover {
    box-shadow: 0 4px 16px var(--shadow2);
}

@media (max-width: 1200px) {
    .prop-right-sidebar { display: none; }
@media (max-width:1200px) { .prop-right-sidebar { display: none !important; } }
}

/* ─── SIDEBAR BG PICKER ────────────────────────────────────────────────────── */
.sidebar-bg-picker {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    gap: 12px !important;
    margin-bottom: 10px;
    max-width: 100% !important;
}

.sbg-option {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 5px;
    cursor: pointer;
    font-size: 11px;
    color: var(--text3);
    font-weight: 600;
}

.sbg-option.active span { color: var(--accent); font-weight: 800; }

.sbg-preview {
    width: 52px;
    height: 52px;
    border-radius: 10px;
    border: 3px solid var(--border);
    transition: all 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
}

.sbg-option:hover .sbg-preview,
.sbg-option.active .sbg-preview {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(29,78,216,0.2);
    transform: scale(1.05);
}

.sbg-preview--default     { background: var(--bg2); }
.sbg-preview--dark        { background: #0f1117; }
.sbg-preview--gradient-blue   { background: linear-gradient(135deg, #1e3a8a, #3b82f6); }
.sbg-preview--gradient-purple { background: linear-gradient(135deg, #4c1d95, #7c3aed); }
.sbg-preview--gradient-green  { background: linear-gradient(135deg, #14532d, #16a34a); }
.sbg-preview--gradient-sunset { background: linear-gradient(135deg, #7c1d0a, #f59e0b); }
.sbg-preview--gradient-gold   { background: linear-gradient(135deg, #92400e, #f59e0b); }
.sbg-preview--image       { background: var(--bg3); border-style: dashed; }

/* Right sidebar background variants */
.prop-right-sidebar[data-bg="dark"] {
    background: #0f1117 !important;
    color: #f1f5f9;
    border-color: #2d3148;
}
.prop-right-sidebar[data-bg="dark"] .rsb-title { color: #64748b; border-color: #2d3148; }
.prop-right-sidebar[data-bg="dark"] .rsb-card { background: #1a1d27; border-color: #2d3148; }
.prop-right-sidebar[data-bg="dark"] .rsb-card-title { color: #f1f5f9; }
.prop-right-sidebar[data-bg="dark"] .rsb-card-location { color: #64748b; }

.prop-right-sidebar[data-bg="gradient-blue"] {
    background: linear-gradient(180deg, #1e3a8a 0%, #1e40af 100%) !important;
    border-color: #1e40af;
}
.prop-right-sidebar[data-bg="gradient-blue"] .rsb-title { color: rgba(255,255,255,0.6); border-color: rgba(255,255,255,0.15); }
.prop-right-sidebar[data-bg="gradient-blue"] .rsb-card { background: rgba(255,255,255,0.1); border-color: rgba(255,255,255,0.15); }
.prop-right-sidebar[data-bg="gradient-blue"] .rsb-card:hover { background: rgba(255,255,255,0.18); }
.prop-right-sidebar[data-bg="gradient-blue"] .rsb-card-title { color: #fff; }
.prop-right-sidebar[data-bg="gradient-blue"] .rsb-card-location { color: rgba(255,255,255,0.6); }
.prop-right-sidebar[data-bg="gradient-blue"] .rsb-card-price { color: #93c5fd; }

.prop-right-sidebar[data-bg="gradient-purple"] {
    background: linear-gradient(180deg, #4c1d95 0%, #6d28d9 100%) !important;
    border-color: #6d28d9;
}
.prop-right-sidebar[data-bg="gradient-purple"] .rsb-title { color: rgba(255,255,255,0.6); border-color: rgba(255,255,255,0.15); }
.prop-right-sidebar[data-bg="gradient-purple"] .rsb-card { background: rgba(255,255,255,0.1); border-color: rgba(255,255,255,0.15); }
.prop-right-sidebar[data-bg="gradient-purple"] .rsb-card:hover { background: rgba(255,255,255,0.18); }
.prop-right-sidebar[data-bg="gradient-purple"] .rsb-card-title { color: #fff; }
.prop-right-sidebar[data-bg="gradient-purple"] .rsb-card-location { color: rgba(255,255,255,0.6); }
.prop-right-sidebar[data-bg="gradient-purple"] .rsb-card-price { color: #c4b5fd; }

.prop-right-sidebar[data-bg="gradient-green"] {
    background: linear-gradient(180deg, #14532d 0%, #166534 100%) !important;
    border-color: #166534;
}
.prop-right-sidebar[data-bg="gradient-green"] .rsb-title { color: rgba(255,255,255,0.6); border-color: rgba(255,255,255,0.15); }
.prop-right-sidebar[data-bg="gradient-green"] .rsb-card { background: rgba(255,255,255,0.1); border-color: rgba(255,255,255,0.15); }
.prop-right-sidebar[data-bg="gradient-green"] .rsb-card:hover { background: rgba(255,255,255,0.18); }
.prop-right-sidebar[data-bg="gradient-green"] .rsb-card-title { color: #fff; }
.prop-right-sidebar[data-bg="gradient-green"] .rsb-card-location { color: rgba(255,255,255,0.6); }
.prop-right-sidebar[data-bg="gradient-green"] .rsb-card-price { color: #86efac; }

.prop-right-sidebar[data-bg="gradient-sunset"] {
    background: linear-gradient(180deg, #7c1d0a 0%, #b45309 100%) !important;
    border-color: #b45309;
}
.prop-right-sidebar[data-bg="gradient-sunset"] .rsb-title { color: rgba(255,255,255,0.6); border-color: rgba(255,255,255,0.15); }
.prop-right-sidebar[data-bg="gradient-sunset"] .rsb-card { background: rgba(255,255,255,0.1); border-color: rgba(255,255,255,0.15); }
.prop-right-sidebar[data-bg="gradient-sunset"] .rsb-card:hover { background: rgba(255,255,255,0.18); }
.prop-right-sidebar[data-bg="gradient-sunset"] .rsb-card-title { color: #fff; }
.prop-right-sidebar[data-bg="gradient-sunset"] .rsb-card-location { color: rgba(255,255,255,0.6); }
.prop-right-sidebar[data-bg="gradient-sunset"] .rsb-card-price { color: #fcd34d; }

.prop-right-sidebar[data-bg="gradient-gold"] {
    background: linear-gradient(180deg, #78350f 0%, #d97706 100%) !important;
    border-color: #d97706;
}
.prop-right-sidebar[data-bg="gradient-gold"] .rsb-title { color: rgba(255,255,255,0.6); border-color: rgba(255,255,255,0.15); }
.prop-right-sidebar[data-bg="gradient-gold"] .rsb-card { background: rgba(255,255,255,0.1); border-color: rgba(255,255,255,0.15); }
.prop-right-sidebar[data-bg="gradient-gold"] .rsb-card:hover { background: rgba(255,255,255,0.18); }
.prop-right-sidebar[data-bg="gradient-gold"] .rsb-card-title { color: #fff; }
.prop-right-sidebar[data-bg="gradient-gold"] .rsb-card-location { color: rgba(255,255,255,0.6); }
.prop-right-sidebar[data-bg="gradient-gold"] .rsb-card-price { color: #fef08a; }

.prop-right-sidebar[data-bg="image"] {
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    border-color: transparent;
}
.prop-right-sidebar[data-bg="image"] .rsb-title { color: rgba(255,255,255,0.7); border-color: rgba(255,255,255,0.2); text-shadow: 0 1px 4px rgba(0,0,0,0.5); }
.prop-right-sidebar[data-bg="image"] .rsb-card { background: rgba(0,0,0,0.45); border-color: rgba(255,255,255,0.15); backdrop-filter: blur(6px); }
.prop-right-sidebar[data-bg="image"] .rsb-card:hover { background: rgba(0,0,0,0.6); }
.prop-right-sidebar[data-bg="image"] .rsb-card-title { color: #fff; }
.prop-right-sidebar[data-bg="image"] .rsb-card-location { color: rgba(255,255,255,0.65); }
.prop-right-sidebar[data-bg="image"] .rsb-card-price { color: #93c5fd; }

/* ─── COMPARE ──────────────────────────────────────────────────────────────── */
.compare-checkbox-wrap {
    position: absolute;
    top: 10px;
    right: 10px;
    z-index: 10;
}

.compare-checkbox {
    width: 22px;
    height: 22px;
    cursor: pointer;
    accent-color: #1d4ed8;
    border-radius: 6px;
}

.property-list-card.compare-selected {
    border-color: #1d4ed8 !important;
    box-shadow: 0 0 0 3px rgba(29,78,216,0.25) !important;
}

/* Floating compare bar */
.compare-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: #1e293b;
    border-top: 2px solid #3b82f6;
    padding: 12px 20px;
    display: flex;
    align-items: center;
    gap: 16px;
    z-index: 9999;
    box-shadow: 0 -4px 20px rgba(0,0,0,0.5);
    flex-wrap: wrap;
    transform: translateZ(0);
}

.compare-bar-items {
    display: flex;
    gap: 10px;
    flex: 1;
    flex-wrap: wrap;
}

.compare-bar-item {
    display: flex;
    align-items: center;
    gap: 8px;
    background: rgba(255,255,255,0.1);
    border-radius: 8px;
    padding: 6px 10px;
    font-size: 12px;
    color: #fff;
    font-weight: 600;
    max-width: 200px;
}

.compare-bar-item-img {
    width: 32px;
    height: 32px;
    border-radius: 6px;
    background-size: cover;
    background-position: center;
    background-color: #334155;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
}

.compare-bar-item-title {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 120px;
}

.compare-bar-item-remove {
    background: none;
    border: none;
    color: rgba(255,255,255,0.5);
    cursor: pointer;
    font-size: 14px;
    padding: 0 2px;
    flex-shrink: 0;
}

.compare-bar-item-remove:hover { color: #fff; }

.compare-bar-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}

.compare-bar-count {
    font-size: 13px;
    font-weight: 700;
    color: rgba(255,255,255,0.7);
}

/* Compare table */
.compare-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
    min-width: 500px;
}

.compare-table th {
    padding: 0;
    text-align: center;
    vertical-align: top;
}

.compare-table td {
    padding: 10px 16px;
    border-bottom: 1px solid var(--border);
    vertical-align: middle;
}

.compare-table tr:last-child td { border-bottom: none; }

.compare-table .compare-row-label {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: var(--text3);
    background: var(--bg3);
    width: 130px;
    min-width: 130px;
}

.compare-table .compare-row-value {
    text-align: center;
    color: var(--text2);
    font-weight: 500;
}

.compare-table .compare-row-value--best {
    color: var(--green);
    font-weight: 800;
}

.compare-prop-header {
    padding: 16px;
    text-align: center;
    min-width: 220px;
}

.compare-prop-img {
    width: 100%;
    height: 130px;
    border-radius: 10px;
    background-size: cover;
    background-position: center;
    background-color: var(--bg3);
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 36px;
}

.compare-prop-title {
    font-size: 14px;
    font-weight: 800;
    color: var(--text);
    margin-bottom: 4px;
}

.compare-prop-price {
    font-size: 18px;
    font-weight: 900;
    color: var(--accent);
}

.compare-check { color: var(--green); font-size: 16px; }
.compare-cross { color: var(--text3); font-size: 16px; }

@media (max-width: 768px) {
    .compare-bar { left: 0; }
}

/* ─── PROPERTY ALERTS ──────────────────────────────────────────────────────── */
.alert-row {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 10px;
    border-left: 4px solid #3b82f6;
}

.alert-row-info {
    flex: 1;
    min-width: 0;
}

.alert-row-title {
    font-size: 13px;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 2px;
}

.alert-row-meta {
    font-size: 11px;
    color: var(--text3);
}

.alert-row-del {
    background: none;
    border: none;
    color: var(--text3);
    cursor: pointer;
    font-size: 16px;
    padding: 4px;
    border-radius: 6px;
    flex-shrink: 0;
}

.alert-row-del:hover { background: var(--red); color: #fff; }

.alert-match-badge {
    position: absolute;
    top: -6px;
    right: -6px;
    background: #ef4444;
    color: #fff;
    font-size: 10px;
    font-weight: 800;
    width: 18px;
    height: 18px;
    border-radius: 999px;
    display: flex;
    align-items: center;
    justify-content: center;
    animation: pop 0.3s ease;
}

/* Alert notification popup */
.alert-notification {
    position: fixed;
    top: 80px;
    right: 20px;
    background: #1d4ed8;
    color: #fff;
    border-radius: 12px;
    padding: 14px 18px;
    font-size: 13px;
    font-weight: 600;
    max-width: 320px;
    box-shadow: 0 8px 24px rgba(29,78,216,0.4);
    z-index: 200;
    animation: slideInRight 0.3s ease;
    cursor: pointer;
}

.alert-notification-title {
    font-weight: 800;
    margin-bottom: 4px;
    font-size: 14px;
}

.alert-notification-body {
    opacity: 0.85;
    font-size: 12px;
}

/* ─── MARKET STATS ─────────────────────────────────────────────────────────── */
.mkt-kpi-row {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 12px;
    margin-bottom: 20px;
}

.mkt-kpi-card {
    background: var(--bg3);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 14px 16px;
    text-align: center;
}

.mkt-kpi-icon { font-size: 22px; margin-bottom: 6px; }
.mkt-kpi-value { font-size: 20px; font-weight: 900; color: var(--accent); margin-bottom: 2px; }
.mkt-kpi-label { font-size: 11px; color: var(--text3); font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; }

.mkt-charts-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.mkt-chart-box {
    background: var(--bg3);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 16px;
}

.mkt-chart-title {
    font-size: 12px;
    font-weight: 700;
    color: var(--text2);
    text-transform: uppercase;
    letter-spacing: 0.07em;
    margin-bottom: 12px;
}

@media (max-width: 700px) {
    .mkt-charts-row { grid-template-columns: 1fr; }
}

/* ─── BUMP ─────────────────────────────────────────────────────────────────── */
.bump-pkg-card {
    background: var(--bg3);
    border: 2px solid var(--border);
    border-radius: 12px;
    padding: 14px 10px;
    cursor: pointer;
    transition: all 0.2s;
    text-align: center;
}
.bump-pkg-card:hover {
    border-color: var(--accent);
    transform: translateY(-2px);
}
.bump-pkg-card.selected {
    border-color: var(--accent);
    background: var(--bg2);
    box-shadow: 0 0 0 3px rgba(29,78,216,0.15);
}

/* Bumped card glow */
.property-list-card--bumped {
    border-color: #f59e0b !important;
    box-shadow: 0 0 0 3px rgba(245,158,11,0.2), 0 4px 20px rgba(245,158,11,0.15) !important;
    animation: bumpGlow 2s ease-in-out infinite alternate;
}
@keyframes bumpGlow {
    from { box-shadow: 0 0 0 2px rgba(245,158,11,0.2), 0 4px 16px rgba(245,158,11,0.1); }
    to   { box-shadow: 0 0 0 4px rgba(245,158,11,0.35), 0 6px 24px rgba(245,158,11,0.25); }
}
.bump-badge {
    position: absolute;
    top: -1px;
    right: 40px;
    background: linear-gradient(135deg, #f59e0b, #d97706);
    color: #fff;
    font-size: 10px;
    font-weight: 800;
    padding: 3px 10px;
    border-radius: 0 0 8px 8px;
    letter-spacing: 0.05em;
    z-index: 5;
    animation: pop 0.3s ease;
}


/* ═══════════════════════════════════════════════════════════════════════════
   PORTAL BLUE THEME — INPUT FIX
   ═══════════════════════════════════════════════════════════════════════════ */
body[data-theme="portal"] input:not([type="radio"]):not([type="checkbox"]):not([type="file"]),
body[data-theme="portal"] select,
body[data-theme="portal"] textarea {
    background-color: #EEF2FF !important;
    color: #0F172A !important;
    border: 1px solid #CBD5E1 !important;
}

body[data-theme="portal"] input:not([type="radio"]):not([type="checkbox"]):not([type="file"]):focus,
body[data-theme="portal"] select:focus,
body[data-theme="portal"] textarea:focus {
    background-color: #FFFFFF !important;
    border-color: #1D4ED8 !important;
    outline: none !important;
}

body[data-theme="portal"] label {
    color: #475569 !important;
}

body[data-theme="portal"] .plan-field-input,
body[data-theme="portal"] .prop-filter-input,
body[data-theme="portal"] .prop-filter-select,
body[data-theme="portal"] .prop-filter-range-input,
body[data-theme="portal"] .cf-input {
    background-color: #EEF2FF !important;
    color: #0F172A !important;
    border-color: #CBD5E1 !important;
}

body[data-theme="portal"] .modal-content {
    background: #FFFFFF !important;
    color: #0F172A !important;
}

body[data-theme="portal"] .modal-content input:not([type="radio"]):not([type="checkbox"]):not([type="file"]),
body[data-theme="portal"] .modal-content select,
body[data-theme="portal"] .modal-content textarea {
    background-color: #F1F5F9 !important;
    color: #0F172A !important;
    border-color: #CBD5E1 !important;
}


/* Landing page footer links — not green */
#landingPage footer a,
#landingPage .footer-col a,
#landingPage .footer-bottom a {
    color: #64748b !important;
    text-decoration: none !important;
}
#landingPage footer a:hover,
#landingPage .footer-col a:hover {
    color: white !important;
}


/* Screenshot lightbox - always on top */
#lpe_lightbox {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    z-index: 2147483647 !important;
    background: rgba(0,0,0,0.95) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* ═══════════════════════════════════════════════════
   CLEANER LAYOUT IMPROVEMENTS
   ═══════════════════════════════════════════════════ */

/* Sidebar logo - kompaktniji */
.sidebar-logo {
    padding: 16px 16px 12px;
}
.sidebar-logo-text {
    font-size: 15px;
}

/* Nav items - malo kompaktniji */
.nav-item {
    padding: 8px 12px;
    font-size: 13px;
}

/* Filter sidebar - cistiji accordion */
.acc-header {
    font-size: 11px;
    padding: 8px 16px;
}
.acc-body {
    padding: 6px 16px 10px;
}

/* Property grid - breathing room */
#propertyGrid {
    padding: 16px;
    gap: 16px;
}

/* Hero slider - malo nizi */
#heroSlider {
    max-height: 260px;
    overflow: hidden;
}
#heroSlider .hero-slide {
    height: 260px;
}

/* Desni sidebar - cistiji naslovi */
.rsb-title {
    font-size: 10px;
    letter-spacing: 0.12em;
    opacity: 0.7;
}
.rsb-card {
    padding: 6px;
    border-radius: 8px;
}
.rsb-card-title {
    font-size: 12px;
    line-height: 1.3;
}
.rsb-card-price {
    font-size: 12px;
    font-weight: 700;
}

/* Filter badge - manje upadljiv */
#filterResultsBadge {
    font-size: 10px;
    padding: 1px 6px;
}

/* Topbar search - malo siri */
.topbar-search {
    width: 280px;
}

/* Prop sidebar scroll - bez vidljive scrollbar-e */
.prop-sidebar::-webkit-scrollbar { width: 4px; }
.prop-sidebar::-webkit-scrollbar-track { background: transparent; }
.prop-sidebar::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }

/* Desni sidebar scroll */
.prop-right-sidebar::-webkit-scrollbar { width: 4px; }
.prop-right-sidebar::-webkit-scrollbar-track { background: transparent; }
.prop-right-sidebar::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }

/* Featured / Istaknuti oglasi sekcija - cistija */
.featured-section-title {
    font-size: 15px;
    font-weight: 700;
    padding: 12px 16px 4px;
    color: var(--text);
    border-bottom: 1px solid var(--border);
    margin-bottom: 8px;
}

/* Property card - blaga senka samo na hover */
.property-card {
    box-shadow: none;
    transition: box-shadow 0.2s, transform 0.2s;
}
.property-card:hover {
    box-shadow: 0 4px 20px var(--shadow);
    transform: translateY(-2px);
}

/* Compare bar - cistiji */
.compare-bar {
    padding: 10px 20px;
    font-size: 13px;
}

/* Category nav bar - cistiji */
.cat-nav-tab {
    font-size: 12px;
    padding: 5px 12px;
}


/* ═══ HIDE RIGHT SIDEBAR COMPLETELY ═══ */
.prop-right-sidebar {
    display: none !important;
}

/* ═══ HERO SLIDER - FULL HEIGHT ═══ */
#heroSlider .hero-slide {
    height: 500px !important;
    max-height: 500px !important;
}
#heroSlider {
    max-height: 500px !important;
}

/* ═══ CLEANER PROP SIDEBAR ═══ */
.prop-sidebar {
    width: 220px !important;
    min-width: 220px !important;
}

/* ═══ SIDEBAR - sakrij Privacy/Terms/custom pages linkove ═══ */
.sidebar .custom-page-nav-item {
    display: none !important;
}

/* ═══ HERO SLIDER - no gap below ═══ */
.hero-slider {
    height: 300px !important;
    min-height: 300px !important;
    margin-bottom: 0 !important;
    background: transparent !important;
}
#heroSlider {
    height: 300px !important;
    min-height: 300px !important;
    margin-bottom: 0 !important;
}
/* Tamna zona ispod slidera - ukloni */
.hero-slider + * {
    margin-top: 0 !important;
}

/* ═══════════════════════════════════════════════════
   CATEGORY GRID
   ═══════════════════════════════════════════════════ */

.cat-grid-title {
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text3);
    margin-bottom: 12px;
    padding: 0 2px;
}

.cat-grid-wrap {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
    gap: 10px;
}

.cat-grid-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 16px 10px 12px;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 12px;
    cursor: pointer;
    transition: all 0.2s;
    text-align: center;
    position: relative;
}

.cat-grid-item:hover {
    background: var(--accent);
    border-color: var(--accent);
    transform: translateY(-3px);
    box-shadow: 0 6px 20px rgba(29, 78, 216, 0.25);
}

.cat-grid-item:hover .cat-grid-icon svg {
    stroke: #fff;
}

.cat-grid-item:hover .cat-grid-name {
    color: #fff;
}

.cat-grid-item:hover .cat-grid-count {
    background: rgba(255,255,255,0.2);
    color: #fff;
}

.cat-grid-icon {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.cat-grid-icon svg {
    width: 36px;
    height: 36px;
    stroke: var(--accent);
    transition: stroke 0.2s;
}

.cat-grid-name {
    font-size: 12px;
    font-weight: 600;
    color: var(--text);
    line-height: 1.3;
    transition: color 0.2s;
}

.cat-grid-count {
    font-size: 10px;
    font-weight: 700;
    color: var(--text3);
    background: var(--bg3);
    padding: 1px 7px;
    border-radius: 999px;
    transition: all 0.2s;
}

@media (max-width: 768px) {
    .cat-grid-wrap {
        grid-template-columns: repeat(auto-fill, minmax(90px, 1fr));
        gap: 8px;
    }
    .cat-grid-item {
        padding: 12px 8px;
    }
    .cat-grid-icon svg {
        width: 28px;
        height: 28px;
    }
    .cat-grid-name {
        font-size: 11px;
    }
}

/* Category grid - active item */
.cat-grid-item--active {
    background: var(--accent) !important;
    border-color: var(--accent) !important;
    box-shadow: 0 4px 16px rgba(29, 78, 216, 0.3);
}
.cat-grid-item--active .cat-grid-icon svg {
    stroke: #fff !important;
}
.cat-grid-item--active .cat-grid-name {
    color: #fff !important;
}
.cat-grid-item--active .cat-grid-count {
    background: rgba(255,255,255,0.2) !important;
    color: #fff !important;
}

/* ═══════════════════════════════════════════════════
   COMPREHENSIVE CLEANUP v2
   ═══════════════════════════════════════════════════ */

/* 1. CRNA ZONA - ukloni tamnu pozadinu hero slidera i dots */
.hero-slider {
    height: 280px !important;
    min-height: 280px !important;
    background: var(--bg) !important;
    margin-bottom: 0 !important;
}
.hero-slide {
    background-color: var(--bg) !important;
}
.hero-slide::before {
    background: linear-gradient(to bottom, rgba(0,0,0,0.1) 0%, rgba(0,0,0,0.4) 70%, rgba(0,0,0,0.6) 100%) !important;
}
.hero-dots {
    bottom: 8px !important;
}

/* 2. CATEGORY GRID - vece i lepse kartice */
.cat-grid-wrap {
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)) !important;
    gap: 12px !important;
}
.cat-grid-item {
    padding: 20px 12px 14px !important;
    border-radius: 14px !important;
    gap: 10px !important;
}
.cat-grid-icon svg {
    width: 42px !important;
    height: 42px !important;
}
.cat-grid-name {
    font-size: 13px !important;
}
.cat-grid-count {
    font-size: 11px !important;
    padding: 2px 8px !important;
}

/* 3. UKLONI "Browse categories" naslov */
.cat-grid-title {
    display: none !important;
}

/* 4. ISTAKNUTI OGLASI - cistiji header */
.featured-header {
    border-bottom: none !important;
    margin-bottom: 10px !important;
    padding-bottom: 0 !important;
}
.featured-badge-title {
    font-size: 14px !important;
    font-weight: 700 !important;
}

/* 5. PROP MAIN - manje padding-a gore */
.prop-main {
    padding: 12px 16px !important;
}

/* 6. PROP RESULTS BAR - kompaktniji */
.prop-results-bar {
    margin-bottom: 8px !important;
    padding: 4px 0 !important;
}

/* 7. CAT NAV BAR - sakrij kad je sidebar aktivan (duplikat "Nekretnine") */
.sidebar .nav-item.active[data-section="properties"] + .cat-nav-bar {
    display: none;
}

/* 8. HERO - bez praznine ispod */
#heroSlider {
    display: block !important;
    margin-bottom: 0 !important;
}
#heroSlider + * {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

/* 9. Prop main category grid - malo vise prostora */
#categoryGrid {
    margin-bottom: 16px !important;
    margin-top: 4px !important;
}

/* ═══ FIX CRNA ZONA ISPOD SLIDERA ═══ */
/* Hero slider wrapper pozadina */
#heroSlider {
    background: var(--bg) !important;
}
/* Dots zona - bez tamne pozadine */
.hero-dots {
    background: transparent !important;
}
/* Main area ispod slidera - ista boja kao bg */
.main {
    background: var(--bg) !important;
}
/* Properties layout - bez crne */
.properties-layout {
    background: var(--bg) !important;
}
/* Prop main - bez crne */
.prop-main {
    background: var(--bg) !important;
}

/* ═══ FIX SIDEBAR LOGO ═══ */
.sidebar-logo-text {
    font-size: 13px !important;
    letter-spacing: 0.02em !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

/* ═══ FIX CATEGORY GRID - sve kategorije vidljive ═══ */
.cat-grid-wrap {
    grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)) !important;
}

/* ═══ FINALNI FIX CRNE ZONE ═══ */
/* Hero slider - nema visine van slika */
#heroSlider {
    line-height: 0 !important;
    font-size: 0 !important;
}
.hero-dots {
    position: absolute !important;
    bottom: 6px !important;
    z-index: 10 !important;
    line-height: normal !important;
    font-size: initial !important;
}
/* Razmak između hero i content = 0 */
.main > #heroSlider {
    flex-shrink: 0 !important;
}
.main > #quickSearchBar,
.main > .page-section.properties-layout {
    flex-shrink: 0 !important;
}
/* Dark theme fix - hero bg = page bg */
body[data-theme="dark"] #heroSlider,
body[data-theme="dark"] .hero-slide {
    background-color: #0f1117 !important;
}
body[data-theme="light"] #heroSlider,
body[data-theme="light"] .hero-slide {
    background-color: #f0f2f7 !important;
}

/* ═══ HERO UNUTAR PROP-MAIN ═══ */
.prop-main > .hero-slider {
    width: 100% !important;
    margin: 0 !important;
    border-radius: 0 !important;
}
.prop-main {
    padding: 0 !important;
}
#categoryGrid {
    padding: 12px 16px 0 !important;
    margin-bottom: 12px !important;
}
.prop-results-bar {
    padding: 8px 16px 0 !important;
}
#featuredSection {
    padding: 0 16px !important;
}
#propertyGrid {
    padding: 0 16px 16px !important;
}

/* ═══ FINALNI FIX - HERO ISPRED PROPERTIES ═══ */
/* Hero slider - puna sirina, nema crne ispod */
#heroSlider {
    width: 100% !important;
    height: 280px !important;
    min-height: 280px !important;
    display: block;
    position: relative !important;
    overflow: hidden !important;
    background: var(--bg) !important;
    flex-shrink: 0 !important;
}
/* Properties layout odmah ispod - nema gap-a */
.main > #heroSlider + .page-section.properties-layout,
.main > #heroSlider ~ .page-section.properties-layout {
    margin-top: 0 !important;
}
/* Prop main - normalan padding */
.prop-main {
    padding: 12px 16px !important;
}

/* ═══ HERO UNUTAR PROPERTIES-LAYOUT - FINALNO RJESENJE ═══ */
.page-section.properties-layout { display:flex !important; flex-direction:column !important; }
/* Hero ide fullwidth na vrhu */
.page-section.properties-layout > #heroSlider {
    width: 100% !important;
    flex-shrink: 0 !important;
    height: 280px !important;
    min-height: 280px !important;
}
/* Sidebar + main u redu ispod hero */
.properties-row {
    display: flex !important;
    flex-direction: row !important;
    flex: 1 !important;
    min-height: 0 !important;
    overflow: hidden !important;
}
/* prop-sidebar i prop-main unutar properties-row */
.properties-row > .prop-sidebar {
    position: sticky !important;
    top: 0 !important;
    height: calc(100vh - 58px - 42px) !important;
    overflow-y: auto !important;
}
/* Properties inner - flex col */
.properties-inner {
    display: flex !important;
    flex-direction: column !important;
    flex: 1 !important;
    overflow: hidden !important;
}

/* ═══ UKLONI TAMNU TRAKU ISPOD SLIDERA ═══ */
.page-section.properties-layout > #heroSlider {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
}
.properties-row {
    margin-top: 0 !important;
    padding-top: 0 !important;
}
/* Hero dots ne prave visinu van slidera */
#heroDots {
    position: absolute !important;
    bottom: 8px !important;
    width: 100% !important;
    pointer-events: none !important;
}
#heroDots .hero-dot {
    pointer-events: all !important;
}
/* Tamna zona = properties-layout bg kad nema sadrzaja */
.page-section.properties-layout {
    background: var(--bg) !important;
}



/* ═══ ADMIN/SETTINGS FULLSCREEN ═══ */
/* Properties se sakriva kad je admin/settings aktivan */
#properties.behind-admin {
    visibility: hidden !important;
    pointer-events: none !important;
    position: absolute !important;
    opacity: 0 !important;
}
#heroSlider.behind-admin {
    display: none !important;
}

/* ═══ SAKRIJ PROPERTIES KAD JE DRUGA SEKCIJA AKTIVNA ═══ */
body:has(#adminPanel.active) #properties,
body:has(#adminPanel.active) #heroSlider,
body:has(#settings.active) #properties,
body:has(#settings.active) #heroSlider,
body:has(#categories.active) #properties,
body:has(#categories.active) #heroSlider,
body:has(#dashboard.active) #properties,
body:has(#dashboard.active) #heroSlider,
body:has(#myListings.active) #properties,
body:has(#myListings.active) #heroSlider,
body:has(#customPageView.active) #properties,
body:has(#customPageView.active) #heroSlider {
    display: none !important;
}

/* ═══ ADMIN FULLSCREEN - KONACNI FIX ═══ */
/* Kad je adminPanel ili settings aktivan, sakrij properties layout */
#adminPanel.active,
#settings.active,
#categories.active,
#softwareSale.active,
#blog.active {
    position: relative !important;
    z-index: 5 !important;
    background: var(--bg) !important;
    min-height: calc(100vh - 58px - 42px) !important;
    width: 100% !important;
}

/* Properties-layout - sakrij ako nije aktivan */
#properties:not(.active) {
    display: none !important;
}

/* HeroSlider - sakrij kad properties nije aktivan */
#heroSlider:not([data-show="true"]) {
    display: none !important;
}

/* ═══ TAMNA ZONA ISPOD SLIDERA - KONACNI FIX ═══ */
/* Hero slider - nema margina, odmah uz properties */
#heroSlider {
    flex-shrink: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    display: block !important;
}

/* Properties layout odmah ispod hero */
#properties.active {
    flex: 1 !important;
    overflow-y: auto !important;
}

/* .main ne treba dark background */
.main {
    background: var(--bg) !important;
}

/* Hero slide background - isto kao .main */
.hero-slider {
    background: #1e293b !important;
}

/* Nema praznine između slidera i content */
.main > * {
    margin-top: 0 !important;
}

/* ═══ QUICK SEARCH BAR FIX ═══ */
.quick-search-bar {
    padding: 10px 16px !important;
    overflow: hidden !important;
}
.quick-search-inner {
    flex-wrap: nowrap !important;
    overflow: hidden !important;
    gap: 8px !important;
}
.quick-search-field {
    flex-shrink: 1 !important;
    min-width: 0 !important;
}
.quick-search-field--wide {
    flex: 2 !important;
    min-width: 120px !important;
}
.quick-search-btn {
    flex-shrink: 0 !important;
    white-space: nowrap !important;
}

/* ═══ QUICK SEARCH BAR - KONACNI FIX ═══ */
.quick-search-bar {
    padding: 8px 12px !important;
    box-sizing: border-box !important;
    width: 100% !important;
    overflow: visible !important;
}
.quick-search-inner {
    flex-wrap: nowrap !important;
    gap: 6px !important;
    width: 100% !important;
    box-sizing: border-box !important;
}
.quick-search-field {
    height: 40px !important;
    padding: 0 10px !important;
    min-width: 0 !important;
    flex-shrink: 1 !important;
}
.quick-search-field--wide {
    flex: 2 1 140px !important;
}
.quick-search-select {
    font-size: 12px !important;
    min-width: 0 !important;
}
.quick-search-btn {
    height: 40px !important;
    padding: 0 16px !important;
    font-size: 13px !important;
    flex-shrink: 0 !important;
    white-space: nowrap !important;
}

/* ═══ HERO SLIDER — OUTSIDE FLEX LAYOUT (FINAL FIX) ═══ */
#heroSlider {
    position: relative !important;
    width: 100% !important;
    height: 380px !important;
    min-height: 380px !important;
    max-height: 380px !important;
    display: none;
    flex-shrink: 0 !important;
    overflow: hidden !important;
    z-index: 1 !important;
    margin: 0 !important;
}
#heroSlider[data-show="true"] {
    display: block !important;
}
#heroSlider .hero-slides {
    width: 100% !important;
    height: 100% !important;
}
#heroSlider .hero-slide {
    width: 100% !important;
    height: 380px !important;
    background-size: cover !important;
    background-position: center !important;
}
/* Properties section - ne počinje odmah uz slider */
#properties.page-section {
    margin-top: 0 !important;
}

/* ═══ LOGIN MODAL — mora biti iznad property detail modala ═══ */
#userLoginModal,
#userRegisterModal,
#forgotPasswordModal {
    z-index: 4500 !important;
}

/* ═══ UMANJI RAZMAK IZMEĐU SLIDERA I KATEGORIJA ═══ */
#heroSlider + #properties,
#heroSlider ~ #properties {
    margin-top: 0 !important;
}
.prop-main {
    padding-top: 8px !important;
}
#categoryGrid {
    margin-top: 0 !important;
    margin-bottom: 12px !important;
}

/* ═══ SIDEBAR SEARCH INPUT — POBOLJŠAN IZGLED ═══ */
.prop-filter-input,
.prop-filter-select {
    padding: 11px 14px !important;
    border-radius: 10px !important;
    font-size: 13.5px !important;
    border: 1.5px solid var(--border) !important;
    transition: border-color 0.2s, box-shadow 0.2s !important;
}
.prop-filter-input:focus,
.prop-filter-select:focus {
    border-color: var(--accent) !important;
    box-shadow: 0 0 0 3px rgba(59,130,246,0.15) !important;
}
.prop-filter-range-input {
    padding: 8px 10px !important;
    border-radius: 9px !important;
    font-size: 13px !important;
}

/* ═══ CONFIRM MODAL — iznad svega ═══ */
#confirmModal {
    z-index: 5000 !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   MOBILE RESPONZIVNOST — PRO-ESTATE ELITE
   ═══════════════════════════════════════════════════════════════════════════ */

/* Topbar clock — sakrij na malim ekranima */
@media (max-width: 900px) {
    #topbarClock { display: none !important; }
    .topbar-search { max-width: 160px !important; }
    .prop-sidebar { width: 180px !important; min-width: 180px !important; }
    .property-list { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)) !important; }
}

@media (max-width: 768px) {
    /* Topbar */
    .topbar { padding: 8px 12px !important; flex-wrap: wrap; gap: 8px; }
    .topbar-search { max-width: 120px !important; font-size: 12px !important; }
    .topbar-brand { font-size: 13px !important; }
    #notifBtn span:not(.badge) { display: none !important; }

    /* Sidebar sakrij na mobilnom */
    .prop-sidebar { display: none !important; }
    .prop-main { margin-left: 0 !important; padding: 8px !important; }
    .properties-layout { flex-direction: column !important; }

    /* Category grid */
    .cat-grid-item { min-width: 80px !important; padding: 10px 8px !important; }
    .cat-grid-icon svg { width: 24px !important; height: 24px !important; }
    .cat-grid-label { font-size: 10px !important; }

    /* Property cards */
    .property-list { grid-template-columns: 1fr !important; }
    .property-list-card { flex-direction: column !important; }
    .property-list-img { width: 100% !important; height: 180px !important; }
    .property-list-info { padding: 12px !important; }

    /* Hero slider */
    #heroSlider { height: 220px !important; min-height: 220px !important; }
    .hero-slide { height: 220px !important; }
    .hero-content h2 { font-size: 20px !important; }
    .hero-content p { font-size: 13px !important; display: none; }

    /* Modal */
    .modal-content { margin: 8px !important; max-height: 95vh !important; }
    .modal-body { padding: 12px !important; }

    /* Cat nav bar */
    .cat-nav-bar { overflow-x: auto !important; flex-wrap: nowrap !important; }

    /* Sidebar nav */
    .left-nav { width: 180px !important; }
    .nav-item span:not(.nav-item-icon) { font-size: 12px !important; }

    /* Featured grid */
    #featuredGrid { grid-template-columns: 1fr 1fr !important; }

    /* Quick search bar */
    .quick-search-bar { flex-wrap: wrap !important; gap: 6px !important; }
    .quick-search-bar input { width: 100% !important; }
}

@media (max-width: 480px) {
    #featuredGrid { grid-template-columns: 1fr !important; }
    .property-list { grid-template-columns: 1fr !important; }
    .cat-grid-wrap { gap: 6px !important; }
    .cat-grid-item { min-width: 70px !important; }
    .topbar-appname { font-size: 12px !important; }
    .left-nav { width: 56px !important; }
    .nav-item span:not(.nav-item-icon) { display: none !important; }
    .nav-item-icon { font-size: 20px !important; }
}

/* ═══ MAPA SVIH OGLASA — sekcija ═══ */
#allPropertiesMap {
    height: 500px;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid var(--border);
    margin-top: 16px;
}
@media (max-width: 768px) {
    #allPropertiesMap { height: 300px; }
}

/* ═══ PROP SIDEBAR — LIGHT STYLE ═══ */
body[data-theme="light"] .prop-sidebar {
    background: #f8fafc !important;
    border-right: 1px solid #e2e8f0 !important;
}
body[data-theme="light"] .prop-sidebar .acc-header {
    color: #475569 !important;
    border-bottom: 0.5px solid #e2e8f0 !important;
}
body[data-theme="light"] .prop-sidebar .acc-body {
    background: #f8fafc !important;
}
body[data-theme="light"] .prop-sidebar input,
body[data-theme="light"] .prop-sidebar select {
    background: #fff !important;
    border: 0.5px solid #e2e8f0 !important;
    color: #1e293b !important;
}
body[data-theme="light"] .prop-sidebar label,
body[data-theme="light"] .prop-sidebar .filter-label {
    color: #64748b !important;
}

/* ═══ PROP SIDEBAR — fade prazan prostor ═══ */
.prop-sidebar {
    -webkit-mask-image: linear-gradient(to bottom, black 85%, transparent 100%);
    mask-image: linear-gradient(to bottom, black 85%, transparent 100%);
}


/* ═══ FIXED FILTER SIDEBAR ═══ */
@media (min-width: 769px) {
    .properties-row {
        position: relative !important;
    }
    .properties-row > .prop-sidebar {
        position: sticky !important;
        top: 0 !important;
        width: 230px !important;
        min-width: 230px !important;
        max-height: calc(100vh - 100px) !important;
        height: auto !important;
        overflow-y: auto !important;
        align-self: flex-start !important;
        flex-shrink: 0 !important;
        z-index: 15 !important;
        background: var(--bg2) !important;
        border-right: 1px solid var(--border) !important;
    }
    .properties-row > .prop-main {
        margin-left: 0 !important;
        flex: 1 !important;
        min-width: 0 !important;
    }
}


/* ═══ COLOR PICKER FIX ═══ */
/* margin-left samo za properties page, ne settings */
#settings.page-section,
#adminPanel.page-section,
#myListings.page-section,
#blog.page-section,
#mapView.page-section {
    margin-left: 0 !important;
}

.sidebar-bg-picker {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(70px, 1fr)) !important;
    gap: 10px !important;
    max-width: 500px !important;
}


/* ═══ DESNI SIDEBAR FIX ═══ */
@media (min-width: 1201px) {
    .prop-right-sidebar {
        display: flex !important;
        position: sticky !important;
        top: 0 !important;
        height: calc(100vh - 100px) !important;
        width: 220px !important;
        min-width: 220px !important;
        overflow-y: auto !important;
        align-self: flex-start !important;
        flex-shrink: 0 !important;
    }
    .properties-row > .prop-main {
        margin-right: 0 !important;
    }
}


/* ═══ PICKER FLEX FIX ═══ */
#sidebarBgPicker {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    gap: 12px !important;
}


/* ═══ ADMIN PANEL ORGANIZACIJA ═══ */
.admin-quick-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    margin: 16px 0;
}
.aqs-card {
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 16px;
    text-align: center;
    transition: transform 0.15s;
}
.aqs-card:hover { transform: translateY(-2px); }
.aqs-icon { font-size: 24px; margin-bottom: 6px; }
.aqs-num { font-size: 28px; font-weight: 800; color: var(--text); }
.aqs-num.aqs-red { color: var(--red); }
.aqs-num.aqs-gold { color: #f59e0b; }
.aqs-label { font-size: 12px; color: var(--text3); margin-top: 4px; font-weight: 600; }

.admin-btn-group {
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 14px 16px;
    margin-bottom: 12px;
}
.admin-btn-group-title {
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: var(--text3);
    margin-bottom: 10px;
}
.admin-btn-group-btns {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

@media (max-width: 768px) {
    .admin-quick-stats { grid-template-columns: repeat(2, 1fr); }
}


/* ═══ DASHBOARD ═══ */
.dash-kpi-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 12px;
    margin-bottom: 20px;
}
.dash-kpi-card {
    border-radius: 14px;
    padding: 18px 14px;
    text-align: center;
    color: #fff;
    position: relative;
    overflow: hidden;
}
.dash-kpi-card::after {
    content: '';
    position: absolute;
    top: -20px; right: -20px;
    width: 80px; height: 80px;
    background: rgba(255,255,255,0.1);
    border-radius: 50%;
}
.dash-kpi-blue   { background: linear-gradient(135deg,#1d4ed8,#3b82f6); }
.dash-kpi-green  { background: linear-gradient(135deg,#059669,#10b981); }
.dash-kpi-red    { background: linear-gradient(135deg,#dc2626,#ef4444); }
.dash-kpi-gold   { background: linear-gradient(135deg,#d97706,#f59e0b); }
.dash-kpi-purple { background: linear-gradient(135deg,#7c3aed,#a78bfa); }
.dash-kpi-teal   { background: linear-gradient(135deg,#0891b2,#22d3ee); }
.dash-kpi-icon   { font-size: 22px; margin-bottom: 6px; }
.dash-kpi-val    { font-size: 26px; font-weight: 800; line-height: 1; }
.dash-kpi-label  { font-size: 11px; opacity: 0.85; margin-top: 4px; font-weight: 600; }

.dash-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
    margin-bottom: 14px;
}
.dash-panel {
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 16px;
}
.dash-panel h2 {
    font-size: 13px !important;
    font-weight: 700 !important;
    margin-bottom: 14px !important;
    color: var(--text2) !important;
}
.dash-bar-row {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 8px;
    font-size: 12px;
}
.dash-bar-label { width: 100px; color: var(--text2); font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dash-bar-track { flex: 1; height: 8px; background: var(--bg3); border-radius: 99px; overflow: hidden; }
.dash-bar-fill  { height: 100%; border-radius: 99px; background: var(--accent); transition: width 0.6s ease; }
.dash-bar-num   { width: 30px; text-align: right; color: var(--text3); font-weight: 700; }

.dash-activity-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 7px 0;
    border-bottom: 1px solid var(--border);
    font-size: 12px;
    color: var(--text2);
}
.dash-activity-item:last-child { border-bottom: none; }
.dash-activity-icon { font-size: 16px; flex-shrink: 0; }

@media (max-width: 1200px) { .dash-kpi-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 768px) { .dash-kpi-grid { grid-template-columns: repeat(2, 1fr); } .dash-grid { grid-template-columns: 1fr; } }


/* ═══ BULK AKCIJE ═══ */
.bulk-toolbar {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    animation: fadeIn 0.2s ease;
}
.prop-results-bar {
    flex-wrap: wrap;
    gap: 8px;
}
.property-list-card.bulk-selected {
    outline: 2px solid var(--accent) !important;
    outline-offset: 2px;
}
.bulk-checkbox-wrap {
    position: absolute;
    top: 8px;
    left: 8px;
    z-index: 5;
    background: var(--bg);
    border-radius: 4px;
    padding: 2px;
    display: none;
}
body.bulk-mode .bulk-checkbox-wrap {
    display: block;
}
body.bulk-mode .property-list-card {
    cursor: pointer;
}

/* Bulk toolbar vidljiv */
#bulkToolbar {
    display: none;
}
#bulkToolbar.active {
    display: flex !important;
}


/* ═══ ACTIVITY LOG ═══ */
.activity-log-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 8px 10px;
    border-radius: 8px;
    margin-bottom: 4px;
    font-size: 12px;
    background: var(--bg);
    border: 1px solid var(--border);
}
.activity-log-item:hover { background: var(--bg3); }
.activity-log-icon { font-size: 16px; flex-shrink: 0; margin-top: 1px; }
.activity-log-main { flex: 1; min-width: 0; }
.activity-log-action { font-weight: 700; color: var(--text); }
.activity-log-details { color: var(--text2); margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.activity-log-meta { color: var(--text3); font-size: 11px; white-space: nowrap; }
.activity-log-item.type-success .activity-log-action { color: #10b981; }
.activity-log-item.type-warning .activity-log-action { color: #f59e0b; }
.activity-log-item.type-danger  .activity-log-action { color: var(--red); }
.activity-log-empty { text-align: center; color: var(--text3); padding: 20px; font-size: 13px; }


/* ═══ MOBILNI PRIKAZ FIX ═══ */
@media (max-width: 768px) {

    /* Topbar - sakrij nepotrebne elemente */
    .topbar-appname { display: none !important; }
    .topbar-search { display: none !important; }
    #darkModeToggle { display: none !important; }
    .topbar-clock { display: none !important; }
    #favoritesBtn span, #myAdsBtn span { display: none !important; }
    #favoritesBtn, #myAdsBtn { min-width: 36px !important; padding: 0 8px !important; }
    
    /* Cat nav - sakrij search bar, ostavi samo tabove */
    .cat-nav-search-wrap { display: none !important; }
    .cat-nav-btn { font-size: 11px !important; padding: 4px 8px !important; }

    /* Oglas kartica - fix slike */
    .prop-card-img, .property-list-card .card-img {
        height: 180px !important;
        width: 100% !important;
        object-fit: cover !important;
    }
    
    /* Plan badge - ne izlazi van */
    .plan-badge, .prop-badge {
        max-width: 90px !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
    }

    /* Oglas kartica - puna širina */
    .property-list-card {
        width: 100% !important;
        margin: 0 0 12px 0 !important;
    }

    /* Lijevi sidebar - ne diramo, ima svoj mobile CSS */
}


/* ═══ MOBILNI FIX #2 ═══ */
@media (max-width: 768px) {

    /* Quick search bar - sakrij na mobilnom */
    .quick-search-bar, .hero-search, #heroSearchBar { 
        display: none !important; 
    }

    /* Category grid ikone - sakrij na mobilnom */
    .cat-grid-wrap, #categoryGrid {
        display: none !important;
    }

    /* Plan badge fix */
    .prop-plan-badge, .listing-plan-badge, [class*="plan-badge"], [class*="prop-badge"] {
        max-width: 100px !important;
        font-size: 10px !important;
        padding: 2px 6px !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
    }

    /* Oglas slika fix */
    .property-list-card img,
    .prop-card-img img,
    .card-image img {
        width: 100% !important;
        height: 200px !important;
        object-fit: cover !important;
        display: block !important;
    }

    /* Card image container */
    .property-list-card .card-img-wrap,
    .property-list-card > div:first-child {
        height: 200px !important;
        overflow: hidden !important;
    }
}


/* ═══ MOBILNI FIX #3 ═══ */
@media (max-width: 768px) {
    /* Plan badge - ne izlazi van */
    .property-plan-badge {
        max-width: 110px !important;
        font-size: 9px !important;
        padding: 2px 6px !important;
        right: 8px !important;
        top: 8px !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
    }

    /* Quick search - sakrij */
    .quick-search-wrap, .qsb-wrap, #quickSearchBar, .hero-quick-search {
        display: none !important;
    }

    /* Post listing dugme - manji */
    #postListingBtn, .post-listing-btn {
        font-size: 12px !important;
        padding: 6px 10px !important;
    }

    /* Topbar dugmad - kompaktnija */
    .topbar .btn {
        font-size: 12px !important;
        padding: 5px 8px !important;
    }
}


/* ═══ MOBILNI FIX #4 — Card layout ═══ */
@media (max-width: 768px) {
    /* Kartica mora imati position:relative za absolute children */
    .property-list-card {
        position: relative !important;
        overflow: hidden !important;
    }

    /* Pinned badge - fix veličina */
    .property-pinned-badge {
        font-size: 9px !important;
        padding: 2px 8px !important;
        left: 8px !important;
        z-index: 5 !important;
    }

    /* Compare checkbox wrap - ne rasteze karticu */
    .compare-checkbox-wrap {
        position: absolute !important;
        top: 8px !important;
        right: 8px !important;
        z-index: 6 !important;
    }

    /* Plan badge - fix */
    .property-plan-badge {
        right: 8px !important;
        top: 8px !important;
        font-size: 9px !important;
        padding: 2px 6px !important;
        max-width: 90px !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
    }
}


/* ═══ MOBILNI SIDEBAR TEKST ═══ */
@media (max-width: 768px) {
    .sidebar {
        background: #1e293b !important;
    }
    .sidebar .nav-item {
        color: #f1f5f9 !important;
    }
    .sidebar .nav-item:hover {
        background: rgba(255,255,255,0.1) !important;
        color: #fff !important;
    }
    .sidebar .nav-item-icon {
        color: #94a3b8 !important;
    }
    .sidebar-logo-text {
        color: #fff !important;
    }
    .sidebar-footer {
        color: #94a3b8 !important;
    }
}


/* ═══ SIDEBAR FOOTER NA MOBILNOM ═══ */
@media (max-width: 768px) {
    .sidebar-footer {
        display: flex !important;
        flex-direction: column !important;
        padding: 12px !important;
        gap: 8px !important;
    }
    .sidebar-footer select,
    #langSelect, #currencySelect, #themeSelectSidebar, 
    [id*="sidebar"][id*="select"], [id*="sidebar"][id*="theme"] {
        display: block !important;
        width: 100% !important;
        color: #fff !important;
        background: rgba(255,255,255,0.1) !important;
        border: 1px solid rgba(255,255,255,0.2) !important;
    }
}


/* ═══ SAKRIJ DUPLI SELECTOR NA MOBILNOM ═══ */
@media (max-width: 768px) {
    #langSelect, #currSelect {
        display: none !important;
    }
    .flag-select {
        display: block !important;
        width: 100% !important;
    }
    .flag-select-btn {
        background: rgba(255,255,255,0.1) !important;
        border: 1px solid rgba(255,255,255,0.2) !important;
        color: #fff !important;
        border-radius: 8px !important;
        padding: 8px 12px !important;
    }
    .flag-select-text, .flag-select-arrow {
        color: #fff !important;
    }
}
