/* ═══════════════════════════════════════
   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: 72px;
  --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; overscroll-behavior:contain; -webkit-overflow-scrolling:touch; 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:72px;
  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:56px; 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:200px; 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:120px; width:auto; margin-bottom:12px; }
.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); }
.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:800px; padding:14px; overflow:visible; }
.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:500; max-height:280px; 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; touch-action:pan-y; -webkit-user-select:none; user-select:none; }
.img-container img { width:100%; height:100%; object-fit:cover; will-change:transform,opacity; transition:opacity 0.15s ease; -webkit-user-drag:none; pointer-events:none; }
.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); }
.price-drop-tag { position:absolute; top:10px; right:10px; background:rgba(74,222,128,.9); backdrop-filter:blur(4px); padding:4px 12px; border-radius:8px; font-weight:700; font-size:11px; color:#06070b; z-index:2; white-space:nowrap; width:auto; display:inline-block; max-width:none; left:auto; }
.ai-field-btn{position:absolute;top:50%;right:8px;transform:translateY(-50%);width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#d4a843,#a07d2e);border:none;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1;transition:transform .2s}
.ai-field-btn:hover{transform:translateY(-50%) scale(1.1)}
.share-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;border-radius:var(--rs);border:1px solid var(--brd);background:var(--bg3);color:var(--t1);font-size:12px;font-weight:700;font-family:var(--fb);cursor:pointer;transition:all .2s;text-decoration:none}
.share-btn:hover{border-color:var(--brds);transform:scale(1.03)}
.share-wa{background:rgba(37,211,102,0.08);border-color:rgba(37,211,102,0.2);color:#25D366}
.share-wab{background:rgba(37,211,102,0.08);border-color:rgba(37,211,102,0.2);color:#128C7E}
.share-tg{background:rgba(0,136,204,0.08);border-color:rgba(0,136,204,0.2);color:#0088cc}
.share-sms{background:rgba(96,165,250,0.08);border-color:rgba(96,165,250,0.2);color:#60a5fa}
.share-copy{background:rgba(201,164,78,0.08);border-color:rgba(201,164,78,0.2);color:var(--acc)}
.share-email{background:rgba(239,68,68,0.08);border-color:rgba(239,68,68,0.2);color:#ef4444}
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.7} }
.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:8px; cursor:pointer; padding:6px 8px; margin:-6px -8px; border-radius:8px; transition:background .15s; }
.agent-info:active { background:rgba(212,168,67,.1); }

/* ═══ PLUS ADD BUTTON ═══ */
.plus-row{display:flex;gap:6px;align-items:center}
.plus-row select,.plus-row input{flex:1}
.plus-btn{width:36px;height:36px;min-width:36px;border-radius:10px;background:linear-gradient(135deg,#d4a843,#f0c95c);border:none;color:#06070b;font-size:20px;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;box-shadow:0 2px 8px rgba(212,168,67,.3)}
.plus-btn:active{transform:scale(.85);box-shadow:0 1px 4px rgba(212,168,67,.2)}
.custom-add-row{display:none;gap:6px;margin-top:8px;align-items:center;padding:10px 12px;background:rgba(212,168,67,.06);border:1px solid rgba(212,168,67,.15);border-radius:10px}
.custom-add-row.show{display:flex}
.custom-add-row input{flex:1;padding:10px 14px;background:var(--bg);border:1px solid rgba(212,168,67,.3);border-radius:8px;color:var(--t1);font-family:var(--fb);font-size:14px}
.custom-add-row input:focus{outline:none;border-color:#d4a843;box-shadow:0 0 0 2px rgba(212,168,67,.15)}
.custom-add-row input::placeholder{color:var(--t3)}
.custom-add-row button{padding:10px 16px;border:none;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;font-family:var(--fb);transition:all .15s}
.custom-add-row .ca-ok{background:linear-gradient(135deg,#4ade80,#22c55e);color:#06070b}
.custom-add-row .ca-ok:active{transform:scale(.9)}
.custom-add-row .ca-no{background:rgba(255,255,255,.06);color:var(--t2);border:1px solid rgba(255,255,255,.1)}
.custom-add-row .ca-no:active{transform:scale(.9)}
/* MSD add row */
.msd-add{display:flex;gap:6px;padding:8px;border-top:1px solid var(--brd);margin-top:4px}
.msd-add input{flex:1;padding:8px 10px;background:var(--bg);border:1px solid var(--brd);border-radius:var(--rx);color:var(--t1);font-family:var(--fb);font-size:12px}
.msd-add input:focus{border-color:var(--acc);outline:none}
.msd-add button{padding:6px 12px;background:linear-gradient(135deg,#d4a843,#f0c95c);color:#06070b;border:none;border-radius:var(--rx);font-size:12px;font-weight:700;cursor:pointer;font-family:var(--fb)}
.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; touch-action:pan-y; -webkit-user-select:none; user-select:none; }

.detail-gallery img { width:100%; height:100%; object-fit:cover; will-change:transform; -webkit-user-drag:none; pointer-events:none; }
.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); }

/* ═══ AGENT CONTACT CARD ═══ */
.agent-card{background:var(--bg3);border:1px solid var(--brds);border-radius:var(--r);padding:16px;margin:16px 0}
.agent-card-top{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.agent-card-info h4{font-size:16px;font-weight:700}
.agent-card-info p{font-size:13px;color:var(--t2)}
.agent-contact-btns{display:flex;gap:8px}
.acb{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 12px;border-radius:var(--rs);font-family:var(--fb);font-size:14px;font-weight:700;text-decoration:none;transition:all .2s;cursor:pointer}
.acb:active{transform:scale(.96)}
.acb-call{background:linear-gradient(135deg,#4ade80,#22c55e);color:#06070b}
.acb-wa{background:linear-gradient(135deg,#25D366,#128C7E);color:#fff}

/* ═══ SIMILAR PORTFOLIOS ═══ */
.similar-section{margin-top:20px;padding-top:16px;border-top:1px solid var(--brd)}
.similar-section h3{font-size:15px;font-weight:700;margin-bottom:12px;color:var(--t2)}
.similar-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.similar-card{border-radius:var(--rs);overflow:hidden;border:1px solid var(--brd);background:var(--bg);cursor:pointer;transition:all .2s}
.similar-card:active{border-color:var(--acc);transform:scale(.97)}
.similar-card img{width:100%;height:100px;object-fit:cover;display:block}
.similar-info{padding:8px 10px}
.similar-price{font-size:14px;font-weight:800;color:var(--acc)}
.similar-title{font-size:11px;font-weight:600;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.similar-loc{font-size:10px;color:var(--t3);margin-top:2px}

/* ═══ MODAL CLOSE ═══ */
.modal-close{position:absolute;top:12px;right:14px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);color:var(--t1);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;transition:all .15s}
.modal-close:active{background:rgba(255,255,255,.15);transform:scale(.9)}
.modal{position:relative}

/* ═══ MEMBERSHIP BADGE ═══ */
.member-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:10px;font-size:9px;font-weight:700;background:rgba(212,168,67,.12);color:var(--acc);border:1px solid rgba(212,168,67,.2)}

/* ═══ AGENT PHOTO ═══ */
.agent-photo{width:100%;height:100%;object-fit:cover;border-radius:50%}

/* ═══ CUSTOM REMOVE PANEL ═══ */
.custom-remove-panel{display:none;margin-top:8px;padding:10px 12px;background:rgba(248,113,113,.06);border:1px solid rgba(248,113,113,.15);border-radius:10px;max-height:200px;overflow-y:auto}
.custom-remove-panel.show{display:block}

/* ═══ AI ADD PAGE ═══ */
#aiAddForm textarea,#aiTextInput{background:var(--bg2);border:1px solid var(--brds);border-radius:var(--rs);color:var(--t1);font-family:var(--fb);font-size:14px;padding:14px;width:100%;box-sizing:border-box;resize:vertical}
#aiProcessBtn{position:relative;overflow:hidden;transition:all .3s}
#aiProcessBtn:disabled{opacity:.7;cursor:wait}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
#aiProcessBtn::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);background-size:200% 100%;animation:shimmer 2s infinite}
.voice-pulse{display:inline-block;animation:vpulse 1s ease-in-out infinite}
@keyframes vpulse{0%,100%{opacity:1}50%{opacity:.3}}
#voiceBtn.recording{background:rgba(239,68,68,0.2)!important;border-color:rgba(239,68,68,0.5)!important;animation:vpulse 1s ease-in-out infinite}

/* AI Step Indicator */
.ai-step-indicator{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:18px}
.ai-step{width:28px;height:28px;border-radius:50%;background:var(--bg4);border:2px solid var(--brd);color:var(--t3);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .3s}
.ai-step.active{background:var(--acc);color:#06070b;border-color:var(--acc)}
.ai-step.done{background:rgba(74,222,128,0.15);color:#4ade80;border-color:rgba(74,222,128,0.3)}
.ai-step-line{width:24px;height:2px;background:var(--brd);transition:background .3s}
.ai-step-line.done{background:rgba(74,222,128,0.3)}

/* AI Reveal Cards */
.ai-reveal-card{background:var(--bg3);border:1px solid var(--brd);border-radius:var(--rs);padding:14px;margin-bottom:10px;animation:cardSlideIn .4s ease;opacity:0;animation-fill-mode:forwards}
@keyframes cardSlideIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.ai-reveal-card h4{font-size:12px;color:var(--acc);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.ai-reveal-card .rv-val{font-size:15px;font-weight:700;color:var(--t1)}
.ai-reveal-card .rv-row{display:flex;gap:12px;flex-wrap:wrap}
.ai-reveal-card .rv-item{flex:1;min-width:80px}
.ai-reveal-card .rv-item .rv-lbl{font-size:10px;color:var(--t3);text-transform:uppercase}
.ai-reveal-card .rv-item .rv-v{font-size:14px;font-weight:600;color:var(--t1)}
.ai-reveal-card .rv-desc{font-size:13px;color:var(--t2);line-height:1.6}
.ai-reveal-card .rv-missing{font-size:12px;color:#fbbf24;margin-top:6px}

/* Agent Bubble */
.agent-bubble{display:flex;gap:12px;background:linear-gradient(135deg,rgba(212,168,67,0.08),rgba(74,222,128,0.04));border:1px solid rgba(212,168,67,0.2);border-radius:var(--r);padding:16px;animation:bubbleIn .5s ease}
@keyframes bubbleIn{from{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}
.agent-bubble-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#d4a843,#a07d2e);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
.agent-bubble-name{font-size:14px;font-weight:800;color:var(--acc);margin-bottom:4px}
.agent-bubble-msg{font-size:12px;color:var(--t2);line-height:1.5}
.agent-bubble-msg strong{color:var(--t1)}

/* AI Final Summary */
.ai-summary-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--brd);font-size:13px}
.ai-summary-row:last-child{border-bottom:none}
.ai-summary-label{color:var(--t3)}
.ai-summary-val{color:var(--t1);font-weight:600;text-align:right}

/* Success Overlay */
@keyframes successPop{from{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}
.success-check{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#4ade80,#22c55e);margin:20px auto 0;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:800;color:#06070b;animation:checkBounce .6s ease .3s both}
@keyframes checkBounce{0%{transform:scale(0)}50%{transform:scale(1.2)}100%{transform:scale(1)}}

/* Agent Badge */
.agent-badge{position:absolute;top:-6px;right:-8px;min-width:16px;height:16px;background:#ef4444;color:#fff;font-size:10px;font-weight:800;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--bg);animation:badgePop .3s ease}
@keyframes badgePop{from{transform:scale(0)}to{transform:scale(1)}}

/* Social Media Page */
.social-card{background:var(--bg3);border:1px solid var(--brd);border-radius:var(--rs);padding:12px;margin-bottom:10px;cursor:pointer;display:flex;gap:10px;align-items:center;transition:border-color .2s;position:relative;overflow:hidden}
.social-card:hover{border-color:var(--brds)}
.social-card .sc-thumb{width:56px;height:56px;border-radius:var(--rx);overflow:hidden;flex-shrink:0}
.social-card .sc-thumb img{width:100%;height:100%;object-fit:cover}
.social-card .sc-info h4{font-size:13px;font-weight:700;color:var(--t1);margin-bottom:2px}
.social-card .sc-info p{font-size:11px;color:var(--t2)}
.social-post-preview{background:var(--bg3);border:1px solid var(--brds);border-radius:var(--r);overflow:hidden;margin-bottom:12px}
.social-post-preview img{width:100%;aspect-ratio:4/5;object-fit:cover}
.social-carousel{position:relative;background:var(--bg3);border:1px solid var(--brds);border-radius:var(--r);overflow:hidden;margin-bottom:12px;max-width:100%;touch-action:pan-y;-webkit-user-select:none;user-select:none}
.social-carousel img{width:100%;height:auto;display:block;background:var(--bg);pointer-events:none;-webkit-user-drag:none}
.car-nav{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:50%;background:rgba(6,7,12,0.6);border:1px solid rgba(201,164,78,0.3);color:var(--t1);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2;transition:background .2s}
.car-nav:hover{background:rgba(6,7,12,0.85)}
.car-prev{left:8px}
.car-next{right:8px}
.car-dots{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);display:flex;gap:6px;z-index:2}
.car-dot{width:8px;height:8px;border-radius:50%;background:rgba(240,236,228,0.35);cursor:pointer;transition:all .2s}
.car-dot.active{background:var(--acc);width:20px;border-radius:4px}
.car-counter{position:absolute;top:10px;right:10px;background:rgba(6,7,12,0.6);color:var(--t1);font-size:11px;font-weight:700;padding:4px 10px;border-radius:12px;z-index:2}

.social-post-text{background:var(--bg3);border:1px solid var(--brd);border-radius:var(--rs);padding:14px;margin-bottom:8px;position:relative}
.social-post-text pre{font-size:12px;color:var(--t1);white-space:pre-wrap;font-family:var(--fb);line-height:1.6;margin:0}
.social-copy-btn{position:absolute;top:8px;right:8px;background:var(--acc);color:#06070b;border:none;padding:4px 10px;border-radius:var(--rx);font-size:11px;font-weight:700;cursor:pointer;font-family:var(--fb)}
.ready-post-card{background:var(--bg3);border:1px solid var(--brd);border-radius:var(--rs);padding:12px;margin-bottom:10px}
.ready-post-card img{width:100%;border-radius:var(--rx);margin-bottom:8px}
.new-appt-card{background:linear-gradient(135deg,rgba(96,165,250,0.08),rgba(74,222,128,0.04));border:1px solid rgba(96,165,250,0.2);border-radius:var(--rs);padding:12px;margin-bottom:10px;animation:newApptGlow 2s ease infinite}
@keyframes newApptGlow{0%,100%{box-shadow:0 0 0 0 rgba(96,165,250,0)}50%{box-shadow:0 0 12px 0 rgba(96,165,250,0.15)}}

/* Instagram Story Circles */
.story-circles{display:flex;gap:16px;overflow-x:auto;padding:8px 4px 12px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.story-circles::-webkit-scrollbar{display:none}
.story-item{display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;flex-shrink:0;width:76px}
.story-ring{width:72px;height:72px;border-radius:50%;padding:3px;background:conic-gradient(#d4a843,#f87171,#a78bfa,#22d3ee,#4ade80,#d4a843);position:relative}
.story-ring-new{animation:ringPulse 2s ease-in-out infinite}
@keyframes ringPulse{0%,100%{box-shadow:0 0 0 0 rgba(74,222,128,0.4)}50%{box-shadow:0 0 0 8px rgba(74,222,128,0)}}
.story-ring::after{content:'';position:absolute;inset:3px;border-radius:50%;border:2px solid var(--bg)}
.story-ring img{width:100%;height:100%;border-radius:50%;object-fit:cover;position:relative;z-index:1}
.story-label{font-size:10px;color:var(--t2);text-align:center;max-width:76px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.story-item:hover .story-ring{transform:scale(1.08);transition:transform .2s}
.social-notify{padding:12px 16px;border-radius:var(--rs);margin-bottom:14px;font-size:13px;font-weight:600;align-items:center;gap:8px;line-height:1.4}
.social-notify-info{background:rgba(96,165,250,0.1);border:1px solid rgba(96,165,250,0.25);color:#60a5fa}
.social-notify-success{background:rgba(74,222,128,0.1);border:1px solid rgba(74,222,128,0.25);color:#4ade80}
.social-notify-error{background:rgba(248,113,113,0.1);border:1px solid rgba(248,113,113,0.25);color:#f87171}
.sc-generating{pointer-events:none;opacity:.7;position:relative;border-color:rgba(96,165,250,0.3)!important}
.sc-gen-badge{position:absolute;top:0;right:0;bottom:0;left:0;background:rgba(6,7,12,0.6);display:flex;align-items:center;justify-content:center;gap:8px;border-radius:var(--rs);font-size:12px;font-weight:700;color:#60a5fa}
.sc-spinner{width:16px;height:16px;border:2px solid rgba(96,165,250,0.3);border-top-color:#60a5fa;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}
#designPickerModal{position:fixed;inset:0;z-index:10001;display:flex;align-items:flex-end;justify-content:center}
.dpm-backdrop{position:absolute;inset:0;background:rgba(6,7,12,0.8)}
.dpm-sheet{position:relative;width:100%;max-width:420px;max-height:85vh;background:var(--bg2);border-radius:20px 20px 0 0;padding:16px 16px 24px;overflow-y:auto;z-index:1}
.dpm-carousel{position:relative;overflow:hidden}
.dpm-slide{display:none;flex-direction:column;gap:10px}
.dpm-slide.active{display:flex}
.dpm-preview{width:100%;aspect-ratio:4/5;background:var(--bg);border-radius:var(--rs);overflow:hidden;display:flex;align-items:center;justify-content:center;border:1px solid var(--brd)}
.dpm-preview-story{aspect-ratio:9/16;max-height:55vh}
.dpm-preview svg{width:100%;height:100%}
.dpm-info{text-align:center;padding:4px 0}
.dpm-title{font-size:15px;font-weight:700;color:var(--t1);display:block}
.dpm-desc{font-size:12px;color:var(--t2);display:block;margin-top:2px}
.dpm-dots{display:flex;justify-content:center;gap:8px;margin-top:10px}
.dpm-dot{width:10px;height:10px;border-radius:50%;background:var(--bg4);cursor:pointer;transition:all .2s}
.dpm-dot.active{background:var(--acc);width:24px;border-radius:5px}
.dpm-select{margin-top:4px}
@keyframes storyGlow{0%,100%{box-shadow:0 0 8px rgba(212,168,67,0.3)}50%{box-shadow:0 0 16px rgba(212,168,67,0.5)}}
.appt-card .appt-actions{flex-wrap:wrap}

/* ═══ SNAKE GAME OVERLAY ═══ */
#snakeOverlay{position:fixed;inset:0;background:rgba(6,7,12,.95);z-index:10000;align-items:center;justify-content:center;flex-direction:column}
.snake-container{width:100%;max-width:340px;padding:16px;box-sizing:border-box}
.snake-header{margin-bottom:14px}
.snake-upload-info{background:var(--bg3);border:1px solid var(--brds);border-radius:var(--rs);padding:14px}
.snake-status{font-size:14px;font-weight:700;color:var(--t1);margin-bottom:8px;text-align:center}
.snake-progress-bar{width:100%;height:6px;background:var(--bg4);border-radius:3px;overflow:hidden;margin-bottom:6px}
.snake-progress-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--acc),#4ade80);border-radius:3px;transition:width .4s ease}
.snake-stats{display:flex;justify-content:space-between;font-size:12px;color:var(--t2)}
.snake-game-area{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--r);padding:14px;text-align:center;position:relative}
.snake-score-row{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--t2);margin-bottom:8px;padding:0 2px}
.snake-score-row strong{color:var(--acc);font-size:14px}
#snakeCanvas{display:block;margin:0 auto;border-radius:var(--rx);background:#0a0b10;border:1px solid var(--brd);touch-action:none;max-width:100%}
.snake-controls{margin-top:10px;user-select:none;-webkit-user-select:none}
.sc-row{display:flex;justify-content:center;gap:6px;margin-bottom:4px}
.sc-btn{width:48px;height:42px;background:var(--bg3);border:1px solid var(--brds);border-radius:var(--rx);color:var(--acc);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s;-webkit-tap-highlight-color:transparent}
.sc-btn:active{background:var(--accg);transform:scale(.93)}
.snake-hint{font-size:10px;color:var(--t3);margin-top:8px}
.snake-gameover{position:absolute;inset:0;background:rgba(6,7,12,0.92);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:5;border-radius:var(--rs);padding:16px;animation:fadeIn .3s}
.sgo-header{font-size:22px;font-weight:800;color:#f87171;text-transform:uppercase;letter-spacing:2px;margin-bottom:6px}
.sgo-score{font-size:32px;font-weight:800;color:var(--acc);margin-bottom:2px}
.sgo-best{font-size:13px;color:var(--t2);margin-bottom:12px}
.snake-lb{background:var(--bg3);border:1px solid var(--brd);border-radius:var(--rs);padding:10px;width:100%;max-height:180px;overflow-y:auto}
.snake-lb-title{font-size:13px;font-weight:700;color:var(--acc);text-align:center;margin-bottom:4px}
.snake-lb-prize{font-size:11px;color:#4ade80;font-weight:700;text-align:center;margin-bottom:8px;padding:4px 0;background:rgba(74,222,128,0.08);border-radius:var(--rx)}
.snake-lb-row{display:flex;align-items:center;gap:8px;padding:4px 0;border-bottom:1px solid var(--brd);font-size:11px}
.snake-lb-row:last-child{border:none}
.snake-lb-rank{width:20px;font-weight:700;color:var(--acc);text-align:center;flex-shrink:0}
.snake-lb-name{flex:1;color:var(--t1);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.snake-lb-store{font-size:10px;color:var(--t3);max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.snake-lb-score{font-weight:700;color:var(--t1);flex-shrink:0}
.snake-lb-row.me{background:var(--accg);border-radius:var(--rx);padding:4px 6px}
@media(min-width:400px){#snakeCanvas{width:280px;height:280px}}
@media(max-width:399px){#snakeCanvas{width:240px;height:240px}.sc-btn{width:44px;height:38px;font-size:16px}}
/* Verified Badge — Instagram style */
.verified-badge{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-size:10px;font-weight:700;flex-shrink:0;line-height:1}
.verified-badge-sm{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-size:8px;font-weight:700;flex-shrink:0;line-height:1;vertical-align:middle;margin-left:3px}

/* Fullscreen Photo Gallery */
.photo-gallery-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:99999;background:rgba(0,0,0,.95);display:none;flex-direction:column;align-items:center;justify-content:center}
.photo-gallery-overlay.active{display:flex}
.photo-gallery-overlay .pg-close{position:absolute;top:12px;right:16px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.15);border:none;color:#fff;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10}
.photo-gallery-overlay .pg-counter{position:absolute;top:16px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.7);font-size:14px;font-weight:600;z-index:10}
.photo-gallery-overlay .pg-img-wrap{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden;touch-action:none}
.photo-gallery-overlay .pg-img-wrap img{max-width:100%;max-height:85vh;object-fit:contain;will-change:transform;-webkit-user-drag:none;pointer-events:none;user-select:none}
.photo-gallery-overlay .pg-nav{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.15);border:none;color:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10}
.photo-gallery-overlay .pg-prev{left:10px}
.photo-gallery-overlay .pg-next{right:10px}
@media(max-width:768px){.photo-gallery-overlay .pg-nav{width:32px;height:32px;font-size:16px}}
/* Prevent double-tap zoom globally */


/* ═══════════════════════════════════════════════════════════════════════
   v8 — Detail Modal Action Buttons (temiz 2x2 grid + download)
   ═══════════════════════════════════════════════════════════════════════ */

.detail-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 14px;
}

.det-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 13px 10px;
  border-radius: 12px;
  border: none;
  cursor: pointer;
  font-family: inherit;
  font-weight: 700;
  font-size: 14px;
  text-decoration: none;
  transition: transform 0.12s ease, box-shadow 0.12s ease, filter 0.12s ease;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
  position: relative;
  overflow: hidden;
}

.det-btn:active { transform: scale(0.97); }
.det-btn:hover { filter: brightness(1.05); }
.det-btn svg { flex-shrink: 0; }
.det-btn span { white-space: nowrap; }

/* Hemen Ara — yeşil gradient (primary CTA) */
.det-btn-call {
  background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
  color: #fff;
  box-shadow: 0 4px 16px rgba(34, 197, 94, 0.25);
}

/* WhatsApp — WA yeşil */
.det-btn-wa {
  background: linear-gradient(135deg, #25d366 0%, #128c7e 100%);
  color: #fff;
  box-shadow: 0 4px 16px rgba(37, 211, 102, 0.25);
}

/* Randevu — altın outline */
.det-btn-apt {
  background: linear-gradient(135deg, rgba(201,164,78,0.15), rgba(201,164,78,0.05));
  color: var(--acc, #c9a44e);
  border: 1.5px solid rgba(201,164,78,0.4);
}

/* Paylaş — koyu outline */
.det-btn-share {
  background: rgba(255,255,255,0.04);
  color: var(--t1, #f4f0e8);
  border: 1.5px solid rgba(255,255,255,0.12);
}

/* Fotoğrafları İndir — full-width, daha büyük */
.det-btn-download {
  display: flex;
  align-items: center;
  gap: 14px;
  width: 100%;
  margin-top: 10px;
  padding: 14px 18px;
  background: linear-gradient(135deg, rgba(15,16,24,0.8), rgba(7,8,12,0.6));
  border: 1.5px dashed rgba(201,164,78,0.35);
  color: var(--acc, #c9a44e);
  border-radius: 14px;
  cursor: pointer;
  font-family: inherit;
  font-weight: 700;
  font-size: 14px;
  text-align: left;
  transition: all 0.15s;
}
.det-btn-download:hover {
  background: linear-gradient(135deg, rgba(201,164,78,0.08), rgba(201,164,78,0.02));
  border-color: rgba(201,164,78,0.6);
  color: #f0d77a;
}
.det-btn-download svg { flex-shrink: 0; }
.det-btn-download > span {
  font-size: 14px;
  font-weight: 700;
  flex: 1;
}
.det-btn-download small {
  display: block;
  font-size: 11px;
  font-weight: 500;
  color: var(--t3, rgba(244,240,232,0.5));
  margin-top: 3px;
  letter-spacing: 0.2px;
}

/* Tablet+ ekranlarda 4'lü satır olarak göster */
@media (min-width: 520px) {
  .detail-actions {
    grid-template-columns: 1fr 1fr 1fr 1fr;
  }
}

/* Eski agent-contact-btns artık yok (agent-card içinden kaldırıldı),
   ama mevcut CSS'e dokunmuyoruz — geri uyumluluk */

/* v8 — Eski detay modal butonları gizle (yeni .detail-actions kullanılıyor) */
.agent-card .agent-contact-btns { display: none !important; }
