﻿/* ===== RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f0f2f5;--bg2:#e4e6eb;--card:#ffffff;--card-hover:#f8f9fc;
  --border:#d1d5db;--border-light:#e5e7eb;
  --text:#1a1a2e;--text2:#4b5563;--text3:#9ca3af;
  --accent:#EF6B5B;--accent-hover:#D94F3F;--accent-glow:rgba(239,107,91,.12);
  --success:#16a34a;--warning:#d97706;--danger:#dc2626;--info:#2563eb;
  --radius:12px;--radius-sm:8px;--radius-lg:16px;
  --sidebar-w:260px;
  --shadow:0 4px 24px rgba(0,0,0,.08);--shadow-sm:0 2px 8px rgba(0,0,0,.05);
  --transition:all .2s cubic-bezier(.4,0,.2,1);
}
html{font-size:14px}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;overflow:hidden;height:100vh}
a{color:var(--accent);text-decoration:none}
.hidden{display:none!important}

/* ===== LOGIN SCREEN ===== */
.login-screen{
  display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;
  background:linear-gradient(135deg,#f0f2f5 0%,#e8edf5 50%,#f5f7fa 100%);
  padding:20px;position:relative;overflow:hidden;
}
.login-screen::before{content:'';position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(239,107,91,.06) 0%,transparent 70%);top:-100px;right:-100px;border-radius:50%;pointer-events:none}
.login-screen::after{content:'';position:absolute;width:400px;height:400px;background:radial-gradient(circle,rgba(59,130,246,.05) 0%,transparent 70%);bottom:-80px;left:-80px;border-radius:50%;pointer-events:none}
.login-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:40px;width:100%;max-width:440px;
  box-shadow:var(--shadow),0 0 60px rgba(239,107,91,.04);
  text-align:center;position:relative;z-index:1;
}
.login-logo{margin-bottom:24px;display:flex;flex-direction:column;align-items:center;gap:12px}
.login-app-icon{width:72px;height:72px;border-radius:18px;box-shadow:0 8px 24px rgba(0,0,0,0.15)}
.login-banner{width:100%;max-width:360px;border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.brand-cursive{
  font-family:'Snell Roundhand','Lucida Handwriting','Brush Script MT',cursive;
  font-weight:400;color:#D86646;letter-spacing:.5px;line-height:1;
}
.login-brand-cursive{font-size:2.6rem;display:block;margin-bottom:8px}
.sidebar-brand-cursive{font-size:1.6rem;color:#D86646}
.login-title{font-size:1.6rem;font-weight:800;color:var(--text);letter-spacing:-.02em;margin-bottom:4px}
.login-sub{color:var(--text3);font-size:.85rem;margin-bottom:28px;font-weight:500}
.login-form{display:flex;flex-direction:column;gap:12px;margin-bottom:28px}
.login-field{position:relative;display:flex;align-items:center}
.login-field-icon{position:absolute;left:14px;font-size:1rem;opacity:.5}
.login-field input{
  width:100%;padding:13px 14px 13px 42px;border-radius:var(--radius);border:1px solid var(--border);
  background:var(--bg2);color:var(--text);font-size:.92rem;font-family:inherit;
  transition:var(--transition);outline:none;
}
.login-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.login-field input::placeholder{color:var(--text3)}
.login-features{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.login-feat{
  display:flex;align-items:center;gap:6px;padding:8px 10px;border-radius:var(--radius-sm);
  background:var(--bg2);border:1px solid var(--border);font-size:.75rem;color:var(--text2);font-weight:500;
  transition:var(--transition);
}
.login-feat:hover{border-color:rgba(239,107,91,.2);transform:translateY(-1px)}
.login-feat span:first-child{font-size:.9rem}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:10px 20px;border:none;border-radius:var(--radius);cursor:pointer;
  font-family:inherit;font-size:.85rem;font-weight:600;transition:var(--transition);
  position:relative;overflow:hidden;
}
.btn::after{content:'';position:absolute;inset:0;opacity:0;background:linear-gradient(180deg,rgba(255,255,255,.08) 0%,transparent 100%);transition:opacity .2s}.btn:hover::after{opacity:1}
.btn-primary{background:linear-gradient(135deg,#EF6B5B 0%,#D94F3F 100%);color:#fff;box-shadow:0 4px 12px var(--accent-glow)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(239,107,91,.3)}
.btn-secondary{background:var(--bg2);color:var(--text2);border:1px solid var(--border)}
.btn-secondary:hover{background:var(--card-hover);color:var(--text);border-color:var(--border-light)}
.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 12px rgba(239,68,68,.2)}
.btn-danger:hover{transform:translateY(-1px)}
.btn-warning{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;box-shadow:0 4px 12px rgba(245,158,11,.2)}
.btn-warning:hover{transform:translateY(-1px)}
.btn-success{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;box-shadow:0 4px 12px rgba(34,197,94,.2)}
.btn-success:hover{transform:translateY(-1px)}
.btn-sm{padding:6px 14px;font-size:.78rem;border-radius:var(--radius-sm)}
.btn-xs{padding:4px 10px;font-size:.72rem;border-radius:6px}
.btn-block{width:100%;padding:13px;font-size:.95rem;font-weight:700;border-radius:var(--radius)}
.btn-group{display:flex;gap:8px;flex-wrap:wrap}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}

/* ===== LAYOUT ===== */
.main-layout{display:flex;height:100vh;overflow:hidden}

/* ===== SIDEBAR ===== */
.sidebar{
  width:var(--sidebar-w);min-width:var(--sidebar-w);height:100vh;height:100dvh;
  background:var(--card);border-right:1px solid var(--border);
  display:flex;flex-direction:column;overflow:hidden;
  transition:transform .3s ease;z-index:100;flex-shrink:0;
}
.sidebar-brand{
  display:flex;align-items:center;padding:18px 20px;border-bottom:1px solid var(--border);
  gap:10px;flex-shrink:0;
}
.sidebar-logo{width:34px;height:34px;border-radius:8px;object-fit:cover}
.sidebar-brand-text{display:flex;flex-direction:column;line-height:1.2}
.sidebar-brand-text strong{font-size:.92rem;color:var(--accent);font-weight:800}
.sidebar-brand-text small{font-size:.7rem;color:var(--text3);font-weight:500}
.sidebar-nav{flex:1;overflow-y:auto;padding:8px 10px 16px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.sidebar-nav::-webkit-scrollbar{width:4px}
.sidebar-nav::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.nav-section{
  font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  color:var(--text3);padding:16px 10px 6px;
}
.nav-link{
  display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-sm);
  color:var(--text2);font-size:.84rem;font-weight:500;cursor:pointer;
  transition:var(--transition);margin-bottom:1px;position:relative;text-decoration:none;
}
.nav-link:hover{background:var(--bg2);color:var(--text)}
.nav-link.active{background:var(--accent-glow);color:var(--accent);font-weight:600}
.nav-link.active::before{
  content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:3px;height:20px;background:var(--accent);border-radius:0 3px 3px 0;
}
.nl-i{font-size:1.05rem;width:22px;text-align:center;flex-shrink:0}
.nl-t{flex:1}
.sidebar-footer{
  padding:14px 16px;border-top:1px solid var(--border);flex-shrink:0;
  display:flex;align-items:center;justify-content:space-between;gap:8px;
}
.sidebar-user{display:flex;align-items:center;gap:8px;min-width:0;flex:1}
.sidebar-avatar{
  width:28px;height:28px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--accent),#f59e0b);
  display:flex;align-items:center;justify-content:center;
  font-size:.7rem;font-weight:700;color:#fff;
}
#userLabel{font-size:.78rem;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.btn-logout{background:transparent;border:1px solid var(--border);color:var(--text3);padding:5px 12px}
.btn-logout:hover{border-color:var(--danger);color:var(--danger);background:rgba(239,68,68,.08)}

/* ===== TOP BAR ===== */
.top-bar{
  display:flex;align-items:center;padding:14px 28px;border-bottom:1px solid var(--border);
  background:var(--card);flex-shrink:0;gap:16px;
}
.sidebar-toggle{
  display:none;background:none;border:1px solid var(--border);color:var(--text2);
  font-size:1.2rem;padding:6px 10px;border-radius:var(--radius-sm);cursor:pointer;
  transition:var(--transition);
}
.sidebar-toggle:hover{background:var(--bg2);color:var(--text)}
.top-bar-title{font-size:1.1rem;font-weight:700;color:var(--text);flex:1}
.top-bar-actions{display:flex;align-items:center;gap:8px;margin-left:auto}
.online-dot{width:8px;height:8px;border-radius:50%;background:var(--success);box-shadow:0 0 6px var(--success);animation:pulse-dot 2s infinite}
.top-bar-status{font-size:.75rem;color:var(--text3);font-weight:500}
@keyframes pulse-dot{0%,100%{opacity:1}50%{opacity:.5}}

/* ===== CONTENT ===== */
.content-area{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}
.content-scroll{flex:1;overflow-y:auto;padding:28px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.content-scroll::-webkit-scrollbar{width:6px}
.content-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:6px}

/* ===== CARDS ===== */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:22px;margin-bottom:20px;transition:border-color .2s}
.card:hover{border-color:var(--border-light)}
.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:8px}
.card-header h2{font-size:1.3rem;font-weight:700;color:var(--text);letter-spacing:-.01em}
.card-header h3{font-size:1rem;color:var(--text2);font-weight:600}

/* ===== STAT GRID ===== */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:24px}
.stat-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:18px 20px;cursor:pointer;transition:var(--transition);position:relative;overflow:hidden;text-align:center;
}
.stat-card:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 8px 24px rgba(0,0,0,.08)}
.stat-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--accent),transparent);opacity:0;transition:opacity .2s;
}
.stat-card:hover::before{opacity:1}
.stat-card .val{font-size:1.7rem;font-weight:800;color:var(--accent);letter-spacing:-.5px}
.stat-card .label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);margin-top:4px}
.stat-card.danger .val{color:var(--danger)}.stat-card.danger::before{background:linear-gradient(90deg,var(--danger),transparent)}
.stat-card.warning .val{color:var(--warning)}.stat-card.warning::before{background:linear-gradient(90deg,var(--warning),transparent)}
.stat-card.success .val{color:var(--success)}.stat-card.success::before{background:linear-gradient(90deg,var(--success),transparent)}
.stat-card.info .val{color:var(--info)}.stat-card.info::before{background:linear-gradient(90deg,var(--info),transparent)}
.stat-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);margin-bottom:6px}
.stat-value{font-size:1.6rem;font-weight:800;color:var(--text);line-height:1.2;margin-bottom:2px}
.stat-sub{font-size:.72rem;color:var(--text3)}

/* ===== TABLES ===== */
.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border);margin-bottom:16px}
table{width:100%;border-collapse:collapse}
thead{background:var(--bg2)}
th{padding:11px 16px;text-align:left;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);border-bottom:1px solid var(--border);white-space:nowrap}
td{padding:12px 16px;border-bottom:1px solid var(--border);font-size:.85rem;color:var(--text);vertical-align:top}
tr:last-child td{border-bottom:none}
tr{transition:background .15s}
tr:hover td{background:rgba(239,107,91,.04)}
.truncate{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ===== BADGES ===== */
.badge{
  display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;
  font-size:.7rem;font-weight:600;letter-spacing:.02em;
}
.badge-danger{background:rgba(239,68,68,.1);color:#dc2626;border:1px solid rgba(239,68,68,.2)}
.badge-warning{background:rgba(245,158,11,.1);color:#d97706;border:1px solid rgba(245,158,11,.2)}
.badge-success{background:rgba(34,197,94,.1);color:#16a34a;border:1px solid rgba(34,197,94,.2)}
.badge-info{background:rgba(59,130,246,.1);color:#2563eb;border:1px solid rgba(59,130,246,.2)}
.badge-critical{background:rgba(239,68,68,.15);color:#dc2626;border:1px solid rgba(239,68,68,.25);animation:pulse 1.5s infinite}
.badge-clean{background:rgba(34,197,94,.1);color:#16a34a;border:1px solid rgba(34,197,94,.2)}
.badge-medium{background:rgba(245,158,11,.1);color:#d97706;border:1px solid rgba(245,158,11,.2)}
.badge-high{background:rgba(239,68,68,.1);color:#dc2626;border:1px solid rgba(239,68,68,.2)}
.badge-low{background:rgba(34,197,94,.1);color:#16a34a;border:1px solid rgba(34,197,94,.2)}
.badge-secondary{background:rgba(107,114,128,.08);color:var(--text2);border:1px solid rgba(107,114,128,.15)}
.badge-purple{background:rgba(168,85,247,.1);color:#7c3aed;border:1px solid rgba(168,85,247,.2)}
.badge-coral{background:rgba(239,107,91,.1);color:var(--accent);border:1px solid rgba(239,107,91,.2)}
.notif-badge{display:inline-block;min-width:18px;height:18px;line-height:18px;text-align:center;border-radius:9px;font-size:10px;font-weight:700;background:linear-gradient(135deg,#EF6B5B,#D94F3F);color:#fff;padding:0 5px;box-shadow:0 2px 8px rgba(239,107,91,.3)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.6}}

/* ===== FORMS ===== */
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:.78rem;font-weight:600;color:var(--text2);margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}
input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],input[type=url],input[type=datetime-local],select,textarea{
  width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);
  background:var(--bg2);color:var(--text);font-family:inherit;font-size:.88rem;
  transition:var(--transition);outline:none;
}
input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
input::placeholder,textarea::placeholder{color:var(--text3)}
textarea{resize:vertical;min-height:80px}
select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%235a6180'%3e%3cpath d='M7 10l5 5 5-5z'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 10px center;background-size:20px;padding-right:36px}
.form-row{display:flex;gap:12px;margin-bottom:12px;flex-wrap:wrap}.form-row>*{flex:1;min-width:200px}
.form-inline{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap}
.form-inline .form-group{flex:1;min-width:140px}

/* ===== TABS ===== */
.tabs,.tab-bar{display:flex;gap:4px;margin-bottom:20px;background:var(--bg2);padding:4px;border-radius:var(--radius);border:1px solid var(--border)}
.tab,.tab-btn{padding:8px 18px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text2);font-size:.82rem;font-weight:600;cursor:pointer;transition:var(--transition);font-family:inherit;border-bottom:2px solid transparent}
.tab:hover,.tab-btn:hover{color:var(--text);background:var(--card)}
.tab.active,.tab-btn.active{background:var(--accent);color:#fff;box-shadow:0 2px 8px var(--accent-glow);border-bottom-color:transparent}

/* ===== ALERTS ===== */
.alert-cards{display:grid;gap:12px}
.alert-card{
  display:flex;align-items:flex-start;gap:14px;padding:14px 18px;border-radius:var(--radius);
  border:1px solid var(--border);border-left:4px solid var(--border);background:var(--card);transition:var(--transition);
}
.alert-card:hover{border-color:var(--border-light)}
.alert-card.critical{border-left-color:var(--danger);background:rgba(239,68,68,.04)}
.alert-card.high{border-left-color:var(--warning);background:rgba(245,158,11,.04)}
.alert-card.medium{border-left-color:var(--info);background:rgba(59,130,246,.04)}
.alert-card.low{border-left-color:var(--success);background:rgba(34,197,94,.04)}
.alert-card.info{border-left-color:var(--info);background:rgba(59,130,246,.04)}
.alert-card .alert-icon{font-size:20px;flex-shrink:0}
.alert-card .alert-body{flex:1}
.alert-card .alert-title{font-weight:600;font-size:14px;color:var(--text)}
.alert-card .alert-detail{font-size:12px;color:var(--text2);margin-top:2px}
.alert-card .alert-time{font-size:11px;color:var(--text3);margin-top:4px}
.alert-card.read{opacity:.45}
.alert-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.alert-dot.critical{background:var(--danger);box-shadow:0 0 8px rgba(239,68,68,.4)}
.alert-dot.high{background:var(--warning);box-shadow:0 0 8px rgba(245,158,11,.4)}
.alert-dot.medium{background:var(--info)}
.alert-dot.low{background:var(--text3)}

/* ===== SECURITY ===== */
.threat-meter{display:flex;gap:4px;align-items:center;margin-bottom:20px}
.threat-bar{height:10px;border-radius:5px;flex:1;transition:all .3s}
.threat-bar.green{background:linear-gradient(90deg,#22c55e,#4ade80)}
.threat-bar.yellow{background:linear-gradient(90deg,#f59e0b,#fbbf24)}
.threat-bar.orange{background:linear-gradient(90deg,#f97316,#fb923c)}
.threat-bar.red{background:linear-gradient(90deg,#ef4444,#f87171)}
.threat-fill{height:100%;border-radius:4px;transition:width .5s ease}
.event-log{max-height:350px;overflow-y:auto}

/* ===== AI SCANNER ===== */
.scan-result{padding:16px;background:var(--bg2);border-radius:var(--radius);border:1px solid var(--border);margin-top:12px;transition:border-color .2s}
.scan-result:hover{border-color:var(--border-light)}
.score{font-size:1.4rem;font-weight:800}
.score.clean,.score.safe{color:var(--success)}.score.medium,.score.low{color:var(--warning)}.score.high,.score.critical{color:var(--danger)}
.threat-list{list-style:none;padding:0}.threat-list li{padding:6px 0;font-size:.82rem;color:var(--text2);border-bottom:1px solid var(--border)}
.threat-list li:last-child{border:none}
.threat-list li::before{content:"\26A0\FE0F ";font-size:11px}

/* ===== HERO CARDS ===== */
.hero-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.hero-card{display:flex;gap:16px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px;align-items:center;cursor:pointer;transition:var(--transition)}
.hero-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:rgba(239,107,91,.3)}
.hero-card img,.hero-avatar{width:56px;height:56px;border-radius:50%;object-fit:cover;background:linear-gradient(135deg,var(--accent),#f59e0b);display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:800;color:#fff;flex-shrink:0;border:2px solid rgba(239,107,91,.2)}
.hero-card .hero-info{flex:1}
.hero-card .hero-name{font-weight:700;font-size:15px;color:var(--text)}
.hero-card .hero-title{font-size:12px;color:var(--accent);margin-top:2px;font-weight:600}
.hero-card .hero-desc{font-size:12px;color:var(--text2);margin-top:4px;line-height:1.4}

/* ===== ADS & PROMOS ===== */
.ad-grid,.promo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.ad-card,.promo-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px;transition:var(--transition);cursor:pointer}
.ad-card:hover,.promo-card:hover{border-color:rgba(239,107,91,.3);transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.08)}
.ad-card .ad-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.ad-card .ad-title{font-weight:700;font-size:14px}
.ad-card .ad-stats{display:flex;gap:16px;font-size:12px;color:var(--text2);margin-top:8px}
.ad-card .ad-stats span{color:var(--accent);font-weight:700}
.promo-card .promo-title{font-weight:700;font-size:15px;color:var(--text)}
.promo-card .promo-desc{font-size:12px;color:var(--text2);margin-top:4px;line-height:1.4}
.promo-card .promo-meta{display:flex;gap:12px;margin-top:10px;font-size:12px;color:var(--text3)}
.price-tag{font-size:1.1rem;font-weight:800;color:var(--accent)}

/* ===== NOTES ===== */
.note-card{background:var(--card);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:0 var(--radius) var(--radius) 0;padding:14px 18px;margin-bottom:10px;transition:border-left-color .2s}
.note-card.high{border-left-color:var(--warning)}
.note-card .note-author{font-size:12px;color:var(--accent);font-weight:700}
.note-card .note-body{font-size:13px;color:var(--text);margin-top:4px;line-height:1.5}
.note-card .note-time{font-size:11px;color:var(--text3);margin-top:4px}

/* ===== BACKUP ===== */
.backup-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-radius:var(--radius-sm);background:var(--bg2);border:1px solid var(--border);margin-bottom:8px;transition:border-color .2s}
.backup-item:hover{border-color:var(--border-light)}
.bk-name{font-weight:600;color:var(--text);font-size:.88rem}
.bk-meta{font-size:.75rem;color:var(--text3);margin-top:2px}

/* ===== PERMISSIONS ===== */
.perm-grid{display:grid;gap:8px;overflow-x:auto}
.perm-grid table th,.perm-grid table td{text-align:center;padding:8px 12px}
.perm-grid .check{color:#16a34a;font-size:16px;text-shadow:none}
.perm-grid .cross{color:#dc2626;font-size:16px}
.perm-row{display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:var(--radius-sm);background:var(--bg2);border:1px solid var(--border)}
.perm-row label{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:4px;font-size:.75rem;cursor:pointer}

/* ===== NOTIFICATION ===== */
.notif-compose{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:22px;margin-bottom:16px}
.notif-compose h4{color:var(--accent);margin-bottom:12px;font-size:15px;font-weight:700}
.notif-preview{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-top:12px}
.notif-prev-title{font-weight:700;font-size:.9rem;color:var(--text);margin-bottom:4px}
.notif-prev-body{font-size:.82rem;color:var(--text2)}
.notif-history-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}
.notif-history-item:last-child{border-bottom:none}
.notif-history-item .nh-icon{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;background:var(--accent-glow)}
.notif-history-item .nh-content{flex:1}
.notif-history-item .nh-title{font-size:13px;font-weight:600;color:var(--text)}
.notif-history-item .nh-detail{font-size:12px;color:var(--text2);margin-top:2px}
.notif-history-item .nh-time{font-size:11px;color:var(--text3)}

/* ===== POLICY ===== */
.policy-section{margin-bottom:20px}
.policy-section h4{font-size:14px;color:var(--accent);margin-bottom:8px;font-weight:700}
.policy-section textarea{min-height:100px}

/* ===== DETAIL VIEW ===== */
.detail-back{display:inline-flex;align-items:center;gap:6px;color:var(--accent);cursor:pointer;font-size:13px;margin-bottom:16px;transition:var(--transition);font-weight:600}
.detail-back:hover{opacity:.8;transform:translateX(-2px)}
.detail-field{display:flex;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px}
.detail-field .df-label{color:var(--text3);width:130px;flex-shrink:0;font-weight:500}
.detail-field .df-value{color:var(--text);flex:1}

/* ===== SEARCH / TOOLBAR ===== */
.toolbar{display:flex;gap:10px;margin-bottom:16px;align-items:center;flex-wrap:wrap}
.toolbar input,.toolbar select{max-width:240px}
.search-input{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 14px;color:var(--text);font-size:13px;min-width:200px;transition:var(--transition);font-family:inherit;outline:none}
.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}

/* ===== TOAST ===== */
.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{
  pointer-events:auto;padding:14px 20px;border-radius:var(--radius);font-size:.84rem;font-weight:500;
  animation:toast-in .3s ease;min-width:280px;max-width:400px;line-height:1.4;
  box-shadow:var(--shadow);border:1px solid var(--border);display:flex;align-items:center;gap:10px;
  backdrop-filter:blur(12px);letter-spacing:.2px;
}
.toast.success,.toast-success{background:linear-gradient(135deg,rgba(34,197,94,.9),rgba(22,163,74,.9));color:#fff;border-color:rgba(34,197,94,.3)}
.toast.error,.toast-error{background:linear-gradient(135deg,rgba(239,68,68,.9),rgba(220,38,38,.9));color:#fff;border-color:rgba(239,68,68,.3)}
.toast.warn,.toast-warn{background:linear-gradient(135deg,rgba(245,158,11,.9),rgba(217,119,6,.9));color:#fff;border-color:rgba(245,158,11,.3)}
.toast.info,.toast-info{background:linear-gradient(135deg,rgba(59,130,246,.9),rgba(37,99,235,.9));color:#fff;border-color:rgba(59,130,246,.3)}
.toast .toast-close{cursor:pointer;opacity:.7;font-size:16px;margin-left:auto}.toast .toast-close:hover{opacity:1}
.toast.removing{animation:slideOut .3s ease forwards}
@keyframes toast-in{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes slideOut{from{transform:translateX(0);opacity:1}to{transform:translateX(100%);opacity:0}}

/* ===== MODALS ===== */
.modal-overlay,.edit-modal{
  position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;z-index:10000;
  animation:fadeIn .2s ease;
}
.modal-box{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:28px;width:440px;max-width:90%;
  box-shadow:0 24px 48px rgba(0,0,0,.12);animation:scaleIn .2s ease;
}
.modal-box h3{font-size:18px;color:var(--text);margin-bottom:10px;font-weight:700}
.modal-box p{font-size:13px;color:var(--text2);margin-bottom:20px;line-height:1.6}
.modal-actions{display:flex;gap:10px;justify-content:flex-end}
.edit-modal-content{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:28px;width:560px;max-width:92%;max-height:85vh;overflow-y:auto;
  box-shadow:0 24px 48px rgba(0,0,0,.12);animation:scaleIn .2s ease;
}
.edit-modal-content h3{font-size:18px;color:var(--text);margin-bottom:16px;display:flex;align-items:center;justify-content:space-between;font-weight:700}
.edit-modal-content h3 .close-btn{cursor:pointer;font-size:20px;color:var(--text2);background:none;border:none;transition:color .15s}.edit-modal-content h3 .close-btn:hover{color:var(--text)}
.confirm-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;z-index:11000;
}
.confirm-box{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:28px;width:90%;max-width:420px;text-align:center;
  animation:scaleIn .25s ease;box-shadow:0 24px 48px rgba(0,0,0,.12);
}
.confirm-box h3{font-size:1.1rem;margin-bottom:10px;color:var(--text)}
.confirm-box p{font-size:.88rem;color:var(--text2);margin-bottom:20px;line-height:1.5}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scaleIn{from{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}

/* ===== UTILITY ===== */
.text-muted{color:var(--text3);font-size:12px}
.text-center{text-align:center}
.text-coral{color:var(--accent)}
.text-danger{color:var(--danger)}
.text-success{color:var(--success)}
.text-warning{color:var(--warning)}
.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}
.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}
.flex-between{display:flex;justify-content:space-between;align-items:center}
.gap-8{gap:8px}.gap-12{gap:12px}
.inline-flex{display:inline-flex;align-items:center;gap:6px}
.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}
.error{color:var(--danger);font-size:.82rem;margin-top:6px}
hr{border:none;border-top:1px solid var(--border);margin:16px 0}

/* ===== CHALLENGES ===== */
.challenge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:16px}
.challenge-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:10px}
.challenge-card .challenge-header{display:flex;align-items:center;gap:10px}
.challenge-card .challenge-emoji{font-size:28px;line-height:1}
.challenge-card .challenge-title{font-weight:700;font-size:.95rem;color:var(--text)}
.challenge-card .challenge-meta{display:flex;gap:8px;flex-wrap:wrap}
.challenge-card .challenge-category{font-size:.74rem;background:var(--primary-light,#fce8e6);color:var(--primary);padding:2px 8px;border-radius:20px;font-weight:600}
.challenge-card .challenge-status{font-size:.74rem;padding:2px 8px;border-radius:20px;font-weight:600}
.challenge-card .challenge-status.active{background:#e8f5e9;color:#2e7d32}
.challenge-card .challenge-status.expired{background:#fce4ec;color:#c62828}
.challenge-card .challenge-status.closed{background:#f5f5f5;color:#616161}
.challenge-chain{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--text-secondary)}
.challenge-actions{display:flex;gap:8px;margin-top:4px}

/* ===== KARMA EVENTS ===== */
.karma-table{width:100%;border-collapse:collapse}
.karma-table th,.karma-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border);font-size:.84rem}
.karma-table th{font-weight:600;color:var(--text-secondary);background:var(--bg)}
.karma-badge{display:inline-flex;align-items:center;gap:4px;font-size:.78rem;font-weight:600;padding:2px 8px;border-radius:20px}
.karma-badge.positive{background:#e8f5e9;color:#2e7d32}
.karma-badge.negative{background:#fce4ec;color:#c62828}
.karma-event-type{font-size:.78rem;background:var(--surface);border:1px solid var(--border);padding:2px 7px;border-radius:10px;color:var(--text-secondary)}

/* ===== SOUL CARDS ===== */
.soul-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-top:16px}
.soul-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:20px;color:#fff;position:relative;overflow:hidden}
.soul-card .sc-emoji{font-size:32px;margin-bottom:8px}
.soul-card .sc-vibe{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;opacity:.85;margin-bottom:6px}
.soul-card .sc-reflection{font-size:.85rem;line-height:1.5;opacity:.92;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.soul-card .sc-user{margin-top:12px;font-size:.78rem;opacity:.8;display:flex;align-items:center;gap:6px}
.soul-card .sc-user img{width:22px;height:22px;border-radius:50%;border:1px solid rgba(255,255,255,.4)}
.soul-card .sc-actions{position:absolute;top:12px;right:12px;display:flex;gap:6px}
.soul-card .sc-shared-badge{font-size:.7rem;background:rgba(255,255,255,.25);padding:2px 8px;border-radius:10px}

/* ===== STORIES MODERATION ===== */
.stories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-top:16px}
.story-mod-card{border-radius:12px;overflow:hidden;background:var(--surface);border:1px solid var(--border);position:relative;aspect-ratio:9/16}
.story-mod-card img,.story-mod-card video{width:100%;height:100%;object-fit:cover;display:block}
.story-mod-card .story-mod-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.7));padding:10px 8px 8px;color:#fff}
.story-mod-card .story-mod-user{font-size:.74rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.story-mod-card .story-mod-time{font-size:.7rem;opacity:.75}
.story-mod-card .story-mod-actions{position:absolute;top:8px;right:8px;display:flex;flex-direction:column;gap:4px}
.story-type-badge{font-size:.7rem;padding:1px 6px;border-radius:8px;font-weight:600}
.story-type-badge.media{background:rgba(255,255,255,.2);color:#fff}
.story-type-badge.soul_card{background:rgba(103,126,234,.85);color:#fff}
.story-type-badge.text{background:rgba(0,0,0,.4);color:#fff}

/* ===== v9: HEALTH MONITOR ===== */
.health-status-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:6px}
.health-status-dot.healthy{background:#16a34a;box-shadow:0 0 6px #16a34a88}
.health-status-dot.degraded{background:#d97706;box-shadow:0 0 6px #d9770688}
.health-status-dot.critical{background:#dc2626;box-shadow:0 0 6px #dc262688;animation:pulse-red 1.2s infinite}
@keyframes pulse-red{0%,100%{opacity:1}50%{opacity:.4}}
.health-metric{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px 20px;display:flex;flex-direction:column;gap:4px}
.health-metric .hm-val{font-size:24px;font-weight:900;line-height:1}
.health-metric .hm-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}
.health-alert-chip{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:10px;gap:12px}
.health-alert-chip.urgent{border-color:#EF6B5B;background:#fff5f3}
.health-alert-chip .hac-val{font-size:22px;font-weight:900;color:#EF6B5B;min-width:32px;text-align:center}
.health-alert-chip .hac-label{font-size:12px;font-weight:600;flex:1}

/* ===== v9: USER ACTIVITY TIMELINE ===== */
.timeline{display:flex;flex-direction:column;gap:0;padding:4px 0}
.timeline-item{display:flex;gap:14px;padding:10px 0;border-bottom:1px solid var(--border);position:relative}
.timeline-item:last-child{border-bottom:none}
.tl-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;margin-top:2px}
.tl-dot.post{background:#FFF3E0;color:#F59E0B}
.tl-dot.comment{background:#E3F2FD;color:#1565C0}
.tl-dot.story{background:#FCE4EC;color:#C62828}
.tl-dot.like{background:#FFF5F3;color:#EF6B5B}
.tl-dot.follow{background:#E8F5E9;color:#2E7D32}
.tl-dot.karma{background:#EDE7F6;color:#7B61FF}
.tl-body{flex:1;min-width:0}
.tl-desc{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tl-meta{font-size:11px;color:var(--text-muted);margin-top:2px;display:flex;gap:8px}
.tl-badge{font-size:10px;padding:1px 7px;border-radius:8px;font-weight:700;background:var(--surface-alt);color:var(--text-muted)}

/* ===== v9: CSS MINI CHARTS ===== */
.bar-chart{display:flex;flex-direction:column;gap:8px;padding:4px 0}
.bar-row{display:flex;align-items:center;gap:10px}
.bar-label{font-size:12px;font-weight:600;min-width:110px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar-track{flex:1;height:8px;background:var(--border);border-radius:4px;overflow:hidden}
.bar-fill{height:100%;border-radius:4px;transition:width .5s cubic-bezier(.4,0,.2,1)}
.bar-fill.primary{background:var(--primary)}
.bar-fill.purple{background:#7B61FF}
.bar-fill.gold{background:#F59E0B}
.bar-fill.green{background:#16a34a}
.bar-fill.coral{background:#EF6B5B}
.bar-count{font-size:12px;font-weight:700;min-width:36px;text-align:right;color:var(--text)}
.sparkline{display:flex;align-items:flex-end;gap:3px;height:40px}
.spark-bar{flex:1;background:var(--primary);border-radius:2px 2px 0 0;opacity:.7;min-width:4px;transition:height .4s}
.spark-bar:hover{opacity:1}

/* ===== v9: MODERATION QUEUE ===== */
.mod-queue-empty{text-align:center;padding:56px 24px;color:var(--text-muted)}
.mod-queue-empty .mq-emoji{font-size:3.5rem;display:block;margin-bottom:12px}
.mod-queue-empty p{font-weight:700;font-size:16px;color:var(--success)}
.priority-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:700}
.priority-badge.critical{background:#FEE2E2;color:#dc2626}
.priority-badge.high{background:#FFF3CD;color:#d97706}
.priority-badge.medium{background:#DBEAFE;color:#1d4ed8}
.priority-badge.low{background:#DCFCE7;color:#16a34a}

/* ===== v9: BLOCKLIST ===== */
.blocklist-word{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:700;margin:3px;border:1px solid var(--border)}
.blocklist-word.critical{background:#FEE2E2;border-color:#fca5a5;color:#dc2626}
.blocklist-word.high{background:#FFF3CD;border-color:#fcd34d;color:#b45309}
.blocklist-word.medium{background:#EFF6FF;border-color:#93c5fd;color:#1d4ed8}
.blocklist-word.low{background:#F0FDF4;border-color:#86efac;color:#15803d}
.blocklist-word .bl-remove{cursor:pointer;opacity:.6;transition:opacity .15s}
.blocklist-word .bl-remove:hover{opacity:1}

/* ===== v9: APP CONFIG ===== */
.config-row{display:grid;grid-template-columns:220px 1fr auto;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border)}
.config-row:last-child{border-bottom:none}
.config-key{font-family:monospace;font-size:12px;background:var(--surface-alt);padding:2px 8px;border-radius:4px;font-weight:600}
.config-val{font-weight:700}
.config-val.bool-true{color:var(--success)}
.config-val.bool-false{color:var(--danger)}
.config-edit-input{padding:5px 10px;border:1.5px solid var(--border);border-radius:8px;font-size:13px;font-family:monospace;background:var(--surface);color:var(--text);transition:border-color .2s}
.config-edit-input:focus{border-color:var(--primary);outline:none}

/* ===== v9: DELETION REQUESTS ===== */
.del-req-row-urgent{background:#fff5f3}
.del-req-type-account{color:#dc2626;font-weight:700}
.del-req-type-data{color:#1d4ed8;font-weight:700}
.compliance-banner{display:flex;align-items:center;gap:12px;padding:12px 18px;background:#E8F5E9;border:1px solid #86efac;border-radius:10px;margin-bottom:16px;font-size:13px;font-weight:600;color:#15803d}
.compliance-banner .cb-icon{font-size:20px}

/* ===== v9: SCHEDULED NOTIFICATIONS ===== */
.sched-notif-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px 18px;display:flex;align-items:center;gap:14px;margin-bottom:10px}
.sched-notif-card .sn-icon{width:40px;height:40px;border-radius:10px;background:var(--primary-light);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.sched-notif-card .sn-body{flex:1;min-width:0}
.sched-notif-card .sn-title{font-size:14px;font-weight:700;margin-bottom:2px}
.sched-notif-card .sn-meta{font-size:11px;color:var(--text-muted);display:flex;gap:10px;flex-wrap:wrap}
.sched-notif-card.sent{opacity:.6}
.audience-chip{display:inline-block;padding:2px 9px;border-radius:10px;font-size:11px;font-weight:700;background:#EDE7F6;color:#7B61FF}

/* ===== v9: SHADOWBAN ===== */
.shadowban-banner{display:flex;align-items:center;gap:10px;padding:10px 16px;background:#FFF8E1;border:1px solid #fcd34d;border-radius:10px;margin-bottom:12px;font-size:13px;font-weight:600;color:#b45309}

/* ===== v9: ANALYTICS GRID ===== */
.analytics-2col{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.analytics-metric-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:20px;text-align:center;transition:transform .2s,box-shadow .2s}
.analytics-metric-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.08)}
.analytics-metric-card .amc-val{font-size:28px;font-weight:900;line-height:1;margin-bottom:4px}
.analytics-metric-card .amc-label{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);font-weight:700}
.analytics-metric-card .amc-sub{font-size:11px;color:var(--text-muted);margin-top:4px}
.analytics-metric-card.up .amc-val{color:var(--success)}
.analytics-metric-card.down .amc-val{color:var(--danger)}
.analytics-metric-card.purple .amc-val{color:#7B61FF}
.analytics-metric-card.gold .amc-val{color:#F59E0B}

/* ===== CRITICAL ALERT BANNER ===== */
.critical-alert-banner{position:fixed;top:0;left:0;right:0;z-index:9999;background:#c0392b;color:#fff;padding:10px 16px;font-size:14px;font-weight:600;text-align:center;display:flex;align-items:center;justify-content:center;gap:12px}
.critical-alert-banner button{background:rgba(255,255,255,.2);border:none;color:#fff;padding:2px 8px;cursor:pointer;border-radius:4px;font-size:13px}

/* ===== SCROLLBAR ===== */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(0,0,0,.12);border-radius:6px}
::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.2)}

/* ===== RESPONSIVE ===== */
@media(max-width:900px){
  .sidebar{position:fixed;left:0;top:0;transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0);box-shadow:0 0 40px rgba(0,0,0,.15)}
  .sidebar-toggle{display:block}
  .content-scroll{padding:18px}
  .stat-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}
}
@media(max-width:600px){
  .login-card{padding:24px 20px}
  .login-features{grid-template-columns:repeat(2,1fr)}
  .stat-grid{grid-template-columns:1fr 1fr}
  .hero-grid,.ad-grid,.promo-grid{grid-template-columns:1fr}
  .content-scroll{padding:14px}
  .top-bar{padding:12px 16px;gap:10px}
  /* free up room so the logout button is never cut off on phones */
  .top-bar-status{display:none}
  .top-bar-title{font-size:1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
}
