/* ═══════════════════════════════════════
   PORTFOLINK — Emlak Portföy Yönetim Sistemi
   CSS v1.0
   ═══════════════════════════════════════ */

:root {
  --bg: #07080c;
  --bg2: #0e1017;
  --bg3: #151720;
  --bg4: #1c1e2d;
  --bgi: #12141c;
  --acc: #c9a44e;
  --accl: #e4c76b;
  --accd: #a07d2e;
  --accg: rgba(201,164,78,0.12);
  --acc2: #3b7dd8;
  --t1: #f0ece4;
  --t2: #9a96a6;
  --t3: #5e5b6a;
  --brd: rgba(201,164,78,0.10);
  --brds: rgba(201,164,78,0.22);
  --ok: #4ade80;
  --no: #f87171;
  --info: #60a5fa;
  --warn: #fbbf24;
  --r: 16px;
  --rs: 10px;
  --rx: 6px;
  --sh: 0 8px 32px rgba(0,0,0,0.5);
  --fb: 'Plus Jakarta Sans', -apple-system, sans-serif;
  --fd: 'Cormorant Garamond', Georgia, serif;
  --st: env(safe-area-inset-top, 0px);
  --sb: env(safe-area-inset-bottom, 0px);
  --nh: 60px;
  --bh: 68px;
}

* { margin:0; padding:0; box-sizing:border-box; -webkit-tap-highlight-color:transparent; }
html, body {
  font-family: var(--fb);
  background: var(--bg);
  color: var(--t1);
  min-height: 100vh;
  min-height: 100dvh;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
}
body { padding-top: var(--st); }
::-webkit-scrollbar { width: 3px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--accd); border-radius: 4px; }

/* Animations */
@keyframes fadeIn { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:translateY(0); } }
@keyframes scaleIn { from { opacity:0; transform:scale(.92); } to { opacity:1; transform:scale(1); } }
@keyframes spin { to { transform:rotate(360deg); } }

/* ─── BUTTONS ─── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:7px;
  padding:12px 20px; border:none; border-radius:var(--rs);
  font-family:var(--fb); font-size:13.5px; font-weight:600;
  cursor:pointer; transition:all .15s; text-decoration:none;
  -webkit-user-select:none; user-select:none; white-space:nowrap;
}
.btn-primary { background:linear-gradient(135deg,var(--acc),var(--accd)); color:var(--bg); box-shadow:0 4px 16px rgba(201,164,78,0.25); }
.btn-primary:active { transform:scale(.97); }
.btn-secondary { background:var(--bg3); color:var(--t1); border:1px solid var(--brd); }
.btn-secondary:active { background:var(--bg4); }
.btn-danger { background:rgba(248,113,113,0.12); color:var(--no); border:1px solid rgba(248,113,113,0.15); }
.btn-blue { background:rgba(59,125,216,0.15); color:var(--acc2); border:1px solid rgba(59,125,216,0.2); }
.btn-sm { padding:9px 14px; font-size:12.5px; border-radius:var(--rx); }
.btn-full { width:100%; }
.btn-icon { width:40px; height:40px; padding:0; border-radius:50%; }

/* ─── INPUTS ─── */
.input-group { margin-bottom:14px; }
.input-group label { display:block; font-size:11px; font-weight:600; color:var(--t2); margin-bottom:5px; text-transform:uppercase; letter-spacing:.5px; }
.input-group input,
.input-group textarea,
.input-group select {
  width:100%; padding:13px 14px; background:var(--bgi);
  border:1px solid var(--brd); border-radius:var(--rs);
  color:var(--t1); font-family:var(--fb); font-size:16px;
  transition:border-color .15s;
}
.input-group input:focus, .input-group textarea:focus, .input-group select:focus { outline:none; border-color:var(--acc); }
.input-group textarea { resize:vertical; min-height:72px; }
.input-group select {
  -webkit-appearance:none; appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%239a96a6' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 12px center;
}
.input-row { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
@media(max-width:360px) { .input-row { grid-template-columns:1fr; } }

/* ─── BADGES ─── */
.badge { display:inline-flex; padding:3px 9px; border-radius:20px; font-size:10.5px; font-weight:600; text-transform:uppercase; letter-spacing:.3px; }
.badge-gold { background:var(--accg); color:var(--acc); }
.badge-green { background:rgba(74,222,128,0.1); color:var(--ok); }
.badge-blue { background:rgba(96,165,250,0.1); color:var(--info); }
.badge-red { background:rgba(248,113,113,0.1); color:var(--no); }
.badge-yellow { background:rgba(251,191,36,0.1); color:var(--warn); }

/* ─── AVATAR ─── */
.avatar { width:38px; height:38px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:13px; color:var(--bg); flex-shrink:0; }
.avatar-sm { width:30px; height:30px; font-size:11px; }
.avatar-lg { width:52px; height:52px; font-size:18px; }

/* ─── TOAST ─── */
.toast-container { position:fixed; top:calc(var(--st)+12px); left:12px; right:12px; z-index:10000; pointer-events:none; }
.toast { background:var(--bg3); border:1px solid var(--brds); border-radius:var(--rs); padding:12px 16px; font-size:13.5px; font-weight:500; margin-bottom:6px; animation:scaleIn .3s; pointer-events:auto; display:flex; align-items:center; gap:8px; box-shadow:var(--sh); }
.toast-success { border-left:3px solid var(--ok); }
.toast-error { border-left:3px solid var(--no); }
.toast-info { border-left:3px solid var(--info); }

/* ─── EMPTY STATE ─── */
.empty-state { text-align:center; padding:40px 20px; color:var(--t2); }
.empty-state h3 { font-size:16px; margin-bottom:6px; color:var(--t1); }
.empty-state p { font-size:13px; }

/* ─── MODAL ─── */
.modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.75); z-index:9000; display:flex; align-items:flex-end; justify-content:center; opacity:0; pointer-events:none; transition:opacity .15s; }
.modal-overlay.active { opacity:1; pointer-events:auto; }
.modal { background:var(--bg2); border-radius:var(--r) var(--r) 0 0; width:100%; max-width:480px; max-height:88vh; overflow-y:auto; padding:20px 18px calc(20px + var(--sb)); transform:translateY(100%); transition:transform .25s cubic-bezier(.22,1,.36,1); }
.modal-overlay.active .modal { transform:translateY(0); }
.modal-handle { width:32px; height:4px; background:var(--t3); border-radius:4px; margin:0 auto 16px; }
.modal h3 { font-size:17px; font-weight:700; margin-bottom:16px; }

/* ─── LAYOUT ─── */
.app { min-height:100vh; min-height:100dvh; display:flex; flex-direction:column; }

.top-nav {
  position:fixed; top:var(--st); left:0; right:0; height:var(--nh);
  background:rgba(7,8,12,.94); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--brd);
  display:flex; align-items:center; padding:0 14px; gap:10px; z-index:1000;
}
.top-nav .spacer { flex:1; }
.top-nav .nav-logo { height:32px; width:auto; }

.bottom-nav {
  position:fixed; bottom:0; left:0; right:0;
  height:calc(var(--bh) + var(--sb));
  background:rgba(7,8,12,.96); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border-top:1px solid var(--brd);
  display:flex; align-items:flex-start; justify-content:space-around;
  padding-top:6px; z-index:1000;
}
.bottom-nav .nav-item {
  display:flex; flex-direction:column; align-items:center; gap:3px;
  padding:5px 8px; background:none; border:none; cursor:pointer;
  color:var(--t3); transition:color .15s; font-family:var(--fb);
}
.bottom-nav .nav-item.active { color:var(--acc); }
.bottom-nav .nav-item svg { width:20px; height:20px; }
.bottom-nav .nav-item span { font-size:9.5px; font-weight:600; letter-spacing:.3px; }

.page {
  flex:1; padding-top:calc(var(--nh) + var(--st));
  padding-bottom:calc(var(--bh) + var(--sb) + 12px);
  display:none; min-height:100vh; min-height:100dvh;
}
.page.active { display:block; }
.page-content { padding:14px; max-width:480px; margin:0 auto; }

/* ─── LOGIN PAGE ─── */
.login-page {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  min-height:100vh; min-height:100dvh; padding:28px 20px; text-align:center;
  background:radial-gradient(ellipse at 50% 20%, rgba(201,164,78,0.04), transparent 60%);
}
.login-page .brand { margin-bottom:32px; }
.login-page .brand img { max-width:240px; height:auto; }
.login-page .brand p { color:var(--t3); font-size:11px; text-transform:uppercase; letter-spacing:2px; margin-top:6px; }
.login-box { width:100%; max-width:340px; background:var(--bg2); border:1px solid var(--brd); border-radius:var(--r); padding:24px 20px; }
.login-box h2 { font-size:18px; font-weight:700; margin-bottom:20px; }
.demo-accounts { margin-top:16px; padding-top:16px; border-top:1px solid var(--brd); }
.demo-accounts h4 { font-size:10px; text-transform:uppercase; letter-spacing:.5px; color:var(--t3); margin-bottom:10px; }
.demo-btn {
  width:100%; padding:10px 14px; background:var(--bg3); border:1px solid var(--brd);
  border-radius:var(--rs); display:flex; align-items:center; gap:10px;
  cursor:pointer; transition:all .15s; margin-bottom:6px; text-align:left;
  font-family:var(--fb); color:var(--t1);
}
.demo-btn:active { border-color:var(--acc); background:var(--accg); }
.demo-btn .demo-role { font-size:10.5px; color:var(--t2); }
.demo-btn .demo-name { font-size:13.5px; font-weight:600; }

/* ─── VITRIN / PUBLIC ─── */
.vitrin-hero {
  position:relative; padding:28px 18px 0; text-align:center;
  background:linear-gradient(180deg, rgba(201,164,78,0.06), transparent 100%);
}
.vitrin-hero .hero-logo { height:44px; width:auto; margin-bottom:10px; }
.vitrin-hero h1 { font-family:var(--fd); font-size:26px; font-weight:600; line-height:1.2; margin-bottom:6px; }
.vitrin-hero h1 em { color:var(--acc); font-style:normal; }
.vitrin-hero > p { color:var(--t2); font-size:13px; margin-bottom:18px; }
.hero-stats { display:flex; justify-content:center; gap:24px; margin-bottom:20px; }
.hero-stat .hs-num { font-size:24px; font-weight:800; color:var(--acc); font-family:var(--fd); }
.hero-stat .hs-lbl { font-size:9.5px; color:var(--t3); text-transform:uppercase; letter-spacing:.8px; }

/* ─── SEARCH PANEL ─── */
.search-panel { margin:0 14px 10px; background:var(--bg2); border:1px solid var(--brd); border-radius:var(--r); overflow:hidden; }
.search-main { padding:14px; }
.search-input-wrap { position:relative; margin-bottom:12px; }
.search-input-wrap input { width:100%; padding:13px 14px 13px 42px; background:var(--bg); border:1px solid var(--brd); border-radius:var(--rs); color:var(--t1); font-family:var(--fb); font-size:15px; }
.search-input-wrap input:focus { outline:none; border-color:var(--acc); }
.search-input-wrap input::placeholder { color:var(--t3); }
.search-input-wrap .si { position:absolute; left:14px; top:50%; transform:translateY(-50%); color:var(--t3); }

/* Type Toggle */
.type-toggle { display:flex; gap:0; border-radius:var(--rs); overflow:hidden; border:1px solid var(--brd); margin-bottom:12px; }
.type-toggle-btn { flex:1; padding:10px 4px; text-align:center; font-size:12px; font-weight:600; background:var(--bg); color:var(--t2); border:none; cursor:pointer; font-family:var(--fb); transition:all .15s; }
.type-toggle-btn:not(:last-child) { border-right:1px solid var(--brd); }
.type-toggle-btn.active { background:var(--acc); color:var(--bg); }
.type-toggle-btn .tt-i { display:block; font-size:16px; margin-bottom:1px; }

/* Category Grid */
.cat-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:6px; margin-bottom:4px; }
.cat-card { padding:12px 4px; text-align:center; border-radius:var(--rs); border:1px solid var(--brd); background:var(--bg); cursor:pointer; transition:all .15s; font-family:var(--fb); }
.cat-card:active { transform:scale(.96); }
.cat-card.active { border-color:var(--acc); background:var(--accg); }
.cat-card .ci { font-size:22px; display:block; margin-bottom:2px; }
.cat-card .cn { font-size:10.5px; font-weight:600; color:var(--t2); }
.cat-card.active .cn { color:var(--acc); }

/* Advanced Toggle */
.adv-toggle { display:flex; align-items:center; justify-content:center; gap:6px; padding:10px; border-top:1px solid var(--brd); cursor:pointer; font-size:12px; font-weight:600; color:var(--t2); background:rgba(201,164,78,0.02); }
.adv-toggle:active { color:var(--acc); }
.adv-toggle svg { width:14px; height:14px; transition:transform .2s; }
.adv-toggle.open svg { transform:rotate(180deg); }
.adv-filters { padding:0 14px; max-height:0; overflow:hidden; transition:max-height .3s, padding .3s; }
.adv-filters.open { max-height:600px; padding:14px; }
.fl { font-size:11px; font-weight:600; color:var(--t3); text-transform:uppercase; letter-spacing:.5px; margin-bottom:7px; }

/* Multi-Select Dropdown */
.msd-wrap { position:relative; margin-bottom:12px; }
.msd-btn { width:100%; padding:10px 12px; background:var(--bg); border:1px solid var(--brd); border-radius:var(--rs); color:var(--t2); font-family:var(--fb); font-size:13px; text-align:left; cursor:pointer; display:flex; justify-content:space-between; align-items:center; }
.msd-btn .has-sel { color:var(--acc); }
.msd-btn::after { content:'▾'; font-size:10px; }
.msd-panel { display:none; position:absolute; top:100%; left:0; right:0; background:var(--bg2); border:1px solid var(--brds); border-radius:var(--rs); padding:8px; z-index:100; max-height:200px; overflow-y:auto; box-shadow:var(--sh); }
.msd-wrap.open .msd-panel { display:block; }
.msd-item { display:flex; align-items:center; gap:8px; padding:8px; border-radius:var(--rx); cursor:pointer; font-size:13px; color:var(--t1); }
.msd-item:active { background:var(--accg); }
.msd-item input { width:18px; height:18px; accent-color:var(--acc); }

/* Active Filters */
.active-filters { display:flex; flex-wrap:wrap; gap:5px; padding:0 14px; margin-bottom:6px; }
.af-tag { padding:4px 10px; border-radius:14px; font-size:11px; font-weight:600; background:var(--accg); color:var(--acc); border:1px solid var(--brds); display:flex; align-items:center; gap:4px; }
.af-tag button { background:none; border:none; color:var(--acc); font-size:14px; cursor:pointer; padding:0; line-height:1; }
.clear-all-btn { font-size:12px; color:var(--no); background:none; border:none; cursor:pointer; font-family:var(--fb); font-weight:600; padding:4px 8px; }

/* Sort Bar */
.sort-bar { display:flex; align-items:center; justify-content:space-between; padding:6px 14px; margin-bottom:4px; }
.sort-bar .rt { font-size:13px; color:var(--t2); }
.sort-bar .rt strong { color:var(--acc); }
.sort-select { padding:7px 28px 7px 10px; background:var(--bg3); border:1px solid var(--brd); border-radius:var(--rx); color:var(--t1); font-family:var(--fb); font-size:12px; -webkit-appearance:none; appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' fill='%239a96a6' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 8px center; }

/* ─── PORTFOLIO CARD ─── */
.portfolio-grid { padding:0 14px 14px; display:flex; flex-direction:column; gap:14px; }
.portfolio-card { background:var(--bg3); border:1px solid var(--brd); border-radius:var(--r); overflow:hidden; animation:fadeIn .4s ease forwards; opacity:0; }
.img-container { position:relative; width:100%; height:200px; overflow:hidden; }
.img-container img { width:100%; height:100%; object-fit:cover; }
.img-nav-btn { position:absolute; top:50%; transform:translateY(-50%); width:32px; height:32px; border-radius:50%; background:rgba(0,0,0,.55); backdrop-filter:blur(4px); border:none; color:#fff; cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:16px; }
.img-nav-btn.prev { left:6px; }
.img-nav-btn.next { right:6px; }
.img-counter { position:absolute; bottom:10px; right:10px; background:rgba(0,0,0,.6); padding:3px 8px; border-radius:10px; font-size:10px; font-weight:600; color:#fff; }
.price-tag { position:absolute; top:10px; left:10px; background:rgba(7,8,12,.85); backdrop-filter:blur(8px); padding:5px 10px; border-radius:8px; font-weight:700; font-size:14px; color:var(--acc); }
.sahibinden-link { position:absolute; top:10px; right:10px; width:36px; height:36px; border-radius:8px; background:#ffe800; display:flex; align-items:center; justify-content:center; box-shadow:0 2px 8px rgba(0,0,0,.3); z-index:2; text-decoration:none; }
.card-body { padding:12px; }
.card-title { font-size:15px; font-weight:700; margin-bottom:3px; line-height:1.3; }
.card-location { font-size:12px; color:var(--t2); margin-bottom:8px; display:flex; align-items:center; gap:4px; }
.card-features { display:flex; gap:12px; margin-bottom:10px; flex-wrap:wrap; }
.feature { display:flex; align-items:center; gap:4px; font-size:12px; color:var(--t2); }
.feature svg { width:14px; height:14px; color:var(--acc); }
.card-footer { display:flex; align-items:center; justify-content:space-between; padding-top:10px; border-top:1px solid var(--brd); }
.agent-info { display:flex; align-items:center; gap:6px; }
.agent-name { font-size:12px; font-weight:600; }
.agent-role { font-size:10px; color:var(--t3); }
.card-date { font-size:10px; color:var(--t3); }

/* ─── DASHBOARD ─── */
.dash-header { padding:14px 0; margin-bottom:10px; }
.dash-header .greeting { font-size:13px; color:var(--t2); margin-bottom:3px; }
.dash-header h2 { font-size:20px; font-weight:800; }
.dash-header h2 span { color:var(--acc); }
.stat-cards { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:14px; }
.stat-card { background:var(--bg3); border:1px solid var(--brd); border-radius:var(--rs); padding:12px; }
.stat-card .stat-label { font-size:10px; color:var(--t3); text-transform:uppercase; letter-spacing:.5px; margin-bottom:5px; }
.stat-card .stat-value { font-size:24px; font-weight:800; color:var(--acc); font-family:var(--fd); }
.section-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.section-header h3 { font-size:15px; font-weight:700; }

/* Portfolio List Item */
.pli { background:var(--bg3); border:1px solid var(--brd); border-radius:var(--rs); padding:10px; display:flex; gap:10px; margin-bottom:8px; cursor:pointer; transition:all .15s; }
.pli:active { border-color:var(--acc); }
.pli .thumb { width:64px; height:64px; border-radius:8px; overflow:hidden; flex-shrink:0; }
.pli .thumb img { width:100%; height:100%; object-fit:cover; }
.pli .info { flex:1; min-width:0; }
.pli .info h4 { font-size:13px; font-weight:600; margin-bottom:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pli .info .loc { font-size:11px; color:var(--t2); margin-bottom:3px; }
.pli .info .price { font-size:14px; font-weight:700; color:var(--acc); }
.pli .actions { display:flex; flex-direction:column; justify-content:center; gap:4px; }

/* ─── FORM ─── */
.form-section { margin-bottom:18px; }
.form-section h3 { font-size:13px; font-weight:600; color:var(--acc); text-transform:uppercase; letter-spacing:.5px; margin-bottom:10px; padding-bottom:6px; border-bottom:1px solid var(--brd); }
.photo-upload-area { border:2px dashed var(--brd); border-radius:var(--rs); padding:24px 14px; text-align:center; cursor:pointer; margin-bottom:10px; }
.photo-upload-area:active { border-color:var(--acc); background:var(--accg); }
.photo-upload-area p { font-size:12.5px; color:var(--t2); }
.photo-preview-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:6px; margin-top:10px; }
.photo-preview-item { position:relative; aspect-ratio:1; border-radius:8px; overflow:hidden; }
.photo-preview-item img { width:100%; height:100%; object-fit:cover; }
.photo-preview-item .rp { position:absolute; top:3px; right:3px; width:22px; height:22px; border-radius:50%; background:rgba(0,0,0,.7); border:none; color:#fff; font-size:13px; cursor:pointer; display:flex; align-items:center; justify-content:center; }

/* Quick-Add dropdown */
.qw { display:flex; gap:6px; }
.qw select { flex:1; }
.qadd-btn { padding:0 14px; background:var(--acc); color:var(--bg); border:none; border-radius:var(--rs); font-size:18px; font-weight:700; cursor:pointer; }
.qadd-row { display:flex; gap:6px; margin-top:6px; }
.qadd-row input { flex:1; padding:10px; background:var(--bg); border:1px solid var(--acc); border-radius:var(--rx); color:var(--t1); font-family:var(--fb); font-size:14px; }
.qadd-row button { padding:0 12px; border:none; border-radius:var(--rx); font-size:16px; cursor:pointer; }
.qadd-row button:first-of-type { background:var(--ok); color:var(--bg); }
.qadd-row button:last-of-type { background:var(--bg4); color:var(--t2); }

/* Location */
.loc-wrap { position:relative; }
.loc-suggestions { position:absolute; top:100%; left:0; right:0; background:var(--bg2); border:1px solid var(--brds); border-radius:0 0 var(--rs) var(--rs); z-index:100; box-shadow:var(--sh); max-height:250px; overflow-y:auto; }
.loc-sug-item { display:flex; align-items:flex-start; gap:8px; padding:10px 12px; cursor:pointer; transition:background .1s; }
.loc-sug-item:active { background:var(--accg); }
.sug-pin { font-size:16px; margin-top:2px; }
.sug-main { font-size:13px; font-weight:600; color:var(--t1); }
.sug-sub { font-size:11px; color:var(--t3); margin-top:1px; }
.loc-searching { padding:12px; text-align:center; font-size:12px; color:var(--t2); }
.loc-selected-badge { display:flex; align-items:center; gap:6px; margin-top:8px; padding:8px 12px; background:var(--accg); border:1px solid var(--brds); border-radius:var(--rs); font-size:12px; }
.loc-selected-badge button { background:none; border:none; color:var(--no); font-size:16px; cursor:pointer; margin-left:auto; }
#locMap { height:180px; border-radius:var(--rs); margin-top:8px; display:none; }

/* ─── ADMIN ─── */
.admin-tabs { display:flex; gap:4px; margin-bottom:14px; overflow-x:auto; scrollbar-width:none; -webkit-overflow-scrolling:touch; }
.admin-tabs::-webkit-scrollbar { display:none; }
.admin-tab { padding:8px 14px; border-radius:20px; font-size:12px; font-weight:600; white-space:nowrap; border:1px solid var(--brd); background:var(--bg3); color:var(--t2); cursor:pointer; font-family:var(--fb); }
.admin-tab.active { background:var(--acc); color:var(--bg); border-color:var(--acc); }
.apn { display:none; }
.apn.active { display:block; }

.ec { background:var(--bg3); border:1px solid var(--brd); border-radius:var(--rs); padding:12px; display:flex; align-items:center; gap:10px; margin-bottom:8px; }
.ec .ei { flex:1; }
.ec .ei h4 { font-size:13px; font-weight:600; }
.ec .ei p { font-size:11px; color:var(--t2); }
.ec .es { text-align:right; }
.ec .es .cnt { font-size:18px; font-weight:700; color:var(--acc); }
.ec .es .lbl { font-size:9px; color:var(--t3); text-transform:uppercase; }

.cr { background:var(--bg3); border:1px solid var(--brd); border-radius:var(--rs); padding:12px; margin-bottom:6px; }
.cr .cn { font-size:13px; font-weight:600; margin-bottom:2px; }
.cr .cd { font-size:11px; color:var(--t2); display:flex; align-items:center; gap:4px; margin-top:1px; }
.cc { display:inline-flex; padding:2px 8px; border-radius:10px; font-size:10px; font-weight:600; background:rgba(59,125,216,0.12); color:var(--acc2); margin-left:6px; }

/* Logs */
.li { background:var(--bg3); border:1px solid var(--brd); border-radius:var(--rs); padding:11px 13px; margin-bottom:6px; display:flex; align-items:flex-start; gap:10px; }
.li .ld { width:8px; height:8px; border-radius:50%; margin-top:5px; flex-shrink:0; }
.li .lb { flex:1; }
.li .lm { font-size:13px; line-height:1.4; }
.li .lt { font-size:10px; color:var(--t3); margin-top:2px; }
.ld.add { background:var(--ok); }
.ld.edit { background:var(--warn); }
.ld.delete { background:var(--no); }
.ld.login { background:var(--info); }
.ld.msg { background:#c084fc; }

/* Messaging */
.compose-box { background:var(--bg3); border:1px solid var(--brd); border-radius:var(--r); padding:16px; margin-bottom:14px; }
.compose-box h4 { font-size:13px; font-weight:600; margin-bottom:10px; color:var(--acc); }
.rtag { padding:4px 10px; border-radius:14px; font-size:11px; background:var(--accg); color:var(--acc); border:1px solid var(--brd); }
.chk { display:flex; align-items:center; gap:8px; padding:8px 0; cursor:pointer; }
.chk input { width:18px; height:18px; accent-color:var(--acc); }
.chk label { font-size:13px; cursor:pointer; flex:1; }
.chk .chd { font-size:11px; color:var(--t3); }

/* City filter bar */
.cfb { display:flex; gap:5px; flex-wrap:wrap; margin-bottom:12px; }
.cp { padding:5px 12px; border-radius:14px; font-size:11px; font-weight:600; border:1px solid var(--brd); background:var(--bg3); color:var(--t2); cursor:pointer; font-family:var(--fb); }
.cp.active { background:var(--acc2); color:#fff; border-color:var(--acc2); }

/* Detail Modal */
.detail-gallery { position:relative; width:100%; height:220px; overflow:hidden; border-radius:var(--rs); margin-bottom:14px; }
.detail-gallery img { width:100%; height:100%; object-fit:cover; }
.detail-info h2 { font-family:var(--fd); font-size:20px; font-weight:600; margin-bottom:3px; }
.detail-location { color:var(--t2); font-size:13px; margin-bottom:10px; }
.detail-price { font-size:22px; font-weight:800; color:var(--acc); margin-bottom:14px; }
.dfg { display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-bottom:14px; }
.dfi { background:var(--bg3); border:1px solid var(--brd); border-radius:var(--rx); padding:9px; text-align:center; }
.dfi .dfv { font-size:16px; font-weight:700; color:var(--acc); }
.dfi .dfl { font-size:10px; color:var(--t3); text-transform:uppercase; }
.dd { font-size:13px; color:var(--t2); line-height:1.6; margin-bottom:14px; }
.da { display:flex; align-items:center; gap:10px; padding:12px; background:var(--bg3); border-radius:var(--rs); border:1px solid var(--brd); }
.oib { background:rgba(201,164,78,0.05); border:1px solid var(--brd); border-radius:var(--rs); padding:12px; margin-top:10px; }
.oib h4 { font-size:12px; font-weight:600; color:var(--acc); margin-bottom:6px; }
.oib .oir { font-size:12px; color:var(--t2); margin-bottom:3px; }

/* Body states */
body.no-nav .top-nav, body.no-nav .bottom-nav { display:none; }
body.no-nav .page { padding-top:0; padding-bottom:0; }
body.public-view .bottom-nav { display:none; }
body.public-view .page { padding-bottom:12px; }
.lbn { padding:7px 14px; background:var(--acc); color:var(--bg); border:none; border-radius:20px; font-size:12px; font-weight:600; cursor:pointer; font-family:var(--fb); }
