@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Plus+Jakarta+Sans:wght@400;600;700;800&display=swap');
/* gpLead dashboard — clean, unified, international design system */
:root{
 --brand:#7c3aed;--brand-ink:#6d28d9;--accent:#f59e0b;--warn:#d97706;--re:#dc2626;
 --ink:#15101f;--mu:#645a73;--bg:#f7f5fd;--card:#ffffff;--line:#e9e5f3;--soft:#f0e9fe;
 --sidebar:#ffffff;--sidebar-line:#e9e5f3;--radius:14px;
 --sh:0 1px 2px rgba(16,24,40,.04),0 8px 24px -16px rgba(16,24,40,.16)
}
html[data-theme="dark"]{
 --ink:#f3f0ff;--mu:#b8a9e8;--bg:#0f0a1e;--card:#221a3e;--line:#2e2450;--soft:#1e1638;
 --brand:#a78bfa;--brand-ink:#c4b5fd;--accent:#fbbf24;--sidebar:#16102b;--sidebar-line:#2a2150;
 --sh:0 4px 24px rgba(124,58,237,.18),0 12px 36px -18px rgba(124,58,237,.42)
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:"Inter","Plus Jakarta Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg);line-height:1.55;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
h1,h2,h3,h4{letter-spacing:-.02em;line-height:1.2;font-family:"Plus Jakarta Sans","Inter",sans-serif}
.btn{display:inline-flex;align-items:center;gap:8px;border:none;border-radius:10px;padding:10px 18px;font-weight:700;font-size:14px;cursor:pointer;transition:.15s;font-family:inherit;white-space:nowrap}
.btn-p{background:var(--brand);color:#fff}.btn-p:hover{background:var(--brand-ink)}
html[data-theme="dark"] .btn-p{background:#7c3aed;color:#fff}
html[data-theme="dark"] .btn-p:hover{background:#6d28d9}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}
@keyframes slideIn{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}
.btn-g{background:var(--soft);color:var(--brand-ink)}.btn-g:hover{background:color-mix(in srgb,var(--brand) 14%,transparent)}
.btn-o{background:var(--card);color:var(--ink);border:1px solid var(--line)}.btn-o:hover{border-color:var(--brand);color:var(--brand)}
.btn-lg{padding:13px 24px;font-size:15px}.btn-sm{padding:7px 13px;font-size:13px}
.btn-block{width:100%;justify-content:center}
.btn:disabled{opacity:.6;cursor:wait}
.wrap{max-width:1180px;margin:0 auto;padding:0 22px}
.muted{color:var(--mu)}.center{text-align:center}
.pill{font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px}
.p-blue{background:var(--soft);color:var(--brand-ink)}.p-green{background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent)}
.p-amber{background:#fef3c7;color:#92400e}.p-red{background:#fee2e2;color:#b91c1c}.p-grey{background:#eef1f5;color:#64748b}
html[data-theme="dark"] .p-amber{background:#3a2c0e;color:#fbbf24}html[data-theme="dark"] .p-red{background:#3a1414;color:#fca5a5}html[data-theme="dark"] .p-grey{background:#1e2738;color:#9aa8bd}
.vbadge{font-size:10.5px;font-weight:800;padding:2px 8px;border-radius:6px;background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent)}
.nbadge{font-size:10.5px;font-weight:800;padding:2px 8px;border-radius:6px;background:#eef1f5;color:#64748b}
.ebadge{font-size:10.5px;font-weight:800;padding:2px 8px;border-radius:6px;background:#fef3c7;color:#92400e}
html[data-theme="dark"] .nbadge{background:#1e2738;color:#9aa8bd}html[data-theme="dark"] .ebadge{background:#3a2c0e;color:#fbbf24}

/* ---- AUTH MODAL (shared) ---- */
.modal-bg{position:fixed;inset:0;background:rgba(10,16,26,.55);display:none;align-items:center;justify-content:center;z-index:100;padding:20px}
.modal-bg.on{display:flex}
.modal{background:var(--card);border:1px solid var(--line);border-radius:16px;width:420px;max-width:100%;padding:28px;box-shadow:var(--sh)}
.modal h2{font-size:22px;margin-bottom:4px}.modal .sub{color:var(--mu);font-size:14px;margin-bottom:18px}
.field{margin-bottom:13px}
.field label{display:block;font-size:12.5px;font-weight:600;color:var(--mu);margin-bottom:6px}
.field input{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:10px;font-size:14px;background:var(--bg);color:var(--ink);font-family:inherit}
.field input:focus{outline:none;border-color:var(--brand)}
.gbtn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:12px;border:1px solid var(--line);border-radius:10px;background:var(--card);font-weight:700;cursor:pointer;font-size:14px;color:var(--ink)}
.gbtn:hover{border-color:var(--brand)}
.divider{display:flex;align-items:center;gap:12px;color:var(--mu);font-size:12px;margin:16px 0}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--line)}
.switch{text-align:center;font-size:13.5px;color:var(--mu);margin-top:16px}.switch a{color:var(--brand);font-weight:700;cursor:pointer}
.err{background:#fee2e2;color:#b91c1c;font-size:13px;padding:9px 12px;border-radius:9px;margin-bottom:14px;display:none}.err.on{display:block}

/* ---- APP SHELL ---- */
.app{display:grid;grid-template-columns:244px 1fr;grid-template-rows:60px 1fr;height:100vh}
aside.side{grid-row:1/3;background:var(--sidebar);color:var(--mu);display:flex;flex-direction:column;padding:14px 12px;overflow-y:auto;border-right:1px solid var(--sidebar-line)}
.brand{font-weight:800;font-size:20px;color:var(--ink);padding:8px 12px 16px;letter-spacing:-.03em;display:flex;align-items:center}
.brand span{color:var(--brand)}
.brand .mk{width:26px;height:26px;margin-right:8px;flex:none}
.nav-i{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:9px;cursor:pointer;font-weight:600;color:var(--mu);margin-bottom:1px;font-size:14px;transition:.12s}
.nav-i .ic{width:18px;text-align:center;opacity:.85}
.nav-i:hover{background:color-mix(in srgb,var(--ink) 5%,transparent);color:var(--ink)}
.nav-i.active{background:var(--soft);color:var(--brand-ink);font-weight:700}
.nav-i.active .ic{opacity:1}
.nav-sep{font-size:10.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--mu);padding:14px 12px 6px;opacity:.7}
.side-foot{margin-top:auto;padding-top:12px}
.uchip{display:flex;align-items:center;gap:10px;background:var(--bg);border:1px solid var(--line);border-radius:11px;padding:9px}
.uchip .av{width:32px;height:32px;border-radius:50%;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;flex:none}
.uchip .nm{font-size:13px;color:var(--ink);font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.uchip .pl{font-size:11px;color:var(--mu)}
topbar,.topbar{grid-column:2;display:flex;align-items:center;gap:14px;background:var(--card);border-bottom:1px solid var(--line);padding:0 24px}
.topbar .search{flex:1;max-width:440px}
.topbar .search input{width:100%;padding:9px 14px;border:1px solid var(--line);border-radius:10px;background:var(--bg);font-size:14px;color:var(--ink);font-family:inherit}
.topbar .search input:focus{outline:none;border-color:var(--brand)}
.topbar .tr{margin-left:auto;display:flex;align-items:center;gap:12px}
main.content{grid-column:2;overflow-y:auto;padding:24px;background:var(--bg)}
.iconbtn{background:var(--card);border:1px solid var(--line);border-radius:9px;width:37px;height:37px;cursor:pointer;font-size:14px;color:var(--ink)}
.menu-btn{display:none;background:var(--card);border:1px solid var(--line);border-radius:10px;width:40px;height:40px;cursor:pointer;color:var(--ink);font-size:18px;align-items:center;justify-content:center;flex:none}
.side-bg{position:fixed;inset:0;background:rgba(10,16,26,.45);z-index:115;display:none}
.side-bg.on{display:block}
.collapse-btn{background:var(--card);border:1px solid var(--line);border-radius:9px;width:34px;height:34px;cursor:pointer;color:var(--mu);font-size:15px;display:none}
@media(min-width:861px){.collapse-btn{display:inline-flex;align-items:center;justify-content:center}}
.app.collapsed{grid-template-columns:64px 1fr}
.app.collapsed aside.side .brand span,.app.collapsed aside.side .nav-i,.app.collapsed aside.side .nav-sep,.app.collapsed aside.side .side-foot{font-size:0}
.app.collapsed aside.side .nav-i .ic{font-size:17px}
.app.collapsed aside.side .nav-i{justify-content:center;gap:0}
.app.collapsed aside.side .nav-sep{padding:8px 0;margin:0}
.app.collapsed aside.side .uchip{justify-content:center}
@media(max-width:860px){
 .app{grid-template-columns:1fr}.topbar{grid-column:1}main.content{grid-column:1}.menu-btn{display:inline-flex}
 aside.side{position:fixed;left:0;top:0;bottom:0;width:min(84vw,300px);z-index:120;transform:translateX(-100%);transition:transform .25s ease;box-shadow:0 20px 60px rgba(0,0,0,.25);padding-bottom:max(14px,env(safe-area-inset-bottom))}
 aside.side.open{transform:none}
 .topbar{padding:0 14px;gap:10px}
 .topbar .search{max-width:none;min-width:0}
 .topbar .tr{gap:8px}
 #dateTag{display:none}
 main.content{padding:18px 14px}
}
@media(max-width:560px){
 .topbar{padding:0 12px;gap:8px}
 .topbar .search input{padding:8px 12px;font-size:13.5px}
 .lastupd #lastUpdTxt{display:none}
 .lastupd{padding:6px;gap:0}
 main.content{padding:14px 12px}
 .phead{gap:8px;margin-bottom:14px}
 .phead h1{font-size:20px}
 .phead .sub{font-size:12.5px}
 .phead .act{width:100%;margin-left:0}
 .phead .act .btn,.phead .act button{flex:1 1 auto;justify-content:center}
 .cards{gap:10px}
 .card{padding:14px}.card .n{font-size:22px}
 .panel{padding:14px}
 .filters{padding:10px;gap:8px}
 .filters input,.filters select,select{flex:1 1 auto;min-width:0}
 .tabs{gap:6px}.tab{padding:7px 12px;font-size:13px}
 th,td{padding:9px 10px;font-size:12.5px}
 .grid-cards{grid-template-columns:1fr;gap:12px}
 .toast{left:12px;right:12px;transform:none;text-align:center;bottom:calc(78px + env(safe-area-inset-bottom))}
}

/* ---- PAGE PRIMITIVES ---- */
.phead{display:flex;align-items:center;gap:12px;margin-bottom:18px;flex-wrap:wrap}
.phead h1{font-size:23px;letter-spacing:-.03em}.phead .sub{color:var(--mu);font-size:13.5px}
.phead .act{margin-left:auto;display:flex;gap:10px;flex-wrap:wrap}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:20px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px}
.card .l{font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--mu)}
.card .n{font-size:25px;font-weight:800;color:var(--ink);margin-top:5px}
.card .d{font-size:12px;color:var(--accent);margin-top:3px}
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin-bottom:18px}
.panel h3{font-size:15px;margin-bottom:14px}
.filters{display:flex;gap:9px;flex-wrap:wrap;align-items:center;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:12px;margin-bottom:14px}
select,.filters input{padding:9px 12px;border:1px solid var(--line);border-radius:10px;font-size:13.5px;background:var(--card);color:var(--ink);font-family:inherit}
select:focus,.filters input:focus{outline:none;border-color:var(--brand)}
table{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
th,td{padding:11px 14px;text-align:left;border-bottom:1px solid var(--line);font-size:13.5px;vertical-align:top}
th{background:var(--soft);font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--mu)}
tr:last-child td{border-bottom:none}tbody tr:hover{background:color-mix(in srgb,var(--brand) 4%,transparent)}
.score{font-weight:800;color:#fff;border-radius:8px;padding:3px 9px;font-size:13px;display:inline-block;min-width:34px;text-align:center}
.s-hot{background:var(--accent)}.s-warm{background:var(--warn)}.s-low{background:#94a3b8}
.tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px}
.tab{padding:8px 15px;border-radius:9px;background:var(--card);border:1px solid var(--line);cursor:pointer;font-weight:600;font-size:13.5px;color:var(--mu)}
.tab.active{background:var(--brand);color:#fff;border-color:var(--brand)}
.link{color:var(--brand);font-weight:600}
.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.tcard{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px;transition:.15s}
.tcard:hover{border-color:var(--brand);box-shadow:var(--sh)}
.tcard h4{font-size:15px}.tcard .url{font-size:12px;color:var(--brand);margin:3px 0 8px}.tcard p{font-size:13px;color:var(--mu)}
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--ink);color:var(--bg);padding:12px 20px;border-radius:10px;font-size:14px;z-index:200;opacity:0;transition:.2s;pointer-events:none}
.toast.on{opacity:1}
.brand,h1,h2,h3,.card .n,.phead h1{font-family:"Plus Jakarta Sans","Inter",sans-serif}

/* ---- shared content helpers ---- */
main.content{background:var(--bg)}
.socrow{display:inline-flex;gap:5px;flex-wrap:wrap}
.soc{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:21px;padding:0 6px;border:1px solid var(--line);border-radius:6px;font-size:11px;font-weight:800;color:var(--brand);background:var(--card)}
.soc:hover{background:var(--soft);border-color:var(--brand)}
.ctline{font-size:13px}.ctline a{color:var(--brand);font-weight:600}
.favbtn{border:none;background:transparent;cursor:pointer;font-size:18px;line-height:1;color:#cbd5e1;padding:2px 4px;transition:.12s}
.favbtn:hover{transform:scale(1.15)}.favbtn.on{color:#ef4444}
.tagpill{font-size:11px;font-weight:700;padding:2px 9px;border-radius:999px;background:var(--soft);color:var(--brand-ink)}
.collab{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.ccard{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px;position:relative;transition:.15s}
.ccard:hover{box-shadow:var(--sh);border-color:var(--brand)}
.ccard h4{font-size:16px;padding-right:26px}
.ccard .meta{font-size:12.5px;color:var(--mu);margin-top:5px}
.ccard .desc{font-size:13.5px;color:var(--mu);margin:10px 0}
.ccard .fav{position:absolute;top:10px;right:10px}
