:root{--c-bg: #f6f7f9;--c-surface: #ffffff;--c-border: #e4e7ec;--c-border-strong: #d0d5dd;--c-text: #1d2939;--c-text-muted: #667085;--c-primary: #145ea8;--c-primary-hover: #0f4a86;--c-primary-soft: #e6f0fb;--c-success: #198754;--c-warning: #b54708;--c-danger: #b42318;--c-danger-soft: #fef3f2;--radius: 6px;--radius-sm: 4px;--shadow-sm: 0 1px 2px rgba(16, 24, 40, .06);--shadow-md: 0 4px 12px rgba(16, 24, 40, .08);--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: "SF Mono", Menlo, Consolas, "DejaVu Sans Mono", monospace}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100%;background:var(--c-bg);color:var(--c-text);font-family:var(--font);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--c-primary);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4{margin:0 0 12px;line-height:1.25;color:var(--c-text)}h1{font-size:22px;font-weight:600}h2{font-size:18px;font-weight:600}h3{font-size:15px;font-weight:600}p{margin:0 0 12px}code,pre{font-family:var(--font-mono)}pre{background:#f0f2f5;padding:12px;border-radius:var(--radius);overflow-x:auto;font-size:12px;line-height:1.5}code{background:#f0f2f5;padding:1px 5px;border-radius:3px;font-size:12px}pre code{background:transparent;padding:0;border-radius:0;font-size:inherit;color:inherit}[role=tooltip] code{background:#ffffff24;color:#fff;padding:1px 5px;border-radius:3px;font-size:.92em}::selection{background:var(--c-primary-soft)}.app-shell{display:grid;grid-template-columns:240px 1fr;height:100vh;overflow:hidden}.sidebar{background:#0e1726;color:#d0d5dd;padding:18px 12px;display:flex;flex-direction:column;gap:4px;height:100vh;overflow-y:auto;position:sticky;top:0}.sidebar-brand{display:flex;align-items:center;justify-content:center;padding:4px 12px 10px;border-bottom:1px solid #1f2937;margin-bottom:8px}.sidebar-brand img{max-width:140px;width:100%;height:auto;display:block}.nav-section{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:#6b7280;padding:14px 8px 6px}.nav-link{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:var(--radius-sm);color:#d0d5dd;text-decoration:none;font-size:13px}.nav-link:hover{background:#1f2937;color:#fff;text-decoration:none}.nav-link.active{background:var(--c-primary);color:#fff}.nav-link svg{width:16px;height:16px;flex-shrink:0;opacity:.9}.nav-link.nav-link-bottom{margin-top:auto}.sidebar-footer{padding:10px 6px 6px;border-top:1px solid #1f2937;display:flex;align-items:center;gap:4px}.sidebar-user{flex:1;min-width:0;display:flex;align-items:center;gap:8px;padding:7px 10px;color:#d0d5dd;text-decoration:none;font-size:13px;font-weight:500;border-radius:var(--radius-sm);transition:background .1s,color .1s}.sidebar-user:hover{background:#1f2937;color:#fff;text-decoration:none}.sidebar-user.active{background:var(--c-primary);color:#fff}.sidebar-user svg{width:16px;height:16px;flex-shrink:0;opacity:.85}.sidebar-user-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-logout{flex-shrink:0;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;color:#9aa3ad;border-radius:var(--radius-sm);cursor:pointer;transition:background .1s,color .1s}.sidebar-logout:hover{background:#7f1d1d;color:#fff}.sidebar-logout svg{width:16px;height:16px}.main-area{display:flex;flex-direction:column;height:100vh;overflow:hidden;min-width:0}.page{padding:24px;max-width:1280px;width:100%;margin:0 auto;flex:1;min-height:0;overflow-y:auto}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:12px;flex-wrap:wrap}.page-header h1{margin:0}.page-fill{flex:1;min-height:0;display:flex;flex-direction:column;padding:18px 24px;width:100%;max-width:1600px;margin:0 auto;gap:12px}.page-fill>.page-header{margin-bottom:0;flex-shrink:0}.page-fill>.toolbar{margin-bottom:0;flex-shrink:0}.table-wrap{flex:1;min-height:0;display:flex;flex-direction:column;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);overflow:hidden}.table-scroll{flex:1;min-height:0;overflow-y:scroll;overflow-x:auto}.table-scroll table{border:none;border-radius:0;box-shadow:none;margin:0}.table-scroll thead th{position:sticky;top:0;z-index:2;background:#fafbfc;box-shadow:inset 0 -1px 0 var(--c-border)}.table-scroll thead th:after{display:none}.table-footer{flex-shrink:0;padding:8px 14px;border-top:1px solid var(--c-border);background:#fafbfc;display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--c-text-muted);gap:12px}.table-footer .btn-sm{padding:3px 10px;font-size:12px}.table-scroll::-webkit-scrollbar{-webkit-appearance:none;appearance:none;display:block;width:12px;height:12px;background:#f0f2f5}.table-scroll::-webkit-scrollbar-track{background:#f0f2f5}.table-scroll::-webkit-scrollbar-thumb{background:#c0c6cf;border-radius:6px;border:2px solid #f0f2f5;min-height:30px}.table-scroll::-webkit-scrollbar-thumb:hover{background:#98a2b3}.table-scroll::-webkit-scrollbar-corner{background:#f0f2f5}@supports (scrollbar-color: auto) and (not selector(::-webkit-scrollbar)){.table-scroll{scrollbar-width:auto;scrollbar-color:#c0c6cf #f0f2f5}}.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(at 30% 20%,#eaf1ff 0%,transparent 55%),radial-gradient(at 70% 80%,#f1ebff 0%,transparent 55%),linear-gradient(180deg,#f5f7fb,#e8edf4)}.login-card-shell{display:grid;grid-template-columns:1fr 1fr;width:100%;max-width:960px;min-height:520px;background:var(--c-surface);border-radius:18px;overflow:hidden;box-shadow:0 24px 60px #0f172a2e,0 2px 6px #0f172a0f}@media(max-width:820px){.login-card-shell{grid-template-columns:1fr;max-width:420px;min-height:0}.login-hero{display:none}}.login-hero{display:flex;align-items:center;justify-content:center;padding:40px 32px;background:radial-gradient(at 20% 20%,#eef4ff 0%,transparent 55%),radial-gradient(at 80% 80%,#f0eaff 0%,transparent 55%),linear-gradient(180deg,#fbfcff,#eef2f8);position:relative;overflow:hidden}.login-hero:before{content:"";position:absolute;top:-120px;right:-120px;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(40,112,237,.1),transparent 70%)}.login-hero-inner{position:relative;max-width:460px;width:100%;text-align:center;display:flex;flex-direction:column;align-items:center;gap:18px}.login-hero-logo img{max-width:320px;width:100%;height:auto;filter:drop-shadow(0 8px 24px rgba(20,94,168,.12))}.login-hero-title{font-size:32px;font-weight:700;color:var(--c-text);margin:14px 0 0}.login-hero-sub{font-size:15px;line-height:1.55;color:var(--c-text-muted);max-width:380px;margin:0}.login-hero-features{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:16px}.login-feature{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:#fff;border:1px solid var(--c-border);border-radius:999px;font-size:13px;font-weight:500;color:var(--c-text);box-shadow:0 1px 2px #0000000a}.login-feature-icon{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--c-primary-soft);color:var(--c-primary);border-radius:6px}.login-feature-icon svg{width:14px;height:14px}.login-panel{display:flex;align-items:center;justify-content:center;padding:40px;background:#0e1726;color:#d0d5dd}.login-form{width:100%;max-width:380px;display:flex;flex-direction:column;gap:14px}.login-form-head{margin-bottom:8px}.login-form-head h2{font-size:24px;font-weight:600;color:#fff;margin:0 0 6px}.login-form-sub{font-size:13px;color:#98a2b3;margin:0}.login-input{position:relative;display:flex;align-items:center}.login-input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#6b7280;display:inline-flex;pointer-events:none}.login-input .input{width:100%;padding:11px 12px 11px 40px;font-size:14px;background:#1a2436;border:1px solid #2a3548;color:#fff;border-radius:var(--radius-sm);transition:border-color .1s,box-shadow .1s}.login-input .input::placeholder{color:#6b7280}.login-input .input:focus{outline:none;border-color:var(--c-primary);box-shadow:0 0 0 3px #2870ed40}.login-input-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;background:transparent;border:none;color:#6b7280;border-radius:4px;cursor:pointer}.login-input-toggle:hover{background:#2a3548;color:#fff}.login-submit{margin-top:4px;padding:12px;font-size:14px;font-weight:600;justify-content:center;width:100%}.login-form-foot{margin-top:18px;padding-top:16px;border-top:1px solid #2a3548;font-size:12px;color:#6b7280;text-align:center}.card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm)}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border:1px solid var(--c-border-strong);background:var(--c-surface);color:var(--c-text);border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:500;line-height:1.4;transition:background .1s,border-color .1s}.btn:hover:not(:disabled){background:#f8fafc;border-color:var(--c-text-muted)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}.btn-primary:hover:not(:disabled){background:var(--c-primary-hover);border-color:var(--c-primary-hover)}.btn-danger{background:var(--c-danger);color:#fff;border-color:var(--c-danger)}.btn-danger:hover:not(:disabled){background:#98261b;border-color:#98261b}.btn-sm{padding:4px 10px;font-size:12px}.btn-ghost{background:transparent;border-color:transparent;color:var(--c-text-muted)}.btn-ghost:hover:not(:disabled){background:#f0f2f5;color:var(--c-text)}.input,.select,.textarea{width:100%;padding:7px 10px;border:1px solid var(--c-border-strong);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font);background:var(--c-surface);color:var(--c-text)}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--c-primary);box-shadow:0 0 0 3px var(--c-primary-soft)}.textarea{min-height:80px;resize:vertical;font-family:var(--font-mono)}.field{margin-bottom:14px}.field label{display:block;font-size:12px;font-weight:500;margin-bottom:4px;color:var(--c-text)}.field .help{color:var(--c-text-muted);font-size:12px;margin-top:4px}.field-row{display:flex;gap:12px}.field-row .field{flex:1}table{width:100%;border-collapse:collapse;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);overflow:hidden}th,td{padding:9px 12px;text-align:left;font-size:13px}th{background:#fafbfc;font-weight:600;font-size:12px;color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid var(--c-border)}tbody tr{border-bottom:1px solid var(--c-border)}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:#fafbfc}td.actions{text-align:right}table.table-compact{font-size:13px;table-layout:fixed;width:100%}table.table-compact th,table.table-compact td{padding:4px 10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-right:1px solid #f0f2f5}table.table-compact th:last-child,table.table-compact td:last-child{border-right:none}table.table-compact th{padding:6px 10px}table.table-compact td.col-menu{padding:2px 6px;width:36px;text-align:center}table.table-compact td.col-icon{text-align:center;width:60px}table.table-compact tbody tr{cursor:default}table.table-rows-clickable tbody tr{cursor:pointer;transition:background .1s}table.table-rows-clickable tbody tr:hover,table.table-compact tr.version-row-open{background:var(--c-primary-soft)}table.table-compact tr.version-row-detail td{background:#fafbfc;padding:14px 16px;white-space:normal;overflow:visible;border-bottom:2px solid var(--c-primary-soft)}table.table-compact tr.version-row-detail:hover td{background:#fafbfc}.row-menu-trigger{background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);padding:4px 6px;cursor:pointer;color:var(--c-text-muted);display:inline-flex;align-items:center;justify-content:center;line-height:0;transition:background .1s,color .1s,border-color .1s}.row-menu-trigger:hover{background:#f0f2f5;color:var(--c-text);border-color:var(--c-border)}.row-menu-trigger[aria-expanded=true]{background:var(--c-primary-soft);color:var(--c-primary);border-color:var(--c-primary)}.row-menu-dropdown{position:absolute;top:calc(100% + 4px);left:0;z-index:100;background:var(--c-surface);border:1px solid var(--c-border-strong);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);min-width:180px;padding:4px;display:flex;flex-direction:column}.row-menu-item{display:flex;align-items:center;gap:8px;padding:7px 10px;background:transparent;border:none;text-align:left;font-size:13px;cursor:pointer;color:var(--c-text);border-radius:var(--radius-sm);width:100%}.row-menu-item:hover:not(:disabled){background:#f0f2f5}.row-menu-item:disabled{color:var(--c-text-muted);cursor:not-allowed;opacity:.6}.row-menu-item.destructive{color:var(--c-danger)}.row-menu-item.destructive:hover:not(:disabled){background:var(--c-danger-soft)}.row-menu-icon{display:inline-flex;align-items:center;width:14px}.badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:500;letter-spacing:.02em}.badge-default{background:#f0f2f5;color:var(--c-text-muted)}.badge-success{background:#d1fadf;color:#027a48}.badge-warning{background:#fef0c7;color:var(--c-warning)}.badge-danger{background:var(--c-danger-soft);color:var(--c-danger)}.badge-info{background:var(--c-primary-soft);color:var(--c-primary)}.badge-mono{font-family:var(--font-mono);font-size:11px;padding:1px 6px}.alert{padding:10px 14px;border-radius:var(--radius-sm);margin-bottom:14px;font-size:13px;border:1px solid}.alert-error{background:var(--c-danger-soft);border-color:#fda29b;color:var(--c-danger)}.alert-success{background:#d1fadf;border-color:#6ce9a6;color:#027a48}.alert-info{background:var(--c-primary-soft);border-color:#b9dafd;color:var(--c-primary)}.modal-backdrop{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:flex-start;justify-content:center;z-index:1000;padding:20px;overflow-y:auto;-webkit-overflow-scrolling:touch}.modal{background:var(--c-surface);border-radius:var(--radius);padding:22px 24px;width:100%;max-width:460px;box-shadow:var(--shadow-md);max-height:calc(100vh - 40px);overflow-y:scroll;margin:auto}.modal h2{font-size:16px;margin-bottom:8px}.modal p{color:var(--c-text-muted);font-size:13px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:18px}.modal::-webkit-scrollbar{-webkit-appearance:none;appearance:none;display:block;width:12px;height:12px;background:#e4e7ec}.modal::-webkit-scrollbar-track{background:#e4e7ec;border-radius:0 var(--radius) var(--radius) 0}.modal::-webkit-scrollbar-thumb{background:#98a2b3;border-radius:6px;border:2px solid #e4e7ec;min-height:30px}.modal::-webkit-scrollbar-thumb:hover{background:#667085}.modal::-webkit-scrollbar-corner{background:#e4e7ec}@supports (scrollbar-color: auto) and (not selector(::-webkit-scrollbar)){.modal{scrollbar-width:auto;scrollbar-color:#98a2b3 #e4e7ec}}.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.stat-card .stat-label{color:var(--c-text-muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em}.stat-card .stat-value{font-size:26px;font-weight:600;margin-top:4px}.stat-card .stat-meta{color:var(--c-text-muted);font-size:12px;margin-top:4px}.toolbar{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap}.toolbar .spacer{flex:1}.copyable{display:inline-flex;align-items:center;gap:6px;background:#f0f2f5;padding:4px 10px;border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:12px;cursor:pointer}.filter-bar{display:flex;align-items:flex-end;flex-wrap:wrap;gap:8px;padding:10px 12px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);flex-shrink:0}.filter-field{display:flex;flex-direction:column;gap:2px;min-width:0}.filter-field label{font-size:11px;color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.03em}.filter-field .input,.filter-field .select{padding:5px 8px;font-size:12px;min-width:140px;height:28px;line-height:1.2;box-sizing:border-box}.filter-field input[type=datetime-local]{font-family:var(--font)}.filter-field input[type=datetime-local]::-webkit-calendar-picker-indicator{padding:0;margin-left:4px;cursor:pointer;opacity:.6}.filter-field input[type=datetime-local]::-webkit-calendar-picker-indicator:hover{opacity:1}.combobox{position:relative}.combobox-input{position:relative;display:flex}.combobox-input .input{padding-right:22px}.combobox-clear{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:18px;height:18px;padding:0;line-height:1;border:none;background:transparent;cursor:pointer;color:var(--c-text-muted);font-size:16px;display:flex;align-items:center;justify-content:center;border-radius:3px}.combobox-clear:hover{background:#f0f2f5;color:var(--c-text)}.combobox-list{position:absolute;top:calc(100% + 2px);left:0;right:0;z-index:50;margin:0;padding:4px;list-style:none;background:var(--c-surface);border:1px solid var(--c-border-strong);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);max-height:240px;overflow-y:auto;min-width:100%}.combobox-item{display:flex;align-items:baseline;gap:8px;padding:6px 8px;font-size:12px;cursor:pointer;border-radius:3px}.combobox-item.is-focus{background:var(--c-primary-soft);color:var(--c-primary)}.combobox-item.is-current:before{content:"✓ ";color:var(--c-primary);font-weight:600}.combobox-item-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.combobox-item-hint{color:var(--c-text-muted);font-size:11px}.combobox-empty{padding:8px;color:var(--c-text-muted);font-size:12px;font-style:italic;text-align:center}.audit-detail-table{width:100%;margin-bottom:8px}.audit-detail-table th{text-align:left;font-size:11px;color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.04em;padding:4px 8px 4px 0;vertical-align:top;width:90px;background:transparent}.audit-detail-table td{padding:4px 0;font-size:13px}.audit-diff-table{width:100%;border:1px solid var(--c-border);border-radius:var(--radius-sm);overflow:hidden}.audit-diff-table th,.audit-diff-table td{padding:6px 10px;font-size:12px;vertical-align:top;border-bottom:1px solid var(--c-border)}.audit-diff-table thead th{background:#fafbfc;font-size:11px;color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.03em}.audit-diff-table tbody tr:last-child td{border-bottom:none}.audit-diff-before{background:var(--c-danger-soft);color:var(--c-danger);font-size:12px}.audit-diff-after{background:#d1fadf;color:#027a48;font-size:12px}.audit-diff-pill{display:inline-block;padding:2px 8px;border-radius:999px;background:#ffffffb3;font-family:var(--font-mono);font-size:11px;color:inherit;border:1px solid currentColor;white-space:nowrap}.audit-diff-after .audit-diff-pill{border-color:#6ce9a6}.audit-diff-before .audit-diff-pill{border-color:#fda29b}.audit-meta-pre{margin:0;padding:10px 12px;background:#f0f2f5;border-radius:var(--radius-sm);font-size:11px;line-height:1.5;max-height:200px;overflow:auto}.tabbar{display:flex;gap:4px;border-bottom:1px solid var(--c-border);margin-bottom:18px}.tab{padding:8px 14px;border:none;background:transparent;cursor:pointer;font-size:13px;color:var(--c-text-muted);border-bottom:2px solid transparent;margin-bottom:-1px}.tab.active{color:var(--c-primary);border-bottom-color:var(--c-primary);font-weight:500}.tab:hover{color:var(--c-text)}.muted{color:var(--c-text-muted)}.text-mono{font-family:var(--font-mono);font-size:12px}.chart{width:100%;height:220px}.kbd{display:inline-block;padding:1px 6px;border:1px solid var(--c-border-strong);border-radius:3px;font-family:var(--font-mono);font-size:11px;background:#fafbfc}.empty-state{text-align:center;padding:40px 20px;color:var(--c-text-muted);border:1px dashed var(--c-border-strong);border-radius:var(--radius);background:var(--c-surface)}.empty-state h3{color:var(--c-text);margin-bottom:6px}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px}@media(max-width:960px){.detail-grid{grid-template-columns:1fr}}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-bottom:16px}.kpi-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);padding:14px 16px;display:flex;flex-direction:column;gap:4px}.kpi-label{font-size:11px;color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.05em}.kpi-value{font-size:26px;font-weight:600;line-height:1.1}.kpi-sub{font-size:12px;color:var(--c-text-muted);margin-top:2px}.period-switch{display:inline-flex;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-sm);padding:2px;gap:2px}.period-btn{padding:5px 12px;background:transparent;border:none;font-size:12px;font-weight:500;color:var(--c-text-muted);cursor:pointer;border-radius:3px;transition:background .1s,color .1s}.period-btn:hover:not(.is-active){color:var(--c-text);background:#f0f2f5}.period-btn.is-active{background:var(--c-primary);color:#fff}.chart-card{padding:18px 20px}.chart-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:12px}.chart-header h3{margin:0}.bar-list{display:flex;flex-direction:column;gap:10px}.bar-row{display:flex;flex-direction:column;gap:4px}.bar-row-head{display:flex;justify-content:space-between;align-items:baseline;gap:8px;font-size:12px}.bar-row-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bar-row-value{color:var(--c-text-muted);font-variant-numeric:tabular-nums}.bar-row-track{height:6px;background:#f0f2f5;border-radius:3px;overflow:hidden}.bar-row-fill{height:100%;background:linear-gradient(90deg,var(--c-primary),#4a8cf2);border-radius:3px;transition:width .25s ease}.permission-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 18px;padding:6px 0}@media(max-width:720px){.permission-grid{grid-template-columns:1fr}}.permission-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:1px dashed var(--c-border)}.permission-row:last-child{border-bottom:none}.switch{position:relative;display:inline-block;width:36px;height:20px}.switch input{opacity:0;width:0;height:0}.switch-slider{position:absolute;cursor:pointer;inset:0;background:#cfd6dd;transition:.15s;border-radius:20px}.switch-slider:before{content:"";position:absolute;height:14px;width:14px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.15s}.switch input:checked+.switch-slider{background:var(--c-primary)}.switch input:checked+.switch-slider:before{transform:translate(16px)}.qr-block{text-align:center;padding:12px;background:#fafbfc;border-radius:var(--radius)}.qr-block img{display:block;margin:0 auto 12px;max-width:180px}.integration-content{max-width:980px;min-width:0}.quickstart-step{display:grid;grid-template-columns:48px minmax(0,1fr);gap:16px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);padding:18px 20px;margin-bottom:14px}@media(max-width:640px){.quickstart-step{grid-template-columns:1fr;padding:14px 16px}}.quickstart-step-num{width:36px;height:36px;border-radius:50%;background:var(--c-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:600;flex-shrink:0}.quickstart-step-body{min-width:0}.quickstart-step-body h3{margin:0 0 6px;font-size:16px}.quickstart-step-body p{margin:0 0 10px;font-size:13px;line-height:1.5}.integration-cta{margin-top:18px;padding:14px 18px;background:var(--c-primary-soft);border:1px solid #b9dafd;border-radius:var(--radius);font-size:13px;color:var(--c-text)}.integration-cta a{color:var(--c-primary);font-weight:500}.example-group{margin-bottom:28px}.example-group-title{font-size:18px;font-weight:600;margin:0 0 4px;padding-bottom:6px;border-bottom:2px solid var(--c-primary);display:inline-block}.example-block{margin-top:14px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);overflow:hidden;min-width:0;max-width:100%}.example-group{min-width:0}.example-block-head{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;background:#fafbfc;border-bottom:1px solid var(--c-border);font-size:13px}.example-block-title{font-weight:500}.example-block-lang{font-size:11px;color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.05em;font-family:var(--font-mono)}.docs-grid{display:grid;grid-template-columns:280px 1fr;gap:14px;align-items:start}@media(max-width:880px){.docs-grid{grid-template-columns:1fr}}.docs-list{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);padding:6px;display:flex;flex-direction:column;gap:2px}.docs-list-item{display:flex;flex-direction:column;align-items:flex-start;text-align:left;padding:8px 10px;background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background .1s}.docs-list-item:hover{background:#f0f2f5}.docs-list-item.is-active{background:var(--c-primary-soft);color:var(--c-primary)}.docs-list-name{font-weight:500;font-size:13px}.docs-list-meta{font-size:11px;color:var(--c-text-muted);margin-top:2px}.docs-list-section{margin-top:6px;padding:8px;border-top:1px solid var(--c-border)}.docs-content{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);display:flex;flex-direction:column}.docs-content-head{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--c-border);background:#fafbfc}.docs-content-body{margin:0;padding:16px;font-family:var(--font-mono);font-size:12px;line-height:1.55;white-space:pre-wrap;max-height:70vh;overflow:auto;background:#fff;color:var(--c-text)}.code-block{position:relative;background:#0f1729;color:#d0d5dd;border-radius:var(--radius-sm);margin:6px 0;max-width:100%;min-width:0;overflow:hidden}.code-block.is-bordered{border:1px solid #1f2937}.code-block pre{margin:0;padding:14px 90px 14px 16px;font-family:var(--font-mono);font-size:12.5px;line-height:1.55;overflow-x:auto;background:transparent;color:inherit}.code-block-copy{position:absolute;top:8px;right:8px;padding:4px 10px;font-size:11px;font-weight:500;background:#1f2937;color:#d0d5dd;border:1px solid #2a3548;border-radius:4px;cursor:pointer;transition:background .1s,color .1s}.code-block-copy:hover{background:#2a3548;color:#fff}.code-block-lang-tag{position:absolute;bottom:6px;right:10px;font-size:10px;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;font-family:var(--font-mono);pointer-events:none}
