/* === Deal Hunter Overrides (uses grailden-tokens.css as base) === */
:root {
    --accent: #00BCD4;
    --accent-hover: #26C6DA;
    --accent-dim: rgba(0, 188, 212, 0.1);
    --accent-glow: rgba(0, 188, 212, 0.3);
    --font-display: 'Rajdhani', sans-serif;
    --font-body: 'IBM Plex Sans', -apple-system, sans-serif;
    --font-family: 'IBM Plex Sans', -apple-system, sans-serif;
}

/* Deal Hunter — Full App Parity Stylesheet */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0a0e17;
  --bg-sidebar:#0d1117;
  --bg-card:#161b22;
  --bg-card-hover:#1c2333;
  --bg-surface:#12161f;
  --text:#e6edf3;
  --text-muted:#7d8590;
  --accent-cyan:#00d4ff;
  --accent-gold:#ffd700;
  --accent-green:#3fb950;
  --accent-red:#f85149;
  --accent-magenta:#f778ba;
  --accent-orange:#f0883e;
  --border:#30363d;
  --sidebar-active:rgba(0,212,255,0.15);
  --sidebar-hover:rgba(255,255,255,0.05);
  --radius:10px;
  --radius-sm:6px;
}
html{font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:'IBM Plex Sans',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;min-height:100dvh;overflow:hidden}
h1,h2,h3,h4{font-family:'Rajdhani',system-ui,sans-serif;font-weight:600;letter-spacing:0.02em}
a{color:var(--accent-cyan);text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea,select{font-family:inherit;color:inherit}
img{display:block;max-width:100%}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}

/* ── App Layout ── */
#app{display:flex;height:100vh;height:100dvh;overflow:hidden}
#content-wrap{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}
#main{flex:1;overflow-y:auto;overflow-x:hidden}

/* ── Sidebar ── */
#sidebar{width:260px;min-width:260px;background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden;z-index:101}
.sidebar-header{padding:16px 16px 12px;border-bottom:1px solid var(--border)}
.sidebar-logo{display:flex;align-items:center;gap:10px}
.sidebar-logo img{border-radius:6px}
.sidebar-logo h2{font-family:'Rajdhani',monospace;font-size:1.1rem;font-weight:700;color:var(--accent-cyan);letter-spacing:0.12em;line-height:1.1}
.sidebar-logo span{font-size:0.55rem;color:var(--text-muted);letter-spacing:0.15em;text-transform:uppercase;display:block;margin-top:1px}
.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:8px 0}
.nav-group{margin-bottom:4px}
.nav-group-label{padding:12px 16px 4px;font-size:0.65rem;font-weight:600;color:var(--text-muted);letter-spacing:0.12em;text-transform:uppercase;user-select:none}
.nav-item{display:flex;align-items:center;gap:10px;padding:7px 16px;font-size:0.85rem;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all .12s;position:relative;border-radius:0;margin:0 6px;border-radius:var(--radius-sm)}
.nav-item:hover{background:var(--sidebar-hover);color:var(--text)}
.nav-item.active{background:var(--sidebar-active);color:var(--accent-cyan)}
.nav-item .nav-icon{width:20px;text-align:center;font-size:0.95rem;flex-shrink:0}
.nav-item .nav-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nav-item .nav-badge{background:var(--accent-red);color:#fff;font-size:0.6rem;padding:1px 6px;border-radius:10px;font-weight:600;min-width:18px;text-align:center}
.nav-item .nav-count{font-size:0.72rem;color:var(--text-muted)}

/* ── Top Bar ── */
#topbar{display:flex;align-items:center;gap:10px;padding:10px 16px;background:rgba(10,14,23,0.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);min-height:52px;z-index:50}
.hamburger{display:none;font-size:1.3rem;padding:6px 10px;color:var(--text-muted);min-width:44px;min-height:44px;align-items:center;justify-content:center}
.search-box{flex:1;position:relative;max-width:400px}
.search-box input{width:100%;padding:8px 14px 8px 34px;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;font-size:0.85rem;color:var(--text);transition:border-color .15s}
.search-box input:focus{outline:none;border-color:var(--accent-cyan)}
.search-box .search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:0.85rem;pointer-events:none}
.search-box .search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:0.9rem;cursor:pointer;padding:4px;display:none}
.ai-box{flex:1;position:relative;max-width:300px}
.ai-box input{width:100%;padding:8px 14px 8px 34px;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;font-size:0.85rem;color:var(--text);transition:border-color .15s}
.ai-box input:focus{outline:none;border-color:var(--accent-gold)}
.ai-box .ai-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);font-size:0.85rem;pointer-events:none}

/* ── Status Bar ── */
#statusbar{display:flex;align-items:center;gap:0;padding:6px 16px;background:var(--bg-sidebar);border-top:1px solid var(--border);font-size:0.72rem;color:var(--text-muted);min-height:30px;flex-shrink:0}
#statusbar span{white-space:nowrap}
.status-sep{margin:0 10px;opacity:0.3}
#status-sources{color:var(--accent-green)}
#status-intercepts{color:var(--accent-orange)}

/* ── Bottom Nav (mobile) ── */
#bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--bg-sidebar);border-top:1px solid var(--border);z-index:100;padding-bottom:env(safe-area-inset-bottom,0)}
.btm-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px 6px;font-size:0.6rem;font-weight:500;color:var(--text-muted);-webkit-tap-highlight-color:transparent;min-height:44px;justify-content:center;position:relative}
.btm-tab.active{color:var(--accent-cyan)}
.btm-tab .btm-icon{font-size:1.1rem;line-height:1}
.btm-tab .btm-badge{position:absolute;top:2px;right:50%;transform:translateX(14px);background:var(--accent-red);color:#fff;font-size:0.5rem;padding:1px 4px;border-radius:8px;font-weight:600;min-width:14px;text-align:center}

/* ── Overlay ── */
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:100}
.sidebar-overlay.open{display:block}

/* ── Login ── */
#login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:24px;background:var(--bg)}
.login-card{width:100%;max-width:380px;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:40px 32px;text-align:center}
.login-logo{margin-bottom:8px}
.login-logo img{margin:0 auto 16px;display:block}
.login-logo h1{font-family:'Rajdhani',sans-serif;font-size:2rem;font-weight:700;color:var(--accent-cyan);letter-spacing:0.1em;text-transform:uppercase}
.login-tagline{font-size:0.72rem;color:var(--text-muted);letter-spacing:0.12em;text-transform:uppercase;margin-bottom:32px}
.login-field{margin-bottom:16px;text-align:left}
.login-field label{display:block;font-size:0.72rem;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:0.08em;font-weight:500}
.login-field input{width:100%;padding:12px 14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:0.95rem;transition:border-color .15s}
.login-field input:focus{outline:none;border-color:var(--accent-cyan)}
.login-btn{width:100%;padding:14px;background:var(--accent-cyan);color:var(--bg);font-size:0.95rem;font-weight:600;border-radius:var(--radius-sm);margin-top:8px;transition:opacity .15s;letter-spacing:0.03em}
.login-btn:hover{opacity:0.9}
.login-btn:disabled{opacity:0.5;cursor:not-allowed}
.login-error{color:var(--accent-red);font-size:0.82rem;margin-top:12px;min-height:20px}

/* ── Page Sections ── */
.page-header{padding:20px 20px 12px;max-width:1400px;margin:0 auto}
.page-header h2{font-size:1.3rem;color:var(--text)}
.page-header p{font-size:0.82rem;color:var(--text-muted);margin-top:4px}
.section-pad{padding:0 20px;max-width:1400px;margin:0 auto}

/* ── Stats Cards ── */
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;padding:0 20px;max-width:1400px;margin:0 auto 16px}
.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;text-align:center}
.stat-card .stat-value{font-family:'Rajdhani',sans-serif;font-size:1.8rem;font-weight:700;color:var(--accent-cyan);line-height:1.1}
.stat-card .stat-label{font-size:0.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.06em;margin-top:4px}
.stat-card.gold .stat-value{color:var(--accent-gold)}
.stat-card.green .stat-value{color:var(--accent-green)}
.stat-card.red .stat-value{color:var(--accent-red)}
.stat-card.orange .stat-value{color:var(--accent-orange)}

/* ── Category Pills ── */
.pills-scroll{display:flex;gap:8px;overflow-x:auto;padding:0 20px 12px;max-width:1400px;margin:0 auto;scrollbar-width:none;-ms-overflow-style:none}
.pills-scroll::-webkit-scrollbar{display:none}
.pill{padding:6px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;font-size:0.78rem;color:var(--text-muted);cursor:pointer;white-space:nowrap;transition:all .12s;flex-shrink:0}
.pill:hover{border-color:var(--text-muted)}
.pill.active{background:var(--sidebar-active);border-color:var(--accent-cyan);color:var(--accent-cyan)}
.pill .pill-dot{display:inline-block;width:6px;height:6px;border-radius:50%;margin-right:6px;vertical-align:middle}

/* ── Listing Cards ── */
.listing-list{padding:8px 20px;max-width:1400px;margin:0 auto}
.listing-card{display:flex;gap:12px;padding:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;cursor:pointer;transition:border-color .12s;position:relative}
.listing-card:hover{border-color:var(--text-muted)}
.listing-card:active{transform:scale(0.998)}
.listing-thumb{width:100px;height:100px;min-width:100px;border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-surface);display:flex;align-items:center;justify-content:center}
.listing-thumb img{width:100%;height:100%;object-fit:cover}
.listing-thumb .no-img{color:var(--text-muted);font-size:1.6rem;opacity:0.3}
.listing-body{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:space-between}
.listing-title{font-size:0.88rem;font-weight:500;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.listing-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:4px}
.listing-price{font-family:'Rajdhani',sans-serif;font-size:1.1rem;font-weight:700;color:var(--accent-cyan)}
.listing-price.no-price{color:var(--text-muted);font-size:0.85rem;font-weight:400}
.source-badge{padding:2px 8px;border-radius:10px;font-size:0.65rem;font-weight:600;text-transform:uppercase;letter-spacing:0.04em;white-space:nowrap}
.listing-time{font-size:0.72rem;color:var(--text-muted)}
.listing-indicators{display:flex;gap:4px;align-items:center}
.dot-relevant{width:7px;height:7px;border-radius:50%;background:var(--accent-green);display:inline-block}
.dot-irrelevant{width:7px;height:7px;border-radius:50%;background:var(--border);display:inline-block}
.dot-starred{color:var(--accent-gold);font-size:0.8rem}
.dot-fav{color:var(--accent-red);font-size:0.8rem}
.score-badge{padding:2px 6px;border-radius:4px;font-size:0.65rem;font-weight:700;font-family:'Rajdhani',sans-serif}
.score-high{background:rgba(63,185,80,0.2);color:var(--accent-green)}
.score-mid{background:rgba(240,136,62,0.2);color:var(--accent-orange)}
.score-low{background:rgba(248,81,73,0.15);color:var(--accent-red)}

/* ── Detail View ── */
.detail-back{position:sticky;top:0;z-index:50;background:rgba(10,14,23,0.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:10px 20px;display:flex;align-items:center;gap:10px}
.detail-back button{padding:8px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:0.85rem;min-height:44px;display:flex;align-items:center;gap:6px}
.detail-images{width:100%;background:var(--bg-card);display:flex;align-items:center;justify-content:center;min-height:200px;max-height:420px;overflow:hidden;position:relative}
.detail-images img{width:100%;height:auto;max-height:420px;object-fit:contain}
.detail-images .no-img{color:var(--text-muted);font-size:3rem;opacity:0.2}
.detail-content{padding:20px;max-width:800px;margin:0 auto}
.detail-title{font-size:1.25rem;font-weight:600;line-height:1.35;margin-bottom:12px}
.detail-price-row{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.detail-price{font-family:'Rajdhani',sans-serif;font-size:1.8rem;font-weight:700;color:var(--accent-cyan)}
.detail-price-usd{font-size:0.88rem;color:var(--text-muted)}
.detail-section{margin-bottom:20px}
.detail-section h3{font-size:0.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:8px;font-weight:500}
.detail-section p{font-size:0.9rem;line-height:1.6;white-space:pre-wrap}
.detail-tags{display:flex;flex-wrap:wrap;gap:6px}
.detail-tag{padding:4px 10px;background:var(--bg-surface);border-radius:12px;font-size:0.75rem;color:var(--text-muted)}
.detail-ai{padding:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px}
.detail-ai .ai-label{font-size:0.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:4px}
.detail-ai .ai-verdict{font-weight:600;margin-bottom:4px}
.detail-ai .ai-verdict.relevant{color:var(--accent-green)}
.detail-ai .ai-verdict.irrelevant{color:var(--accent-red)}
.detail-ai .ai-reason{font-size:0.82rem;color:var(--text-muted);line-height:1.5}
.detail-actions{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}
.detail-actions button,.detail-actions a{display:flex;align-items:center;gap:6px;padding:10px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:0.85rem;min-height:44px;transition:all .15s;text-decoration:none;color:var(--text)}
.detail-actions button:hover,.detail-actions a:hover{border-color:var(--accent-cyan);color:var(--accent-cyan)}
.detail-actions .btn-primary{background:var(--accent-cyan);color:var(--bg);border-color:var(--accent-cyan)}
.detail-meta{font-size:0.78rem;color:var(--text-muted);display:flex;flex-direction:column;gap:4px}
.notes-area{width:100%;min-height:80px;padding:10px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:0.88rem;resize:vertical;font-family:inherit}
.notes-area:focus{outline:none;border-color:var(--accent-cyan)}
.notes-save{padding:8px 16px;background:var(--accent-cyan);color:var(--bg);border-radius:var(--radius-sm);font-size:0.82rem;font-weight:500;margin-top:8px}

/* ── Carousel ── */
.carousel{position:relative;width:100%;overflow:hidden}
.carousel-track{display:flex;transition:transform .3s ease;will-change:transform}
.carousel-track img{width:100%;flex-shrink:0;max-height:420px;object-fit:contain;background:var(--bg-card)}
.carousel-dots{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);display:flex;gap:6px}
.carousel-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.3);cursor:pointer}
.carousel-dot.active{background:#fff}
.carousel-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,0.5);color:#fff;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;cursor:pointer;z-index:5}
.carousel-nav.prev{left:8px}
.carousel-nav.next{right:8px}

/* ── Filter Panel ── */
.filter-bar{display:flex;align-items:center;gap:8px;padding:0 20px 12px;max-width:1400px;margin:0 auto;flex-wrap:wrap}
.filter-btn{padding:7px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;font-size:0.82rem;color:var(--text-muted);white-space:nowrap;display:flex;align-items:center;gap:6px;min-height:36px;transition:all .15s}
.filter-btn:hover,.filter-btn.active{border-color:var(--accent-cyan);color:var(--accent-cyan)}
.filter-panel{background:var(--bg-card);border-bottom:1px solid var(--border);padding:16px 20px;display:none;max-height:60vh;overflow-y:auto;max-width:1400px;margin:0 auto}
.filter-panel.open{display:block}
.filter-section{margin-bottom:16px}
.filter-section h3{font-size:0.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:8px;font-weight:500}
.filter-chips{display:flex;flex-wrap:wrap;gap:6px}
.filter-chip{padding:6px 12px;background:var(--bg);border:1px solid var(--border);border-radius:16px;font-size:0.78rem;color:var(--text-muted);cursor:pointer;transition:all .15s}
.filter-chip:hover{border-color:var(--text-muted)}
.filter-chip.selected{background:var(--sidebar-active);border-color:var(--accent-cyan);color:var(--accent-cyan)}
.filter-row{display:flex;gap:8px;align-items:center}
.filter-row input{width:100px;padding:8px 10px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:0.82rem}
.filter-row input:focus{outline:none;border-color:var(--accent-cyan)}
.filter-actions{display:flex;gap:8px;margin-top:12px}
.filter-actions button{padding:8px 16px;border-radius:var(--radius-sm);font-size:0.82rem;font-weight:500}
.filter-apply{background:var(--accent-cyan);color:var(--bg)}
.filter-clear{background:var(--bg-surface);color:var(--text-muted)}
.toggle-wrap{display:flex;align-items:center;gap:8px;cursor:pointer}
.toggle-track{width:36px;height:20px;background:var(--border);border-radius:10px;position:relative;transition:background .2s}
.toggle-track.on{background:var(--accent-cyan)}
.toggle-thumb{width:16px;height:16px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:transform .2s}
.toggle-track.on .toggle-thumb{transform:translateX(16px)}

/* ── Source Directory ── */
.source-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;padding:0 20px;max-width:1400px;margin:0 auto}
.source-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:border-color .12s}
.source-card:hover{border-color:var(--accent-cyan)}
.source-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.source-dot.enabled{background:var(--accent-green)}
.source-dot.disabled{background:var(--accent-red)}
.source-info{flex:1;min-width:0}
.source-name{font-weight:600;font-size:0.9rem}
.source-meta{font-size:0.72rem;color:var(--text-muted);margin-top:2px}
.source-count{font-family:'Rajdhani',sans-serif;font-size:1.1rem;font-weight:700;color:var(--accent-cyan)}

/* ── Saved Searches / Hunt Groups ── */
.search-card{padding:14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;cursor:pointer;transition:border-color .12s}
.search-card:hover{border-color:var(--text-muted)}
.search-card-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.search-card-icon{font-size:1.1rem}
.search-card-name{font-weight:600;font-size:0.95rem;flex:1}
.search-card-count{font-size:0.78rem;color:var(--text-muted);background:var(--bg-surface);padding:2px 8px;border-radius:10px}
.search-card-count.has-new{background:rgba(0,212,255,0.12);color:var(--accent-cyan)}
.search-card-detail{font-size:0.78rem;color:var(--text-muted)}
.group-label{padding:16px 0 8px;font-size:0.8rem;font-weight:600;color:var(--accent-gold);text-transform:uppercase;letter-spacing:0.08em}

/* ── Watch Cards ── */
.watch-card{padding:14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;display:flex;align-items:center;gap:12px}
.watch-info{flex:1;min-width:0}
.watch-keyword{font-weight:600;font-size:0.92rem}
.watch-meta{font-size:0.75rem;color:var(--text-muted);margin-top:2px}
.watch-badge{padding:2px 8px;border-radius:10px;font-size:0.7rem;font-weight:600;text-transform:uppercase}
.priority-urgent{background:rgba(248,81,73,0.2);color:var(--accent-red)}
.priority-high{background:rgba(248,81,73,0.15);color:var(--accent-red)}
.priority-normal{background:rgba(0,212,255,0.1);color:var(--accent-cyan)}
.priority-low{background:var(--bg-surface);color:var(--text-muted)}

/* ── Alert Cards ── */
.alert-card{display:flex;gap:12px;padding:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;cursor:pointer;transition:border-color .12s;position:relative}
.alert-card:hover{border-color:var(--text-muted)}
.alert-card.unseen{border-left:3px solid var(--accent-cyan)}
.alert-trigger{font-size:0.72rem;color:var(--accent-gold);font-weight:500;margin-top:2px}

/* ── Flip / Profit Cards ── */
.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;padding:0 20px;max-width:1400px;margin:0 auto 16px}
.dash-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px}
.dash-card h4{font-size:0.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:8px}
.dash-card .big-num{font-family:'Rajdhani',sans-serif;font-size:1.6rem;font-weight:700;color:var(--accent-cyan)}
.dash-card .sub-text{font-size:0.75rem;color:var(--text-muted);margin-top:4px}
.partner-list{padding:0 20px;max-width:1400px;margin:0 auto}
.partner-card{display:flex;align-items:center;gap:14px;padding:14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;cursor:pointer;transition:border-color .12s}
.partner-card:hover{border-color:var(--accent-cyan)}
.partner-avatar{width:40px;height:40px;border-radius:50%;background:var(--bg-surface);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.partner-info{flex:1}
.partner-name{font-weight:600;font-size:0.95rem}
.partner-meta{font-size:0.75rem;color:var(--text-muted);margin-top:2px}
.partner-amount{font-family:'Rajdhani',sans-serif;font-size:1.2rem;font-weight:700;color:var(--accent-gold)}

/* ── Scraper Health ── */
.health-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px;padding:0 20px;max-width:1400px;margin:0 auto}
.health-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:0.82rem}
.health-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.health-dot.ok{background:var(--accent-green)}
.health-dot.warn{background:var(--accent-orange)}
.health-dot.err{background:var(--accent-red)}
.health-name{flex:1;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.health-stat{font-size:0.72rem;color:var(--text-muted);white-space:nowrap}

/* ── Bar Charts ── */
.bar-chart{padding:0 20px;max-width:1400px;margin:0 auto 16px}
.bar-chart h3{font-size:0.85rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:12px}
.bar-row{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.bar-label{width:120px;font-size:0.78rem;color:var(--text-muted);text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar-track{flex:1;height:20px;background:var(--bg);border-radius:4px;overflow:hidden}
.bar-fill{height:100%;border-radius:4px;transition:width .5s ease;min-width:2px}
.bar-value{font-size:0.72rem;color:var(--text-muted);min-width:40px}

/* ── Settings ── */
.settings-list{padding:0 20px;max-width:600px;margin:0 auto}
.settings-item{display:flex;align-items:center;justify-content:space-between;padding:14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px}
.settings-item .label{font-size:0.9rem;font-weight:500}
.settings-item .value{font-size:0.85rem;color:var(--text-muted)}
.logout-btn{width:100%;padding:14px;background:var(--bg-card);border:1px solid var(--accent-red);border-radius:var(--radius-sm);color:var(--accent-red);font-size:0.9rem;font-weight:500;margin-top:16px;cursor:pointer}
.logout-btn:hover{background:rgba(248,81,73,0.1)}

/* ── Coming Soon Placeholder ── */
.placeholder-view{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;text-align:center}
.placeholder-icon{font-size:3.5rem;opacity:0.3;margin-bottom:16px}
.placeholder-view h3{font-size:1.2rem;margin-bottom:8px;color:var(--text)}
.placeholder-view p{font-size:0.88rem;color:var(--text-muted);max-width:400px;line-height:1.6}
.placeholder-view a{margin-top:16px;padding:10px 20px;background:var(--accent-cyan);color:var(--bg);border-radius:var(--radius-sm);font-weight:500;font-size:0.88rem;display:inline-block}

/* ── Loading / Empty ── */
.loading{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--text-muted)}
.spinner{width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--accent-cyan);border-radius:50%;animation:spin .7s linear infinite;margin-right:10px}
@keyframes spin{to{transform:rotate(360deg)}}
.empty-state{text-align:center;padding:60px 24px;color:var(--text-muted)}
.empty-state .empty-icon{font-size:3rem;opacity:0.3;margin-bottom:12px}
.empty-state h3{font-size:1.1rem;color:var(--text);margin-bottom:8px}
.empty-state p{font-size:0.85rem;max-width:300px;margin:0 auto;line-height:1.5}

/* ── Toast ── */
.toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(100px);background:var(--bg-card);color:var(--text);padding:10px 20px;border-radius:20px;font-size:0.85rem;z-index:200;opacity:0;transition:all .3s ease;pointer-events:none;border:1px solid var(--border);white-space:nowrap}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}

/* ── Progress bar ── */
.progress-bar{height:6px;background:var(--bg);border-radius:3px;overflow:hidden;margin-top:8px}
.progress-fill{height:100%;border-radius:3px;transition:width .5s}

/* ── Responsive ── */
@media(max-width:768px){
  #sidebar{position:fixed;left:-280px;top:0;transition:left .25s ease;z-index:101}
  #sidebar.open{left:0}
  .hamburger{display:flex}
  #bottom-nav{display:flex}
  #statusbar{display:none}
  .ai-box{display:none}
  .listing-thumb{width:80px;height:80px;min-width:80px}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .source-grid{grid-template-columns:1fr}
  .health-grid{grid-template-columns:1fr}
  .dashboard-grid{grid-template-columns:repeat(2,1fr)}
}
@media(min-width:769px){
  #bottom-nav{display:none!important}
  .hamburger{display:none!important}
  .toast{bottom:40px}
}

/* ── Admin Panel ── */
.admin-page{padding:24px;max-width:1200px}
.admin-tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:24px;overflow-x:auto}
.admin-tab{padding:10px 20px;font-size:0.85rem;font-weight:600;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;white-space:nowrap}
.admin-tab:hover{color:var(--text)}
.admin-tab.active{color:var(--accent-cyan);border-bottom-color:var(--accent-cyan)}
.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px}
.admin-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;text-align:center}
.admin-stat-val{font-family:'Rajdhani',sans-serif;font-size:2.2rem;font-weight:700;line-height:1}
.admin-stat-label{font-size:0.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.08em;margin-top:4px}
.admin-table{width:100%;border-collapse:collapse;font-size:0.85rem}
.admin-table th{text-align:left;padding:10px 12px;font-size:0.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.08em;border-bottom:1px solid var(--border);font-weight:600}
.admin-table td{padding:10px 12px;border-bottom:1px solid rgba(48,54,61,0.5)}
.admin-table tr:hover{background:var(--bg-card-hover)}
.admin-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:0.7rem;font-weight:600;text-transform:uppercase;letter-spacing:0.05em}
.admin-badge.admin{background:rgba(0,212,255,0.15);color:var(--accent-cyan)}
.admin-badge.authenticator{background:rgba(255,215,0,0.15);color:var(--accent-gold)}
.admin-badge.beta{background:rgba(63,185,80,0.15);color:var(--accent-green)}
.admin-badge.open{background:rgba(0,212,255,0.15);color:var(--accent-cyan)}
.admin-badge.in_progress{background:rgba(240,136,62,0.15);color:var(--accent-orange)}
.admin-badge.resolved{background:rgba(63,185,80,0.15);color:var(--accent-green)}
.admin-badge.closed{background:rgba(125,133,144,0.15);color:var(--text-muted)}
.admin-badge.bug{background:rgba(248,81,73,0.15);color:var(--accent-red)}
.admin-badge.feature{background:rgba(0,212,255,0.15);color:var(--accent-cyan)}
.admin-badge.question{background:rgba(255,215,0,0.15);color:var(--accent-gold)}
.admin-badge.info{background:rgba(0,212,255,0.15);color:var(--accent-cyan)}
.admin-badge.warning{background:rgba(240,136,62,0.15);color:var(--accent-orange)}
.admin-badge.update{background:rgba(63,185,80,0.15);color:var(--accent-green)}
.admin-badge.maintenance{background:rgba(248,81,73,0.15);color:var(--accent-red)}
.admin-badge.low{background:rgba(125,133,144,0.15);color:var(--text-muted)}
.admin-badge.normal{background:rgba(0,212,255,0.15);color:var(--accent-cyan)}
.admin-badge.high{background:rgba(240,136,62,0.15);color:var(--accent-orange)}
.admin-badge.critical{background:rgba(248,81,73,0.15);color:var(--accent-red)}
.ticket-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px;cursor:pointer;transition:border-color .15s}
.ticket-card:hover{border-color:var(--accent-cyan)}
.ticket-card h3{font-size:0.95rem;margin-bottom:6px}
.ticket-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap;font-size:0.75rem;color:var(--text-muted)}
.ticket-detail{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px}
.ticket-reply{padding:12px;margin:8px 0;border-left:3px solid var(--border);border-radius:0 var(--radius-sm) var(--radius-sm) 0;background:var(--bg-surface)}
.ticket-reply.admin-reply{border-left-color:var(--accent-cyan)}
.ticket-reply-form{display:flex;gap:8px;margin-top:12px}
.ticket-reply-form textarea{flex:1;padding:10px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);resize:vertical;min-height:60px;font-size:0.85rem;color:var(--text);font-family:inherit}
.ticket-reply-form button{padding:10px 20px;background:var(--accent-cyan);color:var(--bg);border:none;border-radius:var(--radius-sm);font-weight:600;font-size:0.85rem;align-self:flex-end;cursor:pointer}
.admin-form{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px}
.admin-form label{display:block;font-size:0.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:4px;font-weight:600}
.admin-form input,.admin-form textarea,.admin-form select{width:100%;padding:10px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:0.85rem;margin-bottom:12px;color:var(--text);font-family:inherit}
.admin-form textarea{min-height:80px;resize:vertical}
.admin-form button[type="submit"]{padding:10px 24px;background:var(--accent-cyan);color:var(--bg);border:none;border-radius:var(--radius-sm);font-weight:600;font-size:0.85rem;cursor:pointer}
.admin-filter-pills{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}
.admin-pill{padding:6px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;font-size:0.78rem;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all .15s}
.admin-pill.active{background:rgba(0,212,255,0.15);color:var(--accent-cyan);border-color:var(--accent-cyan)}
.admin-pill .pill-count{margin-left:4px;opacity:0.6}
.admin-actions{display:flex;gap:8px;margin-bottom:16px}
.admin-actions button{padding:8px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:0.8rem;font-weight:500;color:var(--text);cursor:pointer;transition:all .15s}
.admin-actions button:hover{border-color:var(--accent-cyan);color:var(--accent-cyan)}
.activity-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid rgba(48,54,61,0.3);font-size:0.85rem}
.activity-icon{width:32px;height:32px;border-radius:50%;background:var(--bg-card);display:flex;align-items:center;justify-content:center;font-size:0.9rem;flex-shrink:0}
.activity-text{flex:1}
.activity-time{font-size:0.72rem;color:var(--text-muted);white-space:nowrap}
.ann-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px;display:flex;align-items:flex-start;gap:12px}
.ann-card .ann-body{flex:1}
.ann-card .ann-toggle{padding:6px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:0.75rem;cursor:pointer;white-space:nowrap;color:var(--text)}
@media(max-width:768px){
  .admin-page{padding:16px}
  .admin-stats{grid-template-columns:repeat(2,1fr)}
  .admin-table{font-size:0.78rem}
  .admin-table th,.admin-table td{padding:8px 6px}
}
