@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{color-scheme:light;font-family:Inter,system-ui,-apple-system,sans-serif;--app-height: 100dvh;--safe-bottom: env(safe-area-inset-bottom, 0px);--bg: #f7f7f8;--bg-strong: #eeeef0;--panel: #ffffff;--panel-strong: #ffffff;--text: #111118;--text-secondary: #65656d;--accent: #2563eb;--accent-hover: #1d4ed8;--accent-subtle: rgba(37, 99, 235, .08);--success: #16a34a;--success-subtle: rgba(22, 163, 74, .08);--warning: #ca8a04;--warning-subtle: rgba(202, 138, 4, .08);--danger: #dc2626;--danger-subtle: rgba(220, 38, 38, .08);--border: rgba(0, 0, 0, .08);--border-strong: rgba(0, 0, 0, .14);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--radius: 12px;--radius-sm: 8px;--radius-lg: 16px}*{box-sizing:border-box}html{min-height:100%;touch-action:pan-x pan-y;-webkit-text-size-adjust:100%}html,body,#root{min-height:100%}body{margin:0;min-height:100vh;min-height:100dvh;min-height:var(--app-height);line-height:1.5;background:var(--bg);color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh;min-height:100dvh;min-height:var(--app-height);padding:16px 16px calc(16px + var(--safe-bottom))}.workspace,.auth-shell{display:grid;grid-template-columns:minmax(0,1fr);gap:12px;width:min(100%,960px);margin:0 auto}.auth-shell{min-height:calc(100vh - 32px);min-height:calc(100dvh - 32px);min-height:calc(var(--app-height) - 32px - var(--safe-bottom));align-content:center;max-width:480px}.backdrop{display:none}.panel{min-width:0;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:20px;animation:fadeUp .25s ease-out}.subtle-panel{background:var(--bg);box-shadow:none;border:1px solid var(--border)}.hero-panel{background:var(--panel);border:1px solid var(--border)}.profile-menu{position:relative;justify-self:end}.profile-avatar{width:36px;height:36px;border-radius:999px;border:0;background:var(--accent);color:#fff;font-weight:700;font-size:.88rem;display:grid;place-items:center;cursor:pointer;transition:transform .1s ease,box-shadow .15s ease}.profile-avatar:hover{transform:scale(1.05);box-shadow:var(--shadow-md)}.profile-avatar:active{transform:scale(.97)}.profile-dropdown{position:absolute;right:0;top:calc(100% + 6px);z-index:100;min-width:200px;padding:12px;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);display:grid;gap:10px;animation:fadeUp .15s ease-out}.profile-dropdown-info{display:grid;gap:2px}.profile-dropdown-info strong{font-size:.92rem}.eyebrow{font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:2px}h1,h2,h3,p{margin:0}h1{font-size:1.5rem;font-weight:700;line-height:1.2}h2{font-size:1.2rem;font-weight:600;line-height:1.25}h3{font-size:1.05rem;font-weight:600}.lead,.muted{color:var(--text-secondary)}.lead{max-width:520px;margin-top:6px;font-size:.92rem}.mono{font-family:SF Mono,Consolas,monospace;font-size:.88em}.section-head,.stack-row,.list-overview,.question-meta,.flashcard-meta,.table-controls{display:flex;align-items:center;justify-content:space-between;gap:10px}.section-head{flex-wrap:wrap;align-items:flex-start;margin-bottom:12px}.section-head>*,.list-overview>*,.list-card>*{min-width:0}.stack-row{flex-wrap:wrap;gap:8px}.segmented-control{display:inline-flex;max-width:100%;padding:3px;background:var(--bg-strong);border-radius:var(--radius);gap:2px;flex-wrap:wrap}.segment,.primary-button,.secondary-button,.ghost-button,.option-button,.ghost-card{border:0;border-radius:var(--radius-sm);display:inline-flex;align-items:center;justify-content:center;gap:6px;line-height:1.2;text-align:center;font-weight:500;transition:background .15s ease,box-shadow .15s ease,transform .1s ease}.segment,.ghost-button,.secondary-button,.option-button{padding:8px 14px;background:transparent;color:var(--text);font-size:.88rem}.segment.active{background:var(--panel);color:var(--text);box-shadow:var(--shadow-sm);font-weight:600}.primary-button{padding:10px 18px;background:var(--accent);color:#fff;font-weight:600;font-size:.88rem}.primary-button:hover{background:var(--accent-hover)}.secondary-button{background:var(--accent-subtle);color:var(--accent);font-weight:500}.ghost-button{background:var(--bg-strong);color:var(--text-secondary)}.primary-button:hover,.secondary-button:hover,.ghost-button:hover,.option-button:hover,.ghost-card:hover{transform:translateY(-1px)}.segment:hover:not(.active){background:#0000000a}.primary-button:active,.secondary-button:active,.ghost-button:active,.option-button:active,.ghost-card:active{transform:translateY(0) scale(.98)}.primary-button:disabled,.secondary-button:disabled,.ghost-button:disabled,.option-button:disabled{cursor:default;opacity:.5;transform:none}.pill{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:600;letter-spacing:.01em}.pill-accent,.pill-info{background:var(--accent-subtle);color:var(--accent)}.pill-success{background:var(--success-subtle);color:var(--success)}.pill-warning{background:var(--warning-subtle);color:var(--warning)}.pill-muted{background:var(--bg-strong);color:var(--text-secondary)}.pill-danger{background:var(--danger-subtle);color:var(--danger)}.list-overview,.study-launch,.question-card,.flashcard,.completion-card,.empty-state,.feedback-banner,.auth-panel,.ghost-card,.stat-card{border:1px solid var(--border);border-radius:var(--radius);background:var(--panel)}.study-launch,.question-card,.flashcard,.completion-card,.empty-state,.feedback-banner,.auth-panel,.ghost-card,.stat-card{padding:16px}.list-overview{align-items:flex-start;flex-wrap:wrap;padding:16px}.list-overview>:first-child{display:grid;gap:2px}.feedback-banner{display:flex;align-items:flex-start;gap:10px;margin-top:12px;animation:slideDown .2s ease-out}.feedback-correct{border-color:#16a34a40;background:var(--success-subtle)}.feedback-almost{border-color:#ca8a0440;background:var(--warning-subtle)}.feedback-wrong{border-color:#dc262633;background:var(--danger-subtle)}.feedback-banner .feedback-icon{flex-shrink:0;width:20px;height:20px;display:grid;place-items:center;border-radius:999px;font-size:.7rem;font-weight:700;color:#fff}.feedback-correct .feedback-icon{background:var(--success)}.feedback-almost .feedback-icon{background:var(--warning)}.feedback-wrong .feedback-icon{background:var(--danger)}.feedback-body{display:grid;gap:2px;min-width:0}.feedback-body strong{font-size:.88rem}.feedback-body span{font-size:.82rem;color:var(--text-secondary)}.tab-status{display:inline-block;width:7px;height:7px;border-radius:999px;margin-left:2px;vertical-align:middle}.tab-status-busy{background:var(--accent);animation:pulse 1.5s ease-in-out infinite}.tab-status-done{background:var(--success)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.progress-compact{display:flex;align-items:center;gap:8px;margin-bottom:8px}.progress-compact .progress-bar{flex:1}.progress-pct{font-size:.75rem;font-weight:600;color:var(--text-secondary);min-width:28px;text-align:right}.progress-bar{width:100%;height:4px;background:var(--bg-strong);border-radius:999px;overflow:hidden}.progress-fill{height:100%;border-radius:999px;background:var(--accent);transition:width .4s ease-out}.inline-feedback{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:var(--radius-sm);font-size:.82rem;font-weight:500;animation:slideDown .15s ease-out}.inline-feedback-correct{background:var(--success-subtle);color:var(--success)}.inline-feedback-almost{background:var(--warning-subtle);color:var(--warning)}.inline-feedback-wrong{background:var(--danger-subtle);color:var(--danger)}.inline-feedback-icon{font-weight:700;font-size:.88rem}.inline-feedback-answer{font-weight:600}.flashcard{display:grid;gap:12px;margin-top:12px}.flashcard-toggle{width:100%;padding:0;border:0;background:transparent;text-align:inherit;cursor:pointer}.flashcard-toggle:hover .flashcard-face{box-shadow:var(--shadow-md)}.flashcard-toggle:active{transform:scale(.99)}.flashcard-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:4px;border-radius:var(--radius)}.flashcard-body{min-height:260px;perspective:1200px}.flashcard-rotator{position:relative;min-height:260px;transform-style:preserve-3d;transition:transform .5s cubic-bezier(.4,0,.2,1)}.flashcard.flipped .flashcard-rotator{transform:rotateY(180deg)}.flashcard-face{position:absolute;inset:0;display:grid;place-items:center;padding:32px;text-align:center;border-radius:var(--radius);border:1px solid var(--border);backface-visibility:hidden;-webkit-backface-visibility:hidden;box-shadow:var(--shadow);transition:box-shadow .15s ease}.flashcard-face-front{background:var(--panel)}.flashcard-face-back{transform:rotateY(180deg);background:#fafafa}.flashcard-copy{display:grid;gap:8px;justify-items:center;max-width:min(100%,30rem)}.flashcard-term{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:700;letter-spacing:-.02em}.flashcard-hint{text-align:center;font-size:.82rem;color:var(--text-secondary)}.flashcard-progress{display:flex;gap:4px;justify-content:center}.flashcard-dot{width:6px;height:6px;border-radius:999px;background:var(--border-strong);transition:background .15s ease}.flashcard-dot.active{background:var(--accent);width:18px}.flashcard-dot.done{background:var(--text-secondary)}.question-card{display:grid;gap:12px;margin-top:12px;scroll-margin-block:96px}.answer-form,.form-grid,.option-grid,.stats-grid,.persona-grid,.builder-layout,.list-grid{display:grid;gap:10px}.answer-form{grid-template-columns:1fr auto}.option-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.option-button{background:var(--panel);border:1px solid var(--border);font-weight:500}.option-button:hover{border-color:var(--accent);background:var(--accent-subtle);color:var(--accent)}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));margin:12px 0}.persona-grid{grid-template-columns:repeat(auto-fit,minmax(130px,1fr));margin:12px 0}.builder-layout,.list-grid{grid-template-columns:1fr}.ghost-card{display:grid;gap:4px;padding:14px;text-align:left;cursor:pointer}.ghost-card strong{font-size:.92rem}.ghost-card span{font-size:.82rem;color:var(--text-secondary)}.list-card{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px}.completion-card{position:relative;display:flex;align-items:center;gap:16px;margin-top:12px;padding:20px 18px;overflow:hidden;isolation:isolate;background:radial-gradient(circle at top left,rgba(250,204,21,.28),transparent 38%),linear-gradient(135deg,#16a34a24,#2563eb14);border-color:#16a34a2e}.completion-mark{position:relative;z-index:1;width:48px;height:48px;display:grid;place-items:center;border-radius:999px;background:var(--success);color:#fff;box-shadow:0 10px 24px #16a34a3d;font-size:1.25rem;font-weight:700;flex-shrink:0}.completion-copy{position:relative;z-index:1;display:grid;gap:4px}.completion-kicker{font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--success)}.completion-confetti{position:absolute;inset:0;pointer-events:none}.confetti-piece{position:absolute;top:-18px;width:10px;height:18px;border-radius:999px;opacity:.9;animation:confettiDrop 2.8s ease-in-out infinite}.confetti-blue{background:#2563eb}.confetti-gold{background:#f59e0b}.confetti-green{background:#16a34a}.confetti-piece:nth-child(1){left:8%;animation-delay:0s;transform:rotate(-18deg)}.confetti-piece:nth-child(2){left:24%;animation-delay:.35s;transform:rotate(10deg)}.confetti-piece:nth-child(3){left:43%;animation-delay:.7s;transform:rotate(-12deg)}.confetti-piece:nth-child(4){left:62%;animation-delay:.2s;transform:rotate(18deg)}.confetti-piece:nth-child(5){left:79%;animation-delay:.95s;transform:rotate(-8deg)}.confetti-piece:nth-child(6){left:90%;animation-delay:.5s;transform:rotate(14deg)}.auth-panel,.empty-state{display:grid;gap:12px}.study-launch{display:grid;gap:12px;border:0;background:transparent;padding:0}.student-panel{display:flex;flex-direction:column}.student-panel .question-card,.student-panel .flashcard{margin-top:auto}.stat-card{display:grid;align-content:start;gap:6px;min-height:80px;padding:14px}.stat-card span{color:var(--text-secondary);font-size:.78rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em}.stat-card strong{display:block;font-size:1.8rem;font-weight:700;line-height:1;letter-spacing:-.02em}.stat-card.stat-success{border-left:3px solid var(--success)}.stat-card.stat-warning{border-left:3px solid var(--warning)}.stat-card.stat-danger{border-left:3px solid var(--danger)}.stat-card.stat-neutral{border-left:3px solid var(--text-secondary)}input,select,textarea{width:100%;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--panel);color:var(--text);font-size:.88rem;transition:border-color .15s ease}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}input::placeholder{color:var(--text-secondary);opacity:.6}label{display:grid;gap:4px;font-weight:500;font-size:.85rem;color:var(--text-secondary)}textarea{resize:vertical}.editor-rows{display:grid;gap:8px}.editor-row{display:grid;grid-template-columns:auto minmax(0,1fr) minmax(0,1fr) auto;gap:8px;align-items:center}.editor-row-number{width:28px;text-align:center;font-size:.78rem;font-weight:600;color:var(--text-secondary)}.editor-row .ghost-button{align-self:stretch;min-height:42px;padding:8px;font-size:.82rem}.table-shell{overflow:auto;margin-top:10px;border-radius:var(--radius);border:1px solid var(--border);background:var(--panel)}table{width:100%;border-collapse:collapse}.student-table{min-width:680px}th,td{padding:10px 14px;border-bottom:1px solid var(--border);text-align:left;vertical-align:middle;font-size:.88rem}th{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);background:var(--bg)}tbody tr{transition:background .1s ease}tbody tr:hover{background:var(--bg)}tbody tr:last-child td{border-bottom:0}.warning-list{margin:0;padding-left:18px;color:var(--warning);font-size:.88rem}.file-label{display:grid;gap:4px}.file-label input[type=file]{width:100%;padding:0;border:0;background:transparent;color:var(--text-secondary);font-size:.85rem}.file-label input[type=file]::file-selector-button{margin-right:10px;padding:8px 14px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--panel);color:var(--text);cursor:pointer;font-size:.85rem}.builder-layout{align-items:start}.builder-layout>.panel{display:grid;align-content:start;gap:14px}.form-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));align-items:start}.flashcard-meta,.question-meta{flex-wrap:wrap;font-size:.82rem;color:var(--text-secondary)}.table-controls{justify-content:flex-end}.table-controls input{width:min(100%,360px)}.list-card-actions{justify-content:flex-end}.student-name-cell strong{display:block;margin-bottom:2px}@keyframes fadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes confettiDrop{0%{opacity:0;transform:translate3d(0,-8px,0) rotate(0)}15%{opacity:.9}to{opacity:0;transform:translate3d(10px,110px,0) rotate(220deg)}}@media(min-width:860px){.builder-layout{grid-template-columns:1.1fr .9fr}}@media(max-width:720px){.app-shell{padding:10px 10px calc(10px + var(--safe-bottom))}.workspace,.auth-shell{gap:10px}.section-head,.list-overview,.question-meta,.flashcard-meta,.table-controls,.list-card{flex-direction:column;align-items:flex-start}.persona-grid{grid-template-columns:1fr}.segmented-control{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));width:100%}.admin-tabs{background:transparent;padding:0;gap:6px;grid-template-columns:1fr}.segment{width:100%}.answer-form,.editor-row,.stats-grid{grid-template-columns:1fr}.editor-row{grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto}.editor-row-number{display:none}.list-card{grid-template-columns:1fr}.editor-secondary-actions,.editor-primary-actions{width:100%;display:grid;grid-template-columns:1fr}.list-card-actions{width:100%;display:grid;grid-template-columns:1fr;gap:8px;justify-content:stretch;align-items:stretch}.editor-secondary-actions>button,.editor-primary-actions>button,.list-card-actions>button{width:100%;flex:1 1 100%}.table-controls input{width:100%}.list-card-actions .pill{justify-self:start}.table-shell{overflow:visible;border:0;background:transparent}.student-table,.student-table thead,.student-table tbody,.student-table tr,.student-table td{display:block;width:100%}.student-table{min-width:0}.student-table thead{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.student-table tbody{display:grid;gap:8px}.student-table tr{display:grid;gap:8px;padding:14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--panel)}.student-table td{display:grid;grid-template-columns:minmax(0,90px) minmax(0,1fr);gap:8px;padding:0;border:0;font-size:.85rem}.student-table td:before{content:attr(data-label);font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary)}.panel{padding:16px;border-radius:var(--radius)}input,select,textarea{font-size:16px}.flashcard-body,.flashcard-rotator{min-height:220px}}@media(prefers-reduced-motion:reduce){.flashcard-toggle,.flashcard-rotator,.panel,.feedback-banner{animation:none;transition:none}.confetti-piece{animation:none;opacity:.4}}
