@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700&family=Space+Grotesk:wght@500;600;700&family=Noto+Sans+SC:wght@400;500;600;700&display=swap";:root{font-family:Manrope,Noto Sans SC,system-ui,-apple-system,sans-serif;color:#0f1c2e;background-color:#eef2fb;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--ink-900: #0c1a2b;--ink-800: #12243a;--ink-700: #243751;--ink-600: #3a4f6b;--ink-500: #5b6f8b;--ink-400: #7f91aa;--border: #d6dfeb;--surface: #ffffff;--surface-2: #f4f7fb;--primary-700: #1b4db9;--primary-600: #2563eb;--primary-500: #3b82f6;--primary-200: #cfe0ff;--accent-500: #0ea5a8;--danger: #dc2626;--success: #0f8a4b;--shadow-card: 0 30px 70px -60px rgba(15, 23, 42, .6);--shadow-soft: 0 18px 40px -30px rgba(37, 99, 235, .45);--radius-card: 20px;--font-heading: "Space Grotesk", "Noto Sans SC", "Manrope", sans-serif}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at 20% 10%,rgba(37,99,235,.12),transparent 55%),radial-gradient(circle at 80% 0%,rgba(14,165,168,.16),transparent 48%),linear-gradient(180deg,#eef3ff,#f7f9fc 60%,#f1f5fb);color:var(--ink-800)}a{color:inherit;text-decoration:none}h1,h2,h3{font-family:var(--font-heading);margin:0}h1{font-size:2rem;letter-spacing:-.02em}h2{font-size:1.4rem}p{margin:0}.mono{font-family:SFMono-Regular,Menlo,Monaco,Courier New,monospace}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{padding:32px 24px;background:#ffffffd9;border-right:1px solid rgba(214,223,235,.7);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);display:flex;flex-direction:column;gap:32px}.brand{display:flex;gap:12px;align-items:center}.brand-mark{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,var(--primary-600),var(--accent-500));color:#fff;display:grid;place-items:center;font-weight:700;font-family:var(--font-heading)}.brand-title{font-weight:700}.brand-subtitle{font-size:.85rem;color:var(--ink-500)}.sidebar-nav{display:grid;gap:18px}.nav-group{display:grid;gap:10px}.nav-group-title{font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-500);font-weight:700}.nav-group-toggle{display:flex;align-items:center;justify-content:space-between;gap:8px;background:transparent;border:none;padding:4px 8px;cursor:pointer;text-align:left}.nav-group-toggle:hover .nav-group-title{color:var(--primary-600)}.nav-caret{width:8px;height:8px;border-right:2px solid var(--ink-500);border-bottom:2px solid var(--ink-500);transform:rotate(-45deg);transition:transform .2s ease}.nav-group.is-open .nav-caret{transform:rotate(45deg)}.nav-sub{display:grid;gap:10px}.nav-item{padding:10px 14px;border-radius:12px;border:1px solid transparent;color:var(--ink-700);font-weight:600;font-size:.9rem;transition:all .2s ease}.nav-sub-item{padding-left:18px;font-size:.82rem}.data-table-shell{display:grid;gap:18px}.query-panel{display:grid;gap:12px}.query-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;overflow:hidden;transition:max-height .2s ease}.query-actions{display:flex;flex-wrap:wrap;gap:10px}.table-section{display:grid;gap:12px}.permission-tree{list-style:none;margin:0;padding-left:16px;display:grid;gap:10px}.permission-node-item{display:grid;gap:8px}.permission-node{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;background:var(--surface-2);border:1px solid var(--border)}.permission-name{font-weight:600}.permission-key{margin-left:auto;font-size:.78rem;color:var(--ink-500);font-family:SFMono-Regular,Menlo,Monaco,Courier New,monospace}.modal-backdrop{position:fixed;inset:0;background:#0f172a59;display:grid;place-items:center;padding:24px;z-index:50}.modal{width:min(640px,100%);background:var(--surface);border-radius:18px;border:1px solid var(--border);box-shadow:var(--shadow-card);display:grid;gap:18px;padding:20px}.modal-wide{width:min(860px,100%)}.form-shell{display:grid;gap:18px}.form-shell-body{display:grid;gap:16px}.form-shell-actions{display:flex;justify-content:flex-end;gap:12px}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.modal-body{display:grid;gap:14px}.modal-actions{display:flex;justify-content:flex-end;gap:12px}.checkbox-list{display:grid;gap:8px;margin-top:8px}.checkbox-row{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:10px;background:var(--surface-2);border:1px solid var(--border)}.cell-stack{display:grid;gap:4px}.table-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px 18px}.detail-item{display:grid;gap:4px}.detail-label{text-transform:uppercase;font-size:.7rem;letter-spacing:.14em;color:var(--ink-500)}.detail-value{font-weight:600;color:var(--ink-800)}.detail-meta{color:var(--ink-500);font-size:.78rem}.detail-section{margin-top:18px;display:grid;gap:12px}.feature-list{display:grid;gap:10px}.feature-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:10px;align-items:center}.feature-toggle{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--ink-600)}.feature-toggle input{width:16px;height:16px}.feature-actions{display:flex;justify-content:flex-end}.code-block{margin:0;padding:12px;background:var(--surface-2);border-radius:12px;border:1px solid var(--border);font-size:.8rem;overflow-x:auto}.action-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px}.search-select{position:relative;display:grid;gap:6px}.search-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-card);padding:8px;display:grid;gap:6px;max-height:240px;overflow-y:auto;z-index:20}.search-option{display:flex;align-items:center;justify-content:space-between;gap:8px;background:transparent;border:1px solid transparent;border-radius:10px;padding:8px 10px;cursor:pointer;text-align:left;font-weight:600;color:var(--ink-800)}.search-option:hover{background:#2563eb14;border-color:#2563eb33}.btn.danger{color:var(--danger)}.muted{color:var(--ink-500);font-size:.8rem}.tag-list{display:flex;flex-wrap:wrap;gap:6px}.tag{padding:4px 8px;border-radius:999px;background:#2563eb1f;color:var(--primary-700);font-size:.75rem;font-weight:600}.tag-muted{background:#94a3b833;color:var(--ink-600)}.empty-state{display:grid;place-items:center;text-align:center;padding:24px;color:var(--ink-500)}.permission-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.permission-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--primary-500);margin-right:6px}.nav-item.router-link-active,.nav-item.is-active{background:#2563eb1f;border-color:#2563eb40;color:var(--primary-700)}.nav-item:hover{background:#2563eb14}.app-main{display:flex;flex-direction:column;min-height:100vh}.topbar{padding:12px 36px 0;display:flex;align-items:center;justify-content:space-between;gap:24px}.topbar-right{display:flex;align-items:center;gap:16px}.content{padding:0 36px 48px;display:grid;gap:24px}.page-header{display:flex;justify-content:space-between;align-items:flex-end;gap:16px}.breadcrumb{display:flex;align-items:center;gap:8px;font-size:.95rem;font-weight:600;color:var(--ink-600)}.breadcrumb-link{background:none;border:none;padding:0;font:inherit;color:var(--primary-700);cursor:pointer}.breadcrumb-link:hover{text-decoration:underline}.breadcrumb-item.is-current{color:var(--ink-900)}.breadcrumb-sep{color:var(--ink-400)}.eyebrow{font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:var(--primary-600);font-weight:700}.subtle{color:var(--ink-500)}.card{background:var(--surface);border-radius:var(--radius-card);border:1px solid var(--border);padding:22px;box-shadow:var(--shadow-card)}.card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.stat-card{background:linear-gradient(180deg,rgba(37,99,235,.08),transparent 70%);display:grid;gap:12px}.stat-label{color:var(--ink-500);font-size:.85rem}.stat-value{font-size:1.8rem;font-weight:600}.stat-note{font-size:.85rem;color:var(--ink-500)}.filters{display:flex;flex-wrap:wrap;gap:14px;align-items:flex-end}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px 18px}.form-grid.single{grid-template-columns:1fr}.field{display:grid;gap:6px}.field-label{text-transform:uppercase;font-size:.7rem;letter-spacing:.14em;color:var(--ink-500)}.input,.select{padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:var(--surface);transition:border .2s ease,box-shadow .2s ease}.input:focus,.select:focus{outline:none;border-color:#2563eb66;box-shadow:0 0 0 3px #2563eb2e}.btn{padding:10px 16px;border-radius:12px;border:1px solid transparent;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-primary{background:linear-gradient(135deg,var(--primary-600),var(--primary-500));color:#fff;box-shadow:var(--shadow-soft)}.btn-primary:hover{transform:translateY(-1px)}.btn-ghost{background:transparent;border-color:var(--border);color:var(--ink-700)}.btn-sm{padding:6px 10px;font-size:.8rem;border-radius:10px}.helper{color:var(--ink-500);font-size:.85rem}.form-error{color:var(--danger);font-size:.85rem}.table-wrap{width:100%;overflow-x:auto}.table{width:100%;border-collapse:collapse;min-width:640px}.table th,.table td{padding:12px 16px;text-align:left;font-size:.9rem}.table th{text-transform:uppercase;font-size:.7rem;letter-spacing:.12em;color:var(--ink-500);border-bottom:1px solid var(--border)}.table tr{border-bottom:1px solid var(--border)}.table tbody tr:hover{background:#2563eb0d}.empty-cell{text-align:center;padding:20px;color:var(--ink-500)}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:#2563eb1f;color:var(--primary-700);font-weight:600;font-size:.75rem}.badge-muted{background:#94a3b833;color:var(--ink-600)}.table-pagination{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:16px;flex-wrap:wrap}.pagination-controls{display:flex;align-items:center;gap:10px}.select.select-sm{padding:6px 10px;font-size:.85rem}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:40px 20px}.auth-panel{width:min(520px,100%);display:grid;gap:20px}.auth-brand{display:flex;align-items:center;gap:12px}.auth-card{background:#ffffffeb;border-radius:20px;border:1px solid var(--border);padding:22px;box-shadow:var(--shadow-card);display:grid;gap:16px}.auth-header{display:grid;gap:6px}.otp-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;margin-top:6px}.otp-input{height:54px;border-radius:14px;border:1px solid var(--border);background:var(--surface);text-align:center;font-size:1.2rem;font-weight:700;color:var(--ink-800);box-shadow:inset 0 1px 2px #0f172a14;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}.otp-input:focus{outline:none;border-color:#2563eb80;box-shadow:0 0 0 3px #2563eb2e;transform:translateY(-1px)}.otp-input:disabled{background:var(--surface-2);color:var(--ink-400);cursor:not-allowed}@media(max-width:480px){.otp-grid{gap:8px}.otp-input{height:46px;font-size:1.05rem}}.mfa-setup{display:grid;gap:12px;margin-bottom:12px}.mfa-qr{border:1px solid var(--border);border-radius:12px;padding:12px;background:var(--surface-2);display:grid;gap:8px;place-items:center}.mfa-qr img{width:160px;height:160px;border-radius:10px;background:#fff;padding:8px;box-shadow:var(--shadow-soft)}.qr-frame{display:grid;place-items:center;min-height:180px}.mfa-box{border:1px dashed var(--border);border-radius:12px;padding:12px;background:var(--surface-2)}.wrap{word-break:break-all}.tab-row{display:flex;gap:10px;border-bottom:1px solid var(--border);padding-bottom:12px;margin-bottom:18px}.tab-btn{border:none;background:transparent;font-weight:600;color:var(--ink-500);padding:6px 10px;border-radius:999px;cursor:pointer}.tab-btn.active{background:#2563eb1f;color:var(--primary-700)}@media(max-width:1024px){.app-shell{grid-template-columns:1fr}.sidebar{flex-direction:row;align-items:center;justify-content:space-between}.sidebar-nav{grid-auto-flow:column;grid-auto-columns:minmax(0,1fr)}}@media(max-width:768px){.topbar{flex-direction:column;align-items:flex-start}.content{padding:0 20px 40px}.filters{flex-direction:column;align-items:stretch}}
