:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--background:#f4f6fb;--surface:#fff;--surface-soft:#f8fafc;--surface-raised:#fff;--foreground:#0f172a;--muted:#64748b;--muted-strong:#334155;--border:#e2e8f0;--border-soft:#f1f5f9;--accent:#4f46e5;--accent-dark:#4338ca;--accent-soft:#eef2ff;--accent-border:#c7d2fe;--success:#059669;--success-dark:#047857;--success-bg:#ecfdf5;--success-border:#a7f3d0;--warning:#d97706;--warning-bg:#fffbeb;--danger:#dc2626;--danger-dark:#b91c1c;--danger-bg:#fef2f2;--danger-border:#fecaca;--shadow:0 20px 40px -12px #0f172a1a;--shadow-soft:0 10px 24px -8px #0f172a0f;--glass-bg:#ffffffbf;--glass-border:#fff6}*{box-sizing:border-box}html,body{background:radial-gradient(circle at 10% 0%, #4f46e514, transparent 40rem), radial-gradient(circle at 90% 100%, #a855f70d, transparent 40rem), var(--background);min-height:100%;color:var(--foreground);font-family:var(--font-inter,Arial), "Microsoft YaHei", sans-serif;-webkit-tap-highlight-color:transparent;margin:0}a{color:inherit;text-decoration:none}a,button{touch-action:manipulation}button,input,select{font:inherit}input,select{width:100%;min-height:40px;color:var(--foreground);background:#fff;border:1px solid #cfd8e6;border-radius:8px;padding:0 12px;transition:background-color .14s,border-color .14s,box-shadow .14s,transform 80ms}input:hover,select:hover{border-color:#b8c4d6}input:focus,select:focus{border-color:var(--accent);outline:0;box-shadow:0 0 0 3px #2563eb1f,0 1px 2px #0f172a0d}.filter-bar{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.filter-bar select{width:auto;min-width:140px}.shell{max-width:1040px;margin:0 auto;padding:40px 24px}.admin-shell{grid-template-columns:250px minmax(0,1fr);min-height:100vh;transition:grid-template-columns .24s cubic-bezier(.22,1,.36,1);display:grid}.admin-shell.sidebar-collapsed{grid-template-columns:76px minmax(0,1fr)}.sidebar{color:#fff;background:#111827;flex-direction:column;gap:26px;height:100vh;padding:24px 18px;transition:gap .22s,padding .22s,box-shadow .22s;display:flex;position:sticky;top:0;overflow:hidden auto}.brand-block{align-items:center;gap:12px;padding:4px 6px;transition:gap .22s,padding .22s;display:flex}.brand-icon{background:#1f3b73;border-radius:8px;justify-content:center;align-items:center;width:38px;height:38px;transition:transform .22s;display:inline-flex}.brand-block p,.brand-block h1{margin:0}.brand-block p{color:#9ca3af;font-size:12px}.brand-block h1{font-size:18px}.brand-copy,.sidebar-user-copy,.side-nav span{opacity:1;visibility:visible;min-width:0;transition:opacity .16s,transform .22s,max-width .22s,visibility .16s;overflow:hidden;transform:translate(0)}.brand-copy,.side-nav span,.sidebar-user-copy{max-width:150px}.sidebar-toggle{color:#d1d5db;cursor:pointer;background:0 0;border:1px solid #374151;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;margin-left:auto;padding:0;transition:background-color .14s,border-color .14s,color .14s,transform .2s;display:inline-flex}.sidebar-toggle:hover{color:#fff;background:#1f2937}.side-nav{gap:6px;display:grid}.side-nav a{color:#d1d5db;border-radius:8px;align-items:center;gap:10px;min-height:40px;padding:0 12px;transition:background-color .14s,color .14s,gap .22s,padding .22s,width .22s;display:flex}.side-nav a:hover,.side-nav a.active{color:#fff;background:#1f2937}.side-nav a.active{box-shadow:inset 3px 0 0 var(--accent)}.sidebar-user{border-top:1px solid #374151;align-items:center;gap:10px;margin-top:auto;padding:18px 6px 0;transition:gap .22s,padding .22s;display:flex}.avatar{color:#1d4ed8;background:#e8eefc;border-radius:999px;flex:0 0 34px;justify-content:center;align-items:center;width:34px;height:34px;font-weight:700;line-height:1;display:inline-flex}.sidebar-user strong,.sidebar-user span{display:block}.sidebar-user .avatar{display:inline-flex}.sidebar-user span:not(.avatar){color:#9ca3af;margin-top:2px;font-size:12px}.sidebar-logout{color:#9ca3af;cursor:pointer;background:0 0;border:1px solid #374151;border-radius:8px;flex:0 0 34px;justify-content:center;align-items:center;width:34px;height:34px;margin-left:auto;padding:0;transition:background-color .14s,border-color .14s,color .14s,margin .22s;display:inline-flex}.sidebar-logout:hover{color:#fff;background:#1f2937}.sidebar-collapsed .sidebar{align-items:center;gap:22px;padding-left:12px;padding-right:12px}.sidebar-collapsed .brand-block{justify-items:center;gap:10px;padding:0;display:grid}.sidebar-collapsed .brand-copy,.sidebar-collapsed .side-nav span,.sidebar-collapsed .sidebar-user-copy{opacity:0;visibility:hidden;max-width:0;transform:translate(-6px)}.sidebar-collapsed .sidebar-toggle{margin-left:0}.sidebar-collapsed .side-nav a{justify-content:center;width:42px;height:42px;padding:0}.sidebar-collapsed .side-nav a.active{box-shadow:inset 3px 0 0 var(--accent)}.sidebar-collapsed .sidebar-user{border-top:1px solid #374151;justify-content:center;gap:10px;width:100%;padding-left:0;padding-right:0;display:grid}.sidebar-collapsed .sidebar-logout{margin-left:0}.content-shell{width:100%;min-width:0;max-width:100%;padding:30px}.mobile-bottom-nav,.mobile-more-panel,.mobile-nav-backdrop{display:none}.stack{gap:18px;min-width:0;display:grid}.panel{background:linear-gradient(180deg, var(--surface-raised), #fbfdff);box-shadow:var(--shadow-soft);border:1px solid #dce5f2;border-radius:8px;min-width:0;padding:20px}.muted{color:var(--muted)}.page-header,.section-heading,.question-meta{justify-content:space-between;align-items:center;gap:14px;display:flex}.page-header,.section-heading{min-width:0}.page-header h1,.section-heading h2,.section-heading h3{color:#111827}.page-header h1,.section-heading h2{letter-spacing:0;margin:0}.page-header p,.section-heading p{margin:0 0 4px}.auth-shell{background:radial-gradient(circle at 20% 20%,#2563eb14,#0000 32%),linear-gradient(135deg,#f8fbff 0%,#eef4fb 100%);place-items:center;min-height:100vh;padding:24px;display:grid}.auth-panel{width:min(460px,100%)}.guest-shell{background:#f5f7fb;min-height:100vh;padding:28px}.guest-shell>.stack{max-width:1180px;margin:0 auto}.auth-link-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.auth-card{background:#fffffff5;border:1px solid #d8e1ee;border-radius:8px;padding:28px;box-shadow:0 24px 60px #0f172a1f}.account-security-layout{gap:18px;width:min(760px,100%);display:grid}.account-security-layout .auth-panel{width:100%}.account-center-layout{gap:16px;min-width:0;max-width:980px;display:grid}.account-center-hero{background:linear-gradient(135deg, #e8f0ffeb, #fffffff5 48%, #e7f6ee85), var(--surface);border-color:#cbd9f4}.account-center-tabs{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-soft);background:#fff9;border-radius:12px;flex-wrap:wrap;align-items:center;gap:6px;padding:6px;display:flex;box-shadow:0 4px 16px #0f172a08}.account-center-tabs button{color:var(--muted-strong);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:8px;min-height:36px;padding:0 16px;font-weight:600;transition:all .2s;display:inline-flex}.account-center-tabs button:hover{color:var(--foreground);background:#0f172a0a}.account-center-tabs button.active{background:var(--foreground);color:var(--background);box-shadow:0 4px 12px #0f172a26}.account-center-tabs small{color:inherit;text-align:center;background:#0f172a0f;border-radius:999px;min-width:22px;padding:2px 7px;transition:all .2s}.account-center-tabs button.active small{color:#fff;background:#fff3}.account-center-section{animation:.16s ease-out panelIn}.account-password-form{max-width:560px}.account-history-list{border-top:0;margin-top:0;padding-top:0}@keyframes panelIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.session-device-list{gap:10px;display:grid}.session-device-row{background:var(--surface);border:1px solid var(--border-soft);border-radius:10px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;padding:12px 16px;transition:border-color .2s,box-shadow .2s;display:grid}.session-device-row:hover{border-color:var(--border);box-shadow:0 4px 12px #0f172a08}.session-device-row strong{color:var(--text);font-size:14px;display:block}.session-device-row small{color:var(--muted);margin-top:4px;font-size:12px;display:block}.session-device-table .data-row{align-items:center}.session-device-table .table-actions,.session-device-table .table-actions .confirm-action,.session-device-table .table-actions button{white-space:nowrap}.session-history-heading{margin-top:20px}.session-history-list{border-top:1px solid #e2e8f0;gap:8px;margin-top:18px;padding-top:16px;display:grid}.session-history-list h2{color:var(--text);letter-spacing:0;margin:0 0 4px;font-size:16px}.session-history-row{background:var(--surface);border:1px solid var(--border-soft);border-radius:10px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;padding:12px 16px;transition:border-color .2s,box-shadow .2s;display:grid}.session-history-row:hover{border-color:var(--border);box-shadow:0 4px 12px #0f172a08}.session-history-row strong{color:var(--text);font-size:13px;display:block}.session-history-row small,.session-history-row span{color:var(--muted);font-size:12px}.auth-heading{gap:6px;margin-bottom:20px;display:grid}.auth-heading h1{color:#111827;letter-spacing:0;margin:0;font-size:28px}.auth-heading span{color:var(--muted);font-size:14px;line-height:1.6}.form-stack{gap:14px;display:grid}.form-stack label,.render-toolbar label{color:var(--muted);gap:6px;font-size:13px;display:grid}.password-input{grid-template-columns:minmax(0,1fr) auto;align-items:stretch;display:grid}.password-input input{border-top-right-radius:0;border-bottom-right-radius:0}.password-toggle{border:1px solid var(--line);color:#1f2937;cursor:pointer;white-space:nowrap;background:#eef4fb;border-left:0;border-radius:0 8px 8px 0;padding:0 12px;font-weight:700}.password-toggle:hover{color:var(--accent-dark);background:#dbeafe}.password-strength{color:var(--muted);gap:6px;font-size:12px;display:grid}.password-strength-bar{background:#e5eaf3;border-radius:999px;height:7px;display:block;overflow:hidden}.password-strength-bar i{background:#94a3b8;width:6%;height:100%;transition:width .16s,background-color .16s;display:block}.password-strength-1 .password-strength-bar i{background:#ef4444;width:25%}.password-strength-2 .password-strength-bar i{background:#f59e0b;width:50%}.password-strength-3 .password-strength-bar i{background:#22c55e;width:75%}.password-strength-4 .password-strength-bar i{background:#16a34a;width:100%}.password-match-hint{color:var(--danger)}.password-match-hint.is-match{color:var(--success)}.credential-save-panel{background:#fff7ed;border:1px solid #fdba74;border-radius:8px;gap:14px;margin-top:16px;padding:16px;display:grid}.credential-save-heading{gap:6px;display:grid}.credential-save-heading strong{color:#9a3412;font-size:16px}.credential-save-heading p{color:#7c2d12;margin:0;line-height:1.6}.credential-save-values{gap:8px;display:grid}.credential-save-row{background:#fff;border:1px solid #fed7aa;border-radius:8px;grid-template-columns:72px minmax(0,1fr);align-items:center;gap:8px;padding:10px 12px;display:grid}.credential-save-row span{color:#9a3412;font-size:13px;font-weight:700}.credential-save-row code{color:#111827;overflow-wrap:anywhere;word-break:break-word;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace}.credential-save-actions{flex-wrap:wrap;gap:10px;display:flex}.credential-save-confirm{color:#1f2937;align-items:center;gap:8px;font-size:14px;font-weight:700;display:flex}.credential-save-confirm input{width:16px;height:16px}.credential-login-button{width:100%}.toolbar-form{grid-template-columns:minmax(160px,1.2fr) 150px minmax(190px,1fr) auto;align-items:center;gap:12px;margin-top:14px;display:grid}.ui-button,.primary-button,.secondary-button,.danger-button{cursor:pointer;white-space:nowrap;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:7px;min-height:40px;padding:0 14px;font-weight:700;transition:background-color .14s,border-color .14s,box-shadow .14s,color .14s,transform 80ms;display:inline-flex;position:relative;box-shadow:0 1px 2px #0f172a14,inset 0 1px #ffffff1f}.button-spinner{opacity:0;pointer-events:none;align-items:center;transition:opacity .14s;display:inline-flex;position:absolute;left:10px}.button-spinner.is-visible{opacity:1}.ui-button-loading>.lucide{opacity:0}.ui-button:disabled,.primary-button:disabled,.secondary-button:disabled,.danger-button:disabled{cursor:not-allowed;opacity:.62}.ui-button:focus-visible,.primary-button:focus-visible,.secondary-button:focus-visible,.danger-button:focus-visible,.pagination-bar button:focus-visible{outline:0;box-shadow:0 0 0 3px #2563eb2e}.ui-button:not(:disabled):active,.primary-button:not(:disabled):active,.secondary-button:not(:disabled):active,.danger-button:not(:disabled):active{transform:translateY(1px)}.ui-button-primary,.primary-button{border-color:var(--accent);background:var(--accent);color:#fff}.ui-button-primary:hover,.primary-button:hover{background:var(--accent-dark);box-shadow:0 8px 18px #2563eb2e}.ui-button-success{background:var(--success);border-color:var(--success);color:#fff}.ui-button-success:hover{background:var(--success-dark);border-color:var(--success-dark);box-shadow:0 8px 18px #16794c29}.ui-button-secondary,.secondary-button{background:var(--accent-soft);border-color:var(--accent-border);color:#1e3a8a}.ui-button-secondary:hover,.secondary-button:hover{background:#dbe8ff;border-color:#8fb1fb;box-shadow:0 7px 16px #2563eb1a}.ui-button-danger,.danger-button{background:var(--danger);border-color:var(--danger);color:#fff}.ui-button-danger:hover,.danger-button:hover{background:var(--danger-dark);border-color:var(--danger-dark);box-shadow:0 8px 18px #b4231829}.ui-button-ghost{box-shadow:none;color:var(--muted-strong);background:0 0;border-color:#0000}.ui-button-ghost:hover{background:var(--surface-soft);border-color:var(--border-soft);color:var(--foreground)}.spin{animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.ui-badge,.role-badge,.count-pill,.type-pill{border-radius:999px;justify-content:center;align-items:center;min-height:26px;padding:0 9px;font-size:12px;font-weight:700;display:inline-flex}.badge-blue,.role-badge,.count-pill{color:#1d4ed8;background:#e8eefc}.badge-green,.type-choice{background:var(--success-bg);color:var(--success)}.badge-amber,.type-operation,.type-unknown{background:var(--warning-bg);color:var(--warning)}.badge-red{background:var(--danger-bg);color:var(--danger)}.badge-neutral{color:var(--muted-strong);background:#eef2f6}.status-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;display:grid}.status-item{background:linear-gradient(#fff,#f8fbff);border:1px solid #dfe7f2;border-radius:8px;padding:16px;transition:border-color .14s,box-shadow .14s,transform 80ms;box-shadow:0 8px 20px #0f172a0a}.status-item,.settings-grid label,.summary-list>div,.practice-admin-groups>div,.bank-set-links a,.question-set-item,.practice-feedback-mode{box-shadow:0 1px 2px #0f172a08}.status-item:hover{border-color:#c4d3e8;transform:translateY(-1px);box-shadow:0 12px 28px #0f172a12}.status-item svg{background:var(--accent-soft);border:1px solid var(--accent-border);box-sizing:content-box;color:var(--accent);border-radius:8px;padding:7px}.status-label{color:var(--muted);margin:10px 0 5px;font-size:13px}.status-value{overflow-wrap:anywhere;margin:0;font-weight:700}.table-toolbar{border:1px solid var(--border-soft);background:#f8fbff;border-radius:8px;grid-template-columns:minmax(220px,1fr) 160px 160px;align-items:center;gap:10px;min-width:0;max-width:100%;margin-top:14px;padding:10px;display:grid}.table-toolbar>*{min-width:0}.search-box{background:#fff;border:1px solid #cfd8e6;border-radius:8px;align-items:center;gap:8px;min-height:40px;padding:0 12px;display:flex!important}.search-box input{box-shadow:none;border:0;min-height:0;padding:0}.data-table{background:#fff;border:1px solid #dce5f2;border-radius:8px;width:100%;min-width:0;max-width:100%;margin-top:14px;overflow:auto hidden;box-shadow:0 10px 26px #0f172a0d}.data-row{border-top:1px solid var(--border-soft);grid-template-columns:var(--table-columns,minmax(160px, 1.3fr) 100px 110px minmax(160px, 1fr) auto);min-width:var(--table-min-width,760px);align-items:center;gap:12px;min-height:52px;padding:10px 14px;transition:background-color .14s,box-shadow .14s;display:grid}.data-row:first-child{border-top:0}.data-row:not(.data-head):hover{background:#f8fbff;box-shadow:inset 3px 0 #2563eb38}.compact-table{--table-columns:130px 120px 1fr;--table-min-width:420px}.question-set-answer-table{--table-columns:96px 96px minmax(220px, 1fr) minmax(280px, .9fr);--table-min-width:760px}.data-table.audit-log-table{--table-columns:140px 110px minmax(220px, 1.4fr) minmax(150px, .9fr) 82px;--table-min-width:820px}.audit-log-row>span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.data-table.session-device-table{--table-min-width:860px}.data-table.session-device-active-table{--table-columns:minmax(150px, 1.2fr) 82px minmax(150px, 1fr) minmax(150px, 1fr) 112px}.data-table.session-device-history-table{--table-columns:minmax(150px, 1.2fr) 82px 82px minmax(150px, 1fr) minmax(150px, 1fr)}.extraction-row{--table-columns:minmax(220px, 1.4fr) 90px 100px minmax(160px, 1fr)}.extraction-row-actions{--table-columns:minmax(220px, 1.4fr) 90px 100px minmax(160px, 1fr) auto}.invite-row{--table-columns:96px minmax(140px, 1fr) 112px 120px minmax(140px, 1fr) minmax(150px, auto);text-align:center;justify-items:center}.invite-row>*{min-width:0}.invite-row .ui-badge{min-width:110px}.invite-row .user-actions{justify-content:center;width:100%}.question-bank-layout{grid-template-columns:minmax(0,1.25fr) minmax(360px,.75fr);align-items:start;gap:16px;display:grid}.bank-toolbar{grid-template-columns:minmax(200px,2fr) repeat(5,minmax(110px,1fr)) auto}.compact-table .data-row.bank-row{--table-columns:minmax(280px, 1.8fr) minmax(160px, 1fr) minmax(180px, 1.2fr) 90px 150px;--table-min-width:860px}.bank-row>:nth-child(2),.bank-row>:nth-child(3),.bank-row>:nth-child(4),.bank-row>:nth-child(5){text-align:center;justify-self:center}.bank-statuses,.bank-row-actions{flex-wrap:wrap;justify-content:center;align-items:center;gap:6px;display:inline-flex}.question-set-toolbar{grid-template-columns:minmax(220px,1fr) minmax(160px,.45fr) minmax(160px,.45fr) auto}.compact-table .data-row.question-set-row{--table-columns:minmax(240px, 1.5fr) 70px 140px minmax(200px, 1.2fr) 140px;--table-min-width:800px}.question-set-row>:nth-child(2),.question-set-row>:nth-child(3),.question-set-row>:nth-child(5){text-align:center;justify-self:center}.question-set-row>small{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.pagination-bar{border:1px solid var(--border-soft);color:var(--muted);background:#f8fbff;border-radius:8px;flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;margin-top:14px;padding:9px 10px;display:flex}.pagination-bar button{color:#274b7a;cursor:pointer;background:#fff;border:1px solid #cbd8ea;border-radius:8px;justify-content:center;align-items:center;min-height:34px;padding:0 12px;font-weight:700;transition:background-color .14s,border-color .14s,color .14s;display:inline-flex;box-shadow:0 1px 2px #0f172a0f}.pagination-bar button:hover:not(:disabled){background:var(--accent-soft);border-color:var(--accent-border);color:#1e3a8a}.pagination-bar button:disabled{border-color:var(--border-soft);box-shadow:none;color:#98a2b3;cursor:not-allowed;background:#f5f7fb}.pagination-bar span{border:1px solid var(--border-soft);text-align:center;background:#fff;border-radius:999px;min-width:180px;padding:6px 10px}.pagination-footer{border:1px solid var(--border-soft);color:var(--muted);background:#f8fbff;border-radius:8px;justify-content:space-between;align-items:center;gap:10px;min-width:0;margin-top:14px;padding:9px 10px;display:flex}.page-size-control{border:1px solid var(--border-soft);color:#475569;white-space:nowrap;background:#fff;border-radius:8px;flex:none;align-items:center;gap:6px;min-height:34px;padding:0 8px;font-size:13px;display:inline-flex}.page-size-control select{color:#1f3f68;background:#edf5ff;border:1px solid #c9dbf5;border-radius:6px;height:26px;padding:0 20px 0 8px;font-weight:700}.pagination-summary{border:1px solid var(--border-soft);text-align:center;text-overflow:ellipsis;white-space:nowrap;background:#fff;border-radius:999px;flex:auto;min-width:180px;padding:6px 10px;overflow:hidden}.pagination-actions{flex:none;align-items:center;gap:8px;display:inline-flex}.pagination-footer button,.pagination-actions button{color:#274b7a;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #cbd8ea;border-radius:8px;justify-content:center;align-items:center;min-height:34px;padding:0 12px;font-weight:700;transition:background-color .14s,border-color .14s,color .14s;display:inline-flex;box-shadow:0 1px 2px #0f172a0f}.pagination-footer button:hover:not(:disabled),.pagination-actions button:hover:not(:disabled){background:var(--accent-soft);border-color:var(--accent-border);color:#1e3a8a}.pagination-footer button:disabled,.pagination-actions button:disabled{border-color:var(--border-soft);box-shadow:none;color:#98a2b3;cursor:not-allowed;background:#f5f7fb}@media (max-width:700px){input,select,textarea{font-size:16px!important}.pagination-footer{flex-wrap:wrap;align-items:stretch}.pagination-summary{flex-basis:100%;order:3}}.user-detail-section-tabs{background:#ffffffe0;border:1px solid #dce5f2;border-radius:8px;flex-wrap:wrap;align-items:center;gap:8px;padding:8px;display:flex;box-shadow:0 10px 26px #0f172a0d}.user-detail-section-tabs button{color:#365575;cursor:pointer;background:#f4f7fb;border:1px solid #d6e0ee;border-radius:8px;min-height:36px;padding:0 14px;font-weight:700;transition:background-color .14s,border-color .14s,color .14s}.user-detail-section-tabs button:hover{color:#1e3a8a;background:#eaf2ff;border-color:#b8cced}.user-detail-section-tabs button.active{background:var(--accent);border-color:var(--accent);color:#fff}.user-detail-desktop-heading{margin-bottom:16px}.user-detail-settings-grid{gap:16px;display:grid}.user-detail-field-grid{grid-template-columns:repeat(3,minmax(180px,1fr));gap:14px;display:grid}.user-detail-field{background:linear-gradient(#fff,#f8fbff);border:1px solid #dfe7f2;border-radius:8px;gap:8px;padding:14px;display:grid}.user-detail-field span,.user-detail-permission-panel>span,.user-detail-metric-card span,.user-detail-referral-card span,.user-detail-referral-code span{color:var(--muted);font-size:13px;font-weight:600}.user-detail-field input,.user-detail-field select{border:1px solid var(--border);background:#fff;border-radius:8px;min-height:38px;padding:0 10px}.user-detail-field select.is-success{color:var(--success);font-weight:700}.user-detail-field select.is-danger{color:var(--danger);font-weight:700}.user-detail-permission-panel{background:#fbfdff;border:1px solid #dfe7f2;border-radius:8px;gap:10px;padding:14px;display:grid}.user-detail-permission-row{flex-wrap:wrap;gap:8px;display:flex}.user-detail-permission-row button{border:1px solid var(--border);color:var(--muted-strong);cursor:pointer;background:#fff;border-radius:999px;min-height:30px;padding:0 12px}.user-detail-permission-row button.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent-dark);font-weight:700}.user-detail-action-row{grid-template-columns:minmax(0,1fr) minmax(180px,.35fr);gap:12px;display:grid}.user-detail-action-row .ui-button{justify-content:center;min-height:40px}.user-detail-referral-grid,.user-detail-practice-metrics{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;display:grid}.user-detail-referral-code,.user-detail-referral-card,.user-detail-metric-card{background:linear-gradient(#fff,#f8fbff);border:1px solid #dfe7f2;border-radius:8px;gap:6px;padding:14px;display:grid}.user-detail-referral-code strong,.user-detail-referral-card strong,.user-detail-metric-card strong{color:var(--foreground);font-size:18px}.user-detail-referral-code strong{letter-spacing:1px;font-family:ui-monospace,Cascadia Mono,Consolas,monospace}.user-detail-referral-card .is-amber{color:var(--warning)}.user-detail-referral-card .is-success,.user-detail-metric-card .is-success{color:var(--success)}.user-detail-metric-card .is-accent{color:var(--accent)}.user-detail-metric-card .is-danger{color:var(--danger)}.user-detail-segmented{background:var(--surface-sunken);border:1px solid var(--border-light);border-radius:8px;grid-template-columns:repeat(2,minmax(140px,1fr));gap:3px;margin:14px 0;padding:3px;display:inline-grid}.user-detail-segmented button{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;min-height:34px;padding:0 14px;font-weight:600}.user-detail-segmented button.active{background:var(--background);color:var(--foreground);box-shadow:0 1px 3px #0f172a1a}.user-detail-group-list{gap:10px;margin-bottom:14px;display:grid}.user-detail-group-card{background:#fbfdff;border:1px solid #dfe7f2;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;padding:12px 14px;display:grid}.user-detail-group-card>div{gap:3px;min-width:0;display:grid}.user-detail-group-card strong{color:var(--foreground);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.user-detail-group-card span{color:var(--muted);font-size:12px}@media (max-width:768px){.user-detail-section-tabs{scrollbar-width:none;white-space:nowrap;flex-wrap:nowrap;overflow-x:auto}.user-detail-section-tabs::-webkit-scrollbar{display:none}.user-detail-section-tabs button{flex:none;min-height:34px;padding:0 12px}.panel.user-detail-account-panel,.panel.user-detail-referral-panel,.panel.user-detail-practice-panel,.panel.user-detail-extractions-panel{padding:12px}.user-detail-desktop-heading{display:none}.user-detail-field-grid{background:var(--surface-sunken);border-radius:10px;padding:2px 14px;display:block}.user-detail-field{border:none;border-bottom:1px solid var(--border-light);background:0 0;border-radius:0;justify-content:space-between;align-items:center;gap:12px;padding:10px 0;display:flex}.user-detail-field:last-child{border-bottom:none}.user-detail-field span{color:var(--foreground);white-space:nowrap;flex-shrink:0;font-size:13px}.user-detail-field input,.user-detail-field select{text-align:right;background:0 0;border:none;flex:1;min-width:0;min-height:auto;padding:0;font-size:13px;font-weight:600}.user-detail-permission-panel{background:var(--surface-sunken);border:none;border-radius:10px;padding:12px 14px}.user-detail-permission-panel>span{font-size:12px}.user-detail-permission-row button{min-height:26px;padding:0 10px}.user-detail-action-row{grid-template-columns:minmax(0,2fr) minmax(0,1fr)}.user-detail-referral-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.user-detail-practice-metrics{scrollbar-width:none;gap:6px;margin-bottom:12px;padding-bottom:8px;display:flex;overflow-x:auto}.user-detail-practice-metrics::-webkit-scrollbar{display:none}.user-detail-metric-card{text-align:center;flex:0 0 54px;align-items:center;gap:2px;padding:4px 8px}.user-detail-metric-card span{white-space:nowrap;font-size:10px}.user-detail-metric-card strong{font-size:13px}.user-detail-segmented{grid-template-columns:repeat(2,minmax(0,1fr));width:100%;margin:0 0 12px;display:grid}.user-detail-segmented button{min-height:30px;padding:0;font-size:12px}.user-detail-group-list{gap:6px;margin-bottom:12px}.user-detail-group-card{background:var(--surface-sunken);border:none;gap:8px;padding:6px 10px}.user-detail-group-card strong{font-size:12px}.user-detail-group-card span{font-size:10px}}.question-card.deleted{background:var(--surface-soft)}.question-set-group{gap:10px;display:grid}.question-set-group h3{margin:0;font-size:15px}.question-set-items{gap:12px;display:grid}.question-set-item{border:1px solid var(--border);border-radius:8px;gap:10px;padding:12px;display:grid}.question-set-item.deleted{background:var(--surface-soft);color:var(--muted)}.question-set-item-head{justify-content:space-between;align-items:center;gap:10px;display:flex}.question-set-item-head small{color:var(--muted)}.bank-set-links{gap:8px;display:grid}.bank-set-links a{border:1px solid var(--border-soft);color:inherit;border-radius:8px;gap:2px;padding:9px 10px;text-decoration:none;display:grid}.bank-set-links a:hover{background:var(--surface-soft)}.bank-set-links small{color:var(--muted)}.bank-stem{border:1px solid var(--border);overflow-wrap:anywhere;tab-size:4;white-space:break-spaces;resize:vertical;background:#f8fafc;border-radius:8px;max-height:280px;margin:0;padding:12px;font-family:ui-monospace,Cascadia Mono,Consolas,Microsoft YaHei,monospace;font-size:13px;line-height:1.5;overflow-y:auto}.bank-options{gap:8px;display:grid}.bank-options>div{border:1px solid var(--border-soft);border-radius:8px;grid-template-columns:28px 1fr;align-items:start;gap:10px;padding:9px 10px;display:grid}.bank-subtitle{margin:0 0 8px;font-size:15px}.bank-analysis{border:1px solid var(--border);resize:vertical;border-radius:8px;max-height:280px;padding:12px;font-size:13px;line-height:1.6;overflow-y:auto}.bank-analysis p,.bank-analysis div{margin:0 0 8px}.bank-analysis table{border-collapse:collapse;width:100%}.bank-analysis td,.bank-analysis th{border:1px solid var(--border);padding:6px 8px}.bank-warning{background:var(--warning-bg);color:var(--warning);border:1px solid #f8d48a;border-radius:8px;align-items:center;gap:8px;padding:10px 12px;display:flex}.bank-images{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;display:grid}.bank-images img{border:1px solid var(--border);border-radius:8px;max-width:100%}.practice-layout{grid-template-columns:minmax(0,1fr);align-items:start;gap:16px;display:grid}.practice-builder-shell{grid-template-columns:minmax(0,1fr) minmax(280px,.38fr);align-items:start;gap:16px;display:grid}.practice-builder,.practice-builder-shell,.practice-wrong-book,.practice-history,.practice-builder{min-width:0}.practice-section-tabs,.mobile-section-tabs{background:#ffffffe6;border:1px solid #dce5f2;border-radius:8px;align-items:center;gap:8px;padding:8px;display:flex;overflow-x:auto;box-shadow:0 10px 26px #0f172a0d}.practice-section-tabs button,.mobile-section-tabs button{color:#365575;cursor:pointer;white-space:nowrap;background:#f4f7fb;border:1px solid #d6e0ee;border-radius:8px;flex:1 0 auto;justify-content:center;align-items:center;gap:7px;min-height:38px;padding:0 14px;font-weight:700;display:inline-flex}.practice-section-tabs button.active,.mobile-section-tabs button.active{background:var(--accent);border-color:var(--accent);color:#fff}.practice-section-tabs button span,.mobile-section-tabs button span{color:inherit;text-align:center;background:#ffffffd6;border-radius:999px;min-width:22px;padding:2px 7px}.practice-course-select{color:var(--muted);background:linear-gradient(#fff,#f8fbff);border:1px solid #dce5f2;border-radius:8px;gap:6px;margin-top:14px;padding:12px;font-size:13px;display:grid}.practice-course-select span{color:var(--muted-strong);font-weight:700}.practice-row-list{gap:10px;margin-top:16px;display:grid}.practice-config-row{background:linear-gradient(#fff,#f8fbff);border:1px solid #dce5f2;border-radius:8px;grid-template-columns:minmax(220px,1fr) 110px 86px 40px;align-items:end;gap:10px;padding:12px;display:grid}.practice-config-row label{color:var(--muted);gap:6px;font-size:13px;display:grid}.practice-row-meta{color:var(--muted);text-align:center;white-space:nowrap;align-self:center;font-size:13px}.practice-row-remove{color:var(--danger);cursor:pointer;background:#fff;border:1px solid #f3c8c5;border-radius:999px;justify-content:center;place-self:center;align-items:center;width:30px;height:30px;padding:0;transition:background-color .14s,border-color .14s,box-shadow .14s,color .14s,transform 80ms;display:inline-flex}.practice-row-remove:hover:not(:disabled){background:var(--danger-bg);border-color:var(--danger-border);color:var(--danger-dark);box-shadow:0 6px 14px #b4231824}.practice-row-remove:focus-visible{outline:0;box-shadow:0 0 0 3px #b4231829}.practice-row-remove:active:not(:disabled){transform:translateY(1px)}.practice-row-remove:disabled{border-color:var(--border-soft);color:#cbd5e1;cursor:not-allowed;background:#f8fafc}.practice-summary{background:linear-gradient(#fff,#f8fbff);border:1px solid #dce5f2;border-radius:8px;gap:14px;padding:14px;display:grid}.practice-summary-toggle{border:1px solid var(--border);color:var(--muted-strong);cursor:pointer;background:#fff;border-radius:8px;justify-content:center;align-items:center;min-height:36px;padding:0 10px;font-weight:700;display:none}.summary-list{gap:8px;display:grid}.summary-list>div{border:1px solid var(--border-soft);background:#fff;border-radius:8px;gap:3px;padding:10px 12px;display:grid}.summary-list strong{overflow-wrap:anywhere}.summary-list span{color:var(--muted);font-size:13px;line-height:1.45}.form-error{background:var(--danger-bg);color:var(--danger);border:1px solid #fecdca;border-radius:8px;margin:0;padding:10px 12px}.compact-table .data-row.practice-history-row{--table-columns:170px minmax(90px, 1fr) 120px 150px;--table-min-width:560px}.compact-table .data-row.practice-history-row>:nth-child(3),.compact-table .data-row.practice-history-row>:nth-child(4){text-align:center;justify-self:center}.practice-history-row>span,.practice-history-row>strong{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.practice-history-actions{justify-content:center;align-items:center;gap:8px;min-width:0;display:inline-flex}.practice-history-actions .ui-button{min-height:34px;padding:0 10px}.practice-wrong-book{gap:14px;display:grid}.practice-feedback-mode{background:#fff;border:1px solid #dce5f2;border-radius:8px;gap:10px;padding:12px;display:grid}.practice-feedback-mode label{color:var(--muted-strong);align-items:center;gap:8px;line-height:1.4;display:inline-flex}.practice-feedback-mode input{width:auto;min-height:auto}.practice-wrong-actions,.practice-question-actions,.practice-wrong-item-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.practice-question-actions{justify-content:space-between}.practice-shortcut-hints{color:var(--muted);flex-wrap:wrap;align-items:center;gap:6px;font-size:11px;display:flex}.practice-shortcut-hints span,.practice-shortcut-hints em{background:var(--surface-soft);border:1px solid var(--border-soft);border-radius:999px;padding:4px 8px;font-style:normal}.practice-shortcut-hints kbd{border:1px solid var(--border);color:var(--muted-strong);background:#fff;border-radius:5px;padding:1px 5px;font-family:inherit;font-size:11px}.practice-attempt-layout{grid-template-columns:minmax(240px,.32fr) minmax(0,1fr);align-items:start;gap:16px;display:grid}.practice-attempt-submit-header{justify-content:flex-end;margin-top:-8px;display:flex}.practice-attempt-mobile-back-link{display:none}.practice-finish-confirm-backdrop{z-index:90;background:#0f172a6b;justify-content:center;align-items:center;padding:18px;display:flex;position:fixed;inset:0}.practice-finish-confirm-backdrop.is-hidden{display:none}.practice-finish-confirm-dialog{border:1px solid var(--border);background:#fff;border-radius:8px;grid-template-columns:auto minmax(0,1fr);gap:14px;width:min(100%,440px);max-width:440px;padding:18px;display:grid;box-shadow:0 24px 70px #0f172a3d}.practice-finish-confirm-icon{background:var(--accent-soft);border:1px solid var(--accent-border);color:var(--accent-dark);border-radius:8px;justify-content:center;align-items:center;width:42px;height:42px;display:inline-flex}.practice-finish-confirm-copy{gap:6px;min-width:0;display:grid}.practice-finish-confirm-copy h2,.practice-finish-confirm-copy p{margin:0}.practice-finish-confirm-copy h2{color:#111827;letter-spacing:0;font-size:18px}.practice-finish-confirm-copy p{color:var(--muted);font-size:14px;line-height:1.6}.practice-finish-confirm-actions{grid-column:1/-1;justify-content:flex-end;gap:10px;display:flex}.practice-nav-panel{align-content:start;gap:14px;max-height:calc(100vh - 40px);display:grid;position:sticky;top:20px;overflow-y:auto}.practice-nav-panel::-webkit-scrollbar{width:6px}.practice-nav-panel::-webkit-scrollbar-track{background:0 0}.practice-nav-panel::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.practice-config-detail{gap:8px;display:grid}.practice-nav-group{flex-direction:column;gap:8px;margin-bottom:8px;display:flex}.practice-nav-group-header{background:var(--surface-soft);border:1px solid var(--border-soft);color:var(--foreground);cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;width:100%;padding:8px 12px;font-size:13px;font-weight:600;transition:all .2s;display:flex}.practice-nav-group-header:hover{background:var(--surface-hover);border-color:var(--border)}.practice-nav-group-items{grid-template-columns:repeat(auto-fill,minmax(54px,1fr));gap:8px;display:grid}.practice-nav-group-items button{border:1px solid var(--border);color:var(--muted-strong);cursor:pointer;background:#fff;border-radius:8px;justify-content:center;align-items:center;gap:5px;min-height:34px;font-size:13px;display:inline-flex}.practice-nav-group-items button.active{border-color:var(--accent);color:var(--accent-dark);box-shadow:0 0 0 3px #2563eb1f}.practice-nav-group-items button.answered{color:var(--accent-dark);background:#eff6ff;border-color:#93c5fd}.practice-nav-group-items button.correct{background:var(--success-bg);color:#095c37;border-color:#abefc6}.practice-nav-group-items button.wrong{background:var(--danger-bg);color:var(--danger);border-color:#fecdca}.practice-nav-group-items button.skipped{background:var(--surface-soft);border-color:var(--border);color:var(--muted)}.practice-result-card{background:linear-gradient(#eff6ff 0%,#fff 100%);border:1px solid #bfdbfe;border-radius:10px;gap:12px;padding:14px;display:grid}.practice-result-card>div:first-child{justify-content:space-between;align-items:end;display:flex}.practice-result-card span{color:var(--muted-strong);font-size:13px}.practice-result-card strong{color:var(--foreground)}.practice-result-card>div:first-child strong{color:var(--accent-dark);font-size:34px;line-height:1}.practice-result-bar{background:#dbeafe;border-radius:999px;height:9px;overflow:hidden}.practice-result-bar span{background:linear-gradient(90deg, var(--accent), var(--success));height:100%;display:block}.practice-result-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.practice-result-stats span{border:1px solid var(--border-soft);text-align:center;background:#fff;border-radius:8px;gap:2px;padding:8px;display:grid}.practice-question-nav button svg{flex:none}.practice-question-nav button svg[data-lucide=check-circle-2]{color:var(--success)}.practice-question-nav button svg[data-lucide=x-circle]{color:var(--danger)}.practice-question-panel{gap:16px;min-width:0;display:grid}.practice-mobile-topbar,.practice-mobile-result,.practice-mobile-bottom-actions{display:none}.practice-question-panel pre{background:var(--surface-soft);border:1px solid var(--border);overflow-wrap:anywhere;tab-size:4;white-space:break-spaces;border-radius:8px;margin:0;padding:14px;font-family:ui-monospace,Cascadia Mono,Consolas,Microsoft YaHei,monospace;font-size:16px;line-height:1.65;overflow:auto}.practice-options{gap:10px;display:grid}.practice-option{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:12px;grid-template-columns:auto 28px 1fr;align-items:flex-start;gap:12px;padding:14px 16px;font-size:15px;line-height:1.55;transition:border-color .2s,box-shadow .2s,background-color .2s,transform .15s cubic-bezier(.34,1.56,.64,1);display:grid;position:relative;overflow:hidden}.practice-option:active{transform:scale(.98)}.practice-option:hover{background:var(--surface-soft);border-color:var(--border-soft)}.practice-option.selected{background:var(--accent-soft);border-color:var(--accent-border);box-shadow:0 4px 14px #4f46e51f}.practice-option input{width:auto;min-height:auto;margin-top:3px}.practice-option-label{background:var(--surface-soft);border:1px solid var(--border);color:var(--muted-strong);border-radius:8px;justify-content:center;align-items:center;width:26px;height:26px;font-size:13px;font-weight:700;line-height:1;transition:all .2s;display:inline-flex}.practice-option.selected .practice-option-label{background:var(--accent);border-color:var(--accent);color:#fff;transition:all .2s cubic-bezier(.34,1.56,.64,1);transform:scale(1.05);box-shadow:0 2px 8px #4f46e54d}.practice-option-text{overflow-wrap:anywhere;tab-size:4;white-space:break-spaces;min-width:0;display:block}.practice-feedback{border-radius:8px;gap:10px;padding:14px;line-height:1.6;display:grid}.practice-feedback p{margin:0}.practice-feedback.correct{background:var(--success-bg);color:#095c37;border:1px solid #abefc6}.practice-feedback.wrong{background:var(--danger-bg);color:var(--danger);border:1px solid #fecdca}.practice-feedback.skipped{background:var(--surface-soft);border:1px solid var(--border);color:var(--muted-strong)}.practice-feedback .bank-analysis{color:var(--foreground);background:#fff;margin-top:2px}.practice-admin-groups{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:10px;margin-top:14px;display:grid}.practice-admin-groups>div{background:var(--surface-soft);border:1px solid var(--border-soft);border-radius:8px;gap:4px;padding:12px;display:grid}.practice-admin-groups strong{overflow-wrap:anywhere}.practice-admin-groups span,.practice-admin-groups small{color:var(--muted);font-size:13px}.practice-admin-table{margin-top:14px}.data-table .practice-admin-row{--table-columns:105px 82px 110px 120px minmax(150px, 1fr) 104px;--table-min-width:800px}.practice-admin-row>:last-child{justify-self:center}.practice-admin-row>*,.admin-user-extraction-row>*{min-width:0}.practice-admin-row>span,.practice-admin-row>strong,.admin-user-extraction-row>span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.admin-user-extraction-row{--table-columns:minmax(220px, 1.35fr) 74px 82px minmax(170px, .95fr) 112px;--table-min-width:760px}.admin-user-extraction-row>:nth-child(2),.admin-user-extraction-row>:nth-child(3),.admin-user-extraction-row>:last-child{justify-self:center}.record-title{gap:3px;min-width:0;display:grid}.record-title strong,.record-title small{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.record-title small{color:var(--muted);font-size:12px}.users-row{--table-columns:28px minmax(120px, .85fr) 52px 76px minmax(340px, 1.25fr) minmax(260px, 1fr);--table-min-width:1010px;gap:12px;min-height:72px}.users-row>:nth-child(4){justify-self:end}.users-row>:nth-child(6){text-align:right;justify-self:stretch}.user-select-cell{justify-content:center;align-items:center;display:inline-flex}.user-select-cell input{accent-color:var(--accent);width:14px;height:14px;margin:0}.user-identity{gap:2px;display:grid}.user-expiry-control,.user-actions,.row-password{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.user-expiry-control{grid-template-columns:minmax(98px,.7fr) minmax(154px,1fr) auto;justify-content:stretch;align-items:end;gap:8px;min-width:0;display:grid}.user-expiry-current,.user-expiry-input{gap:5px;min-width:0;display:grid}.user-expiry-current span,.user-expiry-input span{color:var(--muted);font-size:12px;font-weight:700;line-height:1}.user-expiry-current strong{background:var(--surface-soft);border:1px solid var(--border-soft);text-overflow:ellipsis;white-space:nowrap;border-radius:8px;min-height:36px;padding:0 10px;font-size:13px;font-weight:700;line-height:34px;display:block;overflow:hidden}.user-expiry-input input{width:100%;max-width:none;min-height:36px}.user-actions{flex-wrap:nowrap;justify-content:flex-end}.user-actions .ui-button,.row-password .ui-button{white-space:nowrap;min-height:34px;padding:0 9px}.users-row .user-actions{gap:5px}.users-row .user-actions .ui-button{padding:0 7px}.row-password{border:1px solid var(--border);background:#f8fafc;border-radius:8px;margin-left:auto;padding:4px 6px 4px 10px}.row-password code{overflow-wrap:anywhere;font-size:12px}.data-head{color:#52637a;letter-spacing:.01em;background:linear-gradient(#f8fafc,#eef3f9);min-height:42px;font-size:12px;font-weight:700}.confirm-action{vertical-align:middle;gap:8px;min-height:34px;display:inline-flex}.confirm-action-active{animation:.12s ease-out confirmPop}.confirm-entry{min-width:max-content}@keyframes confirmPop{0%{opacity:.7;transform:translateY(1px)}to{opacity:1;transform:translateY(0)}}.copy-result{border:1px solid var(--border);background:#f8fafc;border-radius:8px;align-items:center;gap:10px;margin-top:14px;padding:10px;display:flex}.referral-hero{background:linear-gradient(135deg,#e8f0ffdb,#fffffffa 45%,#e7f6ee75),#fff;border-color:#cbd9f4;box-shadow:0 18px 44px #2563eb14}.referral-section-tabs{z-index:4;position:sticky;top:0}.referral-status-grid{margin-bottom:0}.stack>[hidden]{display:none!important}.referral-split-card{background:#f8fbff;border:1px solid #b8c9e8;border-radius:8px;gap:12px;margin-top:14px;padding:14px;display:grid;box-shadow:0 10px 24px #2563eb14}.referral-split-card>div:first-child{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px 12px;display:flex}.referral-split-card>div:first-child strong{color:#172554;font-size:16px}.referral-split-eyebrow{color:#1d4ed8;background:#dbeafe;border:1px solid #bfdbfe;border-radius:999px;padding:4px 9px;font-size:12px;font-weight:800}.referral-split-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.referral-split-grid>div{background:#fff;border:1px solid #d7e3f4;border-radius:8px;gap:4px;padding:12px;display:grid}.referral-split-grid span{color:#1d4ed8;font-size:13px;font-weight:800}.referral-split-grid strong{color:#0f172a;font-size:18px}.referral-split-card p{color:#475569;margin:0;font-size:13px;line-height:1.6}.referral-copy-layout{grid-template-columns:minmax(240px,.75fr) minmax(280px,1.25fr);gap:12px;margin-top:16px;display:grid}.referral-copy-card{background:#ffffffd1;border:1px solid #d7e3f4;border-radius:8px;gap:9px;min-width:0;padding:14px;display:grid}.referral-copy-card>span{color:var(--muted);font-size:12px;font-weight:700}.referral-copy-card>div{align-items:center;gap:10px;min-width:0;display:flex}.referral-copy-card code{color:#0f172a;letter-spacing:.03em;font-size:20px;font-weight:800}.referral-link-card p{color:#334155;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;margin:0;overflow:hidden}.referral-link-card svg{color:var(--accent);flex:none}.payment-qr-upload{background:linear-gradient(#fff,#f8fbff);border:1px solid #d7e3f4;border-radius:8px;grid-template-columns:minmax(180px,220px) minmax(260px,1fr) auto;align-items:center;gap:10px;margin-top:14px;padding:12px;display:grid}.payment-qr-kind{align-self:center;gap:6px;display:grid}.payment-qr-kind span{color:var(--muted);font-size:12px;font-weight:700}.payment-qr-file{color:var(--muted-strong);cursor:pointer;background:#fff;border:1px dashed #b8c8df;border-radius:8px;align-items:center;gap:10px;min-width:0;min-height:42px;padding:0 12px;transition:background-color .14s,border-color .14s,color .14s;display:flex}.payment-qr-file:hover{color:#1e3a8a;background:#f2f7ff;border-color:#8fb1fb}.payment-qr-file.is-dragging{border-color:var(--accent);color:#1e3a8a;background:#e8f1ff;box-shadow:0 0 0 3px #2563eb1f}.payment-qr-file input{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute}.payment-qr-file span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.payment-qr-submit{align-self:center}.payment-qr-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-top:14px;display:grid}.payment-qr-card{background:linear-gradient(#fff,#f8fbff);border:1px solid #dce5f2;border-radius:8px;grid-template-columns:82px minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px;transition:border-color .14s,box-shadow .14s,transform 80ms;display:grid}.payment-qr-card:hover{border-color:#c4d3e8;transform:translateY(-1px);box-shadow:0 10px 24px #0f172a12}.payment-qr-preview{cursor:zoom-in;background:0 0;border:0;padding:0;display:inline-grid}.payment-qr-preview:focus-visible{border-radius:8px;outline:0;box-shadow:0 0 0 3px #2563eb2e}.payment-qr-card img{border:1px solid var(--border-soft);object-fit:contain;background:#fff;border-radius:8px;width:82px;height:82px;padding:4px}.payment-qr-card strong,.payment-qr-card small{display:block}.payment-qr-card small{color:var(--muted);margin-top:3px}.payment-qr-card-large{grid-template-columns:160px minmax(0,1fr)}.payment-qr-card-large img{width:160px;height:160px}.cleanup-settings{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.settings-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-top:14px;display:grid}.settings-grid label{color:var(--foreground);flex-direction:column;gap:8px;padding:4px;font-size:13px;display:flex}.settings-grid label span{color:var(--muted-strong);font-weight:700}.settings-grid small{color:var(--muted)}.compact-textarea{border:1px solid var(--border);color:var(--foreground);font-family:var(--font-mono,"SFMono-Regular", Consolas, monospace);resize:vertical;background:#fff;border-radius:8px;min-height:110px;padding:10px 12px;font-size:13px;line-height:1.5}.compact-textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2563eb24}.network-denied-page{color:var(--foreground);background:#f6f8fb;align-items:center;min-height:100vh;padding:24px;display:flex}.network-denied-page section{border:1px solid var(--border-soft);box-shadow:var(--shadow);text-align:center;background:#fff;border-radius:8px;max-width:420px;margin:0 auto;padding:24px}.network-denied-page h1{margin-bottom:10px;font-size:22px}.network-denied-page p{color:var(--muted);margin-bottom:12px}.network-denied-page span{color:var(--muted-strong);font-size:13px}.checkbox-setting{border:1px solid var(--border-soft);border-radius:8px;align-self:end;align-items:center;min-height:42px;padding:12px;flex-direction:row!important;gap:10px!important;display:flex!important}.settings-grid .checkbox-setting{min-height:unset;border:none;align-self:center;padding:0}.checkbox-setting input{width:16px;height:16px}.permission-checkboxes{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.permission-checkboxes .checkbox-setting{align-self:center;min-height:36px;padding:8px 10px}.cleanup-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.user-cleanup-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin:14px 0;display:grid}.user-cleanup-option{background:#fff;border:1px solid #dce5f2;border-radius:8px;grid-template-columns:auto 1fr;align-items:center;gap:3px 10px;padding:10px;display:grid}.user-cleanup-option:hover{background:#f8fbff;border-color:#c9d8ec}.user-cleanup-option input{grid-row:1/3;width:auto;min-height:auto}.user-cleanup-option small{color:var(--muted)}.system-admin{gap:18px;display:grid}.system-mode-panel{background:linear-gradient(135deg, #e8f0ffeb, #fffffff5 46%, #e7f6ee80), var(--surface);z-index:1;border-color:#cbd9f4;position:relative;overflow:hidden;box-shadow:0 16px 40px #2563eb14}.system-mode-panel:before{background:linear-gradient(90deg, var(--accent), #22c55e);content:"";height:4px;position:absolute;top:0;left:0;right:0}.system-mode-switch{background:#ffffffc2;border:1px solid #b9cffddb;border-radius:8px;grid-template-columns:repeat(2,minmax(140px,1fr));display:inline-grid;overflow:hidden;box-shadow:0 8px 24px #0f172a0f}.system-mode-switch button{color:#31527a;cursor:pointer;background:0 0;border:0;justify-content:center;align-items:center;gap:8px;min-height:38px;padding:0 14px;font-weight:700;transition:background-color .14s,color .14s,box-shadow .14s;display:inline-flex}.system-mode-switch button.active{background:var(--accent);color:#fff;box-shadow:inset 0 -2px #ffffff38}.system-mode-note{margin:8px 0 0}.system-layout{grid-template-columns:minmax(210px,240px) minmax(0,1fr);align-items:start;gap:18px;display:grid}.system-section-nav{background:#ffffffdb;border:1px solid #dce5f2;border-radius:8px;gap:8px;padding:8px;display:grid;position:sticky;top:22px;box-shadow:0 10px 26px #0f172a0d}.system-section-nav button{color:var(--foreground);cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:8px;gap:4px;padding:10px;transition:background-color .14s,border-color .14s,box-shadow .14s,color .14s,transform 80ms;display:grid;position:relative}.system-section-nav button:hover{background:#f8fbff;border-color:#dce5f2}.system-section-nav button:before{content:"";background:0 0;border-radius:999px;width:3px;position:absolute;top:10px;bottom:10px;left:0}.system-section-nav button span{color:var(--muted);font-size:12px;line-height:1.35}.system-section-nav button.active{color:#1d4ed8;background:linear-gradient(#eef5ff,#e8eefc);border-color:#bfcef7;transform:translate(1px);box-shadow:0 8px 20px #2563eb1a}.system-section-nav button.active:before{background:var(--accent)}.system-section-content{min-width:0}.system-section-content>.panel{border-color:#dce5f2;box-shadow:0 14px 34px #0f172a0f}.settings-subsection{border:1px solid var(--border-soft);background:linear-gradient(#fff,#fbfdff);border-radius:8px;gap:12px;margin-top:16px;padding:16px;display:grid}.settings-subsection:first-of-type{margin-top:0}.settings-subsection h3{margin:2px 0 0;font-size:16px}.danger-panel{border-color:#fecaca;box-shadow:inset 0 3px #ef4444,0 14px 34px #b4231814}.danger-note,.source-warning{color:#991b1b;background:linear-gradient(#fff7f7,#fef2f2);border:1px solid #fecaca;border-radius:8px;align-items:flex-start;gap:10px;margin:12px 0;padding:10px 12px;display:flex}.source-warning p{margin:4px 0 0}.source-editor-panel{border-color:#dce5f2;gap:12px;display:grid;box-shadow:0 14px 34px #0f172a0f}.source-meta{border:1px solid var(--border);color:var(--muted);background:linear-gradient(#f8fafc,#f1f5f9);border-radius:8px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;display:flex}.config-valid{color:var(--success);font-weight:700}.config-invalid{color:var(--danger);font-weight:700}.source-warning-list{color:#92400e;background:linear-gradient(#fffbeb,#fff7d6);border:1px solid #fde68a;border-radius:8px;gap:4px;padding:10px 12px;display:grid}.source-warning-list p{margin:0}.source-json-editor{color:#0f172a;resize:vertical;tab-size:2;white-space:pre;background:linear-gradient(90deg,#f8fafc 0 46px,#e5eaf3 47px,#fff 48px),#fff;border-color:#cfd8e6;min-height:520px;padding:14px 14px 14px 62px;font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;line-height:1.6;box-shadow:inset 0 1px 2px #0f172a0f}.source-json-editor:focus{border-color:var(--accent);outline:0;box-shadow:0 0 0 3px #2563eb1f,inset 0 1px 2px #0f172a0f}.copy-result code,.script-box code{overflow-wrap:anywhere}.error-text{color:var(--danger);margin:10px 0 0}.success-text{color:var(--success);margin:12px 0 0}.empty-state{color:var(--muted);background:#fbfdff;border:1px dashed #cfd8e6;border-radius:8px;padding:18px}.ui-empty{gap:6px;margin-top:14px;display:grid}.ui-empty strong{color:var(--foreground)}.ui-empty p{margin:0}.empty-state-action{margin-top:8px}.script-mode-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.script-mode-card{border:1px solid var(--border);color:var(--foreground);cursor:pointer;text-align:left;background:#fff;border-radius:8px;grid-template-columns:auto 1fr;align-items:flex-start;gap:10px;min-height:104px;padding:14px;transition:border-color .15s,box-shadow .15s,transform .15s;display:grid}.script-mode-card:hover:not(:disabled),.script-mode-card-active{border-color:#2563eb75;box-shadow:0 10px 24px #0f172a14}.script-mode-card:disabled{cursor:not-allowed;opacity:.68}.script-mode-card strong,.script-mode-card small{display:block}.script-mode-card small{color:var(--muted);margin-top:4px;line-height:1.5}.script-mode-card em{color:var(--accent);grid-column:2;font-style:normal;font-weight:700}.script-mode-icon{color:var(--accent);background:#eef4ff;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;display:inline-flex}.script-box{border:1px solid var(--border);border-radius:8px;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;margin-top:14px;padding:12px;display:grid}.watch-status{margin-top:10px}.back-link{color:var(--accent);font-weight:700}.render-toolbar{grid-template-columns:minmax(220px,.9fr) minmax(220px,1fr) minmax(300px,1.4fr) auto;align-items:end;gap:14px;display:grid}.segmented{border:1px solid var(--border);border-radius:8px;grid-template-columns:repeat(3,1fr);display:inline-grid;overflow:hidden}.segmented button{border:0;border-right:1px solid var(--border);cursor:pointer;background:#fff;min-height:38px;padding:0 14px}.segmented button:last-child{border-right:0}.segmented button.active{background:var(--accent);color:#fff;font-weight:700}.filter-stack{gap:8px;display:grid}.chip-row{flex-wrap:wrap;gap:8px;display:flex}.filter-chip{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:999px;min-height:30px;padding:0 11px}.filter-chip.active{color:#1d4ed8;background:#e8eefc;border-color:#bfcef7;font-weight:700}.result-count{color:var(--muted);white-space:nowrap;font-size:13px}.question-group summary{cursor:pointer;font-size:17px;font-weight:700}.question-group summary small{color:var(--muted);margin-left:10px;font-size:13px}.question-list{gap:14px;margin-top:18px;display:grid}.question-card{border-top:1px solid var(--border-soft);padding-top:16px}.question-card.collapsible-question{background:#fff;border:1px solid #dce5f2;border-radius:8px;padding:12px;box-shadow:0 4px 14px #0f172a0a}.question-card.collapsible-question+.question-card.collapsible-question{margin-top:2px}.question-card.collapsible-question>summary{cursor:pointer;list-style-position:inside}.question-card.collapsible-question>summary .question-meta{vertical-align:middle;margin-left:6px;display:inline-flex}.question-set-answer-panel{background:var(--surface-soft);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:8px;min-width:0;padding:10px 12px;display:flex}.question-set-answer-status{flex-wrap:nowrap;align-items:center;gap:8px;font-size:13px;display:flex}.question-set-answer-status small{color:var(--muted)}.question-set-answer-input{align-items:center;gap:8px;display:flex}.question-set-answer-input>span{color:var(--muted);flex-shrink:0;width:60px;font-size:13px}.question-set-answer-input input{border:1px solid var(--border);font:inherit;background:#fff;border-radius:6px;flex:1;min-width:0;padding:6px 10px;font-size:13px}.question-set-answer-actions{display:none}.question-set-answer-actions .ui-button{min-height:34px}.question-card pre{border:1px solid var(--border);tab-size:4;white-space:break-spaces;word-break:normal;background:#f8fbff;border-radius:8px;margin:12px 0;padding:14px;font-family:ui-monospace,Cascadia Mono,Consolas,Microsoft YaHei,monospace;line-height:1.55;overflow-x:auto}.question-detail-grid{grid-template-columns:minmax(0,1.15fr) minmax(280px,.85fr);align-items:stretch;gap:14px;margin-top:12px;display:grid}.question-detail-stack{gap:12px;margin-top:12px;display:grid}.question-main,.question-analysis-panel{flex-direction:column;min-width:0;height:100%;max-height:420px;display:flex}.question-main>.bank-stem{flex:1;max-height:100%;margin:0}.question-analysis-panel{background:#fff;border:1px solid #dce5f2;border-radius:8px;gap:10px;padding:12px;box-shadow:0 4px 14px #0f172a0a}.question-analysis-panel>strong{font-size:14px}.question-analysis-panel .bank-analysis img{max-width:100%}.question-detail-grid.no-image-mode img,.question-detail-stack.no-image-mode img{display:none!important}.question-analysis-panel .bank-analysis{border:none;flex:1;max-height:100%;padding:0}.answer-line{align-items:center;gap:8px;margin:10px 0;display:flex}.image-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-top:12px;display:grid}.image-preview-button{border:1px solid var(--border);cursor:zoom-in;background:#fff;border-radius:8px;justify-content:center;align-items:center;min-height:44px;padding:6px;display:flex}.image-preview-button:disabled{cursor:default}.image-preview-button--missing{color:var(--muted);background:#f8fafc;font-size:13px}.image-loading{color:var(--muted);font-size:13px}.image-preview-button img{border-radius:6px;max-width:100%;display:block}.compact-stack{gap:14px;margin-top:16px;display:grid}.answer-sheet{gap:10px;display:grid}.answer-sheet-row{grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;display:grid}.answer-cell{border:1px solid var(--border);background:#fbfcfe;border-radius:8px;justify-content:space-between;align-items:center;min-height:46px;padding:10px 12px;display:flex}.answer-cell span{color:var(--muted);white-space:nowrap;font-size:13px}.answer-cell strong{color:var(--foreground);font-size:20px;line-height:1}.compact-table .data-row.referral-history-row{--table-columns:96px minmax(160px, 1fr) 110px 100px minmax(180px, .8fr);--table-min-width:760px}.compact-table .data-row.admin-referral-row{--table-columns:minmax(130px, .9fr) 96px minmax(130px, .9fr) 96px 92px minmax(170px, 1fr) 132px;--table-min-width:960px}.compact-table .data-row.admin-referral-group-row{--table-columns:minmax(110px, .9fr) 84px 104px minmax(150px, 1fr) minmax(150px, 1.1fr) 148px;--table-min-width:820px}.compact-table .data-row.refund-request-row{--table-columns:104px 104px minmax(190px, 1.2fr) 86px minmax(180px, 1fr) minmax(158px, .8fr);--table-min-width:860px}.compact-table .data-row.refund-admin-row{--table-columns:minmax(112px, .8fr) 82px 100px minmax(180px, 1.1fr) 92px 82px minmax(156px, .8fr) 206px;--table-min-width:1120px}.compact-table .data-row.real-exam-row{--table-columns:120px minmax(180px, 1.2fr) minmax(200px, 1.5fr) 100px 180px;--table-min-width:780px}.compact-table .data-row.real-exam-detail-row{--table-columns:minmax(140px, 1fr) minmax(200px, 1.5fr) minmax(200px, 1fr) 140px;--table-min-width:680px}.compact-table .data-row.question-set-part-row{--table-columns:80px 100px minmax(200px, 1fr);--table-min-width:380px}.compact-table .data-row.question-set-item-row{--table-columns:60px 80px minmax(200px, 1fr) minmax(360px, 1.2fr);--table-min-width:700px}.compact-table .data-row.backup-row{--table-columns:minmax(200px, 1.5fr) 120px 180px 120px;--table-min-width:620px}.compact-table .data-row.user-session-row{--table-columns:minmax(180px, 1fr) 120px 180px 180px 100px;--table-min-width:760px}.compact-table .data-row.user-history-session-row{--table-columns:minmax(180px, 1fr) 120px 100px 180px 180px;--table-min-width:760px}.compact-table .data-row.extraction-detail-row{--table-columns:120px 180px minmax(200px, 1fr);--table-min-width:500px}.compact-table .data-row.audit-log-row{--table-columns:180px 140px 220px minmax(180px, 1fr) 100px;--table-min-width:820px}.referral-history-row>*,.admin-referral-row>*,.admin-referral-group-row>*,.refund-request-row>*,.refund-admin-row>*,.real-exam-row>*,.real-exam-detail-row>*,.question-set-part-row>*,.question-set-item-row>*,.backup-row>*,.user-session-row>*,.user-history-session-row>*,.extraction-detail-row>*,.audit-log-row>*{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.question-set-item-row .item-stem-summary{white-space:normal;-webkit-line-clamp:3;color:#334155;-webkit-box-orient:vertical;line-height:1.6;display:-webkit-box}.admin-referral-row .table-actions,.refund-admin-row .table-actions,.question-set-row .table-actions,.bank-row .table-actions{white-space:nowrap;justify-content:flex-end;gap:6px;display:inline-flex;overflow:visible}.admin-referral-row .table-actions .ui-button,.refund-admin-row .table-actions .ui-button,.question-set-row .table-actions .ui-button,.bank-row .table-actions .ui-button{min-height:30px;padding:0 10px}.refund-evidence-badge,.refund-evidence-cell{white-space:nowrap;align-items:center;min-width:0;display:inline-flex}.refund-detail-link{flex:none}.admin-referral-panel{overflow:hidden}.admin-referral-viewbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.admin-referral-toolbar{grid-template-columns:minmax(220px,1fr) auto;margin-top:0}.admin-referral-toolbar label{color:var(--muted);gap:6px;font-size:12px;font-weight:700;display:grid}.admin-referral-toolbar select{background-color:#fff}.refund-request-form{background:linear-gradient(#fff,#f8fbff);border:1px solid #d7e3f4;border-radius:8px;grid-template-columns:minmax(130px,.8fr) minmax(180px,1fr) minmax(240px,1.4fr) auto;align-items:end;gap:10px;margin-top:14px;padding:12px;display:grid}.refund-request-form label{color:var(--muted);gap:6px;min-width:0;font-size:12px;font-weight:700;display:grid}.refund-request-form input,.refund-request-form select{min-width:0}.admin-referral-group-row .table-actions{white-space:nowrap;justify-content:flex-end;display:inline-flex;overflow:visible}.admin-referral-group-row .table-actions .ui-button{min-height:34px;padding:0 10px}.table-actions{white-space:nowrap;flex-wrap:nowrap;align-items:center;gap:8px;min-width:0;display:inline-flex}.table-actions .ui-button{white-space:nowrap;flex:none;min-height:34px}.image-lightbox{z-index:50;background:#0f172ab8;justify-content:center;align-items:center;padding:36px;display:flex;position:fixed;inset:0}.image-lightbox>button{cursor:pointer;background:#fff;border:0;border-radius:999px;justify-content:center;align-items:center;width:36px;height:36px;display:inline-flex;position:absolute;top:22px;right:22px}.image-lightbox img{background:#fff;border-radius:8px;max-width:90vw;max-height:90vh}.image-lightbox.payment-qr-lightbox{z-index:90}.image-lightbox.payment-qr-lightbox img{object-fit:contain;width:min(560px,92vw);max-width:92vw;max-height:92vh;padding:16px;box-shadow:0 24px 70px #0f172a47}.modal-backdrop{z-index:60;background:#0f172a9e;justify-content:center;align-items:center;padding:28px;display:flex;position:fixed;inset:0}.modal-panel{border:1px solid var(--border);box-shadow:var(--shadow);background:#fff;border-radius:8px;width:min(760px,100%);max-height:calc(100vh - 56px);padding:20px;overflow:auto}.settlement-modal{gap:16px;width:min(880px,100%);display:grid;position:relative}.settlement-summary{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.settlement-summary>div{background:#f8fbff;border:1px solid #dce5f2;border-radius:8px;gap:5px;min-width:0;padding:11px 12px;display:grid}.settlement-summary span,.settlement-panel-heading span{color:var(--muted);font-size:12px;font-weight:700}.settlement-summary strong{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.settlement-body{grid-template-columns:minmax(280px,1fr) minmax(260px,.85fr);align-items:start;gap:14px;display:grid}.settlement-qr-panel,.settlement-edit-panel{background:linear-gradient(#fff,#f8fbff);border:1px solid #dce5f2;border-radius:8px;min-width:0;padding:14px}.settlement-panel-heading{justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;display:flex}.settlement-qr-grid{grid-template-columns:1fr;margin-top:0}.settlement-form{grid-template-columns:1fr;gap:12px;display:grid}.settlement-form label{color:var(--muted);gap:6px;font-size:13px;display:grid}.modal-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.settlement-actions{margin-top:14px}.settlement-reward-list{border:1px solid var(--border-soft);border-radius:8px;max-height:210px;display:grid;overflow:auto}.settlement-reward-list>div{justify-content:space-between;align-items:center;gap:12px;min-height:38px;padding:0 10px;display:flex}.settlement-reward-list>div+div{border-top:1px solid var(--border-soft)}.settlement-reward-list span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.settlement-note{color:var(--muted);gap:6px;margin-top:12px;font-size:13px;display:grid}.toast-region{z-index:80;gap:10px;width:min(360px,100vw - 44px);display:grid;position:fixed;top:22px;right:22px}.toast{border:1px solid var(--border);box-shadow:var(--shadow);background:#fff;border-radius:8px;grid-template-columns:auto 1fr auto;align-items:flex-start;gap:10px;padding:12px;animation:.18s ease-out toastIn;display:grid}@keyframes toastIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.toast p{color:var(--muted);margin:4px 0 0}.toast button{cursor:pointer;background:0 0;border:0;padding:2px}.toast-success svg{color:var(--success)}.toast-error svg{color:var(--danger)}.toast-warning svg{color:var(--warning)}.toast-info svg{color:var(--accent)}.skeleton{gap:8px;display:grid}.skeleton span{background:#e9eef5;border-radius:8px;height:14px;animation:1.2s ease-in-out infinite pulse}.list-refresh-shell{position:relative}.list-refresh-shell.is-refreshing{min-height:140px}.list-refresh-overlay{border:1px solid var(--border-soft);color:var(--muted-strong);pointer-events:none;z-index:2;background:#f8fbffd1;border-radius:999px;align-items:center;gap:8px;padding:8px 12px;font-size:13px;font-weight:700;display:inline-flex;position:absolute;top:14px;left:50%;transform:translate(-50%);box-shadow:0 8px 22px #0f172a14}.list-refresh-shell.is-refreshing .data-table,.list-refresh-shell.is-refreshing .compact-table{opacity:.72;transition:opacity .14s}.mobile-summary-list,.mobile-summary-card,.mobile-detail-only{display:none}.data-table.mobile-summary-list,.compact-table.mobile-summary-list,.data-row.mobile-summary-card{display:grid}.data-table.mobile-summary-list,.compact-table.mobile-summary-list{display:block}.mobile-card-details{display:none}.mobile-card-actions{display:inline-flex}@keyframes pulse{50%{opacity:.48}}@media (max-width:1024px){:root{--mobile-body-font-size:12px;--mobile-control-font-size:12px;--mobile-muted-font-size:11px;--mobile-page-title-size:18px;--mobile-section-title-size:15px;--practice-mobile-stem-size:14px;--practice-mobile-option-size:13px}body{font-size:var(--mobile-body-font-size);line-height:1.48}input,select,button{font-size:var(--mobile-control-font-size)}.muted,.status-label,.form-stack label,.render-toolbar label,.page-size-control,.pagination-summary,.toast p,.list-refresh-overlay{font-size:var(--mobile-muted-font-size)}.page-header h1,.auth-heading h1{font-size:var(--mobile-page-title-size);line-height:1.18}.section-heading h2,.section-heading h3{font-size:var(--mobile-section-title-size);line-height:1.22}.panel{padding:14px}.status-item{padding:12px}.status-value{font-size:14px}.ui-button,.primary-button,.secondary-button,.danger-button{min-height:36px;padding:0 11px}.mobile-summary-list{gap:10px;margin-top:12px;display:grid}.mobile-summary-card{border:1px solid var(--border);background:#fff;border-radius:8px;gap:9px;min-width:0;padding:11px;display:grid;box-shadow:0 6px 18px #0f172a0a}.mobile-card-main{grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:8px;min-width:0;display:grid}.mobile-card-title{color:var(--foreground);text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:14px;font-weight:700;line-height:1.35;display:block;overflow:hidden}.mobile-card-subtitle,.mobile-card-meta,.mobile-card-details,.mobile-card-details summary{color:var(--muted);font-size:var(--mobile-muted-font-size)}.mobile-card-subtitle,.mobile-card-meta{text-overflow:ellipsis;white-space:nowrap;min-width:0;margin-top:2px;line-height:1.35;display:block;overflow:hidden}.mobile-card-details{border-top:1px solid var(--border-soft);padding-top:8px;display:block}.mobile-card-details summary{color:var(--accent-dark);background:var(--accent-soft);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;border-radius:8px;align-items:center;min-height:32px;padding:0 12px;font-weight:700;list-style:none;transition:background-color .2s,transform .15s;display:inline-flex}.mobile-card-details summary:active{transform:scale(.95)}.mobile-card-details summary::-webkit-details-marker{display:none}.mobile-card-details summary:after{content:"展开"}.mobile-card-details[open] summary:after{content:"收起"}.mobile-card-detail-grid{gap:7px;padding-top:6px;display:grid}.mobile-card-detail-grid>div{grid-template-columns:76px minmax(0,1fr);align-items:start;gap:8px;min-width:0;display:grid}.mobile-card-detail-grid span{color:var(--muted)}.mobile-card-detail-grid strong,.mobile-card-detail-grid code{color:var(--foreground);overflow-wrap:anywhere;min-width:0;font-weight:600}.mobile-card-actions{scrollbar-width:thin;white-space:nowrap;flex-wrap:nowrap;gap:7px;max-width:100%;padding-bottom:1px;display:flex;overflow-x:auto}.mobile-card-actions>*{flex:none}.mobile-detail-only{display:revert}.mobile-secondary-cell{display:none!important}.admin-shell{min-height:100vh;display:block}.sidebar{display:none}.admin-shell.sidebar-collapsed{display:block}.content-shell{padding:calc(18px + env(safe-area-inset-top)) 14px calc(94px + env(safe-area-inset-bottom))}.mobile-bottom-nav{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--border);padding:8px 10px calc(8px + env(safe-area-inset-bottom));z-index:45;grid-auto-columns:minmax(0,1fr);grid-auto-flow:column;align-items:center;gap:4px;display:grid;position:fixed;inset:auto 0 0;box-shadow:0 -10px 30px #0f172a0f}.mobile-bottom-nav a,.mobile-bottom-nav button,.mobile-more-panel a,.mobile-more-panel button{color:var(--muted);cursor:pointer;font:inherit;white-space:nowrap;background:0 0;border:0;border-radius:12px;justify-content:center;align-items:center;gap:6px;min-height:48px;padding:0 8px;font-size:12px;font-weight:600;transition:color .2s,transform .15s cubic-bezier(.34,1.56,.64,1),background-color .2s;display:inline-flex}.mobile-bottom-nav a:active,.mobile-bottom-nav button:active{transform:scale(.92)}.mobile-bottom-nav a,.mobile-bottom-nav button{flex-direction:column}.mobile-bottom-nav a.active,.mobile-bottom-nav button.active,.mobile-more-panel a.active{color:var(--accent)}.mobile-bottom-nav a.active svg,.mobile-bottom-nav button.active svg{filter:drop-shadow(0 2px 6px #4f46e54d);transition:transform .25s cubic-bezier(.34,1.56,.64,1),filter .2s;transform:translateY(-2px)}.mobile-nav-backdrop{z-index:43;background:#0f172a2e;border:0;display:block;position:fixed;inset:0}.mobile-more-panel{border:1px solid var(--border);bottom:calc(76px + env(safe-area-inset-bottom));box-shadow:var(--shadow);z-index:46;background:#fffffffa;border-radius:8px;gap:6px;width:min(260px,100vw - 20px);padding:8px;display:grid;position:fixed;right:10px}.mobile-more-panel a,.mobile-more-panel button{justify-content:flex-start;width:100%;min-height:42px}.toolbar-form,.table-toolbar,.payment-qr-upload,.refund-request-form,.referral-copy-layout,.settlement-body,.settlement-summary,.settlement-form,.render-toolbar{grid-template-columns:1fr}.data-table{border:0;gap:10px;display:grid}.data-head{display:none}.data-row{background:var(--surface);border:1px solid var(--border);border-radius:16px;grid-template-columns:1fr;min-width:0;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 20px -4px #0f172a0f}.data-row:active{transform:scale(.98)}.users-row{grid-template-columns:1fr;align-items:stretch;min-width:0}.invite-row{text-align:left;justify-items:stretch}.invite-row .user-actions{justify-content:flex-start}.question-bank-layout,.question-set-layout{grid-template-columns:1fr}.question-set-answer-table .data-row{gap:8px;padding:10px}.question-set-answer-panel{gap:8px;padding:8px}.question-set-answer-status{flex-direction:column;align-items:flex-start;gap:6px}.question-set-answer-input input{min-height:34px;padding:7px 9px}.question-set-answer-actions{grid-template-columns:1fr;display:grid}.question-set-answer-actions .ui-button{justify-content:center;width:100%;min-height:34px}.system-layout{grid-template-columns:1fr}.system-section-nav{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));position:static}.practice-layout,.practice-builder-shell,.practice-attempt-layout{grid-template-columns:1fr}.practice-summary,.practice-nav-panel{position:static}.practice-question-panel{gap:12px}.practice-question-panel pre{background:var(--surface-soft);border:1px solid var(--border-soft);border-radius:12px;margin:0;padding:3%;font-size:.85rem;line-height:1.5;box-shadow:0 2px 8px #00000005}.practice-option{background:var(--surface-soft);border:2px solid #0000;border-radius:12px;grid-template-columns:auto 1fr;gap:10px;min-height:auto;padding:10px 12px;font-size:.85rem;line-height:1.4;transition:all .2s;box-shadow:0 1px 4px #00000005}.practice-option.selected{background:var(--accent-soft);border-color:var(--accent);box-shadow:0 2px 8px #6366f11a}.practice-option-label{background:var(--surface);width:24px;height:24px;color:var(--muted-strong);border-radius:8px;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.practice-option.selected .practice-option-label{background:var(--accent);color:#fff}.practice-option input[type=radio],.practice-option input[type=checkbox]{display:none}.practice-option-text{font-weight:500}.practice-option.selected .practice-option-text{color:var(--accent-dark);font-weight:600}.practice-question-actions{border:1px solid var(--border-soft);bottom:calc(76px + env(safe-area-inset-bottom));z-index:5;background:#fffffff5;border-radius:8px;padding:8px;position:sticky;box-shadow:0 10px 26px #0f172a1a}.practice-question-actions .ui-button{min-height:36px;padding:0 10px}.guest-shell{padding:18px 14px calc(24px + env(safe-area-inset-bottom))}.practice-row-meta,.compact-table .data-row.practice-history-row>:nth-child(n){text-align:left;justify-self:stretch}.bank-row,.question-set-row{grid-template-columns:1fr;min-width:0}.bank-row>:nth-child(n),.question-set-row>:nth-child(n){text-align:left;justify-self:stretch}.question-detail-grid{grid-template-columns:1fr}.user-actions{justify-content:flex-start}.user-expiry-control input{width:100%;max-width:none}.user-expiry-control{grid-template-columns:1fr}.user-expiry-control .ui-button{justify-self:stretch;width:100%}.answer-sheet-row{grid-template-columns:repeat(2,minmax(0,1fr))}.data-table.session-device-active-table:not(.mobile-summary-list) .data-row,.data-table.session-device-history-table:not(.mobile-summary-list) .data-row,.data-table:not(.mobile-summary-list) .data-row.users-row,.data-table:not(.mobile-summary-list) .data-row.invite-row,.data-table:not(.mobile-summary-list) .data-row.practice-admin-row,.data-table:not(.mobile-summary-list) .data-row.admin-user-extraction-row,.data-table:not(.mobile-summary-list) .data-row.audit-log-row,.data-table:not(.mobile-summary-list) .data-row.referral-history-row,.data-table:not(.mobile-summary-list) .data-row.admin-referral-row,.data-table:not(.mobile-summary-list) .data-row.admin-referral-group-row,.data-table:not(.mobile-summary-list) .data-row.refund-request-row,.data-table:not(.mobile-summary-list) .data-row.refund-admin-row{grid-template-columns:var(--table-columns);min-width:var(--table-min-width)}.data-table.session-device-table:not(.mobile-summary-list) .data-head,.data-table.users-table:not(.mobile-summary-list) .data-head,.data-table.practice-admin-table:not(.mobile-summary-list) .data-head,.data-table.audit-log-table:not(.mobile-summary-list) .data-head,.data-table.admin-user-extraction-table:not(.mobile-summary-list) .data-head,.admin-referral-panel .data-table:not(.mobile-summary-list) .data-head{display:grid}.data-table:not(.mobile-summary-list):has(.invite-row) .data-head{display:grid}.data-table.session-device-table:not(.mobile-summary-list),.data-table.users-table:not(.mobile-summary-list),.data-table.practice-admin-table:not(.mobile-summary-list),.data-table.audit-log-table:not(.mobile-summary-list),.data-table.admin-user-extraction-table:not(.mobile-summary-list),.admin-referral-panel .data-table:not(.mobile-summary-list){-webkit-overflow-scrolling:touch;border:1px solid #dce5f2;display:block;overflow-x:auto}.data-table:not(.mobile-summary-list):has(.invite-row){-webkit-overflow-scrolling:touch;border:1px solid #dce5f2;display:block;overflow-x:auto}.data-table.session-device-active-table .data-row>:nth-child(n),.data-table.session-device-history-table .data-row>:nth-child(n),.data-table .users-row>:nth-child(n),.data-table .invite-row>:nth-child(n),.data-table .practice-admin-row>:nth-child(n),.data-table .audit-log-row>:nth-child(n),.data-table .admin-user-extraction-row>:nth-child(n){text-align:left;justify-self:stretch}.data-table.session-device-active-table .data-row>:last-child,.data-table .users-row>:last-child,.data-table .invite-row>:last-child,.data-table .practice-admin-row>:last-child,.data-table .admin-user-extraction-row>:last-child{text-align:center;justify-self:center}.data-table .referral-history-row>:nth-child(n),.data-table .admin-referral-row>:nth-child(n),.data-table .admin-referral-group-row>:nth-child(n),.data-table .refund-request-row>:nth-child(n),.data-table .refund-admin-row>:nth-child(n){text-align:left;justify-self:stretch}.data-table .admin-referral-row .table-actions,.data-table .admin-referral-group-row .table-actions,.data-table .refund-admin-row .table-actions{justify-content:flex-end}.payment-qr-card,.payment-qr-card-large{grid-template-columns:96px minmax(0,1fr)}.payment-qr-card img,.payment-qr-card-large img{width:96px;height:96px}.payment-qr-card .confirm-action,.payment-qr-card .confirm-entry{grid-column:1/-1;justify-self:stretch}.data-row>*{min-width:0}.data-row .table-actions,.data-row .user-actions,.data-row .practice-history-actions{white-space:nowrap;flex-wrap:nowrap;align-self:center;max-width:100%;height:max-content;overflow-x:auto}.data-row .table-actions>*,.data-row .user-actions>*,.data-row .practice-history-actions>*{flex:none}.practice-builder-shell{gap:12px}.practice-builder .section-heading{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;display:grid}.practice-builder .section-heading .ui-button{min-height:34px;padding:0 10px}.practice-course-select{margin-top:10px;padding:10px}.practice-row-list{gap:8px;margin-top:10px}.practice-config-row,.compact-table .data-row.practice-history-row{grid-template-columns:minmax(0,1fr) 72px 68px 30px}.practice-config-row{align-items:center;gap:6px;padding:8px}.practice-config-row label{min-width:0}.practice-config-row label>span{display:none}.practice-config-row input,.practice-config-row select{min-width:0;min-height:34px;padding:0 8px}.practice-config-row select{text-overflow:ellipsis;overflow:hidden}.practice-row-meta{letter-spacing:0;text-align:center;white-space:nowrap;justify-self:stretch;font-size:11px;line-height:1.2}.practice-row-remove{width:28px;height:28px}.practice-summary{gap:10px;padding:10px}.practice-summary .section-heading{grid-template-columns:minmax(0,1fr) auto;align-items:center;display:grid}.practice-summary-toggle{display:inline-flex}.practice-summary-details{display:none}.practice-summary.is-open .practice-summary-details{display:grid}.practice-feedback-mode{grid-template-columns:1fr 1fr;gap:8px;padding:10px}.practice-feedback-mode strong{grid-column:1/-1}.practice-feedback-mode-responsive label:first-of-type{display:none}.practice-feedback-mode-responsive{grid-template-columns:1fr}.practice-attempt-layout{flex-direction:column;align-items:stretch;gap:0;height:100dvh;padding-bottom:0;display:flex;overflow:hidden}.practice-attempt-page-stack{position:relative}.practice-attempt-page-header{grid-template-columns:minmax(0,1fr) auto;justify-content:center;align-items:center;gap:0;min-height:54px;padding-left:106px;padding-right:106px;display:grid}.practice-attempt-page-header>div{text-align:center;min-width:0}.practice-attempt-page-header .back-link,.practice-attempt-page-header>.ui-badge{display:none}.practice-attempt-page-stack>.practice-attempt-mobile-back-link{z-index:7;min-height:30px;line-height:30px;display:inline-flex;position:absolute;top:27px;left:0}.practice-attempt-page-stack>.practice-attempt-submit-header{z-index:7;margin-top:0;position:absolute;top:27px;right:0}.practice-attempt-submit-header .ui-button{white-space:nowrap;min-height:30px;padding:0 10px}.practice-finish-confirm-dialog{gap:12px;padding:16px}.practice-finish-confirm-copy h2{font-size:17px}.practice-finish-confirm-actions{grid-template-columns:1fr 1fr;display:grid}.practice-finish-confirm-actions .ui-button{width:100%;min-height:40px}@keyframes practiceSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes practiceFadeIn{0%{opacity:0}to{opacity:1}}.practice-nav-panel{display:none}.practice-nav-panel.mobile-open{z-index:100;border-bottom-right-radius:0;border-bottom-left-radius:0;flex-direction:column;max-height:85dvh;animation:.3s cubic-bezier(.16,1,.3,1) forwards practiceSlideUp;display:flex;position:fixed;bottom:0;left:0;right:0}.practice-nav-backdrop{-webkit-backdrop-filter:blur(4px);z-index:99;background:#0f172a66;animation:.3s forwards practiceFadeIn;position:fixed;inset:0}.practice-question-panel{touch-action:pan-y;padding:16px;padding-bottom:calc(76px + env(safe-area-inset-bottom));flex-direction:column;flex:1;gap:12px;display:flex;overflow-y:auto}.practice-question-panel>*{flex-shrink:0}.practice-options{flex-direction:column;flex:none;gap:6px;display:flex}.practice-mobile-topbar{-webkit-backdrop-filter:blur(20px);z-index:6;background:#ffffffb3;border-bottom:1px solid #ffffff80;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:7px;padding:6px 12px;display:grid;position:sticky;top:0}.practice-mobile-topbar strong{color:var(--foreground);white-space:nowrap;font-size:13px;line-height:1}.practice-mobile-nav-toggle{cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:4px;margin-left:-8px;padding:4px 8px;display:flex}.practice-mobile-nav-toggle:active{background:var(--surface-soft)}.practice-mobile-nav-toggle svg{color:var(--muted)}.practice-mobile-topbar span{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.practice-mobile-primary-action{white-space:nowrap;min-height:30px;padding:0 10px}.practice-mobile-result{background:var(--surface-soft);border:1px solid var(--border-soft);color:var(--muted-strong);border-radius:8px;flex-wrap:nowrap;justify-content:space-between;gap:8px;padding:7px 9px;font-size:11px;display:flex}.practice-question-panel .question-meta,.practice-shortcut-hints,.practice-question-actions{display:none}.practice-mobile-bottom-actions{-webkit-backdrop-filter:blur(20px);padding:8px 12px calc(8px + env(safe-area-inset-bottom));z-index:44;background:#ffffffd9;border-top:1px solid #ffffff80;grid-template-columns:minmax(0,1fr) minmax(80px,auto) minmax(0,1fr);align-items:center;gap:6px;display:grid;position:fixed;bottom:0;left:0;right:0}.practice-mobile-bottom-actions .ui-button{white-space:nowrap;border-radius:12px;min-height:38px;padding:0 10px;font-size:13px;font-weight:500}.practice-mobile-bottom-actions .practice-reveal-button{min-width:86px}.practice-mobile-middle-actions{gap:5px;min-height:34px;display:grid}.practice-mobile-middle-actions .ui-button{min-height:32px;padding:0 7px;font-size:11px}.practice-mobile-action-spacer{color:var(--muted);white-space:nowrap;justify-content:center;align-items:center;min-height:34px;font-size:11px;display:inline-flex}.practice-prev-button,.practice-next-button{width:100%}}@media (max-width:640px){.shell{padding:20px 14px}.page-header,.section-heading,.question-meta,.copy-result{flex-direction:column;align-items:stretch}.page-header p.muted,.section-heading p.muted{display:none!important}.page-header h1{margin:0!important;font-size:18px!important}.page-header{margin-bottom:12px}.script-box,.script-mode-grid{grid-template-columns:1fr}.script-mode-card{min-height:0}.system-mode-switch{grid-template-columns:1fr;width:100%}.source-meta{flex-direction:column;align-items:stretch}.answer-sheet-row{grid-template-columns:1fr}.page-header h1,.auth-heading h1{font-size:var(--mobile-page-title-size)}.section-heading h2{font-size:var(--mobile-section-title-size)}.practice-attempt-page-header{flex-direction:initial;align-items:center;display:grid}.panel{padding:12px}.mobile-bottom-nav span{text-overflow:ellipsis;max-width:64px;overflow:hidden}.referral-copy-card>div{flex-wrap:wrap;align-items:stretch}.referral-copy-card code,.referral-link-card p{flex:100%;font-size:16px}.referral-split-grid{grid-template-columns:1fr}.referral-link-card .ui-button,.referral-code-card .ui-button{flex:auto}.payment-qr-upload,.refund-request-form{padding:10px}.payment-qr-file{min-height:52px}.refund-request-table,.referral-history-row,.practice-history-row{overflow:visible}.compact-table .data-row.refund-request-row,.compact-table .data-row.referral-history-row,.compact-table .data-row.practice-history-row,.compact-table.question-set-answer-table .data-row{grid-template-columns:1fr;gap:7px;min-width:0;padding:12px;display:grid}.compact-table .data-row.refund-request-row>*,.compact-table .data-row.referral-history-row>*,.compact-table .data-row.practice-history-row>*,.compact-table.question-set-answer-table .data-row>*{white-space:normal}.compact-table .data-row.refund-request-row.data-head,.compact-table .data-row.referral-history-row.data-head,.compact-table .data-row.practice-history-row.data-head,.compact-table.question-set-answer-table .data-row.data-head{display:none}.refund-admin-table,.admin-referral-panel .data-table{-webkit-overflow-scrolling:touch}.refund-admin-row .table-actions,.admin-referral-row .table-actions,.admin-referral-group-row .table-actions{min-width:max-content}}@media (max-width:1024px){.desktop-only{display:none!important}}@media (min-width:1025px){.mobile-only{display:none!important}}.pure-mobile-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-direction:column;gap:12px;min-width:0;padding:16px;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 4px 20px -4px #0f172a0f}.pure-mobile-card:active{transform:scale(.98)}.pure-mobile-card .mobile-card-actions{margin-top:4px;padding:0}.pure-mobile-card .record-title{flex-direction:column;gap:4px;display:flex}.pure-mobile-card .record-title strong{color:var(--foreground);font-size:16px}.pure-mobile-card .mobile-meta-row{color:var(--muted);justify-content:space-between;align-items:center;gap:12px;font-size:13px;display:flex}.compact-mobile-card{border-bottom:1px solid var(--border-light);background:0 0;flex-direction:row;align-items:center;gap:8px;padding:8px 0;display:flex}.compact-mobile-card:active{background-color:#0000}.compact-mobile-card .compact-main{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.compact-mobile-card .compact-header{justify-content:flex-start;align-items:center;gap:6px;display:flex}.compact-mobile-card .compact-header .user-identity strong,.compact-mobile-card .compact-header strong{color:var(--foreground);white-space:nowrap;text-overflow:ellipsis;vertical-align:middle;max-width:120px;font-size:13px;display:inline-block;overflow:hidden}.compact-mobile-card .compact-header .badge{white-space:nowrap;background:var(--surface-sunken);color:var(--muted);border-radius:4px;flex-shrink:0;padding:1px 4px;font-size:10px}.compact-mobile-card .compact-info{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;flex-wrap:nowrap;align-items:center;gap:4px;font-size:11px;display:flex;overflow:hidden}.compact-mobile-card .compact-info span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.compact-mobile-card .compact-actions-right{flex-shrink:0;align-items:center;gap:6px;display:flex}.compact-mobile-card .compact-actions-right button{white-space:nowrap;border-radius:4px;flex-shrink:0;height:auto;padding:4px 8px;font-size:12px}.compact-mobile-card .icon-btn-mobile{background:var(--surface-sunken);border:none;border-radius:4px;padding:4px 8px;font-size:12px}@media (max-width:768px){input[type=checkbox],input[type=radio]{flex:none!important;width:20px!important;height:20px!important;margin:0!important}}.icon-btn-mobile{color:var(--muted);border:1px solid var(--border-soft);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;padding:6px;display:inline-flex}.icon-btn-mobile:active,.icon-btn-mobile:hover{background:var(--accent-soft);color:var(--accent-dark)}.icon-btn-mobile.danger{color:var(--destructive);border-color:var(--destructive-soft,#fca5a5)}.mobile-action-accordion{margin-top:2px}.mobile-action-accordion summary{color:var(--accent);cursor:pointer;-webkit-user-select:none;user-select:none;background:0 0;border-radius:4px;align-items:center;padding:4px 0;font-size:11px;font-weight:600;list-style:none;display:inline-flex}.mobile-action-accordion summary::-webkit-details-marker{display:none}.mobile-action-accordion summary:after{content:"展开管理面板 ▾"}.mobile-action-accordion[open] summary:after{content:"收起管理面板 ▴"}.mobile-action-accordion[open] summary{color:var(--accent-dark);margin-bottom:8px}.mobile-action-accordion .accordion-content{flex-direction:column;gap:10px;animation:.2s ease-out forwards slideDown;display:flex}@keyframes slideDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.premium-card{background:var(--surface-raised);border:1px solid var(--border);border-radius:12px;padding:24px;transition:transform .3s cubic-bezier(.2,.8,.2,1),box-shadow .3s cubic-bezier(.2,.8,.2,1),border-color .3s;position:relative;overflow:hidden;box-shadow:0 4px 12px -4px #0f172a0d}.premium-card:before{content:"";background:linear-gradient(90deg, var(--accent), #a855f7);opacity:0;height:4px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.premium-hover:hover{border-color:var(--accent-border);transform:translateY(-4px);box-shadow:0 20px 40px -12px #0f172a26}.premium-hover:hover:before{opacity:1}.premium-dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;display:grid}.premium-metric{flex-direction:column;gap:8px;display:flex}.premium-metric .metric-label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:13px;font-weight:500}.premium-metric .metric-value{color:var(--foreground);background:linear-gradient(135deg, var(--foreground), var(--accent-dark));-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:36px;font-weight:800;line-height:1}.compact-metrics{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))!important;gap:12px!important}.compact-metrics .premium-metric{gap:2px;padding:12px}.compact-metrics .premium-metric .metric-value{font-size:18px}.compact-metrics .premium-metric .metric-label{margin-bottom:0;font-size:11px}.premium-list{flex-direction:column;gap:12px;display:flex}.premium-list-item{background:var(--surface-soft);border:1px solid var(--border-soft);border-radius:10px;justify-content:space-between;align-items:center;padding:16px;transition:all .2s;display:flex}.data-row.premium-list-item{align-items:center;justify-content:initial;display:grid}.premium-list-item:hover{background:var(--surface-raised);border-color:var(--accent-border);box-shadow:0 4px 12px -4px #0f172a0d}.premium-input-glass{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border);background:#fff9;transition:all .2s}.premium-input-glass:focus{background:#fff;box-shadow:0 0 0 4px #4f46e51a}.scrollable-tabs{scrollbar-width:none;-ms-overflow-style:none;white-space:nowrap;gap:8px;padding-bottom:4px;display:flex;overflow-x:auto}.scrollable-tabs::-webkit-scrollbar{display:none}@media (max-width:700px){.practice-layout.practice-modern-ui{flex-direction:column;align-items:stretch;gap:0;width:100%;display:flex}.practice-modern-ui .practice-section-tabs{border-radius:10px;flex:none;gap:4px;margin-bottom:6px;padding:4px}.practice-modern-ui .practice-section-tabs button{border-radius:8px;gap:5px;min-height:auto;padding:8px 10px;font-size:13px}.practice-modern-ui .practice-section-tabs button span{padding:1px 6px;font-size:11px}.practice-modern-ui .practice-builder-shell{border-radius:14px;flex-direction:column;align-items:stretch;gap:0;width:100%;display:flex}.practice-modern-ui .practice-builder-shell.panel{padding:0}.practice-modern-ui .practice-builder{padding:10px 10px 4px}.practice-modern-ui .practice-builder .section-heading{margin-bottom:6px;padding:0}.practice-modern-ui .practice-builder .section-heading h2{font-size:14px!important}.practice-modern-ui .practice-builder .section-heading p.muted{margin:0;font-size:11px}.practice-modern-ui .practice-builder .section-heading .ui-button{min-height:28px;padding:0 8px;font-size:12px}.practice-modern-ui .practice-course-select{gap:4px;margin-top:6px;padding:8px}.practice-modern-ui .practice-course-select select,.practice-modern-ui .practice-course-select option{border-radius:8px;padding:8px 10px;font-size:10px}.practice-modern-ui .practice-row-list{gap:6px;margin-top:6px}.practice-modern-ui .practice-config-row{border-radius:10px;grid-template-columns:minmax(0,1fr) 58px 50px 26px;align-items:center;gap:5px;margin-bottom:0;padding:7px 8px;display:grid;box-shadow:none!important;transform:none!important}.practice-modern-ui .practice-config-row:hover{box-shadow:none!important;transform:none!important}.practice-modern-ui .practice-config-row label>span{display:none}.practice-modern-ui .practice-config-row label{gap:0;min-width:0}.practice-modern-ui .practice-config-row select,.practice-modern-ui .practice-config-row option,.practice-modern-ui .practice-config-row input{border-radius:6px;min-height:30px;padding:5px 6px;font-size:9px}.practice-modern-ui .practice-row-meta{text-align:center;color:var(--muted);font-size:10px;line-height:1.2}.practice-modern-ui .practice-row-remove{width:24px;height:24px;padding:4px;opacity:1!important;transform:scale(1)!important}.practice-modern-ui .practice-summary{-webkit-backdrop-filter:blur(16px);width:100%;padding:12px 10px calc(8px + env(safe-area-inset-bottom));background:#fffffff5;border-top:1px solid #c8d2e699;border-left:none;border-radius:0 0 14px 14px;flex-direction:column;flex:none;align-items:stretch;gap:6px;margin-top:24px;display:flex;box-shadow:0 -4px 16px #0f172a0f}.practice-modern-ui .practice-summary-toggle,.practice-modern-ui .practice-summary-details,.practice-modern-ui .practice-summary>.section-heading{display:none!important}.practice-modern-ui .practice-summary .practice-feedback-mode{background:0 0;border:none;flex-direction:row;align-items:center;gap:6px;margin-bottom:0;padding:0;display:flex}.practice-modern-ui .practice-feedback-mode-responsive{display:none!important}.practice-modern-ui .practice-summary .practice-feedback-mode>strong{white-space:nowrap;color:var(--muted-strong);flex:none;font-size:11px}.practice-modern-ui .practice-summary .practice-feedback-mode-options{flex:1;gap:4px;display:flex}.practice-modern-ui .practice-summary .practice-feedback-mode-options label{border-radius:8px;flex:1;min-height:28px;padding:5px 4px;font-size:11px}.practice-modern-ui .practice-summary .form-error{margin:0;padding:5px 8px;font-size:11px}.practice-modern-ui .btn-gradient-primary{border-radius:10px;padding:10px 16px;font-size:14px;box-shadow:0 3px 10px #6366f14d}.practice-modern-ui .practice-wrong-book{-webkit-overflow-scrolling:touch;flex-direction:column;flex:auto;align-items:stretch;gap:10px;width:100%;min-height:0;padding:10px;display:flex;overflow-y:auto}.practice-modern-ui .practice-wrong-book.panel{padding:10px}.practice-modern-ui .practice-wrong-book .section-heading{margin-bottom:6px;padding:0}.practice-modern-ui .practice-wrong-book .section-heading h2{font-size:14px!important}.practice-modern-ui .wrong-dashboard{grid-template-columns:1fr;gap:8px;margin-bottom:10px}.practice-modern-ui .wrong-stat-card{border-radius:10px;padding:10px 12px}.practice-modern-ui .wrong-stat-card h3{margin-bottom:8px;font-size:13px}.practice-modern-ui .wrong-stat-tag{padding:4px 8px;font-size:11px}.practice-modern-ui .practice-wrong-book .practice-feedback-mode{background:0 0;border:none;flex-direction:row;align-items:center;gap:6px;margin-bottom:8px;padding:0;display:flex}.practice-modern-ui .practice-wrong-book .practice-feedback-mode>strong{white-space:nowrap;flex:none;font-size:11px}.practice-modern-ui .practice-wrong-book .practice-feedback-mode-options{flex:1;gap:4px}.practice-modern-ui .practice-wrong-book .practice-feedback-mode-options label{border-radius:8px;min-height:28px;padding:5px 4px;font-size:11px}.practice-modern-ui .practice-wrong-actions{flex-direction:column;gap:7px}.practice-modern-ui .btn-gradient-warning{border-radius:10px;width:100%;padding:10px 16px;font-size:14px}.practice-modern-ui .practice-wrong-actions .ui-button{border-radius:10px;justify-content:center;width:100%;min-height:36px}.practice-modern-ui .practice-history{-webkit-overflow-scrolling:touch;flex-direction:column;flex:auto;align-items:stretch;gap:10px;width:100%;min-height:0;padding:10px;display:flex;overflow-y:auto}.practice-modern-ui .practice-history.panel{padding:10px}.practice-modern-ui .practice-history .section-heading{margin-bottom:6px;padding:0}.practice-modern-ui .practice-history .section-heading h2{font-size:14px!important}.practice-modern-ui .history-card{border-radius:11px;flex-direction:row;align-items:center;gap:10px;padding:9px 11px}.practice-modern-ui .history-card:hover{transform:none}.practice-modern-ui .history-card-left{gap:2px}.practice-modern-ui .history-time span{font-size:10px}.practice-modern-ui .history-summary{font-size:13px;font-weight:600}.practice-modern-ui .score-circle{flex-shrink:0;width:36px;height:36px;font-size:11px}.practice-modern-ui .history-score{flex-shrink:0;align-items:center;gap:8px}.practice-modern-ui .history-actions{opacity:1;gap:5px}.practice-modern-ui .history-actions .ui-button{min-height:28px;padding:0 8px;font-size:12px}.practice-modern-ui .history-card-list{gap:6px}.practice-modern-ui .pagination-footer{flex-wrap:wrap;gap:6px;margin-top:8px;padding:7px 8px;font-size:12px}body:has(.practice-modern-ui) .content-shell{padding-top:max(10px, env(safe-area-inset-top));padding-left:10px;padding-right:10px;padding-bottom:calc(68px + env(safe-area-inset-bottom))}}.custom-select-trigger{width:100%;color:inherit;cursor:pointer;text-align:left;background:0 0;border:1px solid #c8d2e699;border-radius:8px;justify-content:space-between;align-items:center;padding:6px 10px;font-size:13px;display:flex}.practice-course-select .custom-select-trigger{border-radius:10px;padding:8px 12px;font-size:14px}.practice-config-row .custom-select-trigger{border:1px solid #c8d2e666;height:30px;padding:6px 8px;font-size:12px}.custom-select-trigger>span{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.custom-select-trigger .select-arrow{color:#888;flex:none;margin-left:6px;font-size:10px}.custom-select-dialog{background:0 0;border:none;border-radius:16px;width:400px;max-width:90vw;margin:auto;padding:0}.custom-select-dialog::backdrop{-webkit-backdrop-filter:blur(4px);background:#0f172a66}@media (max-width:700px){.custom-select-dialog{border-radius:20px 20px 0 0;width:100%;max-width:100vw;margin:auto 0 0}}.custom-select-panel{background:#fff;flex-direction:column;max-height:70vh;display:flex;overflow:hidden;box-shadow:0 -4px 20px #0000001a}@media (prefers-color-scheme:dark){.custom-select-panel{background:#1e1e1e}}.custom-select-header{border-bottom:1px solid #c8d2e666;justify-content:space-between;align-items:center;padding:16px;display:flex}.custom-select-header h3{white-space:nowrap;margin:0;font-size:16px;font-weight:600}.custom-select-header button{color:#888;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:4px;display:flex}.custom-select-list{-webkit-overflow-scrolling:touch;flex-direction:column;flex:auto;gap:4px;padding:8px;display:flex;overflow-y:auto}.custom-select-list button{color:inherit;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;flex-direction:row;align-items:center;gap:6px;padding:12px 16px;font-size:14px;display:flex}.custom-select-list button:active,.custom-select-list button:hover{background:#6366f114}.custom-select-list button.active{color:#6366f1;background:#6366f11f;font-weight:500}.custom-select-list button small{color:#888;margin-top:0;font-size:11px}.custom-select-list button.active small{color:#6366f1;opacity:.8}@media (max-width:700px){.referral-status-grid.premium-dashboard-grid{grid-template-columns:repeat(3,1fr);gap:4px}.referral-status-grid .premium-metric{flex-direction:row;justify-content:center;align-items:baseline;gap:4px;padding:8px 4px}.referral-status-grid .metric-value{font-size:14px;font-weight:700}.referral-status-grid .metric-label{margin-bottom:0;font-size:10px}.referral-hero{padding:12px}.referral-split-card{gap:8px;margin-top:10px;padding:10px}.referral-split-card>div:first-child strong{font-size:13px}.referral-split-grid{gap:8px;grid-template-columns:repeat(2,minmax(0,1fr))!important}.referral-split-grid>div{padding:8px}.referral-split-grid span{font-size:11px}.referral-split-grid strong{font-size:14px}.referral-split-card p{font-size:11px;line-height:1.4}.referral-copy-layout{gap:8px;margin-top:10px}.referral-copy-card{padding:8px}.referral-copy-card span{font-size:11px}.referral-copy-card code,.referral-copy-card p{font-size:12px}.refund-request-form{gap:8px;padding:8px}.refund-request-form label span{margin-bottom:-2px;font-size:11px}.refund-request-form input,.refund-request-form select{height:32px;padding:6px 8px;font-size:13px}.refund-request-form button[type=submit]{height:32px;padding:0;font-size:13px}}.refund-reason-options{flex-wrap:wrap;gap:8px;width:100%;display:flex}.refund-reason-options button{color:#475569;cursor:pointer;white-space:nowrap;background:#f8fbff;border:1px solid #d7e3f4;border-radius:999px;padding:6px 14px;font-size:13px;transition:all .2s}.refund-reason-options button:hover{background:#eff6ff;border-color:#bfdbfe}.refund-reason-options button.active{color:#1d4ed8;background:#eff6ff;border-color:#3b82f6;font-weight:500;box-shadow:0 0 0 1px #3b82f6}
