/* ═══════════════════════════════════════════════
   CALLVAULT v4.0 — Deep Space Premium UI
   Font: Plus Jakarta Sans + JetBrains Mono
   Theme: Deep indigo / crystalline glass
═══════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:wght@300;400;500;600&display=swap');

:root {
  --bg:          #04040e;
  --bg2:         #07071a;
  --bg3:         #0c0c22;
  --surface:     rgba(255,255,255,0.04);
  --surface2:    rgba(255,255,255,0.07);
  --surface3:    rgba(255,255,255,0.11);
  --border:      rgba(255,255,255,0.07);
  --border2:     rgba(255,255,255,0.12);
  --border3:     rgba(255,255,255,0.2);
  --accent:      #6366f1;
  --accent2:     #818cf8;
  --accent3:     #a5b4fc;
  --accent-dim:  rgba(99,102,241,0.14);
  --accent-glow: rgba(99,102,241,0.3);
  --emerald:     #10b981;
  --emerald-dim: rgba(16,185,129,0.12);
  --rose:        #f43f5e;
  --rose-dim:    rgba(244,63,94,0.12);
  --amber:       #f59e0b;
  --amber-dim:   rgba(245,158,11,0.12);
  --blue:        #3b82f6;
  --blue-dim:    rgba(59,130,246,0.12);
  --violet:      #8b5cf6;
  --violet-dim:  rgba(139,92,246,0.12);
  --sky:         #0ea5e9;
  --text:        #f1f5f9;
  --text2:       #94a3b8;
  --text3:       #475569;
  --text4:       #1e293b;
  --r-xs:        6px;
  --r-sm:        10px;
  --r:           14px;
  --r-lg:        20px;
  --r-xl:        26px;
  --font:        'Plus Jakarta Sans', sans-serif;
  --mono:        'JetBrains Mono', monospace;
  --ease:        cubic-bezier(0.4,0,0.2,1);
  --spring:      cubic-bezier(0.34,1.56,0.64,1);
  --ease-out:    cubic-bezier(0.16,1,0.3,1);
  --t:           0.2s;
}

/* BIZ TYPE COLORS */
:root {
  --biz-shop:       #f59e0b;
  --biz-classes:    #3b82f6;
  --biz-doctor:     #10b981;
  --biz-finance:    #8b5cf6;
  --biz-bakery:     #f97316;
  --biz-restaurant: #ec4899;
  --biz-other:      #6b7280;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth;height:100%}
body{background:var(--bg);color:var(--text);font-family:var(--font);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;line-height:1.5}
body::before{content:'';position:fixed;inset:0;background-image:radial-gradient(ellipse 70% 50% at 15% 0%,rgba(99,102,241,0.08) 0%,transparent 60%),radial-gradient(ellipse 50% 40% at 85% 100%,rgba(139,92,246,0.06) 0%,transparent 60%),linear-gradient(rgba(99,102,241,0.016) 1px,transparent 1px),linear-gradient(90deg,rgba(99,102,241,0.016) 1px,transparent 1px);background-size:100% 100%,100% 100%,48px 48px,48px 48px;pointer-events:none;z-index:0}
::-webkit-scrollbar{width:3px;height:3px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--text4);border-radius:99px}

/* ── KEYFRAMES ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}
@keyframes slideRight{from{transform:translateX(100%)}to{transform:translateX(0)}}
@keyframes slideUp{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.6}}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes loadBar{0%{width:0%}45%{width:55%}80%{width:85%}100%{width:100%}}
@keyframes syncPulse{0%,100%{box-shadow:0 0 0 0 rgba(16,185,129,0.4)}50%{box-shadow:0 0 0 5px rgba(16,185,129,0)}}
@keyframes toastIn{from{opacity:0;transform:translateY(18px) scale(0.93)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes toastOut{from{opacity:1}to{opacity:0;transform:translateY(10px)}}
@keyframes dropIn{from{opacity:0;transform:translateY(-8px) scale(0.97)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes cardIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes orbFloat{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(20px,-16px) scale(1.04)}}

/* ── LOADING ── */
.loading-screen{position:fixed;inset:0;background:var(--bg);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity 0.55s var(--ease),visibility 0.55s}
.loading-screen.fade-out{opacity:0;visibility:hidden;pointer-events:none}
.loading-content{display:flex;flex-direction:column;align-items:center;gap:16px;animation:fadeIn 0.4s var(--ease-out)}
.loading-logo-wrap{filter:drop-shadow(0 0 20px rgba(99,102,241,0.4));animation:pulse 1.8s ease-in-out infinite}
.loading-title{font-size:1.5rem;font-weight:900;letter-spacing:-0.5px;background:linear-gradient(135deg,#fff 0%,var(--accent3) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.loading-sub{font-size:0.72rem;font-family:var(--mono);color:var(--text3);letter-spacing:0.5px}
.loading-bar{width:160px;height:2px;background:var(--surface3);border-radius:99px;overflow:hidden}
.loading-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2),var(--accent3));border-radius:99px;animation:loadBar 2.2s var(--ease-out) forwards;box-shadow:0 0 10px var(--accent-glow)}

/* ── LOGIN ── */
.login-screen{position:fixed;inset:0;z-index:800;display:flex;align-items:center;justify-content:center;padding:20px;overflow:hidden}
.login-bg{position:absolute;inset:0;background:var(--bg)}
.login-orb{position:absolute;border-radius:50%;filter:blur(90px);pointer-events:none}
.orb-a{width:560px;height:560px;top:-200px;left:-180px;background:rgba(99,102,241,0.13);animation:orbFloat 9s ease-in-out infinite}
.orb-b{width:460px;height:460px;bottom:-180px;right:-120px;background:rgba(139,92,246,0.1);animation:orbFloat 12s ease-in-out infinite reverse}
.orb-c{width:320px;height:320px;top:50%;left:50%;transform:translate(-50%,-50%);background:rgba(16,185,129,0.05);animation:orbFloat 15s ease-in-out infinite 3s}
.login-card{position:relative;background:rgba(8,8,20,0.88);border:1px solid var(--border2);border-radius:var(--r-xl);padding:42px 38px;width:100%;max-width:490px;backdrop-filter:blur(32px);box-shadow:0 40px 120px rgba(0,0,0,0.7),0 0 0 1px rgba(255,255,255,0.04),inset 0 1px 0 rgba(255,255,255,0.06);animation:scaleIn 0.45s var(--spring);display:flex;flex-direction:column;gap:16px}
.lc-logo-row{display:flex;align-items:center;gap:10px}
.lc-brand{font-size:1.5rem;font-weight:900;letter-spacing:-0.5px}
.lc-brand b{color:var(--accent2)}
.lc-badge{font-size:0.68rem;font-family:var(--mono);color:var(--accent2);background:var(--accent-dim);border:1px solid rgba(99,102,241,0.22);border-radius:40px;padding:4px 12px;width:fit-content;letter-spacing:0.3px}
.lc-headline{font-size:2rem;font-weight:900;line-height:1.12;letter-spacing:-1px;background:linear-gradient(135deg,#fff 0%,var(--accent3) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.lc-sub{font-size:0.86rem;color:var(--text2);line-height:1.65}
.lc-features{display:flex;flex-direction:column;gap:8px}
.lc-feat{display:flex;align-items:center;gap:9px;font-size:0.82rem;color:var(--text2)}
.lc-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.lc-dot.green{background:var(--emerald);box-shadow:0 0 8px rgba(16,185,129,0.5)}
.lc-dot.blue{background:var(--blue);box-shadow:0 0 8px rgba(59,130,246,0.5)}
.lc-dot.purple{background:var(--violet);box-shadow:0 0 8px rgba(139,92,246,0.5)}
.lc-dot.orange{background:var(--amber);box-shadow:0 0 8px rgba(245,158,11,0.5)}
.lc-divider{display:flex;align-items:center;gap:12px}
.lc-divider::before,.lc-divider::after{content:'';flex:1;height:1px;background:var(--border2)}
.lc-divider span{font-size:0.7rem;color:var(--text3);font-family:var(--mono)}
.login-error{background:var(--rose-dim);border:1px solid rgba(244,63,94,0.28);border-radius:var(--r-sm);padding:10px 14px;font-size:0.82rem;color:var(--rose);text-align:center;animation:fadeUp 0.3s var(--ease-out)}
.btn-google{display:flex;align-items:center;justify-content:center;gap:11px;background:#fff;color:#1a1a2e;border:none;border-radius:var(--r-lg);padding:14px 22px;width:100%;font-family:var(--font);font-size:0.92rem;font-weight:700;cursor:pointer;transition:transform var(--t) var(--spring),box-shadow var(--t);position:relative;overflow:hidden}
.btn-google:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(0,0,0,0.45)}
.btn-google:active{transform:scale(0.97)}
.btn-google:disabled{opacity:0.55;cursor:wait;transform:none}
.btn-guest{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--surface);border:1px solid var(--border2);border-radius:var(--r-lg);padding:13px 22px;color:var(--text2);font-family:var(--font);font-size:0.87rem;font-weight:600;cursor:pointer;width:100%;transition:all var(--t) var(--spring)}
.btn-guest:hover{border-color:var(--border3);color:var(--text);background:var(--surface2);transform:translateY(-1px)}
.badge-local{font-size:0.62rem;font-family:var(--mono);background:rgba(245,158,11,0.12);border:1px solid rgba(245,158,11,0.25);border-radius:40px;padding:2px 9px;color:var(--amber)}
.lc-disclaimer{font-size:0.7rem;color:var(--text3);text-align:center;line-height:1.6}

/* ── APP ROOT ── */
.app-root{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column}

/* ── NAVBAR ── */
.navbar{position:sticky;top:0;z-index:100;display:flex;align-items:center;gap:12px;padding:10px 20px;background:rgba(4,4,14,0.88);backdrop-filter:blur(28px);border-bottom:1px solid var(--border);box-shadow:0 1px 0 rgba(255,255,255,0.03)}
.navbar::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent),var(--accent2),var(--accent),transparent);opacity:0.25}
.nav-left{display:flex;align-items:center;gap:9px;flex-shrink:0}
.nav-brand{display:flex;align-items:center;gap:8px;font-size:1.15rem;font-weight:900;letter-spacing:-0.5px;white-space:nowrap}
.brand-text b{color:var(--accent2)}
.sync-pill{display:flex;align-items:center;gap:5px;background:rgba(16,185,129,0.08);border:1px solid rgba(16,185,129,0.18);border-radius:40px;padding:3px 9px;transition:all 0.4s var(--ease)}
.sync-dot{width:6px;height:6px;border-radius:50%;background:var(--emerald);animation:syncPulse 2s ease-in-out infinite}
.sync-label{font-size:0.6rem;font-family:var(--mono);color:var(--emerald);font-weight:500}
.sync-pill.offline{background:rgba(244,63,94,0.08);border-color:rgba(244,63,94,0.18)}
.sync-pill.offline .sync-dot{background:var(--rose);animation:none}
.sync-pill.offline .sync-label{color:var(--rose)}
.sync-pill.syncing{background:rgba(99,102,241,0.1);border-color:rgba(99,102,241,0.2)}
.sync-pill.syncing .sync-dot{background:var(--accent);animation:spin 1s linear infinite;border-radius:2px}
.sync-pill.syncing .sync-label{color:var(--accent2)}
.sync-pill.guest{background:rgba(245,158,11,0.08);border-color:rgba(245,158,11,0.18)}
.sync-pill.guest .sync-dot{background:var(--amber);animation:none}
.sync-pill.guest .sync-label{color:var(--amber)}

.nav-search-wrap{flex:1;position:relative;max-width:460px;margin:0 auto}
.search-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--text3);pointer-events:none;transition:color var(--t)}
.nav-search-wrap:focus-within .search-icon{color:var(--accent2)}
.search-bar{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:40px;padding:9px 38px 9px 38px;color:var(--text);font-family:var(--font);font-size:0.86rem;outline:none;transition:border-color var(--t),box-shadow var(--t),background var(--t)}
.search-bar::placeholder{color:var(--text3)}
.search-bar:focus{border-color:rgba(99,102,241,0.45);background:var(--surface2);box-shadow:0 0 0 3px var(--accent-dim)}
.search-clear{position:absolute;right:11px;top:50%;transform:translateY(-50%);background:var(--surface2);border:none;border-radius:50%;width:20px;height:20px;color:var(--text3);font-size:0.6rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--t) var(--spring)}
.search-clear:hover{background:var(--rose-dim);color:var(--rose);transform:translateY(-50%) scale(1.15)}

.nav-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.btn-add{display:flex;align-items:center;gap:6px;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border:none;border-radius:40px;padding:8px 16px;font-family:var(--font);font-size:0.82rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:transform var(--t) var(--spring),box-shadow var(--t);box-shadow:0 3px 14px rgba(99,102,241,0.3)}
.btn-add:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(99,102,241,0.4)}
.btn-add:active{transform:scale(0.96)}

.user-wrap{position:relative}
.avatar-btn{background:none;border:2px solid var(--border2);border-radius:50%;width:34px;height:34px;padding:0;cursor:pointer;overflow:hidden;transition:border-color var(--t),transform var(--t) var(--spring)}
.avatar-btn:hover{border-color:var(--accent);transform:scale(1.07)}
.avatar-initials{width:100%;height:100%;background:var(--accent-dim);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.7rem;font-weight:800;color:var(--accent2)}
.avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}

/* DROPDOWN */
.user-dropdown{position:absolute;top:calc(100% + 9px);right:0;width:260px;background:#0b0b20;border:1px solid var(--border2);border-radius:var(--r-lg);box-shadow:0 20px 60px rgba(0,0,0,0.7),0 0 0 1px rgba(255,255,255,0.04);overflow:hidden;animation:dropIn 0.22s var(--spring);z-index:200}
.ud-profile{display:flex;align-items:center;gap:11px;padding:14px 16px}
.ud-avatar-init{width:40px;height:40px;border-radius:50%;background:var(--accent-dim);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:0.85rem;font-weight:800;color:var(--accent2)}
.ud-avatar-img{width:40px;height:40px;border-radius:50%;object-fit:cover;flex-shrink:0}
.ud-info{min-width:0}
.ud-name{font-size:0.86rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ud-email{font-size:0.68rem;color:var(--text3);font-family:var(--mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.ud-divider{height:1px;background:var(--border)}
.ud-stats{display:flex;padding:12px 16px}
.uds{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;font-size:0.68rem;color:var(--text2)}
.uds span{font-size:1.1rem;font-weight:800;color:var(--text);font-family:var(--mono)}
.ud-item{display:flex;align-items:center;gap:9px;width:100%;padding:11px 16px;background:none;border:none;color:var(--text2);font-family:var(--font);font-size:0.82rem;cursor:pointer;text-align:left;transition:background var(--t),color var(--t),padding-left var(--t)}
.ud-item:hover{background:var(--surface2);color:var(--text);padding-left:20px}
.ud-item.danger{color:var(--rose)}
.ud-item.danger:hover{background:var(--rose-dim)}
.ud-item.upgrade{color:var(--amber)}
.ud-item.upgrade:hover{background:var(--amber-dim)}

/* ── GUEST BANNER ── */
.guest-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 20px;background:rgba(245,158,11,0.06);border-bottom:1px solid rgba(245,158,11,0.14);font-size:0.78rem;color:var(--amber);flex-wrap:wrap;animation:slideUp 0.3s var(--ease-out)}
.btn-upgrade-small{background:rgba(245,158,11,0.12);border:1px solid rgba(245,158,11,0.28);border-radius:40px;padding:4px 13px;color:var(--amber);font-family:var(--font);font-size:0.72rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:all var(--t)}
.btn-upgrade-small:hover{background:rgba(245,158,11,0.22);transform:translateY(-1px)}

/* ── STATS ── */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding:16px 20px 0}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:14px 15px;display:flex;align-items:center;gap:12px;position:relative;overflow:hidden;transition:border-color var(--t),transform var(--t) var(--spring),box-shadow var(--t);cursor:default;animation:cardIn 0.35s var(--ease-out) both}
.stat-card:nth-child(1){animation-delay:.05s}
.stat-card:nth-child(2){animation-delay:.1s}
.stat-card:nth-child(3){animation-delay:.15s}
.stat-card:nth-child(4){animation-delay:.2s}
.stat-card:hover{transform:translateY(-2px);border-color:var(--border2);box-shadow:0 10px 36px rgba(0,0,0,0.35)}
.stat-card[data-col="indigo"] .stat-icon{background:rgba(99,102,241,0.12);color:var(--accent2)}
.stat-card[data-col="amber"] .stat-icon{background:var(--amber-dim);color:var(--amber)}
.stat-card[data-col="rose"] .stat-icon{background:var(--rose-dim);color:var(--rose)}
.stat-card[data-col="emerald"] .stat-icon{background:var(--emerald-dim);color:var(--emerald)}
.stat-icon{width:40px;height:40px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform var(--t) var(--spring)}
.stat-card:hover .stat-icon{transform:scale(1.08) rotate(3deg)}
.stat-val{font-size:1.6rem;font-weight:900;line-height:1;letter-spacing:-0.5px;font-family:var(--mono)}
.stat-lbl{font-size:0.66rem;color:var(--text2);margin-top:4px;font-weight:500}

/* ── CONTROLS ── */
.controls-bar{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:14px 20px 10px;flex-wrap:wrap}
.controls-left{display:flex;flex-direction:column;gap:9px;flex:1;min-width:0}
.chip-row{display:flex;align-items:center;gap:5px;overflow-x:auto;scrollbar-width:none;padding-bottom:2px;-webkit-overflow-scrolling:touch}
.chip-row::-webkit-scrollbar{display:none}
.chip{display:flex;align-items:center;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:40px;padding:6px 13px;color:var(--text2);font-family:var(--font);font-size:0.76rem;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all var(--t) var(--spring)}
.chip:hover{border-color:var(--border2);color:var(--text);transform:translateY(-1px)}
.chip.active{background:var(--accent-dim);border-color:rgba(99,102,241,0.35);color:var(--accent2);box-shadow:0 3px 14px rgba(99,102,241,0.15)}
.chip-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.chip-dot.emerald{background:var(--emerald);box-shadow:0 0 6px rgba(16,185,129,0.5)}
.chip-dot.blue{background:var(--blue);box-shadow:0 0 6px rgba(59,130,246,0.5)}
.chip-dot.violet{background:var(--violet);box-shadow:0 0 6px rgba(139,92,246,0.5)}
.chip-dot.rose{background:var(--rose);box-shadow:0 0 6px rgba(244,63,94,0.5)}
.chip-dot.gray{background:var(--text3)}

.filter-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.fsel,.ftag,.fdate{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--r-sm);padding:7px 10px;color:var(--text);font-family:var(--font);font-size:0.78rem;outline:none;cursor:pointer;transition:border-color var(--t),box-shadow var(--t)}
.fsel:focus,.ftag:focus,.fdate:focus{border-color:rgba(99,102,241,0.45);box-shadow:0 0 0 2px var(--accent-dim)}
/* FIX: Make dropdown options visible */
.fsel{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:26px}
.fsel option{background:#0f0f28;color:#f1f5f9;padding:8px}
.fsel option:hover{background:#1e1e48}
.ftag{cursor:text}
.ftag::placeholder{color:var(--text3)}
.fdate{color:var(--text);cursor:pointer}
.fdate::-webkit-calendar-picker-indicator{filter:invert(0.6)}

.date-filter-wrap{display:flex;align-items:center;gap:6px;background:var(--bg2);border:1px solid var(--border2);border-radius:var(--r-sm);padding:5px 10px;transition:border-color var(--t)}
.date-filter-wrap:focus-within{border-color:rgba(99,102,241,0.45);box-shadow:0 0 0 2px var(--accent-dim)}
.date-filter-wrap svg{color:var(--text3);flex-shrink:0}
.date-filter-wrap .fdate{background:none;border:none;padding:2px 4px;font-size:0.76rem;box-shadow:none}
.date-filter-wrap .fdate:focus{border:none;box-shadow:none}
.date-sep{color:var(--text3);font-size:0.72rem}
.clear-date-btn{background:none;border:none;color:var(--text3);cursor:pointer;font-size:0.65rem;padding:2px 4px;border-radius:4px;transition:color var(--t)}
.clear-date-btn:hover{color:var(--rose)}

.prob-wrap{display:flex;align-items:center;gap:7px}
.prob-lbl{font-size:0.72rem;font-family:var(--mono);color:var(--text2);white-space:nowrap}
.prob-range{-webkit-appearance:none;appearance:none;height:4px;border-radius:99px;background:var(--border2);outline:none;cursor:pointer;width:75px}
.prob-range::-webkit-slider-thumb{-webkit-appearance:none;width:15px;height:15px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));cursor:pointer;box-shadow:0 0 8px var(--accent-glow);transition:transform var(--t) var(--spring)}
.prob-range::-webkit-slider-thumb:hover{transform:scale(1.25)}
.prob-range.full{width:100%}

.controls-right{display:flex;align-items:center;gap:7px;flex-shrink:0}
.view-toggle{display:flex;gap:2px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:3px}
.vbtn{background:none;border:none;color:var(--text3);border-radius:6px;padding:5px 8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--t),color var(--t)}
.vbtn.active{background:var(--accent);color:#fff;box-shadow:0 2px 8px var(--accent-glow)}
.vbtn:not(.active):hover{background:var(--surface2);color:var(--text2)}

.results-bar{display:flex;align-items:center;justify-content:space-between;padding:0 20px 8px;font-size:0.72rem;color:var(--text3);font-family:var(--mono)}
.clear-btn{background:none;border:1px solid var(--border);border-radius:40px;padding:3px 11px;color:var(--text2);font-family:var(--font);font-size:0.7rem;cursor:pointer;transition:all var(--t)}
.clear-btn:hover{border-color:var(--rose);color:var(--rose);background:var(--rose-dim)}

/* ── MAIN ── */
.main-area{padding:0 20px 24px;flex:1}

/* ── EMPTY STATE ── */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:70px 20px;text-align:center;gap:10px;animation:fadeUp 0.35s var(--ease-out)}
.empty-icon{animation:pulse 3s ease-in-out infinite;filter:drop-shadow(0 0 18px var(--accent-glow))}
.empty-state h3{font-size:1.15rem;font-weight:800}
.empty-state p{font-size:0.85rem;color:var(--text2)}
.empty-state strong{color:var(--accent2)}

/* ── ENTRY CONTAINERS ── */
.entry-container.list-view{display:flex;flex-direction:column;gap:5px}
.entry-container.list-view .entry-card{display:grid;grid-template-columns:220px 1fr auto auto;align-items:center;gap:14px;padding:11px 14px;border-radius:var(--r-sm)}
.entry-container.list-view .entry-prob,.entry-container.list-view .entry-remarks,.entry-container.list-view .entry-meta-row{display:none}
.entry-container.list-view .entry-tags{margin-top:0}

.entry-container.card-view{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:11px}
.entry-container.card-view .entry-card{display:flex;flex-direction:column;gap:10px;padding:15px;border-radius:var(--r)}

/* ── ENTRY CARD ── */
.entry-card{background:var(--surface);border:1px solid var(--border);position:relative;overflow:hidden;cursor:pointer;transition:border-color var(--t),transform var(--t) var(--spring),box-shadow var(--t),background var(--t);animation:cardIn 0.25s var(--ease-out) both}
.entry-card:hover{border-color:rgba(99,102,241,0.22);box-shadow:0 8px 36px rgba(0,0,0,0.35);transform:translateY(-2px);background:var(--surface2)}
.entry-card:active{transform:translateY(0) scale(0.99)}

/* Biz type color stripe */
.entry-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--biz-color,transparent);display:block;border-radius:0}
.entry-card.biz-shop{--biz-color:var(--biz-shop)}
.entry-card.biz-classes{--biz-color:var(--biz-classes)}
.entry-card.biz-doctor{--biz-color:var(--biz-doctor)}
.entry-card.biz-finance{--biz-color:var(--biz-finance)}
.entry-card.biz-bakery{--biz-color:var(--biz-bakery)}
.entry-card.biz-restaurant{--biz-color:var(--biz-restaurant)}
.entry-card.biz-other{--biz-color:var(--biz-other)}

/* Priority urgency glow */
.entry-card.pri-high{box-shadow:inset 3px 0 0 var(--rose),0 0 0 1px rgba(244,63,94,0.1)}
.entry-card.pri-medium{box-shadow:inset 3px 0 0 var(--amber),0 0 0 1px rgba(245,158,11,0.08)}

/* Swipe */
.entry-card.swipe-right{border-color:var(--emerald);box-shadow:0 0 20px rgba(16,185,129,0.15)}
.entry-card.swipe-left{border-color:var(--rose);box-shadow:0 0 20px rgba(244,63,94,0.15)}

.entry-name-block{min-width:0;padding-left:9px}
.entry-name{font-size:0.92rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.entry-phone{font-family:var(--mono);font-size:0.72rem;color:var(--text2);margin-top:2px}

/* Status badges */
.status-badge{display:inline-flex;align-items:center;gap:5px;font-size:0.65rem;font-weight:700;padding:3px 9px;border-radius:40px;white-space:nowrap;letter-spacing:0.3px}
.status-badge::before{content:'●';font-size:0.4rem}
.sb-call-again{background:var(--blue-dim);color:var(--blue);border:1px solid rgba(59,130,246,0.22)}
.sb-declined{background:var(--rose-dim);color:var(--rose);border:1px solid rgba(244,63,94,0.22)}
.sb-interested{background:var(--emerald-dim);color:var(--emerald);border:1px solid rgba(16,185,129,0.22)}
.sb-no-response{background:rgba(71,85,105,0.12);color:var(--text3);border:1px solid rgba(71,85,105,0.22)}
.sb-converted{background:var(--violet-dim);color:var(--violet);border:1px solid rgba(139,92,246,0.22)}

/* Priority badge */
.pri-badge{font-size:0.58rem;font-family:var(--mono);font-weight:600;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:0.5px}
.pb-high{background:var(--rose-dim);color:var(--rose)}
.pb-medium{background:var(--amber-dim);color:var(--amber)}
.pb-low{background:rgba(71,85,105,0.12);color:var(--text3)}

/* Biz type badge */
.biz-badge{font-size:0.6rem;font-family:var(--mono);font-weight:600;padding:2px 7px;border-radius:4px;text-transform:uppercase;letter-spacing:0.4px}

.entry-prob{width:100%;padding-left:9px}
.prob-bar-wrap{display:flex;align-items:center;gap:7px}
.prob-track{flex:1;height:3px;background:var(--border);border-radius:99px;overflow:hidden}
.prob-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width 0.6s var(--ease-out)}
.prob-pct{font-family:var(--mono);font-size:0.64rem;color:var(--text2);white-space:nowrap}

.entry-tags{display:flex;flex-wrap:wrap;gap:4px;padding-left:9px}
.tag-pill{font-size:0.58rem;font-family:var(--mono);background:var(--accent-dim);color:var(--accent2);border:1px solid rgba(99,102,241,0.18);border-radius:4px;padding:2px 6px}
.tag-pill.hi{background:rgba(99,102,241,0.28);color:#fff;border-color:rgba(99,102,241,0.5)}

.entry-remarks{font-size:0.75rem;color:var(--text2);line-height:1.5;padding-left:9px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.entry-meta-row{display:flex;align-items:center;justify-content:space-between;gap:7px;flex-wrap:wrap;padding-left:9px}
.meta-date{font-family:var(--mono);font-size:0.6rem;color:var(--text3)}
.meta-fup{font-family:var(--mono);font-size:0.6rem;color:var(--amber)}
.meta-fup.overdue{color:var(--rose);font-weight:600}
.badge-row{display:flex;align-items:center;gap:5px;flex-wrap:wrap;padding-left:9px}

.entry-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}
.act-btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xs);padding:5px 8px;color:var(--text2);cursor:pointer;font-size:0.7rem;font-family:var(--font);font-weight:600;transition:all var(--t) var(--spring);white-space:nowrap;display:flex;align-items:center;gap:3px}
.act-btn:hover{border-color:var(--border2);color:var(--text);transform:translateY(-1px)}
.act-btn:active{transform:scale(0.92)}
.act-call{color:var(--emerald);border-color:rgba(16,185,129,0.22)}
.act-call:hover{background:var(--emerald-dim)}
.act-copy{color:var(--blue);border-color:rgba(59,130,246,0.22)}
.act-copy:hover{background:var(--blue-dim)}
.act-edit:hover{background:var(--accent-dim);border-color:var(--accent);color:var(--accent2)}
.act-del{color:var(--rose);border-color:rgba(244,63,94,0.22)}
.act-del:hover{background:var(--rose-dim)}

.inline-status{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--r-xs);padding:4px 6px;color:var(--text);font-family:var(--font);font-size:0.68rem;outline:none;cursor:pointer;transition:border-color var(--t);-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5' viewBox='0 0 8 5'%3E%3Cpath d='M1 1l3 3 3-3' stroke='%2394a3b8' stroke-width='1.2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 5px center;padding-right:18px}
.inline-status:focus{border-color:var(--accent)}
.inline-status option{background:#0f0f28;color:#f1f5f9}

mark{background:rgba(99,102,241,0.32);color:#fff;border-radius:3px;padding:0 2px}

/* ── MODAL ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.72);backdrop-filter:blur(10px);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn 0.2s var(--ease)}
.modal{background:rgba(8,8,22,0.96);border:1px solid rgba(99,102,241,0.18);border-radius:var(--r-xl);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;padding:26px;animation:scaleIn 0.3s var(--spring);box-shadow:0 40px 100px rgba(0,0,0,0.8),0 0 50px rgba(99,102,241,0.1);backdrop-filter:blur(24px)}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.modal-title-row{display:flex;align-items:center;gap:9px}
.modal-icon{width:30px;height:30px;background:var(--accent-dim);border:1px solid rgba(99,102,241,0.25);border-radius:var(--r-xs);display:flex;align-items:center;justify-content:center;color:var(--accent2)}
.modal-title{font-size:1.1rem;font-weight:800}
.modal-close{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xs);padding:6px 9px;color:var(--text2);cursor:pointer;display:flex;align-items:center;transition:all var(--t) var(--spring)}
.modal-close:hover{color:var(--rose);border-color:var(--rose);background:var(--rose-dim);transform:rotate(90deg)}
.modal-form{display:flex;flex-direction:column;gap:14px}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fg{display:flex;flex-direction:column;gap:6px}
.fg label{font-size:0.72rem;color:var(--text2);font-weight:700;letter-spacing:0.3px;display:flex;align-items:center;gap:6px}
.req{color:var(--rose)}
.form-hint{font-weight:400;color:var(--text3);font-size:0.67rem}
.finput{background:rgba(255,255,255,0.03);border:1px solid var(--border);border-radius:var(--r-sm);padding:9px 12px;color:var(--text);font-family:var(--font);font-size:0.86rem;outline:none;transition:border-color var(--t),box-shadow var(--t)}
.finput:focus{border-color:rgba(99,102,241,0.45);box-shadow:0 0 0 3px var(--accent-dim)}
.ftextarea{resize:vertical}
.fselect{-webkit-appearance:none;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-color:rgba(255,255,255,0.03);padding-right:28px}
.fselect option{background:#0f0f28;color:#f1f5f9;padding:6px}
.prob-badge-live{font-size:0.92rem;font-weight:900;margin-left:auto;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.prob-row{display:flex;align-items:center;gap:9px}
.prob-hint{font-size:0.68rem;color:var(--text3);font-family:var(--mono);white-space:nowrap}
.prob-hint.hot{color:var(--amber)}
.modal-footer{display:flex;gap:9px;justify-content:flex-end;margin-top:6px;padding-top:14px;border-top:1px solid var(--border)}
.btn-cancel{background:var(--surface);border:1px solid var(--border);border-radius:40px;padding:9px 20px;color:var(--text2);font-family:var(--font);font-size:0.86rem;font-weight:600;cursor:pointer;transition:all var(--t)}
.btn-cancel:hover{color:var(--text);border-color:var(--border2);background:var(--surface2)}
.btn-save{background:linear-gradient(135deg,var(--accent),var(--accent2));border:none;border-radius:40px;padding:9px 22px;color:#fff;font-family:var(--font);font-size:0.86rem;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:6px;transition:transform var(--t) var(--spring),box-shadow var(--t);box-shadow:0 3px 14px rgba(99,102,241,0.3)}
.btn-save:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(99,102,241,0.45)}
.btn-save:active{transform:scale(0.97)}
.btn-save:disabled{opacity:0.55;cursor:wait;transform:none}

/* ── DRAWER ── */
.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:150;display:flex;justify-content:flex-end;animation:fadeIn 0.2s var(--ease);backdrop-filter:blur(4px)}
.detail-drawer{width:100%;max-width:380px;height:100%;background:rgba(8,8,22,0.97);border-left:1px solid var(--border2);overflow-y:auto;animation:slideRight 0.3s var(--ease-out);display:flex;flex-direction:column;box-shadow:-20px 0 70px rgba(0,0,0,0.6)}
.drawer-hdr{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border);font-size:0.95rem;font-weight:800;position:sticky;top:0;background:rgba(8,8,22,0.98);backdrop-filter:blur(20px)}
.drawer-close{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xs);padding:5px 9px;color:var(--text2);cursor:pointer;font-size:0.78rem;transition:all var(--t)}
.drawer-close:hover{color:var(--rose);border-color:var(--rose);background:var(--rose-dim)}
.drawer-body{padding:22px;display:flex;flex-direction:column;gap:18px}
.d-sect{display:flex;flex-direction:column;gap:7px}
.d-lbl{font-size:0.62rem;font-family:var(--mono);color:var(--text3);text-transform:uppercase;letter-spacing:1.2px}
.d-val{font-size:0.88rem;color:var(--text);line-height:1.6}
.d-actions{display:flex;gap:7px;flex-wrap:wrap;margin-top:6px}

/* ── IMPORT ── */
.import-drop-zone{border:2px dashed var(--border2);border-radius:var(--r);padding:28px;display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--text2);font-size:0.84rem;transition:border-color var(--t),background var(--t)}
.import-drop-zone:hover,.import-drop-zone.drag-over{border-color:var(--accent);background:var(--accent-dim)}
.import-drop-zone svg{color:var(--text3)}
.import-drop-zone span{color:var(--text3);font-size:0.72rem}
.import-browse-btn{background:var(--accent-dim);border:1px solid rgba(99,102,241,0.3);border-radius:var(--r-sm);padding:7px 16px;color:var(--accent2);font-family:var(--font);font-size:0.8rem;font-weight:600;cursor:pointer;transition:all var(--t)}
.import-browse-btn:hover{background:rgba(99,102,241,0.22)}
.import-preview{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:12px 14px;font-size:0.78rem;color:var(--text2);line-height:1.6;max-height:150px;overflow-y:auto}

/* ── FOOTER ── */
.app-footer{padding:16px 20px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:center}
.footer-link{text-decoration:none;font-size:0.72rem;color:var(--text3);font-family:var(--mono);transition:color var(--t)}
.footer-link:hover{color:var(--accent2)}
.footer-link b{color:var(--accent2)}

/* ── TOASTS ── */
.toast-container{position:fixed;bottom:24px;right:24px;z-index:999;display:flex;flex-direction:column;gap:7px;pointer-events:none}
.toast{background:rgba(14,14,32,0.97);border:1px solid var(--border2);border-radius:var(--r-sm);padding:11px 16px;font-size:0.82rem;font-weight:600;color:var(--text);box-shadow:0 14px 44px rgba(0,0,0,0.6);animation:toastIn 0.32s var(--spring) both;display:flex;align-items:center;gap:8px;pointer-events:all;max-width:300px;backdrop-filter:blur(12px)}
.toast.exit{animation:toastOut 0.25s var(--ease) forwards}
.toast.success{border-color:rgba(16,185,129,0.35)}
.toast.success::before{content:'✓';color:var(--emerald);font-weight:900}
.toast.error{border-color:rgba(244,63,94,0.35)}
.toast.error::before{content:'✕';color:var(--rose);font-weight:900}
.toast.info{border-color:rgba(99,102,241,0.35)}
.toast.info::before{content:'ℹ';color:var(--accent2);font-weight:900}

/* ── UTILITY ── */
.hidden{display:none!important}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .entry-container.list-view .entry-card{grid-template-columns:1fr auto}
}
@media(max-width:640px){
  .navbar{padding:9px 14px;gap:7px}
  .brand-text{display:none}
  .sync-label{display:none}
  .btn-add span{display:none}
  .btn-add{padding:8px 11px}
  .stats-row{padding:12px 14px 0;gap:7px}
  .stat-val{font-size:1.35rem}
  .stat-icon{width:36px;height:36px}
  .controls-bar{padding:11px 14px 8px}
  .main-area{padding:0 14px 18px}
  .results-bar{padding:0 14px 7px}
  .entry-container.card-view{grid-template-columns:1fr}
  .entry-container.list-view .entry-card{grid-template-columns:1fr auto}
  .modal-overlay{align-items:flex-end;padding:0}
  .modal{border-radius:var(--r-xl) var(--r-xl) 0 0;max-height:94vh;padding:22px 18px 28px}
  .form-grid-2{grid-template-columns:1fr}
  .detail-drawer{max-width:100%;border-left:none;border-top:1px solid var(--border2)}
  .drawer-overlay{align-items:flex-end}
  .login-card{padding:30px 22px;border-radius:var(--r-xl) var(--r-xl) 0 0;max-width:100%;margin:auto 0 0}
  .login-screen{align-items:flex-end}
  .lc-headline{font-size:1.75rem}
  .toast-container{right:12px;bottom:12px;left:12px}
  .toast{max-width:100%}
  .filter-row{flex-wrap:wrap}
  .date-filter-wrap{flex-wrap:wrap}
}
@supports(padding-top:env(safe-area-inset-top)){
  .navbar{padding-top:calc(9px + env(safe-area-inset-top,0px))}
  .app-footer{padding-bottom:calc(16px + env(safe-area-inset-bottom,0px))}
}