.dashboard-root{min-height:100vh;display:flex;flex-direction:column;background:var(--grad-bg)}.dashboard-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-xl);border-bottom:1px solid var(--color-border);background:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:sticky;top:0;z-index:100}.dashboard-logo{display:flex;align-items:center;gap:var(--space-sm)}.logo-icon{font-size:1.5rem}.logo-text{font-family:var(--font-display);font-weight:800;font-size:1.3rem;background:var(--grad-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.session-badge{display:flex;align-items:center;gap:var(--space-sm);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);padding:6px 16px;font-size:.9rem}.dashboard-main{flex:1;padding:var(--space-xl);max-width:860px;margin:0 auto;width:100%}.create-panel{width:100%}.create-panel h1{margin-bottom:var(--space-sm)}.activity-type-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--space-md);margin-bottom:var(--space-md)}.activity-type-card{background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md);color:var(--color-text);cursor:pointer;text-align:left;transition:all var(--transition-base);display:flex;flex-direction:column;gap:6px}.activity-type-card:hover{border-color:var(--color-primary);background:var(--color-primary-soft);transform:translateY(-1px)}.activity-type-card.selected{border-color:var(--color-primary);background:var(--color-primary-soft)}.at-label{font-weight:600;font-size:.95rem}.at-desc{font-size:.78rem;color:var(--color-text-dim)}.options-list{display:flex;flex-direction:column;gap:var(--space-sm)}.option-row{display:flex;gap:var(--space-sm);align-items:center}.option-row input{flex:1}.scale-preview{display:flex;gap:var(--space-sm);flex-wrap:wrap;margin-bottom:var(--space-md);padding:var(--space-md);background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border)}.scale-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 12px;background:var(--color-surface-hover);border-radius:var(--radius-sm);font-weight:600}.scale-star{font-size:.7rem}.emoji-preview{font-size:1.6rem}.error-msg{background:#ef44441a;border:1px solid #ef4444;border-radius:var(--radius-sm);padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-md);color:var(--color-accent);font-size:.9rem}.active-panel{width:100%}.active-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-lg);flex-wrap:wrap;gap:var(--space-md)}.status-pill{display:flex;align-items:center;gap:var(--space-sm);padding:10px 18px;border-radius:var(--radius-full);font-size:.9rem;font-weight:600;border:1px solid var(--color-border);background:var(--color-surface);white-space:nowrap}.status-pill.active{border-color:var(--color-secondary);background:var(--color-secondary-soft);color:var(--color-secondary)}.status-pill.waiting{border-color:var(--color-primary);background:var(--color-primary-soft);color:var(--color-primary)}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md);margin-bottom:var(--space-lg)}.stat-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--space-lg) var(--space-md);text-align:center}.stat-icon{font-size:1.5rem}.stat-number{font-family:var(--font-display);font-size:1.8rem;font-weight:800;background:var(--grad-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-label{font-size:.8rem;color:var(--color-text-dim)}.url-section{margin-bottom:var(--space-lg)}.url-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);flex-wrap:wrap}.url-code{display:block;font-family:Courier New,monospace;font-size:.85rem;color:var(--color-secondary);margin-top:4px;word-break:break-all}.action-row{display:flex;gap:var(--space-md);flex-wrap:wrap;align-items:center}.finished-panel{text-align:center;padding:var(--space-2xl) 0}@media (max-width: 600px){.dashboard-main{padding:var(--space-md)}.stats-row{grid-template-columns:1fr}.active-header{flex-direction:column}}.ai-config-section{background:var(--color-bg-2);border:1px dashed var(--color-border);padding:var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-lg)}.form-help{font-size:.8rem;color:var(--color-text-dim);margin-bottom:var(--space-sm)}.category-input-row{display:flex;gap:var(--space-sm);margin-bottom:var(--space-sm)}.category-tags{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.category-tag{background:var(--color-primary-soft);color:var(--color-primary);padding:4px 10px;border-radius:var(--radius-full);font-size:.8rem;font-weight:600;display:flex;align-items:center;gap:6px}.category-tag button{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:.8rem;padding:0;display:flex;align-items:center}.category-tag button:hover{opacity:.7}.ai-instructions-textarea{font-size:.9rem;padding:10px;background:#fff}.chart-container{height:260px;width:100%;position:relative}.chart-container.compact{height:180px}.word-cloud{display:flex;flex-wrap:wrap;gap:10px 16px;align-items:center;justify-content:center;padding:var(--space-md);min-height:180px}.word-cloud.compact{min-height:120px}.word-item{display:inline-block;line-height:1.2;transition:transform var(--transition-fast);cursor:default;font-family:var(--font-display)}.word-item:hover{transform:scale(1.08)}.slide-root{width:100%;height:100vh;min-height:240px;background:var(--grad-bg);display:flex;align-items:stretch;justify-content:center;overflow:hidden;padding:clamp(12px,3vw,28px)}.slide-spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-text{color:var(--color-accent);font-size:.9rem}.slide-waiting,.slide-active{width:100%;display:flex;align-items:center;gap:clamp(16px,4vw,40px)}.slide-left{flex:1;display:flex;flex-direction:column;gap:10px}.slide-session-badge{display:inline-block;background:var(--color-primary-soft);border:1px solid var(--color-primary);color:var(--color-primary);border-radius:var(--radius-full);padding:3px 14px;font-size:clamp(.7rem,1.5vw,.85rem);font-weight:700;letter-spacing:.08em;width:fit-content}.slide-title{font-family:var(--font-display);font-size:clamp(.95rem,2.5vw,1.5rem);font-weight:700;color:var(--color-text);line-height:1.3;margin:0}.slide-instructions{font-size:clamp(.72rem,1.6vw,.9rem);color:var(--color-text-dim);line-height:1.5}.slide-url{font-family:Courier New,monospace;font-size:clamp(.65rem,1.4vw,.82rem);color:var(--color-primary);background:var(--color-primary-soft);padding:5px 10px;border-radius:var(--radius-sm);border:1px solid var(--color-border);word-break:break-all}.slide-waiting-status{display:flex;align-items:center;gap:8px;font-size:clamp(.7rem,1.4vw,.82rem);color:var(--color-text-faint);margin-top:4px}.slide-live-counts{display:flex;align-items:center;gap:16px;margin-top:4px}.live-count{display:flex;flex-direction:column;align-items:center;gap:2px}.live-count-num{font-family:var(--font-display);font-size:clamp(1.2rem,3vw,1.8rem);font-weight:800;background:var(--grad-secondary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.live-count-label{font-size:.72rem;color:var(--color-text-faint)}.live-count-divider{width:1px;height:36px;background:var(--color-border)}.slide-qr-wrap{display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:clamp(10px,2vw,20px);flex-shrink:0}.slide-qr-wrap.pulse-qr{border-color:var(--color-primary)}.slide-results{width:100%;display:flex;flex-direction:column;gap:12px}.slide-results-header{display:flex;align-items:center;gap:var(--space-md);flex-wrap:wrap}.slide-title-results{font-family:var(--font-display);font-size:clamp(.95rem,2.2vw,1.3rem);font-weight:700;color:var(--color-text);margin:0}.slide-total-badge{background:var(--color-secondary-soft);border:1px solid var(--color-secondary);color:var(--color-secondary);border-radius:var(--radius-full);padding:3px 12px;font-size:.78rem;font-weight:600;white-space:nowrap}.slide-chart-wrap{flex:1;min-height:0}.student-root{min-height:100vh;display:flex;align-items:flex-start;justify-content:center;padding:var(--space-md);padding-bottom:var(--space-2xl)}.student-wrapper{width:100%;max-width:480px;display:flex;flex-direction:column;gap:var(--space-md)}.student-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) 0}.student-logo{font-family:var(--font-display);font-weight:700;font-size:1rem;color:var(--color-primary)}.student-card{width:100%;padding:var(--space-lg)}.student-question{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--color-text);line-height:1.4;margin-bottom:var(--space-lg)}.choice-list{display:flex;flex-direction:column;gap:var(--space-sm)}.choice-btn{display:flex;align-items:center;gap:var(--space-md);padding:14px 18px;border-radius:var(--radius-md);background:var(--color-surface);border:2px solid var(--color-border);color:var(--color-text);font-size:1rem;font-family:var(--font-base);cursor:pointer;text-align:left;transition:all var(--transition-base);width:100%}.choice-btn:hover,.choice-btn.selected{border-color:var(--color-primary);background:var(--color-primary-soft)}.choice-index{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--color-surface-hover);font-weight:700;font-size:.85rem;flex-shrink:0;transition:background var(--transition-fast)}.choice-btn.selected .choice-index{background:var(--color-primary);color:#fff}.emoji-grid{display:flex;justify-content:space-around;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-sm)}.emoji-btn{display:flex;align-items:center;justify-content:center;font-size:2.4rem;width:72px;height:72px;border-radius:var(--radius-md);background:var(--color-surface);border:2px solid var(--color-border);cursor:pointer;transition:all var(--transition-base);line-height:1}.emoji-btn:hover{transform:scale(1.05);border-color:var(--color-primary);background:var(--color-primary-soft)}.emoji-btn.selected{border-color:var(--color-primary);background:var(--color-primary-soft);transform:scale(1.08)}.submitted-icon{font-size:4rem;margin-bottom:var(--space-md);animation:bounce-in .5s cubic-bezier(.36,.07,.19,.97) both}@keyframes bounce-in{0%{transform:scale(.3);opacity:0}50%{transform:scale(1.15)}70%{transform:scale(.9)}to{transform:scale(1);opacity:1}}.waiting-dots{display:flex;justify-content:center;gap:8px;margin-top:var(--space-lg)}.waiting-dots span{width:8px;height:8px;border-radius:50%;background:var(--color-primary);animation:dot-bounce 1.4s infinite ease-in-out both}.waiting-dots span:nth-child(1){animation-delay:0s}.waiting-dots span:nth-child(2){animation-delay:.16s}.waiting-dots span:nth-child(3){animation-delay:.32s}@keyframes dot-bounce{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.student-spinner{width:48px;height:48px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.student-error{color:var(--color-accent);font-size:.88rem;margin-top:var(--space-sm)}.student-results-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);flex-wrap:wrap;margin-bottom:var(--space-md)}.login-root{min-height:100vh;background:var(--color-bg);padding:var(--space-lg)}.login-card{width:100%;max-width:400px;padding:var(--space-xl)}.login-header{text-align:center;margin-bottom:var(--space-xl)}.login-logo{font-size:1.5rem;font-weight:800;display:block;margin-bottom:var(--space-md);color:var(--color-primary)}.login-header h1{font-size:1.75rem;margin-bottom:var(--space-xs);color:var(--color-text)}.login-header p{color:var(--color-text-dim);font-size:.95rem}.login-form .form-group{margin-bottom:var(--space-lg)}:root{--font-base: "Inter", sans-serif;--font-display: "Inter", sans-serif;--color-bg: #ffffff;--color-bg-2: #f8fafc;--color-surface: #ffffff;--color-surface-hover: #f1f5f9;--color-border: #e2e8f0;--color-primary: #2563eb;--color-primary-soft: #eff6ff;--color-secondary: #0d9488;--color-secondary-soft: #f0fdfa;--color-accent: #0284c7;--color-warning: #d97706;--color-text: #0f172a;--color-text-dim: #475569;--color-text-faint: #94a3b8;--grad-primary: linear-gradient(135deg, #2563eb 0%, #1d4ed8 100%);--grad-secondary: linear-gradient(135deg, #0d9488 0%, #0f766e 100%);--grad-accent: linear-gradient(135deg, #0284c7 0%, #0369a1 100%);--grad-bg: #ffffff;--grad-glass: #ffffff;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 40px;--space-2xl: 64px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.1), 0 2px 4px -1px rgba(0,0,0,.06);--shadow-primary: none;--shadow-secondary: none;--transition-fast: .1s ease;--transition-base: .2s ease;--transition-slow: .4s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%;font-size:16px}body{font-family:var(--font-base);background:var(--grad-bg);color:var(--color-text);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.2}h1{font-size:clamp(1.8rem,4vw,2.8rem)}h2{font-size:clamp(1.4rem,3vw,2rem)}h3{font-size:clamp(1.1rem,2.5vw,1.4rem)}p{line-height:1.7;color:var(--color-text-dim)}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}.glass-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-lg);box-shadow:var(--shadow-md);transition:all var(--transition-base)}.glass-card:hover{border-color:var(--color-primary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:12px 28px;border-radius:var(--radius-full);font-family:var(--font-display);font-size:.95rem;font-weight:600;cursor:pointer;border:none;transition:all var(--transition-base);position:relative;overflow:hidden;white-space:nowrap}.btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#fff0;transition:background var(--transition-fast)}.btn:hover:after{background:#ffffff14}.btn:active:after{background:#ffffff26}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--grad-primary);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary{background:var(--grad-secondary);color:#fff;box-shadow:var(--shadow-sm)}.btn-secondary:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-danger{background:var(--grad-accent);color:#fff;box-shadow:var(--shadow-sm)}.btn-danger:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-ghost{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.btn-ghost:hover{background:var(--color-surface-hover)}.btn-lg{padding:16px 40px;font-size:1.05rem}.btn-sm{padding:8px 18px;font-size:.85rem}.input,input[type=text],input[type=number],textarea,select{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font-base);font-size:1rem;padding:12px 16px;width:100%;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none;resize:vertical}.input:focus,input[type=text]:focus,input[type=number]:focus,textarea:focus,select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-soft)}select option{background:var(--color-bg);color:var(--color-text)}.form-group{margin-bottom:var(--space-md)}.form-label{display:block;margin-bottom:var(--space-sm);font-size:.85rem;font-weight:500;color:var(--color-text-dim);letter-spacing:.04em;text-transform:uppercase}.badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:4px 12px;border-radius:var(--radius-full);font-size:.78rem;font-weight:600;letter-spacing:.03em}.badge-primary{background:var(--color-primary-glow);color:var(--color-primary)}.badge-secondary{background:var(--color-secondary-glow);color:var(--color-secondary)}.badge-warning{background:var(--color-warning-glow);color:var(--color-warning)}.badge-accent{background:var(--color-accent-glow);color:var(--color-accent)}.divider{height:1px;background:var(--color-border);margin:var(--space-lg) 0}.center{display:flex;align-items:center;justify-content:center;flex-direction:column}.flex{display:flex}.flex-col{flex-direction:column}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.w-full{width:100%}.text-center{text-align:center}.text-dim{color:var(--color-text-dim)}.text-faint{color:var(--color-text-faint)}.grad-text-primary{background:var(--grad-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.grad-text-secondary{background:var(--grad-secondary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.pulse-dot{display:inline-block;width:8px;height:8px;border-radius:50%;animation:pulse-anim 1.5s infinite ease-in-out}.pulse-dot.green{background:var(--color-secondary);box-shadow:0 0 6px var(--color-secondary)}.pulse-dot.purple{background:var(--color-primary);box-shadow:0 0 6px var(--color-primary)}.pulse-dot.red{background:var(--color-accent);box-shadow:0 0 6px var(--color-accent)}@keyframes pulse-anim{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.ai-synthesis-card{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #bae6fd;border-radius:var(--radius-lg);padding:var(--space-md);margin-bottom:var(--space-lg);box-shadow:0 4px 12px #0ea5e91a}.ai-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm)}.ai-icon{font-size:1.2rem}.ai-title{font-weight:700;font-size:.85rem;color:#0369a1;text-transform:uppercase;letter-spacing:.05em}.ai-content{color:#0c4a6e;font-size:1rem;line-height:1.5;font-style:italic}.checkbox-container{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label{font-size:.95rem;font-weight:500;color:var(--color-primary)}input[type=checkbox]{width:18px;height:18px;cursor:pointer}.text-results-wrapper{display:flex;flex-direction:column;width:100%}.text-results-wrapper.compact .ai-content{font-size:.9rem}.ai-classification-chart{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md);margin-bottom:var(--space-lg);box-shadow:var(--shadow-sm)}.ai-chart-wrapper{height:250px;width:100%}.compact .ai-chart-wrapper{height:180px}.ai-classification-chart .ai-header{margin-bottom:var(--space-md)}
