.app{display:grid;grid-template-columns:244px 1fr;height:100vh;overflow:hidden;transition:grid-template-columns .25s ease}.app.collapsed{grid-template-columns:72px 1fr}.sidebar{background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.brand{height:64px;display:flex;align-items:center;gap:10px;padding:0 18px;border-bottom:1px solid var(--border);flex-shrink:0}.brand-mark{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,#2563eb,#4f46e5);display:grid;place-items:center;color:#fff;font-weight:700;font-size:14px;flex-shrink:0;box-shadow:0 4px 10px -2px #2563eb73}.brand-text{min-width:0}.brand-name{font-weight:600;font-size:15px;letter-spacing:.2px;white-space:nowrap;color:var(--text)}.brand-sub{color:var(--text-3);font-size:11.5px;white-space:nowrap}.app.collapsed .brand{justify-content:center;padding:0}.app.collapsed .brand-text{display:none}.nav{padding:12px 10px;flex:1;overflow-y:auto}.nav-group-label{font-size:11px;letter-spacing:.8px;color:var(--text-3);padding:14px 12px 6px;text-transform:uppercase;font-weight:600;transition:opacity .2s,height .2s;white-space:nowrap}.app.collapsed .nav-group-label{opacity:0;height:0;padding:0;overflow:hidden}.nav-item{display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:var(--r);color:var(--text-2);cursor:pointer;font-size:14px;font-weight:500;margin-bottom:2px;transition:background .12s,color .12s;white-space:nowrap;position:relative}.nav-item:hover{background:var(--hover);color:var(--text)}.nav-item.active{background:var(--accent-soft);color:var(--accent)}.nav-item .nav-icon{width:18px;height:18px;flex-shrink:0}.nav-item span{overflow:hidden}.nav-badge{margin-left:auto;background:var(--red-soft);color:var(--red);font-size:11px;padding:1px 7px;border-radius:999px;font-weight:600;flex-shrink:0}.app.collapsed .nav-item{justify-content:center;padding:10px}.app.collapsed .nav-item span,.app.collapsed .nav-badge{display:none}.sidebar-foot{border-top:1px solid var(--border);padding:12px;display:flex;align-items:center;gap:10px;flex-shrink:0}.sidebar-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#818cf8,#2563eb);color:#fff;font-weight:600;font-size:13px;display:grid;place-items:center;flex-shrink:0}.sidebar-user{font-size:13px;line-height:1.35;min-width:0;flex:1;overflow:hidden}.sidebar-user-name{font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{color:var(--text-3);font-size:12px}.app.collapsed .sidebar-user,.app.collapsed .sidebar-foot-btn{display:none}.app.collapsed .sidebar-foot{justify-content:center}.main{display:flex;flex-direction:column;min-width:0;overflow:hidden;background:var(--bg)}.topbar{height:64px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:16px;flex-shrink:0}.topbar-toggle{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:var(--r);border:none;background:transparent;color:var(--text-2);cursor:pointer;transition:background .12s,color .12s;flex-shrink:0}.topbar-toggle:hover{background:var(--hover);color:var(--text)}.breadcrumbs{display:flex;align-items:center;gap:8px;color:var(--text-3);font-size:13px}.breadcrumbs .sep{color:var(--text-3)}.breadcrumbs .current{color:var(--text);font-weight:500}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:8px}.topbar-search{display:flex;align-items:center;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r);padding:0 12px;width:260px;height:36px;gap:8px;transition:all .15s;color:var(--text-3)}.topbar-search:focus-within{background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);color:var(--text)}.topbar-search input{border:none;outline:none;background:transparent;flex:1;font-size:13px;color:var(--text);font-family:var(--font)}.topbar-search input::placeholder{color:var(--text-3)}.topbar-search-kbd{font-size:11px;padding:1px 6px;border:1px solid var(--border-strong);border-bottom-width:2px;border-radius:4px;background:var(--surface);color:var(--text-3);font-family:ui-monospace,monospace;white-space:nowrap}.gs-wrap{position:relative;display:flex;align-items:center;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r);padding:0 12px;width:260px;height:36px;gap:8px;transition:all .15s;color:var(--text-3)}.gs-wrap:focus-within{background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);color:var(--text)}.gs-icon{flex-shrink:0}.gs-input{border:none;outline:none;background:transparent;flex:1;font-size:13px;color:var(--text);font-family:var(--font);min-width:0}.gs-input::placeholder{color:var(--text-3)}.gs-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:0 8px 24px #0000001a;z-index:1000;overflow:hidden}.gs-empty{padding:12px 14px;font-size:13px;color:var(--text-3);text-align:center}.gs-item{display:flex;align-items:center;gap:8px;padding:9px 14px;font-size:13px;cursor:pointer;transition:background .1s}.gs-item:hover{background:var(--surface-2)}.gs-item-icon{display:flex;align-items:center;color:var(--text-3);flex-shrink:0}.gs-item-main{font-weight:500;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gs-item-sub{font-size:12px;color:var(--text-3);flex-shrink:0}.gs-item-type{font-size:11px;padding:1px 6px;border-radius:4px;background:var(--surface-2);color:var(--text-3);flex-shrink:0}.topbar-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--r);border:none;background:transparent;color:var(--text-2);cursor:pointer;transition:background .12s,color .12s}.topbar-icon-btn:hover{background:var(--hover);color:var(--text)}.content{flex:1;overflow-y:auto;padding:24px 32px 48px}.lg-wrap{height:100vh;display:grid;grid-template-columns:1.05fr 1fr;background:var(--surface)}.lg-left{background:radial-gradient(900px 500px at 80% -10%,#dbeafe 0%,transparent 60%),radial-gradient(700px 400px at -10% 110%,#ede9fe 0%,transparent 55%),linear-gradient(180deg,#f8fafc,#fff);padding:56px 64px;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden}.lg-brand{display:flex;align-items:center;gap:12px}.lg-mark{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,#2563eb,#4f46e5);display:grid;place-items:center;color:#fff;font-weight:700;font-size:16px;flex-shrink:0;box-shadow:0 4px 10px -2px #2563eb73}.lg-brand-name{font-weight:600;font-size:16px;color:var(--text)}.lg-brand-sub{color:var(--text-3);font-size:12px}.lg-tagline{max-width:480px}.lg-tagline h1{font-size:40px;font-weight:600;letter-spacing:-1px;line-height:1.15;margin:0 0 18px;color:var(--text)}.lg-tagline>p{color:var(--text-2);font-size:15px;line-height:1.6;margin:0}.lg-features{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:36px}.lg-feat{background:#ffffffa6;border:1px solid var(--border);border-radius:var(--r-lg);padding:16px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.lg-feat-icon{width:32px;height:32px;border-radius:9px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;margin-bottom:12px}.lg-feat-icon.green{background:var(--green-soft);color:var(--green)}.lg-feat-icon.violet{background:var(--violet-soft);color:var(--violet)}.lg-feat-icon.amber{background:var(--amber-soft);color:var(--amber)}.lg-feat h4{margin:0 0 4px;font-size:14px;font-weight:600;color:var(--text)}.lg-feat p{margin:0;color:var(--text-3);font-size:12.5px;line-height:1.5}.lg-footer{color:var(--text-3);font-size:12px}.lg-right{display:grid;place-items:center;padding:40px}.lg-card{width:100%;max-width:380px}.lg-card h2{font-size:24px;font-weight:600;margin:0 0 6px;letter-spacing:-.3px;color:var(--text)}.lg-lead{color:var(--text-3);font-size:14px;margin:0 0 28px}.lg-form{display:flex;flex-direction:column;gap:16px}.lg-field{display:flex;flex-direction:column;gap:6px}.lg-label{font-size:12.5px;color:var(--text-2);font-weight:500}.lg-input-wrap{position:relative}.lg-input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-3);pointer-events:none}.lg-input{width:100%;border:1px solid var(--border-strong);background:var(--surface);border-radius:var(--r);padding:10px 12px 10px 38px;font-size:14px;color:var(--text);outline:none;transition:border-color .15s,box-shadow .15s;font-family:var(--font);box-sizing:border-box}.lg-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.lg-input::placeholder{color:var(--text-3)}.lg-error{font-size:13px;color:var(--red);padding:8px 12px;background:var(--red-soft);border-radius:var(--r)}.lg-submit{width:100%;height:44px;background:var(--accent);border:none;border-radius:var(--r);color:#fff;font-size:15px;font-weight:500;cursor:pointer;transition:background .15s,transform .12s;font-family:var(--font);box-shadow:0 2px 8px -2px #2563eb73;margin-top:4px}.lg-submit:hover:not(:disabled){background:var(--accent-hover)}.lg-submit:active:not(:disabled){transform:translateY(.5px)}.lg-submit:disabled{opacity:.7;cursor:not-allowed}.lg-hint{margin-top:20px;padding:10px 14px;background:var(--accent-soft);border:1px solid var(--accent-soft-strong);border-radius:var(--r);font-size:12.5px;color:var(--accent);display:flex;align-items:center;gap:8px}@media (max-width: 960px){.lg-wrap{grid-template-columns:1fr}.lg-left{display:none}}.db-page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:22px;gap:16px;flex-wrap:wrap}.db-page-title{font-size:22px;font-weight:600;letter-spacing:-.2px;margin:0 0 4px;color:var(--text)}.db-page-sub{color:var(--text-3);font-size:13px;margin:0}.db-stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:22px}@media (max-width: 1280px){.db-stat-grid{grid-template-columns:repeat(2,1fr)}}.db-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 20px;box-shadow:var(--shadow-1)}.db-stat-label{display:flex;align-items:center;gap:8px;color:var(--text-2);font-size:13px;margin-bottom:12px}.db-stat-icon{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent);flex-shrink:0}.db-stat-icon.green{background:var(--green-soft);color:var(--green)}.db-stat-icon.amber{background:var(--amber-soft);color:var(--amber)}.db-stat-icon.red{background:var(--red-soft);color:var(--red)}.db-stat-icon.violet{background:var(--violet-soft);color:var(--violet)}.db-stat-value{font-size:28px;font-weight:600;letter-spacing:-.5px;line-height:1;color:var(--text);font-variant-numeric:tabular-nums}.db-stat-value.danger{color:var(--red)}.db-stat-trend{display:flex;align-items:center;gap:6px;margin-top:10px;font-size:12px;color:var(--text-3)}.db-grid-2-1{display:grid;grid-template-columns:1.6fr 1fr;gap:16px}@media (max-width: 1280px){.db-grid-2-1{grid-template-columns:1fr}}.db-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-1);overflow:hidden}.db-card-head{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}.db-card-title{font-weight:600;font-size:15px;color:var(--text)}.db-list-item{display:flex;align-items:center;gap:14px;padding:12px 20px;border-bottom:1px solid var(--border);transition:background .12s}.db-list-item:last-child{border-bottom:0}.db-list-item:hover{background:var(--surface-2)}.db-time-block{width:72px;text-align:center;flex-shrink:0}.db-t1{font-weight:600;font-size:13.5px;font-variant-numeric:tabular-nums;color:var(--text)}.db-t2{font-size:11.5px;color:var(--text-3);margin-top:2px;font-variant-numeric:tabular-nums}.db-divider-v{width:1px;align-self:stretch;background:var(--border);flex-shrink:0}.db-muted{color:var(--text-3)}.db-avatar{width:36px;height:36px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-weight:600;font-size:13px;flex-shrink:0}.db-avatar.red{background:var(--red-soft);color:var(--red)}.db-avatar.amber{background:var(--amber-soft);color:var(--amber)}.db-avatar.green{background:var(--green-soft);color:var(--green)}.db-pill{display:inline-flex;align-items:baseline;gap:2px;font-variant-numeric:tabular-nums;background:var(--green-soft);color:var(--green);padding:2px 9px;border-radius:999px;font-size:12.5px;font-weight:600;white-space:nowrap}.db-pill.warn{background:var(--amber-soft);color:var(--amber)}.db-pill.danger{background:var(--red-soft);color:var(--red)}.db-pill .u{font-weight:500;font-size:11px;opacity:.75}.db-tag{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:500;padding:2px 9px;border-radius:var(--r-sm);background:var(--hover);color:var(--text-2);white-space:nowrap}.db-tag.dot:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}.db-tag.green{background:var(--green-soft);color:var(--green)}.db-tag.amber{background:var(--amber-soft);color:var(--amber)}.db-tag.red{background:var(--red-soft);color:var(--red)}.db-tag.blue{background:var(--accent-soft);color:var(--accent)}.db-tag.violet{background:var(--violet-soft);color:var(--violet)}.db-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 14px;height:36px;border-radius:var(--r);border:1px solid var(--border-strong);background:var(--surface);color:var(--text);font-size:13px;font-weight:500;cursor:pointer;transition:background .12s,border-color .12s,transform .12s;white-space:nowrap;font-family:inherit}.db-btn:hover{background:var(--hover);border-color:var(--text-3)}.db-btn:active{transform:translateY(.5px)}.db-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 6px -1px #2563eb59}.db-btn.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.db-btn.ghost{background:transparent;border-color:transparent;color:var(--text-2)}.db-btn.ghost:hover{background:var(--hover);color:var(--text)}.db-btn.sm{height:30px;padding:0 10px;font-size:12.5px}.db-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;gap:10px;color:var(--text-3)}.db-empty-icon{width:48px;height:48px;border-radius:12px;background:var(--surface-2);border:1px solid var(--border);display:grid;place-items:center}.db-empty-lead{font-size:13.5px;color:var(--text-2);font-weight:500}.st-page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:20px;gap:16px;flex-wrap:wrap}.st-page-title{font-size:22px;font-weight:600;letter-spacing:-.2px;margin:0 0 3px;color:var(--text)}.st-page-sub{color:var(--text-3);font-size:13px;margin:0}.st-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-1);overflow:hidden}.st-toolbar{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--border);background:var(--surface-2)}.st-search{position:relative;width:260px}.st-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-3);pointer-events:none}.st-search-input{width:100%;border:1px solid var(--border-strong);background:var(--surface);border-radius:var(--r);padding:7px 12px 7px 32px;font-size:13.5px;color:var(--text);outline:none;font-family:var(--font);box-sizing:border-box;transition:border-color .15s,box-shadow .15s}.st-search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.st-search-input::placeholder{color:var(--text-3)}.st-select{border:1px solid var(--border-strong);background:var(--surface);border-radius:var(--r);padding:7px 10px;font-size:13.5px;color:var(--text);outline:none;font-family:var(--font);cursor:pointer;height:34px}.st-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.st-table .ant-table{font-size:13.5px}.st-table .ant-table-thead>tr>th{background:var(--surface-2);color:var(--text-3);font-size:12.5px;font-weight:500;border-bottom:1px solid var(--border);padding:10px 16px}.st-table .ant-table-tbody>tr>td{padding:13px 16px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}.st-table .ant-table-tbody>tr:last-child>td{border-bottom:0}.st-table .ant-table-tbody>tr:hover>td{background:var(--surface-2)}.st-table .ant-table-pagination{padding:12px 16px;margin:0;border-top:1px solid var(--border)}.st-table .ant-table-wrapper{border-radius:0}.st-avatar{width:34px;height:34px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-weight:600;font-size:13px;flex-shrink:0}.st-avatar.violet{background:var(--violet-soft);color:var(--violet)}.st-avatar.green{background:var(--green-soft);color:var(--green)}.st-avatar.amber{background:var(--amber-soft);color:var(--amber)}.st-avatar.red{background:var(--red-soft);color:var(--red)}.st-pill{display:inline-flex;align-items:baseline;gap:2px;font-variant-numeric:tabular-nums;background:var(--green-soft);color:var(--green);padding:2px 9px;border-radius:999px;font-size:12.5px;font-weight:600;white-space:nowrap}.st-pill.warn{background:var(--amber-soft);color:var(--amber)}.st-pill.danger{background:var(--red-soft);color:var(--red)}.st-pill .u{font-weight:500;font-size:11px;opacity:.75}.st-tag{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:500;padding:2px 9px;border-radius:var(--r-sm);background:var(--hover);color:var(--text-2);white-space:nowrap}.st-tag.dot:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}.st-tag.green{background:var(--green-soft);color:var(--green)}.st-tag.amber{background:var(--amber-soft);color:var(--amber)}.st-tag.blue{background:var(--accent-soft);color:var(--accent)}.st-tag.violet{background:var(--violet-soft);color:var(--violet)}.st-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 14px;height:36px;border-radius:var(--r);border:1px solid var(--border-strong);background:var(--surface);color:var(--text);font-size:13px;font-weight:500;cursor:pointer;transition:background .12s,border-color .12s,transform .12s;white-space:nowrap;font-family:inherit}.st-btn:hover{background:var(--hover);border-color:var(--text-3)}.st-btn:active{transform:translateY(.5px)}.st-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 6px -1px #2563eb59}.st-btn.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.st-btn.ghost{background:transparent;border-color:transparent;color:var(--text-2)}.st-btn.ghost:hover{background:var(--hover);color:var(--text)}.st-btn.sm{height:30px;padding:0 10px;font-size:12.5px}.st-muted{color:var(--text-3)}.st-link{color:var(--text);cursor:pointer}.st-link:hover{color:var(--accent);text-decoration:underline}.st-form-row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.sc-mode-tabs{display:flex;margin-bottom:20px;border:1px solid var(--border-strong);border-radius:var(--r);overflow:hidden}.sc-mode-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;font-family:inherit;border:none;background:var(--surface);color:var(--text-2);cursor:pointer;transition:background .12s,color .12s}.sc-mode-tab+.sc-mode-tab{border-left:1px solid var(--border-strong)}.sc-mode-tab.active{background:var(--accent-soft);color:var(--accent)}.sc-day-picker{display:flex;gap:6px;flex-wrap:wrap}.sc-day-btn{padding:5px 12px;font-size:13px;font-weight:500;font-family:inherit;border:1px solid var(--border-strong);border-radius:20px;background:var(--surface);color:var(--text-2);cursor:pointer;transition:background .12s,color .12s,border-color .12s}.sc-day-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.sc-preview{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r);padding:12px 14px;margin-bottom:16px}.sc-preview-label{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--text-2);margin-bottom:8px}.sc-preview-dates{display:flex;flex-wrap:wrap;gap:5px}.sc-preview-chip{display:inline-block;padding:2px 8px;font-size:12px;background:var(--surface);border:1px solid var(--border);border-radius:4px;color:var(--text-1);font-variant-numeric:tabular-nums}.sc-preview-chip.more{color:var(--text-3);border-style:dashed}.ci-page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:20px;gap:16px;flex-wrap:wrap}.ci-page-title{font-size:22px;font-weight:600;letter-spacing:-.2px;margin:0 0 3px;color:var(--text)}.ci-page-sub{color:var(--text-3);font-size:13px;margin:0}.ci-grid{display:grid;grid-template-columns:320px 1fr;gap:16px;height:calc(100vh - 160px);min-height:520px}@media (max-width: 1100px){.ci-grid{grid-template-columns:1fr;height:auto}}.ci-session-list{overflow-y:auto;display:flex;flex-direction:column;gap:0}.ci-list-label{padding:0 4px 10px;font-size:11.5px;color:var(--text-3);font-weight:600;letter-spacing:.6px;text-transform:uppercase}.ci-session{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 16px;margin-bottom:10px;cursor:pointer;transition:border-color .12s,box-shadow .12s,transform .12s}.ci-session:hover{border-color:var(--border-strong);transform:translateY(-1px);box-shadow:var(--shadow-1)}.ci-session.active{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 3px #2563eb1a}.ci-session.complete .ci-session-bar-fill{background:var(--green)}.ci-session-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.ci-session-time{font-weight:600;font-size:13.5px;font-variant-numeric:tabular-nums;color:var(--text)}.ci-session-course{font-size:14px;font-weight:600;color:var(--text);margin-bottom:6px}.ci-session-meta{color:var(--text-3);font-size:12.5px;display:flex;align-items:center;gap:10px;margin-bottom:6px}.ci-session-meta span{display:inline-flex;align-items:center;gap:4px}.ci-session-counts{display:flex;justify-content:space-between;align-items:center;font-size:12px;font-variant-numeric:tabular-nums;margin-bottom:8px}.ci-session-bar{height:4px;background:var(--border);border-radius:999px;overflow:hidden}.ci-session-bar-fill{height:100%;background:var(--accent);border-radius:999px;transition:width .3s ease}.ci-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-1);display:flex;flex-direction:column;overflow:hidden}.ci-panel-head{padding:20px 24px;display:flex;justify-content:space-between;align-items:flex-start;border-bottom:1px solid var(--border);gap:12px;flex-shrink:0}.ci-panel-title{font-size:18px;font-weight:600;margin:0 0 6px;letter-spacing:-.2px;color:var(--text)}.ci-panel-meta{color:var(--text-3);font-size:13px;display:flex;gap:16px;flex-wrap:wrap}.ci-pip{display:inline-flex;align-items:center;gap:5px}.ci-panel-id{font-size:11.5px;color:var(--text-3);margin-bottom:6px;text-align:right}.ci-progress{display:flex;align-items:center;gap:14px;padding:12px 24px;background:var(--surface-2);border-bottom:1px solid var(--border);flex-shrink:0}.ci-progress-num{font-weight:600;font-variant-numeric:tabular-nums;font-size:13px;color:var(--text);white-space:nowrap}.ci-progress-bar{flex:1;height:6px;background:var(--border);border-radius:999px;overflow:hidden}.ci-progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),#4f46e5);border-radius:999px;transition:width .35s ease}.ci-progress-pct{font-weight:600;font-variant-numeric:tabular-nums;font-size:13px;color:var(--accent);min-width:36px;text-align:right}.ci-student-rows{flex:1;overflow-y:auto}.ci-student-row{display:flex;align-items:center;gap:14px;padding:12px 24px;border-bottom:1px solid var(--border);transition:background .12s}.ci-student-row:last-child{border-bottom:0}.ci-student-row:hover{background:var(--surface-2)}.ci-student-row.attended{background:linear-gradient(90deg,rgba(5,150,105,.04),transparent 60%)}.ci-student-row.attended:hover{background:linear-gradient(90deg,rgba(5,150,105,.07),var(--surface-2) 60%)}.ci-student-idx{width:22px;text-align:center;font-size:12.5px;font-variant-numeric:tabular-nums;color:var(--text-3);flex-shrink:0}.ci-avatar{width:36px;height:36px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-weight:600;font-size:13px;flex-shrink:0}.ci-avatar.green{background:var(--green-soft);color:var(--green)}.ci-avatar.amber{background:var(--amber-soft);color:var(--amber)}.ci-avatar.red{background:var(--red-soft);color:var(--red)}.ci-student-info{flex:1;min-width:0}.ci-student-name{font-weight:500;font-size:14px;color:var(--text)}.ci-student-sub{font-size:12.5px;color:var(--text-3);margin-top:2px;display:flex;align-items:center;gap:6px}.ci-actions{margin-left:auto;display:flex;gap:6px;flex-shrink:0}.ci-panel-foot{padding:14px 24px;border-top:1px solid var(--border);background:var(--surface-2);display:flex;justify-content:space-between;align-items:center;gap:12px;flex-shrink:0}.ci-foot-notice{font-size:12.5px;color:var(--text-3);display:flex;align-items:center;gap:7px}.ci-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-3);gap:12px;padding:40px}.ci-empty-icon{width:52px;height:52px;border-radius:14px;background:var(--surface-2);border:1px solid var(--border);display:grid;place-items:center}.ci-empty-lead{font-size:14px;font-weight:500;color:var(--text-2)}.xbtn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 14px;height:36px;border-radius:var(--r);border:1px solid var(--border-strong);background:var(--surface);color:var(--text);font-size:13px;font-weight:500;cursor:pointer;transition:background .12s,border-color .12s,transform .12s;white-space:nowrap;font-family:inherit}.xbtn:hover{background:var(--hover);border-color:var(--text-3)}.xbtn:active{transform:translateY(.5px)}.xbtn:disabled{opacity:.5;cursor:not-allowed}.xbtn:disabled:active{transform:none}.xbtn.primary{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 6px -1px #2563eb59}.xbtn.primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.xbtn.ghost{background:transparent;border-color:transparent;color:var(--text-2)}.xbtn.ghost:hover{background:var(--hover);color:var(--text);border-color:transparent}.xbtn.danger{color:var(--red)}.xbtn.danger:hover{background:var(--red-soft);border-color:var(--red-soft)}.xbtn.sm{height:30px;padding:0 10px;font-size:12.5px}.xtag{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:500;padding:2px 9px;border-radius:var(--r-sm);background:var(--hover);color:var(--text-2);white-space:nowrap}.xtag.dot:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}.xtag.green{background:var(--green-soft);color:var(--green)}.xtag.amber{background:var(--amber-soft);color:var(--amber)}.xtag.red{background:var(--red-soft);color:var(--red)}.xtag.blue{background:var(--accent-soft);color:var(--accent)}.xtag.violet{background:var(--violet-soft);color:var(--violet)}.xpill{display:inline-flex;align-items:baseline;gap:2px;font-variant-numeric:tabular-nums;background:var(--green-soft);color:var(--green);padding:2px 9px;border-radius:999px;font-size:12.5px;font-weight:600}.xpill.warn{background:var(--amber-soft);color:var(--amber)}.xpill.danger{background:var(--red-soft);color:var(--red)}.xpill .u{font-weight:500;font-size:11px;opacity:.75}.ci-toast-zone{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:1000;display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none}.ci-toast{background:var(--text);color:#fff;padding:9px 16px 9px 12px;border-radius:999px;font-size:13px;display:flex;align-items:center;gap:8px;box-shadow:var(--shadow-pop);animation:ci-pop .18s ease;pointer-events:none}.ci-toast.success{background:var(--green)}.ci-toast.error{background:var(--red)}@keyframes ci-pop{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}:root{--bg: #f6f7f9;--surface: #ffffff;--surface-2: #fafbfc;--border: #eceef2;--border-strong: #dfe3ea;--hover: #f1f3f7;--text: #0f172a;--text-2: #475569;--text-3: #94a3b8;--text-inv: #ffffff;--accent: #2563eb;--accent-hover: #1d4ed8;--accent-soft: #eff6ff;--accent-soft-strong: #dbeafe;--green: #059669;--green-soft: #ecfdf5;--amber: #b45309;--amber-soft: #fef3c7;--red: #dc2626;--red-soft: #fee2e2;--violet: #7c3aed;--violet-soft: #f3e8ff;--r-sm: 6px;--r: 10px;--r-lg: 14px;--r-xl: 18px;--shadow-1: 0 1px 2px rgba(15, 23, 42, .04), 0 1px 3px rgba(15, 23, 42, .04);--shadow-2: 0 4px 12px rgba(15, 23, 42, .06), 0 2px 4px rgba(15, 23, 42, .04);--shadow-pop: 0 18px 40px -12px rgba(15, 23, 42, .18), 0 8px 16px -8px rgba(15, 23, 42, .12);--font: -apple-system, BlinkMacSystemFont, "PingFang SC", "Helvetica Neue", "Microsoft YaHei", "Hiragino Sans GB", "Segoe UI", Roboto, sans-serif}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font);font-size:14px;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}button{font-family:inherit}#root{height:100vh}.u-page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:20px;gap:16px;flex-wrap:wrap}.u-page-title{font-size:22px;font-weight:600;letter-spacing:-.2px;margin:0 0 3px;color:var(--text)}.u-page-sub{color:var(--text-3);font-size:13px;margin:0}.u-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-1);overflow:hidden}.u-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border);background:var(--surface-2)}.u-card-title{font-weight:600;font-size:15px;color:var(--text)}.u-toolbar{display:flex;align-items:center;gap:10px;padding:12px 18px;border-bottom:1px solid var(--border);background:var(--surface-2)}.u-toolbar-gap{flex:1}.u-search{position:relative;width:240px}.u-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-3);pointer-events:none}.u-search-input{width:100%;border:1px solid var(--border-strong);background:var(--surface);border-radius:var(--r);padding:7px 12px 7px 32px;font-size:13.5px;color:var(--text);outline:none;font-family:var(--font);box-sizing:border-box;transition:border-color .15s,box-shadow .15s}.u-search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.u-search-input::placeholder{color:var(--text-3)}.u-select{border:1px solid var(--border-strong);background:var(--surface);border-radius:var(--r);padding:7px 10px;font-size:13.5px;color:var(--text);outline:none;font-family:var(--font);cursor:pointer;height:34px}.u-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.u-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 14px;height:36px;border-radius:var(--r);border:1px solid var(--border-strong);background:var(--surface);color:var(--text);font-size:13px;font-weight:500;cursor:pointer;transition:background .12s,border-color .12s,transform .12s;white-space:nowrap;font-family:inherit}.u-btn:hover{background:var(--hover);border-color:var(--text-3)}.u-btn:active{transform:translateY(.5px)}.u-btn:disabled{opacity:.5;cursor:not-allowed}.u-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 6px -1px #2563eb59}.u-btn.primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.u-btn.ghost{background:transparent;border-color:transparent;color:var(--text-2)}.u-btn.ghost:hover{background:var(--hover);color:var(--text);border-color:transparent}.u-btn.danger{color:var(--red)}.u-btn.danger:hover{background:var(--red-soft);border-color:var(--red-soft)}.u-btn.sm{height:30px;padding:0 10px;font-size:12.5px}.u-tag{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:500;padding:2px 9px;border-radius:var(--r-sm);background:var(--hover);color:var(--text-2);white-space:nowrap}.u-tag.dot:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}.u-tag.green{background:var(--green-soft);color:var(--green)}.u-tag.amber{background:var(--amber-soft);color:var(--amber)}.u-tag.red{background:var(--red-soft);color:var(--red)}.u-tag.blue{background:var(--accent-soft);color:var(--accent)}.u-tag.violet{background:var(--violet-soft);color:var(--violet)}.u-pill{display:inline-flex;align-items:baseline;gap:2px;font-variant-numeric:tabular-nums;background:var(--green-soft);color:var(--green);padding:2px 9px;border-radius:999px;font-size:12.5px;font-weight:600;white-space:nowrap}.u-pill.warn{background:var(--amber-soft);color:var(--amber)}.u-pill.danger{background:var(--red-soft);color:var(--red)}.u-pill .u{font-weight:500;font-size:11px;opacity:.75}.u-avatar{width:34px;height:34px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-weight:600;font-size:13px;flex-shrink:0}.u-avatar.green{background:var(--green-soft);color:var(--green)}.u-avatar.amber{background:var(--amber-soft);color:var(--amber)}.u-avatar.red{background:var(--red-soft);color:var(--red)}.u-avatar.violet{background:var(--violet-soft);color:var(--violet)}.u-avatar.lg{width:52px;height:52px;font-size:18px;border-radius:14px}.u-card .ant-table,.u-table-wrap .ant-table{font-size:13.5px}.u-card .ant-table-thead>tr>th,.u-table-wrap .ant-table-thead>tr>th{background:var(--surface-2);color:var(--text-3);font-size:12.5px;font-weight:500;border-bottom:1px solid var(--border)!important;padding:10px 16px}.u-card .ant-table-tbody>tr>td,.u-table-wrap .ant-table-tbody>tr>td{padding:13px 16px;border-bottom:1px solid var(--border)!important;color:var(--text);vertical-align:middle}.u-card .ant-table-tbody>tr:last-child>td,.u-table-wrap .ant-table-tbody>tr:last-child>td{border-bottom:0!important}.u-card .ant-table-tbody>tr:hover>td,.u-table-wrap .ant-table-tbody>tr:hover>td{background:var(--surface-2)!important}.u-card .ant-table-pagination,.u-table-wrap .ant-table-pagination{padding:10px 16px;margin:0;border-top:1px solid var(--border)}.u-card .ant-table-wrapper,.u-table-wrap .ant-table-wrapper{border-radius:0}.u-muted{color:var(--text-3)}
