:root{--primary: #2563eb;--primary-hover: #1d4ed8;--success: #16a34a;--success-hover: #15803d;--warning: #f59e0b;--danger: #dc2626;--danger-hover: #b91c1c;--bg-page: #f8f9fb;--bg-card: #ffffff;--muted: #ececf0;--muted-foreground: #717182;--accent: #e9ebef;--border: rgba(0, 0, 0, .1);--text-main: #030213;--text-muted: var(--muted-foreground);--input-background: #f3f3f5;--radius: 10px;--shadow-soft: 0 1px 2px rgba(15, 23, 42, .06);--shadow-card: 0 8px 24px rgba(15, 23, 42, .06);--ring: 0 0 0 3px rgba(37, 99, 235, .18)}.demo-record-page{min-height:100vh;background:linear-gradient(160deg,#f8f9fb,#eef2f7);color:#0f172a}.record-shell{max-width:1100px;margin:0 auto;padding:32px 24px 72px}.record-header{display:flex;justify-content:space-between;align-items:center;gap:24px;margin-bottom:24px}.record-brand{display:flex;gap:16px;align-items:center}.record-logo{width:84px;height:84px;object-fit:contain;display:block}.record-uni{font-weight:600;color:#002f6c;letter-spacing:.04em;text-transform:uppercase;font-size:12px}.record-title{font-size:32px;margin:6px 0}.record-subtitle{color:#475569}.record-badge{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:10px 14px;min-width:180px;text-align:left;box-shadow:0 6px 14px #0f172a14}.record-badge-label{font-size:11px;color:#64748b;text-transform:uppercase;letter-spacing:.06em}.record-badge-value{font-size:18px;font-weight:700;color:#0f172a;margin-top:4px}.record-card{background:#fff;border-radius:20px;padding:24px;border:1px solid #e2e8f0;box-shadow:0 12px 28px #0f172a14;margin-bottom:20px}.record-profile{display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px}.record-profile-main{display:flex;gap:16px;align-items:center}.record-avatar{width:120px;height:120px;border-radius:16px;background:#002f6c;color:#fff;font-weight:700;font-size:24px;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:4px}.record-avatar img{width:100%;height:100%;object-fit:cover;display:block;border-radius:12px}.record-name{font-size:20px;font-weight:600}.record-meta{color:#64748b;margin-top:4px}.record-profile-stats{display:flex;gap:24px;flex-wrap:wrap}.record-stat-label{font-size:12px;color:#64748b;text-transform:uppercase;letter-spacing:.04em}.record-stat-value{font-size:18px;font-weight:600;color:#0f172a}.record-tabs{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:16px}.record-tab{border:1px solid #dbe3ef;background:#f8fafc;border-radius:14px;padding:10px 14px;display:flex;gap:8px;align-items:center;font-weight:500;cursor:pointer}.record-tab.active{background:#002f6c;color:#fff;border-color:#002f6c}.record-status{font-size:11px;padding:2px 6px;border-radius:999px;background:#0f172a14}.record-status.done{background:#c7f9cc;color:#065f46}.record-status.current{background:#fde68a;color:#92400e}.record-year-summary{display:flex;gap:32px;flex-wrap:wrap;padding:12px 0 4px;border-bottom:1px solid #e2e8f0;margin-bottom:16px}.record-semesters{display:grid;gap:16px}.record-semester h3{margin:0 0 12px}.record-table{display:grid;gap:8px}.record-table-head,.record-table-row{display:grid;grid-template-columns:1fr 120px 100px;gap:12px;align-items:center}.record-table-head{font-weight:600;color:#0f172a;border-bottom:1px solid #e2e8f0;padding-bottom:8px;text-transform:uppercase;font-size:12px;letter-spacing:.04em}.record-table-row{padding:10px 12px;color:#334155;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px}.record-grade{font-weight:700;color:#0f172a}@media (max-width: 720px){.record-header,.record-brand{flex-direction:column;align-items:flex-start}.record-badge{width:100%;text-align:left}.record-profile{flex-direction:column}.record-table-head,.record-table-row{grid-template-columns:1fr;text-align:left}.record-table-head .text-right,.record-table-row .text-right{text-align:left}}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-page);color:var(--text-main);line-height:1.45;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}h1,h2,h3,h4{margin:0;line-height:1.2}p{margin:0 0 12px}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}.app-root{min-height:100vh;display:flex;flex-direction:column}.app-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;padding:.75rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg-card);position:sticky;top:0;z-index:20}.app-header-left{display:flex;align-items:center;flex-wrap:wrap;gap:8px;min-width:0}.app-brand-badge{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;background:var(--primary);color:#fff;font-weight:700;letter-spacing:.02em;flex:0 0 auto}.app-brand-text{display:flex;flex-direction:column;line-height:1.1}.app-brand{font-weight:600;font-size:16px;color:#111827}.app-role{font-size:12px;color:var(--text-muted)}.app-header-right{display:flex;align-items:center;flex-wrap:wrap;gap:12px;font-size:14px;color:var(--text-muted);min-width:0}.app-user-email{max-width:min(360px,60vw);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-main{padding:1.5rem;flex:1}.page{width:100%;max-width:1200px;margin:0 auto}.page-md{max-width:900px}.page-sm{max-width:520px}.page-header{margin-bottom:16px}.page-header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}.page-header-titles{min-width:0;flex:1}.page-title{font-size:22px;font-weight:650;letter-spacing:-.02em}.page-subtitle{margin-top:4px;color:var(--text-muted);font-size:13px}.page-header-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center;justify-content:flex-end}.auth-shell{max-width:460px;margin:60px auto}.auth-screen{min-height:calc(100vh - 72px);display:flex;align-items:center;justify-content:center;padding:16px}.auth-card-header{text-align:center;margin-bottom:16px}.brand-badge-lg{width:64px;height:64px;border-radius:14px;background:var(--primary);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:750;font-size:22px;letter-spacing:.02em;margin:0 auto 12px}.auth-title{font-size:20px;font-weight:650;letter-spacing:-.02em;margin-bottom:4px}.auth-desc{color:var(--text-muted);font-size:13px}.card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-card);padding:1.5rem}.card-noshadow{box-shadow:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;border-radius:calc(var(--radius) - 2px);border:1px solid transparent;font-size:14px;cursor:pointer;background:#fff;color:var(--text-main);transition:background .15s ease,border-color .15s ease,color .15s ease,box-shadow .15s ease;min-height:36px}.btn-sm{min-height:32px;padding:6px 10px;font-size:13px}.btn-icon{min-height:32px;min-width:32px;width:32px;padding:0;border-radius:9999px;display:inline-flex;align-items:center;justify-content:center}.btn-icon:hover:not(:disabled){background:#0000000a}.btn-icon-danger{color:var(--danger)}.btn-icon-danger:hover:not(:disabled){background:#dc262614}.btn:disabled{opacity:.6;cursor:default}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover:not(:disabled){background:var(--primary-hover);border-color:var(--primary-hover)}.btn-success{background:var(--success);color:#fff;border-color:var(--success)}.btn-success:hover:not(:disabled){background:var(--success-hover);border-color:var(--success-hover)}.btn-outline{background:#fff;color:#111827;border-color:var(--border)}.btn-outline:hover:not(:disabled){background:#f9fafb}.btn-ghost{background:transparent;border-color:transparent}.btn-ghost:hover{background:#f9fafb}.form{display:flex;flex-direction:column;gap:12px}.form-row{display:flex;flex-wrap:wrap;gap:12px}.form-field{display:flex;flex-direction:column;gap:4px;font-size:14px}.form-label{font-weight:500}.input,.select{border-radius:calc(var(--radius) - 2px);border:1px solid var(--border);padding:8px 10px;font-size:14px;width:100%;background:var(--input-background)}.input:focus,.select:focus{outline:none;border-color:var(--primary);box-shadow:var(--ring)}.searchable-select{position:relative;width:100%}.searchable-select.is-disabled{opacity:.7}.searchable-select-trigger{display:flex;align-items:center;justify-content:space-between;gap:8px;cursor:pointer}.searchable-select-value.is-placeholder{color:var(--text-muted)}.searchable-select-caret{color:var(--text-muted);font-size:12px}.searchable-select-panel{position:absolute;z-index:20;left:0;right:0;margin-top:6px;padding:8px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-card)}.searchable-select-search{margin-bottom:8px}.searchable-select-options{max-height:240px;overflow:auto;display:flex;flex-direction:column;gap:6px}.searchable-select-option{border:1px solid transparent;border-radius:10px;padding:8px 10px;text-align:left;background:transparent;cursor:pointer;font-size:14px}.searchable-select-option:hover:not(:disabled){background:#2563eb14;border-color:#2563eb59}.searchable-select-option.is-selected{background:#2563eb1f;border-color:#2563eb8c}.searchable-select-empty{color:var(--text-muted);font-size:13px;padding:6px 2px}.searchable-select.input-sm .searchable-select-trigger,.searchable-select.input-sm .searchable-select-search{padding:6px 8px;font-size:13px}.join-card{display:flex;flex-direction:column;gap:8px}.join-form{display:flex;flex-direction:column;gap:12px}.join-form-row{align-items:flex-end;gap:12px}.join-form-row .form-field{flex:1;min-width:220px}.join-duration-field{max-width:200px}.join-form-actions{display:flex;align-items:flex-end;justify-content:flex-end;min-width:180px}.join-primary-btn{width:100%}.join-status{margin-top:8px}.segmented{display:inline-flex;gap:6px;padding:4px;border-radius:12px;background:#0f172a0f}.segmented-btn{border:1px solid transparent;background:transparent;color:var(--text-muted);padding:8px 14px;border-radius:10px;font-weight:600;cursor:pointer}.segmented-btn.is-active{background:#fff;color:var(--text);border-color:var(--border);box-shadow:0 4px 12px #0f172a14}.btn:focus-visible,.input:focus-visible,.select:focus-visible{outline:none;box-shadow:var(--ring)}.btn-danger{color:#fff;background:var(--danger);border-color:var(--danger)}.btn-danger:hover:not(:disabled){background:var(--danger-hover);border-color:var(--danger-hover)}.btn-outline-danger{background:#fff;color:var(--danger);border-color:#dc262673}.btn-outline-danger:hover:not(:disabled){background:#fef2f2;border-color:#dc2626b3}.list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.list-item{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px;border:1px solid var(--border);border-radius:10px;background:var(--bg-card)}.list-item-main{min-width:0;flex:1}.list-item-title{font-weight:600;margin-bottom:2px}.list-item-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:8px}.quiz-page{padding-top:8px}.quiz-timer{font-size:13px;font-weight:650;padding:6px 12px;border:1px solid var(--border);border-radius:999px;background:#f8fafc}.quiz-timer-inner{display:inline-flex;align-items:center;gap:6px}.quiz-header-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:flex-end}.quiz-preview-badge{font-size:12px;font-weight:600;padding:4px 10px;border-radius:999px;border:1px dashed rgba(37,99,235,.5);color:var(--primary);background:#2563eb14}.quiz-card{padding:16px}.quiz-question{margin-bottom:20px;padding:18px;border:1px solid var(--border);border-radius:12px;background:linear-gradient(180deg,#fff,#f8fafc)}.quiz-question-meta{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}.quiz-question-count{font-size:13px;color:var(--text-muted)}.quiz-progress{height:6px;border-radius:999px;background:#0f172a14;overflow:hidden}.quiz-progress-bar{height:100%;background:linear-gradient(90deg,var(--primary),rgba(37,99,235,.55));border-radius:inherit;transition:width .2s ease}.quiz-question-text{font-size:18px;font-weight:650;line-height:1.4;-webkit-user-select:none;user-select:none}.quiz-options{display:flex;flex-direction:column;gap:12px}.quiz-option{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border:1.5px solid var(--border);border-radius:12px;background:#fff;cursor:pointer;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease}.quiz-option:hover:not(.is-disabled){border-color:#2563eb99;box-shadow:0 6px 14px #2563eb1f}.quiz-option.is-selected{border-color:var(--primary);background:#2563eb14}.quiz-option.is-disabled{cursor:not-allowed;opacity:.75}.quiz-option-input{margin-top:2px}.quiz-option-text{flex:1;min-width:0}.quiz-textarea{min-height:140px;resize:vertical}.quiz-footer{display:flex;align-items:center;justify-content:space-between;gap:12px}.quiz-progress-text{color:var(--text-muted);font-size:13px}.quiz-nav{display:flex;gap:12px;justify-content:flex-end;flex-wrap:wrap}.list.list-courses{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}.course-item{flex-direction:column;gap:12px;padding:16px;border-color:#94a3b866;box-shadow:0 1px 2px #0f172a14;background:linear-gradient(180deg,#fff,#f8fafc)}.course-item .list-item-title{font-size:16px;line-height:1.4;letter-spacing:-.01em;overflow-wrap:anywhere}.course-item .list-item-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;justify-items:stretch}.course-item .list-item-actions .btn{width:100%;justify-content:center}.course-item .list-item-actions .course-delete-btn{grid-column:1 / -1;margin-top:4px}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.table.table-min-720{min-width:720px}.input-sm{padding:6px 8px;font-size:13px}.table{width:100%;border-collapse:collapse;font-size:14px}.table th,.table td{padding:8px;border-bottom:1px solid var(--border)}.table tbody tr:hover{background:#00000005}.table tbody tr:nth-child(2n){background:#00000003}.table th{text-align:left;font-weight:500;color:var(--text-muted);background:#00000005}.table td{color:#111827}.text-center{text-align:center}.text-right{text-align:right}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.stats-grid{display:grid;gap:12px;margin-bottom:16px}@media (min-width: 768px){.stats-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.stat-label{font-size:12px;color:var(--text-muted);margin-bottom:6px}.stat-value{font-size:28px;font-weight:650;letter-spacing:-.02em}.alert{font-size:13px;padding:8px 10px;border-radius:calc(var(--radius) - 2px);margin-top:8px}.alert-info{background:#eff6ff;color:#1d4ed8;border:1px solid rgba(37,99,235,.25)}.container{width:100%;max-width:1200px;margin:0 auto}.error{color:var(--danger)}.alert-error{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.alert-success{background:#ecfdf3;color:#15803d;border:1px solid #bbf7d0}.text-muted{color:var(--text-muted);font-size:13px}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-16{margin-bottom:16px}.mb-8{margin-bottom:8px}.mb-24{margin-bottom:24px}.badge{display:inline-flex;align-items:center;padding:2px 6px;border-radius:9999px;font-size:11px;font-weight:500;background:#eef2ff;color:#3730a3}.empty-state{text-align:center;padding:28px 16px;border:1px dashed var(--border);border-radius:var(--radius);background:#00000003}.empty-state-icon{width:56px;height:56px;border-radius:9999px;background:#2563eb1a;color:var(--primary);display:inline-flex;align-items:center;justify-content:center;margin:0 auto 12px}.empty-state-title{font-weight:650;letter-spacing:-.02em;margin-bottom:6px}.empty-state-desc{color:var(--text-muted);font-size:13px;max-width:520px;margin:0 auto 12px}.empty-state-action{display:flex;justify-content:center}@media (max-width: 640px){.app-header{padding:.75rem 1rem}.app-main,.card{padding:1rem}.auth-shell{margin:28px auto;padding:0 8px}.list-item{flex-direction:column;align-items:stretch}.list-item-actions{justify-content:flex-start}.course-item .list-item-actions{grid-template-columns:1fr}.join-form-row{flex-direction:column;align-items:stretch}.join-form-actions{width:100%;justify-content:flex-start;min-width:0}.quiz-card,.quiz-question{padding:12px}.quiz-footer{flex-direction:column;align-items:stretch}.quiz-nav{flex-direction:column-reverse;width:100%}.quiz-nav .btn{width:100%}}
