@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";*{box-sizing:border-box}body{margin:0;font-family:Inter,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;background:#f4f7fb;color:#111827}a{color:inherit}.layout{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.sidebar{background:#0f172a;color:#e2e8f0;padding:24px 18px}.brand{display:flex;align-items:center;gap:12px;font-size:18px;font-weight:600;margin-bottom:28px}.brand-badge{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#1f6feb,#38bdf8);display:grid;place-items:center;color:#fff;font-weight:700}.nav{display:grid;gap:10px}.nav a{color:#cbd5f5;text-decoration:none;padding:10px 12px;border-radius:8px;background:#94a3b814}.nav a.active{background:#3b82f640;color:#fff}.content{padding:28px 32px 48px}.header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.header-title{font-size:22px;font-weight:600}.card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 8px 24px #0f172a14;border:1px solid #e5e7eb;margin-bottom:18px}h1,h2{margin:0 0 12px}h2{font-size:18px}table{width:100%;border-collapse:collapse;font-size:13px}th,td{border-bottom:1px solid #eef2f7;padding:10px 8px;text-align:left;vertical-align:top}th{color:#6b7280;font-weight:600;letter-spacing:.2px;text-transform:uppercase;font-size:11px}input,select,textarea,button{padding:10px 12px;border-radius:10px;border:1px solid #d1d5db;font-size:14px;font-family:inherit}input,select,textarea{width:100%;background:#f9fafb}textarea{min-height:80px}form{display:grid;gap:14px}label{font-size:12px;color:#6b7280;display:grid;gap:6px}.row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}.actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.muted{color:#6b7280;font-size:12px}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:#eff6ff;color:#1d4ed8;font-size:12px;font-weight:600}.badge.success{background:#dcfce7;color:#16a34a}.badge.danger{background:#fee2e2;color:#dc2626}.toolbar{display:flex;gap:12px;align-items:center}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}.chart-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px}.chart-card{border:1px solid #e5e7eb;border-radius:12px;padding:16px;background:#f9fafb;display:grid;gap:12px}.chart-wrap{min-height:180px;display:grid;place-items:center;background:#fff;border:1px solid #eef2f7;border-radius:12px;padding:16px}.pie-chart{width:180px;height:180px}.bar-chart{width:100%;height:180px}.bar-label{fill:#6b7280;font-size:11px;font-weight:600}.chart-legend{display:grid;gap:8px}.legend-item{display:grid;grid-template-columns:12px 1fr auto auto;align-items:center;gap:8px;font-size:12px;color:#111827}.legend-color{width:10px;height:10px;border-radius:999px}.legend-label{font-weight:600}.legend-percent{color:#6b7280;min-width:48px;text-align:right}.legend-value{color:#111827;min-width:36px;text-align:right}.stat-card{border:1px solid #e5e7eb;border-radius:12px;padding:16px;background:#f9fafb}.stat-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.stat-title{font-weight:600}.stat-icon{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;font-weight:700;color:#fff;font-size:14px}.stat-icon.app{background:linear-gradient(135deg,#2563eb,#60a5fa)}.stat-icon.page{background:linear-gradient(135deg,#9333ea,#c084fc)}.stat-list{display:grid;gap:10px}.stat-item{display:flex;align-items:center;justify-content:space-between;background:#fff;border-radius:10px;padding:10px 12px;border:1px solid #eef2f7}.stat-pill{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:#111827}.stat-dot{width:8px;height:8px;border-radius:999px;display:inline-block}.stat-dot.app{background:#2563eb}.stat-dot.page{background:#9333ea}.stat-count{font-weight:600;color:#6b7280}.alert{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;border-radius:12px;padding:12px 16px;margin-bottom:18px;font-size:13px}.empty-state{padding:16px;text-align:center;color:#6b7280;font-size:12px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:grid;place-items:center;padding:24px;z-index:20}.modal{background:#fff;border-radius:14px;width:100%;max-width:720px;box-shadow:0 20px 40px #0f172a33;padding:20px;display:grid;gap:16px}.modal-header{display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:18px;font-weight:600}.modal-body{display:grid;gap:14px}.icon-btn{width:32px;height:32px;border-radius:8px;border:1px solid #e5e7eb;background:#fff;font-size:18px;cursor:pointer}.btn{border:none;cursor:pointer;font-weight:600}.btn-primary{background:#1f6feb;color:#fff}.btn-primary:hover{background:#1a56c7}.btn-outline{background:#fff;color:#111827;border:1px solid #d1d5db}.btn-secondary{background:#e5edff;color:#1d4ed8;border:1px solid #c7ddff}.login-layout{min-height:100vh;display:grid;place-items:center;padding:40px;background:radial-gradient(circle at top,#e0ecff,#f4f7fb 45%,#f8fafc)}.login-card{width:100%;max-width:420px;padding:28px;border-radius:16px;background:#fff;box-shadow:0 8px 24px #0f172a14;border:1px solid #e5e7eb}.login-title{font-size:20px;font-weight:600;margin-bottom:6px}.section-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
