:root{--bg-page:#070e1b;--bg-card:#0c162ae0;--line-soft:#3c79ff40;--text-main:#e5edff;--text-sub:#9fb0d5;--primary:#3a79ff;--primary-soft:#2f62d347;--danger-soft:#ac385442;--radius-card:18px;--radius-control:12px;--shadow-soft:0 10px 30px #405bb01f}body{color:var(--text-main);background:linear-gradient(#4588ff0f 1px,#0000 1px) 0 0/52px 52px,linear-gradient(90deg,#4588ff0f 1px,#0000 1px) 0 0/52px 52px,radial-gradient(1200px 600px at 10% -10%,#3481ff33 0%,#0000 55%),radial-gradient(900px 420px at 90% -20%,#6c4eff2e 0%,#0000 60%),linear-gradient(#0a1222 0%,#060c18 100%);margin:0;font-family:PingFang SC,Microsoft YaHei,Arial,sans-serif}.container.login-centered{box-sizing:border-box;justify-content:center;align-items:center;max-width:none;min-height:100vh;padding:24px;display:flex}.login-shell{max-width:980px;margin:6vh auto 0}.container.login-centered .login-shell{width:min(980px,100%);margin:0}.auth-boot{text-align:center;min-width:min(420px,100%);color:var(--text-sub);padding:28px 32px}.login-card{background:#081022eb;border:1px solid #448fff59;border-radius:22px;grid-template-columns:1fr 1.1fr;gap:16px;padding:0;display:grid;overflow:hidden;box-shadow:0 20px 60px #00000080}.login-hero{color:#fff;background:linear-gradient(150deg,#2a60dcf2,#274db2eb 55%,#1b378af2);padding:34px 26px}.login-mark{letter-spacing:.22em;color:#9ed0ff;margin-bottom:8px;font-weight:700;display:inline-block}.login-hero h1{color:#fff;margin:0;font-size:30px}.login-hero p{color:#ffffffeb;margin-top:12px;line-height:1.6}.login-form{padding:28px 24px}.card{background:var(--bg-card);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);border-radius:var(--radius-card);box-shadow:var(--shadow-soft);border:1px solid var(--line-soft);margin-bottom:16px;padding:20px}.grid{gap:10px;margin-bottom:12px;display:grid}input,select,textarea{border-radius:var(--radius-control);color:#000;background:#fff;border:1px solid #c5d0dd;padding:10px 12px;transition:border-color .2s,box-shadow .2s}input::placeholder,textarea::placeholder{color:#6b7280}input:focus,select:focus,textarea:focus{border-color:#8ea7ff;outline:none;box-shadow:0 0 0 3px #8ea7ff2e}textarea{font:inherit}button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6f8dff,#7fa7ff);border:0;border-radius:999px;padding:9px 16px;font-weight:600;transition:transform .15s,box-shadow .15s}button:hover{transform:translateY(-1px);box-shadow:0 6px 14px #5f81ff40}button:disabled{cursor:not-allowed;box-shadow:none;background:#cad6ff}.secondary{background:var(--primary-soft);color:#b6d0ff;box-shadow:none}.danger{background:var(--danger-soft);color:#af2b41;box-shadow:none}.msg{color:var(--text-sub);margin-top:8px}.topbar{background:#0d172cd9;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.topbar-title h1{margin:0 0 4px}.page-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.page-header-left{align-items:flex-start;gap:10px;min-width:0;display:flex}.page-title{margin:0;font-size:18px}.page-subtitle{color:var(--text-sub);margin:6px 0 0;line-height:1.4}.page-header-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;padding:2px 0;display:flex}.page-back{padding:10px 12px}.page-body{flex-direction:column;gap:14px;display:flex}.page-section{margin-bottom:0}.command-bar{justify-content:space-between;align-items:center;gap:12px;display:flex}.command-search,.command-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.actions{flex-wrap:wrap;gap:10px;padding:2px 0;display:flex}.subtitle{color:var(--text-sub);margin-top:4px}.stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.stat-card{background:linear-gradient(#0d182efa,#091120f5);border:1px solid #3f79f247;border-radius:14px;padding:18px;box-shadow:inset 0 1px #aac9ff14}.label{color:#82b6ff;margin-bottom:8px;font-size:13px}.value{color:#eaf1ff;font-size:30px;font-weight:700}.tabs{background:#0a1427c7;border:1px solid #407cf447;border-radius:14px;flex-wrap:wrap;gap:8px;margin-bottom:16px;padding:10px;display:flex}.admin-layout{grid-template-columns:260px minmax(0,1fr);align-items:start;gap:16px;display:grid}.admin-sidebar{padding:14px;position:sticky;top:14px}.admin-main{min-width:0}.notify-mask{z-index:29;background:#01050c61;position:fixed;inset:0}.notify-drawer{z-index:30;width:340px;max-height:calc(100vh - 28px);transition:transform .2s;position:fixed;top:14px;right:14px;overflow:auto;transform:translate(120%)}.notify-drawer-open{transform:translate(0)}.notify-head{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.notify-head h3{margin:0}.notify-head-actions{gap:8px;display:flex}.notify-list{flex-direction:column;gap:10px;display:flex}.notify-item{background:#0a14269e;border:1px solid #5f8bec42;border-radius:10px;padding:10px}.notify-item-unread{border-color:#8aafffb8;box-shadow:inset 0 0 0 1px #8aafff33}.notify-title{color:#d8e7ff;margin:0;font-weight:600}.notify-detail{color:#9bb1d9;margin:6px 0}.notify-time{color:#7f96c7;margin:0;font-size:12px}.notify-foot{justify-content:space-between;align-items:center;gap:8px;display:flex}.side-tabs{background:0 0;border:0;flex-direction:column;gap:12px;margin-bottom:0;padding:0}.nav-group{border-bottom:1px dashed #5b84e347;flex-direction:column;gap:8px;padding-bottom:8px;display:flex}.nav-group:last-child{border-bottom:0;padding-bottom:0}.nav-group-title{letter-spacing:.08em;text-transform:uppercase;color:#7f96c7;margin:0;font-size:12px}.nav-group-toggle{color:#b5c6e8;background:0 0;border-radius:8px;justify-content:space-between;align-items:center;width:100%;padding:4px 2px;display:flex}.nav-group-toggle:hover{box-shadow:none;background:#3f68bc26;transform:none}.nav-group-arrow{opacity:.9;font-size:12px}.side-tab-btn{text-align:left;border-radius:12px;align-items:center;gap:8px;width:100%;display:inline-flex;position:relative}.side-tab-btn.is-active:before{content:"";background:linear-gradient(#8eb4ff,#5d89ff);border-radius:8px;width:4px;position:absolute;top:8px;bottom:8px;left:-6px}.tab-icon{text-align:center;opacity:.9;width:18px}.table-wrap{background:#fff;border:1px solid #edf2f7;border-radius:16px;overflow-x:auto}table{border-collapse:collapse;background:#fff;width:100%;font-size:13px}th,td{text-align:left;vertical-align:middle;border-bottom:1px solid #edf2f7;padding:12px 14px}th{color:#2c4d62;white-space:nowrap;background:#fafcff;font-weight:700}.row-actions,.inline-form,.inline-options{flex-wrap:wrap;align-items:center;gap:10px;margin-top:10px;padding:2px 0;display:flex}.row-actions>button,.actions>button,.page-header-actions>button{margin:2px 0}td .row-actions{margin-top:0;padding:2px}.user-error-state{text-align:center;background:#0d182ecc;border:1px dashed #5a86ee80;border-radius:12px;padding:20px}.user-error-illustration{color:#8fb6ff;margin-bottom:10px;font-size:36px;line-height:1}.user-error-state h4{color:#dbe8ff;margin:0}.user-error-state p{color:#a7badf;margin:8px 0 0}.user-error-actions{justify-content:center}.user-error-detail{color:#d2ddf7;background:#08101fd9;border-radius:8px;margin-top:10px;padding:10px}.skeleton-row{padding:12px}.skeleton-line{background:linear-gradient(90deg,#829dda26,#829dda52,#829dda26);border-radius:999px;height:14px;animation:1.3s infinite shimmer}@keyframes shimmer{0%{opacity:.55}50%{opacity:1}to{opacity:.55}}.status-badge{border-radius:999px;align-items:center;padding:2px 10px;font-size:12px;font-weight:600;display:inline-flex}.status-paid{color:#6de0a5;background:#30ba7633}.status-trial{color:#9cc1ff;background:#5288ff38}.status-unpaid{color:#b7c5e1;background:#677ba433}.tag-badges{flex-wrap:wrap;gap:6px;display:flex}.tag-badge{color:#cde0ff;background:#4e7de73d;border-radius:999px;align-items:center;padding:2px 10px;font-size:12px;display:inline-flex}.user-tag-modal-mask{z-index:38;background:#03081285;position:fixed;inset:0}.user-tag-modal{z-index:39;width:min(560px,100vw - 28px);position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.modal-sheet{width:min(760px,100vw - 28px)}.libraries-word-modal-mask{background:#2034486b}.libraries-word-sheet{color:#294056;background:linear-gradient(#fafcfd 0%,#f3f6fa 100%);border:1px solid #c8d6e4;padding:22px 24px 20px;box-shadow:0 20px 48px #283e5233}.libraries-word-sheet h3{color:#2a4358;font-weight:700}.libraries-word-sheet .grid input,.libraries-word-sheet .grid select{color:#000;background:#fff;border-color:#c4d2e2}.libraries-word-sheet .grid input:focus,.libraries-word-sheet .grid select:focus{border-color:#8aa3bc;box-shadow:0 0 0 3px #5a769624}.libraries-word-sheet button:not(.secondary):not(.danger):not(:disabled){background:linear-gradient(135deg,#4d6b82 0%,#5f8199 100%);box-shadow:0 4px 12px #34485a33}.libraries-word-sheet button:not(.secondary):not(.danger):not(:disabled):hover{box-shadow:0 6px 16px #34485a42}.libraries-word-sheet button.secondary{color:#3d566d;background:#e6edf5;border:1px solid #c8d6e6}.libraries-word-sheet button.secondary:hover{background:#dbe4ee}.admin-create-modal.card.user-tag-modal{color:#1f2937;background:#fff;border:1px solid #e5e7eb;padding:22px 24px 20px;box-shadow:0 18px 48px #0f285029}.admin-create-modal-title{text-align:center;color:#111827;margin:0 0 18px;font-size:18px;font-weight:700}.admin-create-modal-body{max-width:520px;margin:0 auto}.admin-create-modal-body .admin-form-row{align-items:center;gap:12px;margin-bottom:12px;display:flex}.admin-create-modal-body .admin-form-row>label{text-align:right;color:#374151;flex:0 0 104px;margin:0;font-size:14px;font-weight:600;line-height:1.35}.admin-create-modal-body .admin-form-row>input:not([type=radio]){flex:1;min-width:0}.admin-create-modal-body input[type=text],.admin-create-modal-body input[type=password]{color:#000;background:#fff;border:1px solid #d1d5db;border-radius:10px;padding:9px 12px;font-size:14px;line-height:1.35}.admin-create-modal-body input[type=text]:focus,.admin-create-modal-body input[type=password]:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f633}.admin-readonly-input{cursor:text;-webkit-user-select:all;user-select:all;color:#4b5563!important;background:#f9fafb!important}.admin-create-hint{color:#6b7280;margin:-8px 0 14px 116px;font-size:14px;font-weight:400;line-height:1.45}.admin-create-role-dropdown{flex:1;min-width:0;position:relative}.admin-create-rest-label{align-self:center}.admin-create-role-dropdown-trigger{box-sizing:border-box;color:#111827;cursor:pointer;width:100%;min-height:40px;box-shadow:none;background:#fff;border:1px solid #d1d5db;border-radius:10px;justify-content:space-between;align-items:center;gap:8px;padding:9px 12px;font-size:14px;font-weight:500;line-height:1.35;display:inline-flex;transform:none}.admin-create-role-dropdown-trigger:hover{border-color:#3b82f6}.admin-create-role-dropdown-trigger.is-open{border-color:#2563eb}.admin-create-role-dropdown-text{text-align:left;text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.admin-create-role-dropdown-text.is-placeholder{color:#9ca3af;font-weight:400}.admin-create-role-dropdown-caret{opacity:.75;flex-shrink:0;font-size:11px}.admin-create-role-dropdown-panel{z-index:45;background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:10px 12px;position:absolute;top:calc(100% + 6px);left:0;right:0;box-shadow:0 12px 28px #1122361f}.admin-create-modal-body .admin-role-radio{flex-shrink:0;width:16px;height:16px;margin:0}.admin-create-role-radio-list{flex-direction:column;gap:10px;display:flex}.admin-create-role-radio-option{cursor:pointer;color:#374151;align-items:center;gap:10px;font-size:14px;line-height:1.35;display:flex}.admin-create-role-radio-option:hover{color:#111827}.admin-create-modal-actions{border-top:1px solid #f3f4f6;justify-content:space-between;align-items:center;gap:16px;max-width:520px;margin-top:20px;margin-left:auto;margin-right:auto;padding-top:16px;display:flex}.admin-create-modal-actions button{min-width:120px}.modal-grid-two{grid-template-columns:1fr 1fr;gap:12px}.modal-grid-three{grid-template-columns:120px 1fr 1fr;gap:10px}.filter-actions select{min-width:180px}.quick-filter-row{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:10px;display:flex}.quick-filter-row .secondary{cursor:grab}.users-modern{color:#1f2937;--um-border:#e5e7eb;--um-muted:#6b7280;--um-bg:#fff;--um-soft:#f9fafb;--um-primary:#3b82f6;--um-primary-dark:#2563eb}.users-modern .users-kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-bottom:14px;display:grid}.users-modern .users-kpi-card{border:1px solid var(--um-border);background:linear-gradient(140deg,#f5faff 0%,#eaf3ff 100%);border-radius:12px;justify-content:space-between;align-items:center;padding:18px;display:flex;box-shadow:0 1px 2px #1018280a}.users-modern .users-kpi-grid .users-kpi-card:nth-child(2){background:linear-gradient(140deg,#f3fff8 0%,#e8f9f0 100%)}.users-modern .users-kpi-grid .users-kpi-card:nth-child(3){background:linear-gradient(140deg,#f8f5ff 0%,#efeaff 100%)}.users-modern .users-kpi-title{color:var(--um-muted);margin:0;font-size:12px}.users-modern .users-kpi-value{color:#111827;margin:9px 0 2px;font-size:30px;font-weight:700}.users-modern .users-kpi-desc{color:var(--um-muted);margin:0;font-size:12px}.users-modern .users-kpi-icon{border-radius:999px;justify-content:center;align-items:center;width:46px;height:46px;font-size:18px;display:inline-flex}.users-modern .users-kpi-blue{color:#2563eb;background:#eff6ff}.users-modern .users-kpi-green{color:#16a34a;background:#ecfdf5}.users-modern .users-kpi-purple{color:#7c3aed;background:#f5f3ff}.users-modern .users-filter-card,.users-modern .users-table-card{background:var(--um-bg);border:1px solid var(--um-border);border-radius:12px;box-shadow:0 1px 2px #1018280a}.users-modern .users-filter-card{margin-bottom:14px}.users-modern{background:linear-gradient(#f9fcff 0%,#f0f6ff 58%,#eaf2ff 100%);border-radius:16px;padding:8px}.users-modern input,.users-modern select{background:var(--um-bg);color:#000;border:1px solid #d1d5db;border-radius:8px;min-height:28px;padding:3px 8px;line-height:1.2}.users-modern input::placeholder{color:#9ca3af}.users-modern table{background:var(--um-bg)}.users-modern th{background:var(--um-soft);color:var(--um-muted);text-transform:uppercase;letter-spacing:.02em;font-size:12px}.users-modern td{color:#374151;vertical-align:middle;border-bottom:1px solid #f3f4f6}.users-modern tbody tr{transition:background-color .2s}.users-modern tbody tr:hover{background:#f9fafb}.users-modern .filter-actions{flex-wrap:wrap;align-items:center}.users-modern button{border-radius:10px;min-height:36px;padding:8px 14px;font-size:13px}.users-modern button.secondary{color:#374151;box-shadow:none;background:#fff;border:1px solid #d1d5db}.users-modern button.secondary:hover{background:#f9fafb;border-color:#c4c9d4;transform:none}.users-modern .filter-actions>button:not(.secondary):not(.user-extra-dropdown-trigger){background:var(--um-primary);color:#fff}.users-modern .filter-actions>button:not(.secondary):not(.user-extra-dropdown-trigger):hover{background:var(--um-primary-dark)}.users-modern .user-extra-dropdown{position:relative}.users-modern .user-extra-dropdown-trigger{box-sizing:border-box;background:var(--um-bg);color:#1f2937;cursor:pointer;min-height:28px;box-shadow:none;white-space:nowrap;text-align:left;border:1px solid #d1d5db;border-radius:8px;justify-content:space-between;align-items:center;gap:8px;width:min(220px,36vw);padding:3px 8px;font-weight:500;display:inline-flex;transform:none}.users-modern .user-extra-dropdown-trigger:hover{background:var(--um-bg);border-color:var(--um-primary);transform:none}.users-modern .user-extra-dropdown-trigger.is-open{border-color:var(--um-primary-dark)}.users-modern .user-extra-dropdown-text{text-overflow:ellipsis;flex:1;font-size:13px;line-height:1.2;overflow:hidden}.users-modern .user-extra-dropdown-text.is-placeholder{color:#9ca3af}.users-modern .user-extra-dropdown-caret{opacity:.75;flex-shrink:0;font-size:11px}.users-modern .user-extra-dropdown-panel{z-index:40;background:#fff;border:1px solid #e5e7eb;border-radius:10px;min-width:230px;padding:10px 12px;position:absolute;top:calc(100% + 6px);left:0;box-shadow:0 12px 28px #1122361f}.users-modern .filter-actions>button.secondary{color:#fff;background:#dc2626;border:1px solid #dc2626}.users-modern .filter-actions>button.secondary:hover{background:#b91c1c;border-color:#b91c1c}.danger,.users-modern .danger,.users-modern button.danger{color:#fff;background:#dc2626;border-color:#dc2626}.danger:hover,.users-modern .danger:hover,.users-modern button.danger:hover{background:#b91c1c}.users-modern .batch-toolbar{border-bottom:1px solid #f3f4f6;padding:12px 14px}.users-modern .table-sort-btn{color:#4b5563;font-size:12px}.users-modern .table-sort-btn:hover{color:#1f2937}.users-modern .tag-badge{color:#4b5563;background:#f3f4f6;border:1px solid #e5e7eb}.users-modern .status-badge{font-size:11px}@media (width<=900px){.users-modern .users-kpi-grid{grid-template-columns:1fr}}.checkbox{color:#4f587a;align-items:center;gap:4px;display:inline-flex}.role-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.role-card{background:#fff;border:1px solid #eceff5;border-radius:12px;padding:16px}h1,h2{color:#dbe8ff}h3{margin:0}ul{margin:8px 0 0;padding-left:18px}.user-search-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.detail-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:16px;display:grid}.split-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-bottom:16px;display:grid}.textarea{resize:vertical;min-height:140px}@media (width<=900px){#app{padding:14px}.stats,.split-grid,.detail-grid,.role-grid,.user-search-grid,.login-card{grid-template-columns:1fr}.topbar,.command-bar{flex-direction:column;align-items:flex-start}.notify-drawer{width:calc(100vw - 16px);max-height:calc(100vh - 16px);top:8px;right:8px}.admin-layout{grid-template-columns:1fr}.admin-sidebar{position:static}.side-tabs{flex-flow:wrap}.nav-group{width:100%}.side-tab-btn{width:auto}}.dash-kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px;display:grid}.dash-kpi-card{background:linear-gradient(#f7fbff,#edf4ff);border:1px solid #d7e6fb;border-radius:14px;padding:16px 16px 14px;box-shadow:inset 0 1px #ffffffe6}.dash-kpi-head{justify-content:space-between;align-items:center;gap:10px;display:flex}.dash-kpi-icon{letter-spacing:.02em;background:#648cff24;border-radius:12px;justify-content:center;align-items:center;width:34px;height:34px;font-weight:800;display:inline-flex}.icon-blue{color:#2f6fcb;background:#e6f0ff}.icon-purple{color:#505fbf;background:#ecefff}.icon-cyan{color:#2f7ba4;background:#e7f6ff}.icon-green{color:#2f7f64;background:#eaf6f1}.dash-kpi-title{color:var(--text-sub);font-size:13px;font-weight:600}.dash-kpi-value{color:#1f3f68;margin-top:10px;font-size:28px;font-weight:800}.dash-kpi-sub{color:#6b83a3;margin-top:6px;font-size:12px}.dash-row-main{grid-template-columns:1.6fr 1fr;align-items:start;gap:16px;display:grid}.dash-card-title{color:#284f7d;margin:0 0 12px;font-size:16px}.bar-chart{align-items:flex-end;gap:10px;height:200px;padding:10px 6px 6px;display:flex;overflow-x:auto}.bar-col{flex-direction:column;flex:none;align-items:center;gap:8px;width:26px;display:flex}.bar{background:linear-gradient(#7fb2ff,#3f7fdd);border-radius:10px 10px 4px 4px;width:100%;box-shadow:0 8px 18px #3f7fdd38}.bar-label{color:#9fb0d5f2;white-space:nowrap;text-overflow:ellipsis;max-width:26px;font-size:11px;overflow:hidden}.bar-foot{margin-top:8px}.bar-foot-muted{color:#9fb0d5f2;font-size:12px}.bar-chart--dual .bar-col--dual{width:40px}.bar-pair{justify-content:center;align-items:flex-end;gap:4px;width:100%;height:160px;display:flex}.bar--active{background:linear-gradient(#a78bfa,#7c3aed);width:14px;box-shadow:0 6px 14px #7c3aed40}.bar--learned{background:linear-gradient(#7fb2ff,#3f7fdd);width:14px;box-shadow:0 6px 14px #3f7fdd38}.bar-foot{flex-wrap:wrap;gap:16px;display:flex}.bar-legend{color:#9fb0d5f2;align-items:center;gap:6px;font-size:12px;display:inline-flex}.bar-legend-dot{border-radius:3px;width:10px;height:10px;display:inline-block}.bar-legend-dot--active{background:linear-gradient(#a78bfa,#7c3aed)}.bar-legend-dot--learned{background:linear-gradient(#7fb2ff,#3f7fdd)}.dash-side-card{padding:18px}.dash-side-section+.dash-side-section{border-top:1px dashed #d5e3f6;margin-top:16px;padding-top:12px}.dash-side-subtitle{color:#3c6da8;margin-bottom:10px;font-weight:700}.dash-rank-list{flex-direction:column;gap:8px;display:flex}.dash-rank-item{background:#f5f9ff;border:1px solid #d6e4f8;border-radius:12px;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;display:flex}.rank-num{color:#2c5f9f;background:#e5efff;border-radius:8px;justify-content:center;align-items:center;width:22px;height:22px;font-weight:800;display:inline-flex}.rank-code{color:#24486f;flex:1;font-weight:600}.rank-count{color:#9fb0d5f2;font-size:12px}.dash-row-bottom{grid-template-columns:1fr 1fr;gap:16px;margin-top:16px;display:grid}.dash-deep-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.dash-deep-item{background:#f5f9ff;border:1px solid #d6e4f8;border-radius:14px;padding:14px}.dash-analytics-block{flex-direction:column;gap:0;margin-top:20px;display:flex}.dash-realtime-strip{background:linear-gradient(90deg,#eef5ff,#e7f0fd);border:1px solid #cfe0f6;margin-bottom:12px}.dash-realtime-inner{flex-wrap:wrap;align-items:center;gap:12px 20px;padding:4px 0;display:flex}.dash-realtime-dot{background:#3be4a3;border-radius:50%;width:10px;height:10px;animation:1.4s ease-in-out infinite dash-pulse;box-shadow:0 0 12px #3be4a3bf}@keyframes dash-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(.92)}}.dash-realtime-label{color:#254d7a;font-weight:600}.dash-realtime-metrics{color:#587598;font-size:14px}.dash-realtime-metrics strong{color:#1f4f82;margin:0 4px}.dash-submatrix{flex-direction:column;gap:8px;margin-top:14px;display:flex}.dash-subrow{color:#d2dcf4f2;flex-wrap:wrap;align-items:baseline;gap:10px 16px;font-size:14px;display:flex}.dash-subhead{color:#e8f0fffa;min-width:72px;font-weight:600}.dash-submuted{color:#9fb0d5d9;font-size:13px}.dash-footnote{color:#9fb0d5f2;margin-top:12px;font-size:13px;line-height:1.5}.dash-footnote.muted{color:#8c9ec0d9}.dash-table-card .dash-table-compact table{font-size:13px}.dash-table-card .dash-table-compact th,.dash-table-card .dash-table-compact td{padding:8px 10px}@media (width<=1100px){.dash-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dash-row-main,.dash-row-bottom{grid-template-columns:1fr}}:root{--bg-page:#eef2f7;--bg-card:#fff;--line-soft:#dde6f0;--text-main:#233444;--text-sub:#6a7f96;--primary:#325f8a;--primary-soft:#eaf1f8;--danger-soft:#fdebed;--shadow-soft:0 2px 8px #00000008}body{color:var(--text-main);background:radial-gradient(1200px 520px at 12% -10%,#547eaa29 0%,#0000 60%),radial-gradient(1000px 420px at 90% -18%,#799dc41f 0%,#0000 62%),linear-gradient(#edf2f8 0%,#e4ebf4 52%,#dbe4f0 100%)}#app{padding:0}.container{max-width:none;margin:0}.topbar{border:1px solid var(--line-soft);background:#fff;margin-bottom:14px;padding:16px 18px}.topbar-title h1,h1,h2{color:#1f2f3a}.topbar-title h1{font-size:24px}.topbar .subtitle{font-size:13px}.app-layout.admin-layout{border:1px solid var(--line-soft);background:#f2f6fb;border-radius:18px;grid-template-columns:260px minmax(0,1fr) 280px;gap:0;min-height:calc(100vh - 130px);display:grid;overflow:hidden}.admin-sidebar{background:linear-gradient(#1f3a56 0%,#1a324b 100%);border:1px solid #5e7fa047;border-radius:22px;margin:10px 8px 10px 10px;padding:0;overflow:hidden;box-shadow:0 14px 30px #14273b38,inset 0 1px #cedff014}.logo-area{background:linear-gradient(#325576e6 0%,#254563e0 100%);border:1px solid #83a7c947;border-radius:18px;margin:12px 10px 10px;padding:20px 18px;box-shadow:0 8px 18px #13283e38}.logo-area h2{color:#fff;margin:0;font-size:24px;font-weight:600}.logo-area span{color:#a9bfd2;margin-top:8px;font-size:12px;display:block}.nav-menu{background:#213e5a61;border:1px solid #799dbe3d;border-radius:20px;flex-direction:column;gap:10px;margin:12px 10px 14px;padding:14px 10px;display:flex;box-shadow:inset 0 1px #c6d8ea14,0 8px 20px #12253a33}.nav-item{text-align:left;color:#d5e2ee;background:linear-gradient(#416283c7 0%,#325372c2 100%);border:1px solid #8fadcb52;border-radius:16px;width:100%;padding:12px 16px;transform:none;box-shadow:0 4px 10px #0f213433}.nav-item:hover{background:linear-gradient(#4e7194e0 0%,#3c5e7ed6 100%);transform:none;box-shadow:0 7px 14px #1124383d}.nav-item.active{color:#fff;background:linear-gradient(#4e7fab 0%,#3f6f99 100%);border-color:#bbd4ec8a;box-shadow:0 8px 16px #18314a4d}.nav-item-expand{justify-content:space-between;align-items:center;display:flex}.sub-nav{gap:8px;margin:-2px 4px 2px 12px;display:grid}.nav-item.sub{background:linear-gradient(#2d4f6fb8 0%,#24425fb3 100%);border-radius:14px;padding:9px 12px;font-size:13px;box-shadow:0 3px 8px #10213338}.admin-main{padding:18px 18px 16px;overflow:auto}.admin-main .msg{display:none}.global-toast{z-index:60;color:#23456a;background:#f4f9ff;border:1px solid #d7e7fb;border-radius:12px;min-width:260px;max-width:520px;padding:10px 14px;position:fixed;top:18px;right:24px;box-shadow:0 8px 22px #15315429}.global-toast-error{color:#8b2f3e;background:#fff3f5;border-color:#f2c4cc}.help-sidebar{border-left:1px solid var(--line-soft);background:#fff;padding:24px 16px;overflow:auto}.help-title{color:#1f2f3a;margin:0 0 14px;font-size:16px}.help-card{background:#f8fafc;border:1px solid #eef2f6;border-radius:16px;margin-bottom:14px;padding:14px 16px}.help-card h4{color:#0b2b3b;margin:0 0 8px;font-size:14px}.help-card p{color:#4b5e6b;margin:0;font-size:12px;line-height:1.5}.login-form{flex-direction:column;justify-content:center;display:flex}.login-form h2{color:#fff;text-align:center;letter-spacing:.12em;word-spacing:0;margin-top:0;font-size:34px;line-height:1.2}.login-form .subtitle{text-align:center;margin-bottom:14px}.login-actions-row{align-items:center;gap:10px;margin-top:12px;display:flex}.login-actions-row>button{flex:1}.login-form input{box-sizing:border-box;width:100%;min-height:38px}.login-form .grid{width:100%;max-width:560px;margin:0 auto 12px}.login-card{grid-template-columns:1fr 1.3fr}.users-shell{background:linear-gradient(#f7fbff 0%,#eef5ff 52%,#e8f1fd 100%);border:1px solid #dbe8f6;border-radius:22px;padding:8px 10px;box-shadow:0 10px 24px #1e4a7314}.libraries-shell{background:linear-gradient(#f4f7fb 0%,#eef2f8 52%,#e8eef5 100%);border:1px solid #cfd9e6;border-radius:22px;padding:8px 10px;box-shadow:0 8px 22px #2d415812}.libraries-shell .page-body>.card.page-section{background:#fafbfd;border:1px solid #d4dee8;box-shadow:0 1px 5px #2d465f0d}.libraries-shell h2,.libraries-shell h3,.libraries-shell .page-section h3,.libraries-shell .page-title{color:#2a4358}.libraries-shell .page-subtitle,.libraries-shell .subtitle,.libraries-shell .page-body .subtitle{color:#5a6e84}.libraries-shell ul li{color:#3d546c}.libraries-shell .detail-grid strong{color:#38556f}.libraries-shell input,.libraries-shell select,.libraries-shell textarea{color:#000;background:#fff;border-color:#c4d2e2}.libraries-shell input:focus,.libraries-shell select:focus,.libraries-shell textarea:focus{border-color:#8aa3bc;box-shadow:0 0 0 3px #5a769624}.libraries-shell .role-card{background:linear-gradient(#f8fafc 0%,#f1f5f9 100%);border:1px solid #cad6e4}.libraries-shell .role-card h3{color:#2f4a61}.libraries-shell .table-wrap.user-table-wrapper{border-color:#ced8e4}.libraries-shell .split-grid>div{background:#f7f9fc;border:1px solid #dde5ef;border-radius:12px;padding:12px 14px}.libraries-shell button:not(.secondary):not(.danger):not(:disabled){background:linear-gradient(135deg,#4d6b82 0%,#5f7f96 100%);box-shadow:0 4px 12px #34485a33}.libraries-shell button:not(.secondary):not(.danger):not(:disabled):hover{box-shadow:0 6px 16px #34485a42}.libraries-shell button.secondary{color:#3d566d;background:#e6edf5;border:1px solid #c8d6e6}.libraries-shell button.secondary:hover{background:#dbe4ee}.tabs-bar{border-bottom:1px solid #e2e8f0;gap:28px;margin-bottom:20px;display:flex}.tab-item{color:#5b6f82;background:0 0;border-bottom:2px solid #0000;border-radius:0;padding:0 0 10px;font-size:14px;font-weight:600}.tab-item.active{color:#1e5d7a;border-bottom-color:#1e5d7a}.tab-item:hover{box-shadow:none;transform:none}.filter-bar{background:#fff;border:1px solid #edf2f7;border-radius:20px;padding:16px 18px}.filter-row{flex-wrap:wrap;gap:12px;margin-bottom:12px;display:flex}.filter-main-row{flex-wrap:wrap;align-items:flex-end;gap:6px;display:flex}.filter-main-row .filter-row{flex:1;margin-bottom:0}.filter-main-row .filter-group{flex-direction:row;align-items:center;gap:6px;min-width:240px}.filter-main-row .filter-group label{white-space:nowrap;min-width:44px;margin:0;font-size:12px}.filter-group{flex-direction:column;gap:6px;min-width:132px;display:flex}.filter-group label{color:#5b6f82;font-size:12px;font-weight:600}.filter-actions{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.filter-more-panel{margin-bottom:8px}.filter-actions .filter-more-panel{margin-bottom:0}.filter-more-panel>summary{cursor:pointer;color:#1e5d7a;-webkit-user-select:none;user-select:none;background:#eef6fb;border:1px solid #d7eaf6;border-radius:10px;padding:4px 8px;font-size:12px;font-weight:600;display:inline-block}.filter-more-panel[open]>summary{margin-bottom:6px}.filter-option-list{flex-wrap:wrap;gap:8px 12px;display:flex}.filter-row-more{gap:8px;margin-bottom:0}.filter-row-more .filter-group{flex-direction:row;align-items:center;gap:6px;min-width:240px}.filter-row-more .filter-group label{white-space:nowrap;min-width:56px;margin:0;font-size:12px}.user-table-wrapper{background:#fff;border:1px solid #edf2f7;border-radius:22px;overflow:auto}.user-table-wrapper table{font-size:13px}.user-table-wrapper th{color:#2c4d62;text-align:center;vertical-align:middle;white-space:nowrap;background:#fafcff;padding:14px;font-size:13px;font-weight:700}.user-table-wrapper td{color:#2f3e4d;vertical-align:middle;padding:12px 14px;font-size:13px}.user-table-wrapper td button,.user-table-wrapper th button,.learning-strategy-table{font-size:13px}.learning-strategy-table th{color:#2c4d62;text-align:center;vertical-align:middle;white-space:nowrap;background:#fafcff;padding:14px;font-size:13px;font-weight:700}.learning-strategy-table td{color:#2f3e4d;vertical-align:middle;padding:12px 14px;font-size:13px}.user-info{align-items:center;gap:10px;display:flex}.avatar{color:#1e5d7a;background:#e2edf5;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-weight:700;display:flex}.avatar.avatar-img{object-fit:cover;background:#e2edf5;display:block}.user-name{font-size:13px;font-weight:600}.user-email{color:#7b8c9e;font-size:11px}.word-stats{color:#2c6b2f;background:#e9f6ef;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:700}.action-icons{gap:8px;display:flex}.action-icons span{color:#66819b;cursor:pointer;background:#f5f9fe;border-radius:999px;padding:4px 9px;font-size:11px}.batch-toolbar{justify-content:space-between;align-items:center;gap:10px;padding:12px 14px 0;display:flex}.table-sort-btn{color:inherit;background:0 0;border:0;align-items:center;gap:6px;padding:0;font-size:12px;font-weight:700;display:inline-flex}.table-sort-btn:hover{box-shadow:none;transform:none}.empty-row{text-align:center;color:#74879b;padding:20px 12px!important}.learning-binding-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.strategy-list-head,.learning-analysis-head{justify-content:space-between;align-items:center;gap:10px;margin-bottom:6px;display:flex}.learning-analysis-head h2,.strategy-list-head h2{margin:0}.binding-actions-cell{vertical-align:middle}.binding-actions{flex-wrap:wrap;gap:8px;padding:2px 0;display:flex}.binding-actions button{border-radius:10px;padding:5px 10px;font-size:12px;line-height:1.2}.trend-text{color:#73879b;font-size:12px}.trend-up{color:#2f8a5a}.trend-down{color:#b44747}.stats-dashboard{background:#fff;border:1px solid #edf2f7;border-radius:24px;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;padding:16px;display:grid}.stat-card{background:#f9fefb;border:1px solid #e2f0e8;border-radius:16px;padding:14px}.stat-card p{margin-top:8px;font-size:22px;font-weight:700}.strategy-curve{background:#fbfcfe;border:1px solid #e8edf5;border-radius:14px;margin-top:6px;padding:12px}.curve-svg{width:100%;height:120px;margin:8px 0 6px;display:block}.curve-line{fill:none;stroke:#1e5d7a;stroke-width:2.5px}.curve-labels{color:#6c7d92;justify-content:space-between;font-size:11px;display:flex}.card{border:1px solid var(--line-soft);box-shadow:var(--shadow-soft);background:#fff}button{padding:8px 14px;font-size:13px;font-weight:600}.secondary{color:#4f647b}.msg{color:#6a7d92;font-size:13px}.subtitle{color:#6a7d92;font-size:12px}.user-portrait .portrait-section{border-top:1px solid #407cf426;margin-top:18px;padding-top:12px}.user-portrait .portrait-section:first-of-type{border-top:0;margin-top:0;padding-top:0}.portrait-kpi-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;display:grid}.portrait-label{color:#4f647b;margin:0 0 8px;font-size:12px;font-weight:700}.portrait-heading{margin:0 0 12px;font-size:14px;font-weight:700}.portrait-table{font-size:13px}.portrait-table th,.portrait-table td{vertical-align:middle}.portrait-list{max-height:260px;margin:8px 0 0;padding-left:18px;font-size:13px;overflow:auto}.calendar-toolbar,.timeline-toolbar{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:10px;display:flex}.narrow-input{width:88px}.timeline-preview{font-size:13px}.portrait-log-table td.log-snippet{white-space:nowrap;text-overflow:ellipsis;max-width:280px;overflow:hidden}.admin-permission-table{table-layout:fixed;background:#fff;min-width:1180px}.admin-permission-table th{color:#1f3a56;text-align:center;vertical-align:top;background:#f4f8fd;border-bottom:1px solid #e3ebf5;padding:12px 10px;font-size:13px;font-weight:700}.admin-permission-table td{color:#22313d;background:#fff;border-bottom:1px solid #edf2f7;line-height:1.5}.admin-permission-table td .subtitle{color:#5f7389}.admin-permission-table th:first-child,.admin-permission-table td:first-child{width:12%}.admin-permission-table th:nth-child(2),.admin-permission-table td:nth-child(2){width:8%}.admin-permission-table th:nth-child(3),.admin-permission-table td:nth-child(3){width:14%}.admin-permission-table th:nth-child(4),.admin-permission-table td:nth-child(4){width:24%}.admin-permission-table th:nth-child(5),.admin-permission-table td:nth-child(5){width:16%}.admin-permission-table th:nth-child(6),.admin-permission-table td:nth-child(6){width:12%}.admin-permission-table th:nth-child(7),.admin-permission-table td:nth-child(7){width:14%}.admin-list-table th.admin-table-check-col,.admin-list-table td.admin-table-check-col{text-align:center;vertical-align:top;width:48px;max-width:52px;padding-left:10px;padding-right:10px}.admin-list-table th:nth-child(2),.admin-list-table td:nth-child(2){width:11%}.admin-list-table th:nth-child(3),.admin-list-table td:nth-child(3){width:8%}.admin-list-table th:nth-child(4),.admin-list-table td:nth-child(4){width:13%}.admin-list-table th:nth-child(5),.admin-list-table td:nth-child(5){width:18%}.admin-list-table th:nth-child(6),.admin-list-table td:nth-child(6),.admin-list-table th:nth-child(7),.admin-list-table td:nth-child(7){width:11%}.admin-list-table th:nth-child(8),.admin-list-table td:nth-child(8){width:auto;min-width:112px}.batch-delete-admins-btn.danger{color:#fff;background:#dc2626}.batch-delete-admins-btn.danger:hover:not(:disabled){background:#b91c1c}.batch-delete-admins-btn.danger:disabled{opacity:.5;cursor:not-allowed}.role-permission-panel{padding:12px 10px 10px}.role-permission-toolbar{flex-wrap:wrap;align-items:center;gap:12px 14px;margin-bottom:10px;display:flex}.role-permission-toolbar .filter-group{min-width:220px}.role-permission-toolbar .role-permission-role-field{flex-direction:row;align-items:center;gap:10px;margin-top:4px}.role-permission-toolbar .role-permission-role-field label{white-space:nowrap;margin:0}.role-permission-toolbar .role-permission-role-field select{min-width:280px}.role-permission-tip{margin:10px 0 0;padding-left:4px}.role-permission-matrix{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:8px 12px;max-height:min(560px,65vh);margin-top:14px;padding:4px;display:grid;overflow:auto}.role-permission-checkbox{cursor:pointer;background:#fbfcfe;border:1px solid #edf2f7;border-radius:10px;align-items:flex-start;gap:8px;padding:8px 10px;font-size:12px;display:flex}.role-permission-checkbox input[disabled]~.role-permission-code,.role-permission-checkbox input[disabled]~.role-permission-name{opacity:.72}.role-permission-checkbox .role-permission-code{color:#1e5d7a;flex:none;font-weight:700}.role-permission-checkbox .role-permission-name{color:#5f7389;line-height:1.35}.admin-permission-table td.admin-table-op-col,.admin-permission-table th.admin-table-op-col{text-align:center;vertical-align:middle;white-space:nowrap;min-width:128px}.admin-table-row-actions{box-sizing:border-box;flex-flow:row;justify-content:center;align-items:center;gap:8px 10px;max-width:100%;margin-top:0;padding:2px 6px;display:flex}.admin-table-row-actions>button{flex:none}button.secondary.btn-disabled,button.secondary:disabled.btn-disabled{opacity:.42;cursor:not-allowed;color:#9aa8b8!important;box-shadow:none!important;background:#e8ecf0!important;border-color:#d5dde6!important}.table-op-cell{text-align:center;vertical-align:middle;white-space:nowrap}.table-op-dropdown{display:inline-block;position:relative}.table-op-trigger{letter-spacing:.08em;min-width:40px;font-size:20px;line-height:1;padding:4px 12px!important}.table-op-trigger.is-open{background:#e8f4fd;border-color:#7ecef7}.table-op-panel{z-index:80;background:#fff;border:1px solid #e2e8f0;border-radius:10px;min-width:148px;padding:6px;position:absolute;top:calc(100% + 4px);right:0;box-shadow:0 10px 28px #0f172a24}.table-op-item{text-align:left;color:#2f3e4d;cursor:pointer;background:0 0;border:none;border-radius:8px;width:100%;margin:0;padding:10px 12px;font-size:13px;display:block}.table-op-item:hover{color:#1e5d7a;background:#f0f7ff}.admin-list-table td:nth-child(6)>div,.admin-list-table td:nth-child(5) .subtitle{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.word-meaning-preview{color:#2f3e4d;margin-right:8px}.word-meaning-more-btn{border-radius:999px;min-width:28px;padding:2px 8px;font-size:12px;line-height:1.2}.word-list-actions{flex-wrap:nowrap;align-items:center;gap:8px}.word-list-actions>button{min-width:64px;padding:4px 14px;line-height:1.1}.marketing-split-head{justify-content:space-between;align-items:center;gap:10px;margin-bottom:6px;display:flex}.marketing-split-head h3{margin:0}.marketing-prop-sheet{background:#fff;border:1px solid #e5e7eb;border-radius:4px;overflow:hidden}.marketing-prop-row{border-bottom:1px solid #e8ecf0;align-items:center;min-height:36px;display:flex}.marketing-prop-row:last-child{border-bottom:none}.marketing-prop-row--tall{align-items:flex-start}.marketing-prop-label{color:#374151;white-space:nowrap;background:#fff;flex:0 0 112px;padding:8px 12px;font-size:13px}.marketing-prop-label:after{content:"："}.marketing-prop-value{flex:1;min-width:0;padding:6px 12px 6px 0}.marketing-prop-row--tall .marketing-prop-label{padding-top:10px}.marketing-prop-value input,.marketing-prop-value select,.marketing-prop-value textarea{box-sizing:border-box;color:#111827;background:#fff;border:1px solid #d1d5db;border-radius:4px;width:100%;font-size:13px}.marketing-prop-value input:focus,.marketing-prop-value select:focus,.marketing-prop-value textarea:focus{border-color:#9ca3af;outline:none;box-shadow:0 0 0 2px #9ca3af33}.marketing-prop-value textarea{resize:vertical;min-height:72px}.shop-product-editor{background:#fff;border:1px solid #e5e7eb;border-radius:4px;margin-top:8px;padding:14px 16px 16px}.shop-product-editor__title{color:#111827;margin:0 0 12px;font-size:15px;font-weight:600}.marketing-push-head{margin-top:10px}.marketing-head-actions{justify-content:flex-end;margin-top:0}.marketing-layout{flex-direction:column;padding:0 4px 8px;display:flex}.marketing-tab-frame{background:#fff;border:1px solid #c8c8c8;border-radius:2px;overflow:hidden}.marketing-tabs{background:#f0f0f0;border-bottom:1px solid #c8c8c8;flex-wrap:wrap;align-items:flex-end;gap:0;margin:0;padding:8px 8px 0;display:flex}.marketing-tabs__item{color:#333;cursor:pointer;box-shadow:none;white-space:nowrap;background:#e8e8e8;border:1px solid #c8c8c8;border-bottom:none;border-radius:3px 3px 0 0;margin:0 2px 0 0;padding:5px 14px 6px;font-size:13px;font-weight:400;line-height:1.35;position:relative;transform:none}.marketing-tabs__item:hover:not(.active){color:#111;box-shadow:none;background:#f5f5f5;transform:none}.marketing-tabs__item.active{color:#111;z-index:1;background:#fff;border-color:#c8c8c8 #c8c8c8 #fff;border-bottom-style:solid;border-bottom-width:1px;margin-bottom:-1px;padding-bottom:7px;font-weight:600}.marketing-panel{flex:1;min-width:0}.marketing-tab-panel{background:#fff;border:none;border-radius:0;padding:0}.marketing-tab-panel>.card.page-section{box-shadow:none;border:none;border-radius:0;margin:0;padding:16px 18px 18px}.marketing-shell{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0f172a0f}.marketing-shell .page-body>.card.page-section{box-shadow:none;background:#fff;border:1px solid #e5e7eb}.marketing-shell .announce-primary{box-shadow:none;border-color:#e5e7eb}.marketing-shell .section-hint{margin:-4px 0 14px}.marketing-shell .page-title,.marketing-shell h2,.marketing-shell h3{color:#111827}.marketing-shell .subtitle,.marketing-shell .page-subtitle{color:#6b7280}.marketing-shell .table-wrap{background:#fff;border-color:#e5e7eb}.marketing-shell input,.marketing-shell select,.marketing-shell textarea{color:#111827;background:#fff;border-color:#d1d5db}.marketing-shell button:not(.secondary):not(.danger):not(:disabled):not(.marketing-tabs__item){background:linear-gradient(135deg,#4d6b82 0%,#5f7f96 100%);box-shadow:0 4px 12px #34485a33}.marketing-shell button:not(.secondary):not(.danger):not(:disabled):not(.marketing-tabs__item):hover{box-shadow:0 6px 16px #34485a42}.marketing-shell button.secondary{color:#374151;background:#fff;border:1px solid #d1d5db}.marketing-shell button.secondary:hover{background:#f9fafb}.user-tag-modal.modal-sheet .marketing-prop-sheet{margin-bottom:12px}.user-tag-modal.modal-sheet .marketing-prop-label{flex:0 0 96px}.log-filter-shell .user-extra-dropdown{position:relative}.log-filter-shell .user-extra-dropdown-trigger{box-sizing:border-box;color:#4b5563;cursor:pointer;min-height:34px;box-shadow:none;white-space:nowrap;text-align:left;background:#f3f4f6;border:1px solid #d1d5db;border-radius:8px;justify-content:space-between;align-items:center;gap:8px;width:min(220px,36vw);padding:6px 10px;font-weight:500;display:inline-flex;transform:none}.log-filter-shell .user-extra-dropdown-trigger:hover{background:#f3f4f6;border-color:#3b82f6;transform:none}.log-filter-shell .user-extra-dropdown-trigger.is-open{background:#f3f4f6;border-color:#2563eb}.log-filter-shell .user-extra-dropdown-text{text-overflow:ellipsis;flex:1;font-size:13px;line-height:1.2;overflow:hidden}.log-filter-shell .user-extra-dropdown-text.is-placeholder{color:#6b7280}.log-filter-shell .user-extra-dropdown-caret{opacity:.75;flex-shrink:0;font-size:11px}.log-filter-shell .user-extra-dropdown-panel{z-index:40;background:#fff;border:1px solid #e5e7eb;border-radius:10px;min-width:230px;padding:10px 12px;position:absolute;top:calc(100% + 6px);left:0;box-shadow:0 12px 28px #1122361f}.monitoring-page{flex-direction:column;min-height:calc(100vh - 120px);display:flex}.monitoring-head{border-bottom:1px solid var(--line-soft);justify-content:space-between;align-items:flex-start;gap:16px;padding:18px 20px 8px;display:flex}.monitoring-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.monitoring-open-link{border-radius:var(--radius-control);color:var(--text-main);border:1px solid var(--line-soft);background:#ffffff0f;align-items:center;padding:8px 14px;font-size:13px;font-weight:600;text-decoration:none;display:inline-flex}.monitoring-open-link:hover{background:#3a79ff26}.monitoring-title{margin:0;font-size:20px;font-weight:700}.monitoring-sub{color:var(--text-sub);margin:6px 0 0;font-size:13px}.monitoring-body{flex-direction:column;flex:1;min-height:0;padding:12px 16px 20px;display:flex}.monitoring-frame-wrap{border:1px solid var(--line-soft);background:#0f172a;border-radius:12px;flex:1;min-height:360px;overflow:hidden}.monitoring-frame-wrap--full{min-height:calc(100vh - 220px)}.monitoring-frame-wrap--panel{min-height:320px}.monitoring-panels-grid{flex:1;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px;display:grid}.monitoring-iframe{width:100%;height:100%;min-height:inherit;background:#fff;border:0;display:block}.monitoring-hint{color:#fde68a;background:#eab3081f;border:1px solid #eab30859;border-radius:10px;margin:0 0 12px;padding:10px 12px;font-size:13px;line-height:1.5}
