@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--background: 0 0% 100%;--foreground: 222.2 84% 4.9%;--card: 0 0% 100%;--card-foreground: 222.2 84% 4.9%;--popover: 0 0% 100%;--popover-foreground: 222.2 84% 4.9%;--primary: 222.2 47.4% 11.2%;--primary-foreground: 210 40% 98%;--secondary: 210 40% 96.1%;--secondary-foreground: 222.2 47.4% 11.2%;--muted: 210 40% 96.1%;--muted-foreground: 215.4 16.3% 46.9%;--accent: 210 40% 96.1%;--accent-foreground: 222.2 47.4% 11.2%;--destructive: 0 84.2% 60.2%;--destructive-foreground: 210 40% 98%;--border: 214.3 31.8% 91.4%;--input: 214.3 31.8% 91.4%;--ring: 222.2 84% 4.9%;--chart-1: 12 76% 61%;--chart-2: 173 58% 39%;--chart-3: 197 37% 24%;--chart-4: 43 74% 66%;--chart-5: 27 87% 67%;--radius: .5rem }html,body{margin:0;padding:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:#faf5ff}.table{display:table}.border-\[\#B436F0\]{--tw-border-opacity: 1;border-color:rgb(180 54 240 / var(--tw-border-opacity, 1))}.border-\[\#F24C0A\]{--tw-border-opacity: 1;border-color:rgb(242 76 10 / var(--tw-border-opacity, 1))}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}@keyframes enter{0%{opacity:var(--tw-enter-opacity, 1);transform:translate3d(var(--tw-enter-translate-x, 0),var(--tw-enter-translate-y, 0),0) scale3d(var(--tw-enter-scale, 1),var(--tw-enter-scale, 1),var(--tw-enter-scale, 1)) rotate(var(--tw-enter-rotate, 0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity, 1);transform:translate3d(var(--tw-exit-translate-x, 0),var(--tw-exit-translate-y, 0),0) scale3d(var(--tw-exit-scale, 1),var(--tw-exit-scale, 1),var(--tw-exit-scale, 1)) rotate(var(--tw-exit-rotate, 0))}}#root{min-height:100vh}body{color:#2b2b2b}.shell{width:min(480px,100%);margin:0 auto;min-height:100vh;padding:16px}.shell h1{margin:0;font-size:24px;line-height:1.2;font-weight:700}.shell h2{margin:0;font-size:18px;line-height:1.2;font-weight:600}.shell--login{display:grid;align-content:center;gap:20px;background:#faf5ff}.login-project-title{margin:-10px 0 0;color:#471260;font-size:14px;font-weight:600}.login-form{background:#fff;border:1px solid #edd9fb;border-radius:14px;padding:16px;display:grid;gap:10px;box-shadow:0 16px 36px #4712601a}.login-form label{font-size:14px;font-weight:600;color:#471260}.login-form input,.login-form button,.students-table button,.student-topics input,.student-topics button,.bulk-box button{min-height:44px;border-radius:10px;border:1px solid #d8c4e7;padding:0 12px;font-size:14px;font-weight:500}.login-form input,.student-topics input{background:#fff}button{background:#b436f0;border-color:#b436f0;color:#fff;font-weight:600;transition:transform .15s ease,box-shadow .15s ease,opacity .15s ease}button:hover:enabled{transform:translateY(-1px);box-shadow:0 10px 20px #47126038}button:disabled{opacity:.68}.header,.sidebar{display:flex;align-items:center;justify-content:space-between;gap:12px}.shell--student{background:radial-gradient(circle at 15% 0%,#edd9fbd9 0,#edd9fb00 44%),linear-gradient(180deg,#faf5ff,#f6effb)}.shell--student .header{border-radius:14px;padding:18px 16px;color:#fff;background:linear-gradient(135deg,#471260,#b436f0);box-shadow:0 18px 32px #47126040}.shell--student .header button{background:#ffffff29;border-color:#ffffff57;color:#fff;box-shadow:none;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.shell--student .header button:hover:enabled{transform:none;box-shadow:none;background:#ffffff3d}.student-topics{margin-top:-12px;display:grid;gap:10px}.student-topics label{font-size:14px;color:#471260;font-weight:600}.student-topics input{border:1px solid #d2bce4;box-shadow:0 10px 24px #4712601a;background:#fff}.topic-search-wrap{background:#fff;border:1px solid #e3d3f0;border-radius:12px;padding:6px 10px;box-shadow:0 10px 24px #47126029}.topic-search-wrap input{border:0;box-shadow:none;width:100%;min-height:36px;padding:0 4px}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.topic-skeletons{display:grid;gap:8px}.topic-skeleton-row{height:52px;border-radius:10px;border:1px solid #ead8f6;background:linear-gradient(90deg,#f6ebff 20%,#edd9fb,#f6ebff 80%);animation:skeleton-shift 1.2s linear infinite}@keyframes skeleton-shift{0%{background-position:100% 0}to{background-position:-100% 0}}.topic-accordion-item{border:1px solid #e8d8f4;border-radius:12px;overflow:hidden;background:#fff}.topic-accordion-item--open{border-left:3px solid #b436f0}.topic-accordion-trigger{width:100%;min-height:44px;border:0;background:#fff;color:#2b2b2b;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 16px;text-align:left;box-shadow:none}.topic-accordion-trigger:hover:enabled{transform:none;box-shadow:none;background:#fdf9ff}.topic-availability-badge{font-size:12px;font-weight:700;border-radius:999px;padding:4px 10px;color:#7b2a9e;background:#edd9fb;white-space:nowrap}.topic-accordion-content{padding:0 16px 14px;display:grid;gap:8px}.topic-select-btn{width:100%;border:1px solid #b436f0;background:#b436f0;color:#fff}.topic-race-alert{margin:0;border:1px solid #f24c0a;background:#fff1ea;color:#812902;border-radius:10px;padding:10px 12px;font-size:14px}.topic-dialog-overlay{position:fixed;inset:0;background:#47126073;display:flex;align-items:center;justify-content:center;padding:16px;z-index:25}.topic-dialog,.modal-like{width:min(560px,100%);background:#fff;border:1px solid #ead8f4;border-radius:12px;padding:16px;display:grid;gap:10px}.modal-actions{display:flex;flex-wrap:wrap;gap:8px}.topic-confirmed{border:1px solid #dfc9f0;border-radius:14px;background:#fff;padding:18px 16px;display:grid;gap:6px;box-shadow:0 16px 30px #4712601f}.topic-confirmed-mark{margin:0;color:#b436f0;font-size:28px;line-height:1}.shell--admin{width:min(1200px,100%);background:#f2f2f2;display:grid;gap:0;min-height:auto;border:1px solid #e3d7ec;border-radius:18px;overflow:hidden;box-shadow:0 18px 34px #4712601a}.admin-sidebar{background:#471260;color:#fff;display:flex;flex-direction:column;border-radius:14px;overflow:hidden}.admin-logo{padding:16px 14px;border-bottom:1px solid rgb(255 255 255 / 10%)}.admin-logo span{font-size:12px;line-height:1.3;font-weight:700}.admin-nav{flex:1;padding:10px 8px;display:grid;grid-auto-rows:max-content;align-content:start;gap:4px}.admin-nav-item{display:flex;align-items:center;justify-content:flex-start;width:100%;border:0;background:transparent;border-radius:10px;box-shadow:none;min-height:34px;font-size:12px;font-weight:500;color:#ffffffad;text-align:left;padding:0 10px 0 12px}.admin-nav-item:hover:enabled{transform:none;box-shadow:none;color:#fff;background:#ffffff17}.admin-nav-item.active{color:#fff;background:#b436f0;font-weight:600}.admin-logout-btn{margin:10px;border-radius:8px;min-height:36px}.admin-content{padding:20px;display:grid;gap:12px;align-content:start}.admin-panel{display:grid;gap:12px}.admin-panel-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px}.admin-panel-actions{display:flex;flex-wrap:wrap;gap:8px}.admin-btn-muted{background:#f2f2f2;color:#471260;border:1px solid #edd9fb}.admin-btn-muted:hover:enabled{background:#eae2f3;transform:none;box-shadow:none}.admin-title{margin:0;font-size:16px;font-weight:700;color:#471260}.admin-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px}.admin-stat{background:#fff;border-radius:10px;border-left:3px solid #b436f0;padding:14px}.admin-stat-orange{border-left-color:#f24c0a}.admin-stat-num{margin:0;font-size:24px;line-height:1;font-weight:700;color:#471260}.admin-stat-label{margin:4px 0 0;font-size:11px;color:#888}.admin-progress{background:#fff;border-radius:10px;padding:14px}.admin-progress-label{display:flex;justify-content:space-between;font-size:11px;color:#888;margin-bottom:8px}.admin-progress-bar{height:8px;background:#edd9fb;border-radius:4px;overflow:hidden}.admin-progress-fill{display:block;height:100%;background:#b436f0;border-radius:4px}.admin-topic-health{font-size:12px;color:#666}.admin-dashboard-actions{display:grid;gap:8px;justify-items:start}.bulk-box{background:#fff;border-radius:10px;border:1px solid #e9e0f1;padding:14px;display:grid;gap:10px}.admin-table{background:#fff;border-radius:10px;overflow:hidden}.admin-table-header{padding:12px 14px;border-bottom:1px solid #f0e8f8;display:flex;justify-content:space-between;align-items:center}.admin-table-title{font-size:13px;font-weight:600;color:#471260}.students-table{width:100%;border-collapse:collapse;border-radius:10px;overflow:hidden}.students-table th,.students-table td{border:1px solid #ece4f3;padding:10px;text-align:left;vertical-align:top;font-size:14px}.students-table th{background:#fff;color:#999;font-size:10px;letter-spacing:.05em;text-transform:uppercase;font-weight:600;border-bottom:1px solid #f5f5f5}.table-actions{display:flex;flex-wrap:wrap;gap:8px}.students-table td button{min-height:32px;padding:0 10px;font-size:12px}.badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600}.badge-taken{background:#edd9fb;color:#b436f0}.badge-free{background:#f0f0f0;color:#888}.error{margin:0;color:#b42800;font-size:14px}.error-list{margin:0;padding-left:16px;color:#b42800}.secret{margin:0;color:#14532d;font-size:14px}@media(min-width:768px){.shell{padding:24px}.shell--student{width:min(560px,100%)}.shell--admin{grid-template-columns:160px 1fr;min-height:auto}.admin-sidebar{position:sticky;top:0;min-height:100%}}
