:root,[data-theme=light]{color-scheme:light;--color-bg: #ffffff;--color-bg-subtle: #fafafa;--color-bg-elevated: #ffffff;--color-bg-muted: #f4f4f5;--color-fg: #0a0a0a;--color-fg-muted: #52525b;--color-fg-subtle: #71717a;--color-border: #e4e4e7;--color-border-strong: #d4d4d8;--color-accent: #2563eb;--color-accent-hover: #1d4ed8;--color-accent-fg: #ffffff;--color-accent-soft: rgba(37, 99, 235, .1);--color-danger: #dc2626;--color-danger-fg: #ffffff;--color-danger-soft: rgba(220, 38, 38, .1);--color-success: #16a34a;--color-success-soft: rgba(22, 163, 74, .12);--color-card: #ffffff;--color-card-fg: #0a0a0a;--color-input-bg: #ffffff;--color-input-border: #d4d4d8;--color-input-fg: #0a0a0a;--color-input-placeholder: #a1a1aa;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .06);--transition-fast: .12s ease;--space-2xs: 2px;--space-xs: 4px;--space-sm: 8px;--space-md: 12px;--space-lg: 16px;--space-xl: 24px;--space-2xl: 36px;--header-height: 56px;--font-primary: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-mono: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font-primary);font-size:14px;line-height:1.5;background:var(--color-bg-subtle);color:var(--color-fg);-webkit-font-smoothing:antialiased}h1,h2,h3,p{margin:0}.app-loading{min-height:100%;display:grid;place-items:center;color:var(--color-fg-muted);font-size:14px}.text-muted{color:var(--color-fg-muted)}.text-error{color:var(--color-danger);font-size:13px;margin:0}.section-title{font-size:15px;font-weight:600;letter-spacing:-.01em}.app-shell{min-height:100%;display:flex;flex-direction:column}.app-header{height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-xl);background:var(--color-bg-elevated);border-bottom:1px solid var(--color-border)}.app-header-brand{display:flex;align-items:center;gap:var(--space-sm)}.app-header-user{display:flex;align-items:center;gap:var(--space-md);font-size:13px}.app-main{flex:1;padding:var(--space-xl);max-width:1100px;width:100%;margin:0 auto}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);white-space:nowrap;border-radius:var(--radius-md);font-size:14px;font-weight:500;line-height:1;padding:0 var(--space-md);height:36px;border:1px solid transparent;background:transparent;color:var(--color-fg);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast),opacity var(--transition-fast)}.btn:focus-visible{outline:none;box-shadow:0 0 0 2px var(--color-accent-soft)}.btn:disabled{opacity:.5;pointer-events:none}.btn-loading{opacity:.8;pointer-events:none}.btn-default{background:var(--color-accent);color:var(--color-accent-fg);border-color:var(--color-accent)}.btn-default:hover:not(:disabled){background:var(--color-accent-hover);border-color:var(--color-accent-hover)}.btn-outline{background:var(--color-bg-elevated);color:var(--color-fg);border-color:var(--color-border-strong)}.btn-outline:hover:not(:disabled){background:var(--color-bg-muted)}.btn-secondary{background:var(--color-bg-muted);color:var(--color-fg)}.btn-ghost{background:transparent}.btn-ghost:hover:not(:disabled){background:var(--color-bg-muted)}.btn-link{background:transparent;color:var(--color-accent);height:auto;padding:0;border:none}.btn-destructive{background:var(--color-danger);color:var(--color-danger-fg);border-color:var(--color-danger)}.btn-sm{height:30px;font-size:13px}.btn-lg{height:42px;padding:0 var(--space-lg)}.input{display:flex;width:100%;height:36px;align-items:center;border-radius:var(--radius-md);border:1px solid var(--color-input-border);background:var(--color-input-bg);color:var(--color-input-fg);padding:0 var(--space-md);font-size:14px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.input::placeholder{color:var(--color-input-placeholder)}.input:focus,.input:focus-visible{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 2px var(--color-accent-soft)}.field-group{display:grid;gap:6px}.label{font-size:13px;font-weight:500;color:var(--color-fg);line-height:1.3}.card{border-radius:var(--radius-lg);border:1px solid var(--color-border);background:var(--color-card);color:var(--color-card-fg);box-shadow:var(--shadow-sm)}.card-header{display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-xl)}.card-title{font-size:16px;font-weight:600;line-height:1.3;letter-spacing:-.01em}.card-description{font-size:13px;color:var(--color-fg-muted)}.card-content{display:grid;gap:var(--space-md);padding:var(--space-xl);padding-top:0}.card-footer{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xl);padding-top:0}.login-page{display:flex;align-items:center;justify-content:center;min-height:100%;padding:var(--space-xl);background:var(--color-bg-subtle)}.login-card{width:100%;max-width:400px;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-2xl);box-shadow:var(--shadow-md);display:grid;gap:var(--space-lg)}.login-brand{display:flex;align-items:center;gap:var(--space-sm)}.login-brand-mark{width:36px;height:32px;border-radius:var(--radius-md);background:var(--color-accent);color:var(--color-accent-fg);display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:12px}.login-title{font-size:20px;font-weight:600;letter-spacing:-.02em}.login-subtitle{font-size:13px;color:var(--color-fg-muted)}.login-form{display:grid;gap:var(--space-md)}.login-submit-btn{width:100%;margin-top:var(--space-xs)}.shell{display:flex;height:100%}.sidebar{width:270px;flex-shrink:0;border-right:1px solid var(--color-border);background:var(--color-bg-elevated);display:flex;flex-direction:column;height:100%}.sidebar-brand{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-lg);border-bottom:1px solid var(--color-border)}.sidebar-search{padding:var(--space-md) var(--space-lg)}.sidebar-nav{flex:1;overflow-y:auto;padding:0 var(--space-sm) var(--space-md);display:flex;flex-direction:column;gap:2px}.sidebar-msg{padding:var(--space-md) var(--space-md);font-size:13px}.sidebar-item{display:flex;flex-direction:column;gap:2px;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);text-decoration:none;color:var(--color-fg);cursor:pointer}.sidebar-item:hover{background:var(--color-bg-muted)}.sidebar-item.is-active{background:var(--color-accent-soft);color:var(--color-accent)}.sidebar-item-name{font-size:13.5px;font-weight:500;line-height:1.3}.sidebar-item-code{font-size:11px;color:var(--color-fg-subtle);font-family:var(--font-mono)}.shell-main{flex:1;display:flex;flex-direction:column;min-width:0}.content{flex:1;overflow:auto;padding:var(--space-xl)}.report-state{padding:var(--space-2xl);text-align:center;font-size:14px}.report{display:flex;flex-direction:column;gap:var(--space-2xl)}.exam-head{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--space-lg);margin-bottom:var(--space-md);flex-wrap:wrap}.exam-title{font-size:17px;font-weight:600;letter-spacing:-.01em}.exam-sub{font-size:13px;margin-top:2px}.exam-actions{display:flex;align-items:center;gap:var(--space-sm)}.exam-search{width:200px}.table-wrap{overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-card)}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th,.data-table td{padding:10px 12px;text-align:left;white-space:nowrap}.data-table thead th{background:var(--color-bg-subtle);border-bottom:1px solid var(--color-border);font-weight:600;color:var(--color-fg-muted);position:sticky;top:0}.data-table tbody tr{border-bottom:1px solid var(--color-border)}.data-table tbody tr:last-child{border-bottom:none}.data-table .col-num{width:40px;color:var(--color-fg-subtle)}.data-table .col-score,.data-table .col-final{text-align:center;font-variant-numeric:tabular-nums}.data-table .col-final{font-weight:600;border-left:1px solid var(--color-border)}.row-untaken td{color:var(--color-fg-subtle)}.table-empty{text-align:center;padding:var(--space-xl)}
