:root{
  --brand:#5A5AFF;--brand-h:#4848E8;--brand-light:#EEEEFF;--brand-dim:rgba(90,90,255,.12);
  --bg:#F1F3F9;--surface:#FFFFFF;--surface2:#F8FAFC;
  --border:#E2E8F0;--border2:#CBD5E1;
  --text:#0F172A;--text2:#475569;--text3:#94A3B8;
  --r:8px;--r2:12px;--r3:16px;
  --sh:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --sh2:0 4px 16px rgba(0,0,0,.08),0 2px 4px rgba(0,0,0,.04);
  --sh3:0 8px 32px rgba(0,0,0,.10),0 2px 8px rgba(0,0,0,.06);
  --competitor-bg:#FFF0F0;--competitor:#DC2626;--competitor-bd:#FCA5A5;
  --business-bg:#EFF6FF;--business:#2563EB;--business-bd:#93C5FD;
  --lead-bg:#F0FDF4;--lead:#16A34A;--lead-bd:#86EFAC;
  --altro-bg:#FFFBEB;--altro:#D97706;--altro-bd:#FCD34D;
  --nr-bg:#F8FAFC;--nr:#64748B;--nr-bd:#CBD5E1;
}
/* ── Dark theme ───────────────────────────────────────── */
[data-theme="dark"]{
  --bg:#0F172A;--surface:#1E293B;--surface2:#263348;
  --border:#334155;--border2:#475569;
  --text:#F1F5F9;--text2:#94A3B8;--text3:#4E6580;
  --brand:#6B6BFF;--brand-h:#5959F0;--brand-light:rgba(107,107,255,.18);--brand-dim:rgba(107,107,255,.18);
  --sh:0 1px 3px rgba(0,0,0,.35),0 1px 2px rgba(0,0,0,.25);
  --sh2:0 4px 16px rgba(0,0,0,.45),0 2px 4px rgba(0,0,0,.25);
  --sh3:0 8px 32px rgba(0,0,0,.55),0 2px 8px rgba(0,0,0,.35);
  --competitor-bg:rgba(220,38,38,.12);--competitor-bd:rgba(220,38,38,.28);
  --business-bg:rgba(37,99,235,.12);--business-bd:rgba(37,99,235,.28);
  --lead-bg:rgba(22,163,74,.12);--lead-bd:rgba(22,163,74,.28);
  --altro-bg:rgba(217,119,6,.12);--altro-bd:rgba(217,119,6,.28);
  --nr-bg:rgba(100,116,139,.1);--nr-bd:rgba(100,116,139,.22);
}
[data-theme="dark"] .header{background:rgba(15,23,42,.96)}
[data-theme="dark"] .login-page{background:linear-gradient(135deg,#1a2340 0%,#0F172A 60%,#171f38 100%)}
[data-theme="dark"] .score-high{background:rgba(22,163,74,.18);color:#4ADE80}
[data-theme="dark"] .score-mid{background:rgba(202,138,4,.18);color:#FCD34D}
[data-theme="dark"] .score-low{background:rgba(220,38,38,.18);color:#F87171}
[data-theme="dark"] .detail-att{color:#F87171}
[data-theme="dark"] .form-feedback-err{background:rgba(220,38,38,.1);border-color:rgba(220,38,38,.28);color:#F87171}
[data-theme="dark"] .form-feedback-ok{background:rgba(22,163,74,.1);border-color:rgba(22,163,74,.28);color:#4ADE80}
[data-theme="dark"] .role-owner{background:rgba(124,58,237,.18);color:#A78BFA}
[data-theme="dark"] .role-super{background:rgba(37,99,235,.18);color:#93C5FD}
[data-theme="dark"] .tbl-btn-del{border-color:rgba(220,38,38,.3);background:transparent;color:#F87171}
[data-theme="dark"] .tbl-btn-del:hover{background:rgba(220,38,38,.1)}
[data-theme="dark"] .btn-delete-company{border-color:rgba(220,38,38,.3);background:transparent;color:#F87171}
[data-theme="dark"] .btn-delete-company:hover{background:rgba(220,38,38,.1)}
[data-theme="dark"] .btn-del-comment:hover{color:#F87171;background:rgba(220,38,38,.1)}
[data-theme="dark"] .fav-btn-detail.active{background:rgba(245,158,11,.1);border-color:rgba(245,158,11,.32);color:#FCD34D}
[data-theme="dark"] .cat-btn.fav-filter-btn{background:rgba(217,119,6,.12);border-color:rgba(245,158,11,.3);color:#FCD34D}
[data-theme="dark"] .cat-btn.fav-filter-btn:hover,[data-theme="dark"] .cat-btn.fav-filter-btn.active{background:#B45309;border-color:#B45309;color:#fff}
[data-theme="dark"] .users-table tbody tr.tr-editing td{background:rgba(107,107,255,.1)}
[data-theme="dark"] .login-input.err{border-color:#F87171}
[data-theme="dark"] .login-err{color:#F87171}
[data-theme="dark"] .modal-overlay{background:rgba(0,0,0,.65)}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--brand);text-decoration:none}a:hover{text-decoration:underline}
img{max-width:100%}

/* ── Spinner ─────────────────────────────────────────── */
.spin-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh}
.spinner{width:36px;height:36px;border:3px solid var(--brand-light);border-top-color:var(--brand);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Login ────────────────────────────────────────────── */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(135deg,#EEEEFF 0%,#F1F3F9 60%,#EEF5FF 100%)}
.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r3);box-shadow:var(--sh3);padding:40px 36px;width:100%;max-width:400px}
.login-logo{display:flex;justify-content:center;margin-bottom:28px}
.login-logo img{height:32px}
.login-card h1{font-size:20px;font-weight:700;text-align:center;color:var(--text);margin-bottom:4px}
.login-card p{font-size:13px;color:var(--text3);text-align:center;margin-bottom:24px}
.login-label{display:block;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:6px;letter-spacing:.03em;text-transform:uppercase}
.login-input{width:100%;padding:10px 12px;font-size:14px;font-family:inherit;border:1.5px solid var(--border);border-radius:var(--r);background:var(--surface);color:var(--text);outline:none;transition:border-color .15s,box-shadow .15s}
.login-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-dim)}
.login-input.err{border-color:#DC2626}
.login-err{margin-top:8px;font-size:12px;color:#DC2626;display:flex;align-items:center;gap:4px}
.btn-primary{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:11px 16px;background:var(--brand);color:#fff;border:none;border-radius:var(--r);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s,transform .1s;margin-top:20px}
.btn-primary:hover{background:var(--brand-h)}
.btn-primary:active{transform:scale(.98)}
.btn-primary:disabled{opacity:.6;cursor:not-allowed}

/* ── Header ───────────────────────────────────────────── */
.header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.95);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);padding:0 24px;height:56px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.header-left{display:flex;align-items:center;gap:12px}
.header-left img{height:26px;cursor:pointer}
.header-divider{width:1px;height:24px;background:var(--border)}
.header-title{font-size:13px;font-weight:500;color:var(--text2);white-space:nowrap}
.header-right{display:flex;align-items:center;gap:10px}
.btn-ghost{padding:6px 12px;background:transparent;border:1px solid var(--border);border-radius:var(--r);font-size:13px;font-weight:500;font-family:inherit;color:var(--text2);cursor:pointer;transition:all .15s}
.btn-ghost:hover{background:var(--surface2);border-color:var(--border2);color:var(--text)}

/* ── User menu ────────────────────────────────────────── */
.user-menu-wrap{position:relative}
.user-chip{display:flex;align-items:center;gap:7px;padding:6px 10px 6px 7px;background:var(--surface2);border:1px solid var(--border);border-radius:20px;font-size:13px;font-weight:500;color:var(--text2);cursor:pointer;font-family:inherit;transition:all .15s}
.user-chip:hover,.user-chip.open{background:var(--surface);border-color:var(--border2);color:var(--text)}
.user-avatar{width:26px;height:26px;border-radius:50%;background:var(--brand-light);color:var(--brand);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.user-chip-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-chip-arrow{color:var(--text3);transition:transform .2s;flex-shrink:0}
.user-chip-arrow.rotated{transform:rotate(180deg)}
.user-menu-backdrop{position:fixed;inset:0;z-index:110}
.user-menu{position:absolute;top:calc(100% + 8px);right:0;z-index:120;background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);box-shadow:var(--sh3);min-width:200px;overflow:hidden}
.user-menu-profile{padding:14px 16px 12px}
.user-menu-name{font-size:14px;font-weight:600;color:var(--text)}
.user-menu-username{font-size:12px;color:var(--text3);margin-top:2px}
.user-menu-divider{height:1px;background:var(--border);margin:0}
.user-menu-row{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;gap:12px}
.user-menu-row-label{font-size:13px;color:var(--text2)}
.theme-switch{width:38px;height:22px;border-radius:11px;background:var(--border2);border:none;cursor:pointer;position:relative;padding:0;flex-shrink:0;transition:background .2s}
.theme-switch.on{background:var(--brand)}
.theme-switch-knob{position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.theme-switch.on .theme-switch-knob{transform:translateX(16px)}
.user-menu-item{display:flex;align-items:center;gap:9px;width:100%;padding:10px 16px;background:none;border:none;font-size:13px;font-weight:500;font-family:inherit;color:var(--text2);cursor:pointer;text-align:left;transition:background .12s,color .12s}
.user-menu-item:hover{background:var(--surface2);color:var(--text)}
.user-menu-item-danger{color:#DC2626}
.user-menu-item-danger:hover{background:#FEF2F2;color:#DC2626}
[data-theme="dark"] .user-menu-item-danger:hover{background:rgba(220,38,38,.1)}

/* ── App navigation ───────────────────────────────────── */
.app-nav{background:var(--surface);border-bottom:1px solid var(--border)}
.app-nav-inner{max-width:1280px;margin:0 auto;padding:0 16px;display:flex;gap:0}
.nav-tab{padding:12px 18px;background:none;border:none;font-size:14px;font-weight:500;font-family:inherit;color:var(--text2);cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s;margin-bottom:-1px}
.nav-tab:hover{color:var(--text)}
.nav-tab.active{color:var(--brand);border-bottom-color:var(--brand);font-weight:600}

/* ── Main layout ──────────────────────────────────────── */
.main{max-width:1280px;margin:0 auto;padding:24px 16px 48px}

/* ── Toolbar ──────────────────────────────────────────── */
.toolbar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px;align-items:center}
.search-wrap{position:relative;flex:1;min-width:200px;max-width:340px}
.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text3);pointer-events:none}
.search-input{width:100%;padding:9px 10px 9px 34px;font-size:13px;font-family:inherit;border:1.5px solid var(--border);border-radius:var(--r);background:var(--surface);color:var(--text);outline:none;transition:border-color .15s,box-shadow .15s}
.search-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-dim)}
.sort-select{padding:8px 10px;font-size:13px;font-family:inherit;border:1.5px solid var(--border);border-radius:var(--r);background:var(--surface);color:var(--text);outline:none;cursor:pointer}
.sort-select:focus{border-color:var(--brand)}
.sort-dir-btn{padding:8px 10px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);cursor:pointer;color:var(--text2);font-size:14px;transition:all .15s;line-height:1}
.sort-dir-btn:hover{background:var(--surface2);border-color:var(--border2)}
.results-count{margin-left:auto;font-size:12px;color:var(--text3);white-space:nowrap}

/* ── Category filter ──────────────────────────────────── */
.cat-filters{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}
.cat-btn{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;border:1.5px solid transparent;transition:all .15s;white-space:nowrap}
.cat-btn.all-btn{background:var(--surface);border-color:var(--border);color:var(--text2)}
.cat-btn.all-btn:hover,.cat-btn.all-btn.active{background:var(--text);border-color:var(--text);color:#fff}
.cat-btn.competitor-btn{background:var(--competitor-bg);border-color:var(--competitor-bd);color:var(--competitor)}
.cat-btn.competitor-btn.active,.cat-btn.competitor-btn:hover{background:var(--competitor);color:#fff;border-color:var(--competitor)}
.cat-btn.business-btn{background:var(--business-bg);border-color:var(--business-bd);color:var(--business)}
.cat-btn.business-btn.active,.cat-btn.business-btn:hover{background:var(--business);color:#fff;border-color:var(--business)}
.cat-btn.lead-btn{background:var(--lead-bg);border-color:var(--lead-bd);color:var(--lead)}
.cat-btn.lead-btn.active,.cat-btn.lead-btn:hover{background:var(--lead);color:#fff;border-color:var(--lead)}
.cat-btn.altro-btn{background:var(--altro-bg);border-color:var(--altro-bd);color:var(--altro)}
.cat-btn.altro-btn.active,.cat-btn.altro-btn:hover{background:var(--altro);color:#fff;border-color:var(--altro)}
.cat-btn.nr-btn{background:var(--nr-bg);border-color:var(--nr-bd);color:var(--nr)}
.cat-btn.nr-btn.active,.cat-btn.nr-btn:hover{background:var(--nr);color:#fff;border-color:var(--nr)}
.cat-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;border-radius:9px;background:rgba(0,0,0,.1);font-size:10px;font-weight:700;padding:0 4px;margin-left:4px}

/* ── Company grid ─────────────────────────────────────── */
.company-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.company-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);box-shadow:var(--sh);padding:18px;cursor:pointer;transition:box-shadow .15s,border-color .15s,transform .1s;display:flex;flex-direction:column;gap:10px}
.company-card:hover{box-shadow:var(--sh2);border-color:var(--border2);transform:translateY(-1px)}
.card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.card-name{font-size:15px;font-weight:600;color:var(--text);flex:1;line-height:1.3}
.score-badge{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:24px;border-radius:6px;font-size:11px;font-weight:700;padding:0 6px;flex-shrink:0}
.score-high{background:#DCFCE7;color:#16A34A}
.score-mid{background:#FEF9C3;color:#854D0E}
.score-low{background:#FEF2F2;color:#DC2626}
.score-none{background:var(--surface2);color:var(--text3)}
.card-badges{display:flex;align-items:center;flex-wrap:wrap;gap:5px}
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid transparent}
.badge-competitor{background:var(--competitor-bg);color:var(--competitor);border-color:var(--competitor-bd)}
.badge-business{background:var(--business-bg);color:var(--business);border-color:var(--business-bd)}
.badge-lead{background:var(--lead-bg);color:var(--lead);border-color:var(--lead-bd)}
.badge-altro{background:var(--altro-bg);color:var(--altro);border-color:var(--altro-bd)}
.badge-nr{background:var(--nr-bg);color:var(--nr);border-color:var(--nr-bd)}
.comment-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;border-radius:20px;font-size:11px;font-weight:600;background:var(--brand-light);color:var(--brand)}
.card-desc{font-size:13px;color:var(--text2);line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.card-opp{font-size:12px;color:var(--text3);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.empty-state{text-align:center;padding:60px 24px;color:var(--text3)}
.empty-state svg{margin-bottom:16px;opacity:.4}
.empty-state p{font-size:15px;color:var(--text2);font-weight:500;margin-bottom:6px}
.empty-state small{font-size:13px}

/* ── Detail page ──────────────────────────────────────── */
.detail-wrap{max-width:900px;margin:0 auto}
.back-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);font-size:13px;font-weight:500;font-family:inherit;color:var(--text2);cursor:pointer;transition:all .15s;margin-bottom:20px}
.back-btn:hover{background:var(--surface2);color:var(--text)}
.detail-header{background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);box-shadow:var(--sh);padding:24px;margin-bottom:16px}
.detail-name{font-size:24px;font-weight:700;color:var(--text);margin-bottom:10px;line-height:1.2}
.detail-meta{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:14px}
.detail-score-big{display:inline-flex;align-items:center;gap:5px;font-size:14px;font-weight:700;padding:5px 11px;border-radius:var(--r)}
.detail-website{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;background:var(--brand);color:#fff;border-radius:var(--r);font-size:13px;font-weight:500;text-decoration:none;transition:background .15s;margin-left:auto}
.detail-website:hover{background:var(--brand-h);text-decoration:none}
.detail-desc{font-size:14px;color:var(--text2);line-height:1.6}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px}
.detail-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);box-shadow:var(--sh);padding:18px}
.detail-card.full{grid-column:1/-1}
.detail-card-title{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px;display:flex;align-items:center;gap:6px}
.detail-card-title .dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.detail-text{font-size:13px;color:var(--text2);line-height:1.6}
.detail-opp{font-size:13px;color:var(--text2);line-height:1.6}
.detail-att{font-size:13px;color:#DC2626;line-height:1.6}
.detail-rows{display:flex;flex-direction:column;gap:8px}
.detail-row{display:flex;gap:8px}
.detail-row-label{font-size:12px;font-weight:600;color:var(--text3);width:120px;flex-shrink:0;padding-top:1px}
.detail-row-val{font-size:13px;color:var(--text2);flex:1}

/* ── Comments ─────────────────────────────────────────── */
.comments-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);box-shadow:var(--sh);padding:20px}
.comments-title{font-size:15px;font-weight:600;color:var(--text);margin-bottom:16px;display:flex;align-items:center;gap:8px}
.comments-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;border-radius:11px;background:var(--brand-light);color:var(--brand);font-size:11px;font-weight:700;padding:0 6px}
.comment-form{margin-bottom:20px}
.comment-textarea{width:100%;padding:10px 12px;font-size:13px;font-family:inherit;border:1.5px solid var(--border);border-radius:var(--r);resize:vertical;min-height:80px;color:var(--text);outline:none;transition:border-color .15s,box-shadow .15s;background:var(--surface)}
.comment-textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-dim)}
.comment-form-actions{display:flex;justify-content:flex-end;margin-top:8px}
.btn-submit{padding:8px 16px;background:var(--brand);color:#fff;border:none;border-radius:var(--r);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s}
.btn-submit:hover{background:var(--brand-h)}
.btn-submit:disabled{opacity:.6;cursor:not-allowed}
.comment-list{display:flex;flex-direction:column;gap:12px}
.comment-item{border:1px solid var(--border);border-radius:var(--r);padding:14px}
.comment-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.comment-avatar{width:28px;height:28px;border-radius:50%;background:var(--brand-light);color:var(--brand);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.comment-author{font-size:13px;font-weight:600;color:var(--text)}
.comment-date{font-size:11px;color:var(--text3);margin-left:auto}
.comment-body{font-size:13px;color:var(--text2);line-height:1.6;white-space:pre-wrap;word-break:break-word}
.no-comments{text-align:center;padding:24px;color:var(--text3);font-size:13px}

/* ── Favorites ────────────────────────────────────────── */
.cat-btn.fav-filter-btn{background:#FFFBEB;border-color:#FCD34D;color:#D97706}
.cat-btn.fav-filter-btn:hover,.cat-btn.fav-filter-btn.active{background:#F59E0B;border-color:#F59E0B;color:#fff}

.fav-btn{background:none;border:none;cursor:pointer;font-size:17px;color:var(--text3);padding:0 2px;line-height:1;flex-shrink:0;transition:color .15s,transform .12s}
.fav-btn:hover{color:#F59E0B;transform:scale(1.2)}
.fav-btn.active{color:#F59E0B}

.fav-btn-detail{display:inline-flex;align-items:center;gap:5px;padding:5px 11px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);font-size:13px;font-weight:500;font-family:inherit;color:var(--text2);cursor:pointer;transition:all .15s}
.fav-btn-detail:hover{border-color:#FCD34D;color:#D97706}
.fav-btn-detail.active{background:#FFFBEB;border-color:#FCD34D;color:#D97706}

/* ── Settings ─────────────────────────────────────────── */
.btn-icon{padding:6px 9px}
.settings-layout{display:grid;grid-template-columns:220px 1fr;gap:24px;max-width:960px;margin:0 auto}
.settings-sidebar{background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);box-shadow:var(--sh);padding:16px;height:fit-content;position:sticky;top:72px}
.settings-sidebar-header{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;padding:0 8px 12px;border-bottom:1px solid var(--border);margin-bottom:8px}
.settings-nav{display:flex;flex-direction:column;gap:2px;margin-bottom:12px}
.settings-nav-item{display:block;width:100%;text-align:left;padding:8px 10px;border:none;background:none;font-size:13px;font-weight:500;font-family:inherit;color:var(--text2);border-radius:var(--r);cursor:pointer;transition:all .15s}
.settings-nav-item:hover{background:var(--surface2);color:var(--text)}
.settings-nav-item.active{background:var(--brand-light);color:var(--brand);font-weight:600}
.settings-back-btn{display:block;width:100%;text-align:left;padding:8px 10px;border:1px solid var(--border);background:transparent;font-size:13px;font-weight:500;font-family:inherit;color:var(--text2);border-radius:var(--r);cursor:pointer;transition:all .15s;margin-top:4px}
.settings-back-btn:hover{background:var(--surface2);color:var(--text)}
.settings-title{font-size:20px;font-weight:700;color:var(--text);margin-bottom:4px}
.settings-desc{font-size:13px;color:var(--text3);margin-bottom:20px}
.settings-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);box-shadow:var(--sh);padding:22px}
.settings-card-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:16px}
.form-group{margin-bottom:16px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-label{display:block;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:6px;letter-spacing:.03em;text-transform:uppercase}
.form-input{width:100%;padding:9px 12px;font-size:14px;font-family:inherit;border:1.5px solid var(--border);border-radius:var(--r);background:var(--surface);color:var(--text);outline:none;transition:border-color .15s,box-shadow .15s}
.form-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-dim)}
.form-label-check{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--text2);cursor:pointer;user-select:none}
.form-label-check input[type=checkbox]{width:15px;height:15px;accent-color:var(--brand);cursor:pointer}
.form-hint{font-size:12px;color:var(--text3);margin-top:5px}
.form-feedback{margin-top:14px;padding:10px 12px;border-radius:var(--r);font-size:13px}
.form-feedback-err{background:#FEF2F2;color:#DC2626;border:1px solid #FCA5A5}
.form-feedback-ok{background:#F0FDF4;color:#16A34A;border:1px solid #86EFAC}
.form-actions{display:flex;gap:8px;margin-top:20px;align-items:center}
.btn-save{padding:9px 18px;background:var(--brand);color:#fff;border:none;border-radius:var(--r);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s}
.btn-save:hover{background:var(--brand-h)}
.btn-save:disabled{opacity:.6;cursor:not-allowed}
.btn-cancel{padding:9px 14px;background:transparent;border:1px solid var(--border);border-radius:var(--r);font-size:13px;font-weight:500;font-family:inherit;color:var(--text2);cursor:pointer;transition:all .15s}
.btn-cancel:hover{background:var(--surface2)}
.users-table{width:100%;border-collapse:collapse}
.users-table th{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.04em;padding:10px 14px;text-align:left;border-bottom:1px solid var(--border);background:var(--surface2)}
.users-table td{padding:11px 14px;font-size:13px;color:var(--text2);border-bottom:1px solid var(--border)}
.users-table tbody tr:last-child td{border-bottom:none}
.users-table tbody tr:hover td{background:var(--surface2)}
.users-table tbody tr.tr-editing td{background:var(--brand-light)}
.td-id{color:var(--text3);font-weight:600;width:36px}
.td-actions{text-align:right;white-space:nowrap;width:160px}
.role-badge{display:inline-flex;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600}
.role-owner{background:#EDE9FE;color:#7C3AED}
.role-super{background:#EFF6FF;color:#2563EB}
.role-user{background:var(--surface2);color:var(--text3)}
.tbl-btn-edit{padding:4px 10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);font-size:12px;font-weight:500;font-family:inherit;color:var(--text2);cursor:pointer;transition:all .15s;margin-right:4px}
.tbl-btn-edit:hover{border-color:var(--brand);color:var(--brand)}
.tbl-btn-del{padding:4px 10px;background:var(--surface);border:1px solid #FCA5A5;border-radius:var(--r);font-size:12px;font-weight:500;font-family:inherit;color:#DC2626;cursor:pointer;transition:all .15s}
.tbl-btn-del:hover{background:#FEF2F2}

/* ── Leads page ───────────────────────────────────────── */
.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px}
.page-title{font-size:22px;font-weight:700;color:var(--text);line-height:1.2}
.page-subtitle{font-size:13px;color:var(--text3);margin-top:3px}
.btn-new-lead{padding:9px 18px;background:var(--brand);color:#fff;border:none;border-radius:var(--r);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s;white-space:nowrap;flex-shrink:0}
.btn-new-lead:hover{background:var(--brand-h)}
.leads-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--r2);box-shadow:var(--sh)}
.leads-table{width:100%;border-collapse:collapse;background:var(--surface);min-width:780px}
.leads-table th{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.04em;padding:11px 14px;text-align:left;border-bottom:1px solid var(--border);background:var(--surface2);white-space:nowrap}
.leads-table td{padding:12px 14px;font-size:13px;color:var(--text2);border-bottom:1px solid var(--border);vertical-align:top}
.leads-table tbody tr:last-child td{border-bottom:none}
.leads-table tbody tr:hover td{background:var(--surface2)}
.lead-company-name{font-weight:600;color:var(--text);margin-bottom:2px}
.lead-website{font-size:11px;color:var(--text3);display:block}
.lead-td-email .lead-email{display:block;color:var(--brand)}
.lead-phone{display:block;font-size:12px;color:var(--text3);margin-top:2px}
.lead-td-creator{white-space:nowrap;font-size:12px}
.lead-td-date{white-space:nowrap;font-size:12px}
.lead-updated{display:block;color:var(--text3);font-size:11px;margin-top:2px}
.lead-empty{color:var(--text3)}
.lead-td-actions{white-space:nowrap;text-align:right}

/* ── Detail admin bar ─────────────────────────────────── */
.detail-admin-bar{display:flex;gap:8px;margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}
.btn-edit-company{padding:7px 16px;background:var(--brand);color:#fff;border:none;border-radius:var(--r);font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;transition:background .15s}
.btn-edit-company:hover{background:var(--brand-h)}
.btn-delete-company{padding:7px 16px;background:var(--surface);color:#DC2626;border:1px solid #FCA5A5;border-radius:var(--r);font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .15s}
.btn-delete-company:hover{background:#FEF2F2}

/* ── Delete comment button ─────────────────────────────── */
.btn-del-comment{margin-left:auto;background:none;border:none;color:var(--text3);font-size:16px;line-height:1;cursor:pointer;padding:2px 6px;border-radius:4px;transition:all .15s;flex-shrink:0}
.btn-del-comment:hover{color:#DC2626;background:#FEF2F2}

/* ── Modal ─────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;display:flex;align-items:center;justify-content:center;padding:16px}
.modal-box{background:var(--surface);border-radius:var(--r3);box-shadow:var(--sh3);width:100%;max-width:680px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border);flex-shrink:0}
.modal-title{font-size:16px;font-weight:600;color:var(--text)}
.modal-close{background:none;border:none;font-size:22px;line-height:1;color:var(--text3);cursor:pointer;padding:0 4px;border-radius:4px;transition:color .15s}
.modal-close:hover{color:var(--text)}
.modal-body{padding:20px 24px;overflow-y:auto;display:flex;flex-direction:column;gap:0}
.form-textarea{resize:vertical;min-height:64px}

/* ── Responsive ────────────────────────────────────────── */
@media(max-width:720px){
  .header{padding:0 14px;height:52px}
  .header-title{display:none}
  .user-chip-name{display:none}
  .app-nav-inner{padding:0 8px}
  .nav-tab{padding:10px 14px;font-size:13px}
  .main{padding:16px 12px 40px}
  .detail-grid{grid-template-columns:1fr}
  .detail-card.full{grid-column:1}
  .detail-name{font-size:20px}
  .detail-website{margin-left:0}
  .detail-meta{flex-wrap:wrap}
  .toolbar{gap:8px}
  .search-wrap{max-width:100%;width:100%}
  .results-count{display:none}
}
@media(max-width:480px){
  .login-card{padding:28px 20px}
  .company-grid{grid-template-columns:1fr}
  .settings-layout{grid-template-columns:1fr}
  .settings-sidebar{position:static}
  .form-row{grid-template-columns:1fr}
  .td-actions{width:auto}
}
