:root{--bg-sidebar: #f7f6f3;--bg-sidebar-hover: #efefec;--bg-main: #ffffff;--bg-white: #ffffff;--bg-elevated: #f7f6f3;--text-primary: #37352f;--text-dark: #37352f;--text-muted: #787774;--text-light: #37352f;--text-light-muted: #787774;--text-placeholder: #9b9a97;--accent-primary: #7c3aed;--accent-primary-hover: #6d28d9;--accent-ai: #37352f;--accent-ai-light: #f7f6f3;--accent-success: #0f7b6c;--accent-success-light: #e6f5f0;--accent-warning: #c27719;--accent-error: #e03e3e;--border-light: #e9e9e7;--border-dark: #e9e9e7;--empathy-thinks: #f7f6f3;--empathy-says: #f7f6f3;--empathy-does: #f7f6f3;--empathy-feels: #f7f6f3;--left-panel-width: 260px;--right-panel-width: 360px;--header-height: 56px;--mobile-header-height: 52px;--font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 3px;--radius-md: 4px;--radius-lg: 6px;--radius-xl: 8px;--shadow-sm: rgba(15, 15, 15, .04) 0px 0px 0px 1px;--shadow-md: rgba(15, 15, 15, .05) 0px 0px 0px 1px, rgba(15, 15, 15, .1) 0px 3px 6px;--shadow-lg: rgba(15, 15, 15, .05) 0px 0px 0px 1px, rgba(15, 15, 15, .1) 0px 5px 10px, rgba(15, 15, 15, .2) 0px 15px 40px;--transition-fast: .12s ease;--transition-normal: .2s ease}body{font-family:var(--font-family);font-size:14px;line-height:1.5;color:var(--text-dark);background:var(--bg-main);-webkit-font-smoothing:antialiased}.left-panel,.content-wrapper,.right-panel,.left-panel *,.content-wrapper *,.right-panel *{scrollbar-width:none;-ms-overflow-style:none}.left-panel::-webkit-scrollbar,.content-wrapper::-webkit-scrollbar,.right-panel::-webkit-scrollbar,.left-panel *::-webkit-scrollbar,.content-wrapper *::-webkit-scrollbar,.right-panel *::-webkit-scrollbar{display:none}.app-layout{display:grid;grid-template-columns:var(--left-panel-width) 1fr var(--right-panel-width);grid-template-rows:1fr;grid-template-areas:"sidebar content aipanel";height:calc(100vh - var(--header-height));overflow:hidden}.app-layout.ai-collapsed{grid-template-columns:var(--left-panel-width) 1fr 0;grid-template-areas:"sidebar content content"}.header-brand{font-size:18px;font-weight:700;color:var(--text-dark)}.header .header-right{display:flex;align-items:center;gap:var(--spacing-sm)}.header .header-profile-link{display:flex;align-items:center;gap:var(--spacing-sm);text-decoration:none;cursor:pointer;border-radius:var(--radius-md);padding:4px 8px;transition:background var(--transition-fast)}.header .header-profile-link:hover{background:var(--bg-elevated)}.header .profile-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#667eea,#8b5cf6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0}.header .user-name-display{font-size:14px;font-weight:500;color:var(--text-primary)}.header .user-email-display{font-size:12px;color:var(--text-muted)}.header .btn-text{background:none;border:none;cursor:pointer;font-size:13px;color:var(--text-muted);padding:4px 8px;margin-left:48px;display:flex;align-items:center;gap:4px}.header .btn-text:hover{color:var(--accent-error)}.header .btn-notification{position:relative;display:flex;align-items:center;justify-content:center;color:var(--text-muted);text-decoration:none;padding:4px;margin-right:var(--spacing-md);line-height:0;height:32px}.header .btn-notification:hover{color:var(--text-primary)}.header .notification-badge{position:absolute;top:-2px;right:-4px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--accent-error);color:#fff;font-size:10px;font-weight:600;display:flex;align-items:center;justify-content:center;line-height:1}#sidebar-container{display:contents}.left-panel{grid-area:sidebar;background:var(--bg-sidebar);display:flex;flex-direction:column;overflow:hidden;border-right:1px solid var(--border-light)}.logo-section{padding:16px var(--spacing-md);border-bottom:1px solid var(--border-light)}.logo{display:flex;align-items:center;gap:var(--spacing-sm)}.logo-icon{width:32px;height:32px;background:var(--text-dark);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:11px}.logo-img{width:36px;height:36px;object-fit:contain;border-radius:8px}.logo-text{color:var(--text-dark);font-weight:600;font-size:17px}.user-quick-info{display:flex;flex-direction:column;gap:0;padding-top:var(--spacing-sm);padding:12px var(--spacing-md);margin:12px 8px 0;border-radius:var(--radius-sm);text-decoration:none;color:inherit;cursor:pointer;transition:background .15s ease}.user-quick-info:hover{background:var(--bg-elevated)}.user-quick-info-title{font-size:12px;font-weight:600;color:var(--text-muted);letter-spacing:.3px;margin-bottom:8px}.user-profile-row{display:flex;align-items:center;gap:10px}.user-profile-row .user-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-stats-bar{display:flex;flex-direction:column;gap:4px;margin-top:8px}.user-stats-bar .user-level{font-size:12px;font-weight:500;color:var(--text-secondary)}.xp-progress-row{display:flex;align-items:center;gap:8px;padding-left:20px}.xp-progress-bar{width:80px;flex-shrink:0;height:6px;background:var(--border-light);border-radius:3px;overflow:hidden}.xp-progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#8b5cf6);border-radius:3px;transition:width .4s ease;min-width:2px}.xp-progress-row .user-gold{font-size:11px;font-weight:600;color:#f5a623;white-space:nowrap;flex-shrink:0}.xp-progress-label{font-size:11px;color:var(--text-muted);font-weight:500;white-space:nowrap;flex-shrink:0}.user-avatar{width:40px;height:40px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:15px;flex-shrink:0;border:2px solid rgba(255,255,255,.9);box-shadow:0 2px 8px #667eea4d;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.user-avatar:hover{transform:scale(1.05);box-shadow:0 4px 12px #667eea66}.user-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.user-info-stack{display:flex;flex-direction:column;align-items:flex-start;text-align:left;gap:1px;flex:1}.user-name{color:var(--text-dark);font-weight:600;font-size:14px;line-height:1.2}.user-level{color:var(--text-muted);font-size:11px;line-height:1.2}.user-actions{display:flex;align-items:center;gap:2px;flex-shrink:0;position:relative}.user-team{color:var(--text-muted);font-size:12px}.btn-logout{background:transparent;border:none;padding:var(--spacing-xs);cursor:pointer;color:var(--text-muted);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.btn-logout:hover{background:var(--bg-sidebar-hover);color:var(--accent-error)}.btn-notification{position:relative;background:transparent;border:none;padding:var(--spacing-xs);cursor:pointer;color:var(--text-muted);border-radius:var(--radius-sm)}.btn-notification:hover{background:var(--bg-sidebar-hover)}.btn-notification svg{width:18px;height:18px}.notification-badge{position:absolute;top:0;right:0;width:14px;height:14px;background:var(--accent-error);border-radius:50%;font-size:9px;color:#fff;display:flex;align-items:center;justify-content:center}.nav-menu{flex:1;overflow-y:auto;padding:16px var(--spacing-sm) var(--spacing-sm);scrollbar-width:none;-ms-overflow-style:none}.nav-menu::-webkit-scrollbar{display:none}.nav-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:6px 10px;margin:1px 0;color:var(--text-muted);text-decoration:none;font-size:14px;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.nav-item:hover{background:var(--bg-sidebar-hover);color:var(--text-dark)}.nav-item svg{width:18px;height:18px;flex-shrink:0;opacity:.7}.nav-section{margin:1px 0}.nav-section-header{display:flex;align-items:center;gap:var(--spacing-sm);padding:6px 10px 6px 14px;margin:1px 0;color:var(--text-muted);font-size:14px;cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.nav-section-header:hover{background:var(--bg-sidebar-hover);color:var(--text-dark)}.nav-section-header.active{color:var(--text-dark);font-weight:500}.nav-section-header svg{width:18px;height:18px;flex-shrink:0;opacity:.7}.nav-section-header .chevron{margin-left:auto;width:14px;height:14px;transition:transform var(--transition-fast)}.nav-section-content{overflow:hidden;overflow-y:auto;max-height:600px;transition:max-height var(--transition-normal);scrollbar-width:none;-ms-overflow-style:none}.nav-section-content::-webkit-scrollbar{display:none}.nav-section-content.collapsed{max-height:0}.phase-label{padding:12px 10px 6px 16px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--text-secondary);margin-top:var(--spacing-md)}.phase-label:first-child{margin-top:0}.anchor-icon{font-size:10px;margin-left:auto}.nav-sub-item.anchor{background:transparent}.nav-sub-item.anchor:not(.locked){color:var(--accent-warning)}.nav-sub-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:5px 10px 5px 28px;margin:1px 0;color:var(--text-muted);text-decoration:none;font-size:13px;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.nav-sub-item:hover{background:var(--bg-sidebar-hover);color:var(--text-dark)}.nav-sub-item.active{color:var(--text-dark);background:var(--bg-sidebar-hover);font-weight:500}.nav-sub-item.completed{color:var(--accent-success)}.nav-sub-item.locked{opacity:.4;pointer-events:none}.week-indicator{width:20px;height:20px;border-radius:var(--radius-sm);background:var(--border-light);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:var(--text-muted)}.week-indicator.current{background:var(--text-dark);color:#fff}.check-icon{margin-left:auto;color:var(--accent-success);font-size:12px}.lock-icon{margin-left:auto;font-size:10px;opacity:.5}.nav-more-btn{display:block;width:100%;padding:4px 10px 4px 42px;background:transparent;border:none;color:var(--text-muted);font-size:11px;text-align:left;cursor:pointer;border-radius:var(--radius-sm)}.nav-more-btn:hover{background:var(--bg-sidebar-hover);color:var(--text-dark)}.workspace-items{display:flex;flex-direction:column}.workspace-item{display:flex;align-items:center;gap:var(--spacing-xs);position:relative}.workspace-item:hover .btn-delete-item{opacity:1}.hash-prefix{color:var(--text-light-muted);font-weight:500;font-size:14px}.workspace-item-name{flex:1;font-size:13px}.btn-delete-item{opacity:0;background:transparent;border:none;color:var(--text-light-muted);font-size:16px;cursor:pointer;padding:2px 6px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.btn-delete-item:hover{background:#ef444433;color:var(--accent-error)}.btn-add-workspace{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-lg);padding-left:52px;background:transparent;border:none;color:var(--text-light-muted);font-size:12px;cursor:pointer;transition:all var(--transition-fast)}.btn-add-workspace:hover{color:var(--accent-primary)}.nav-bottom{border-top:1px solid var(--border-light);padding:var(--spacing-sm)}.profile-item{display:flex;align-items:center;gap:var(--spacing-sm)}.profile-avatar{width:22px;height:22px;background:var(--text-muted);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:#fff;font-size:10px;font-weight:500}.center-panel{display:contents}.page-header{display:flex;justify-content:space-between;align-items:center;padding:16px var(--spacing-lg);background:var(--bg-white);min-height:69px;box-sizing:border-box;flex-shrink:0}.page-header-left{display:flex;align-items:center;gap:var(--spacing-md)}.breadcrumb{display:flex;align-items:center;gap:var(--spacing-xs);font-size:13px;color:var(--text-muted)}.breadcrumb svg{width:12px;height:12px}.breadcrumb .current{color:var(--text-dark);font-weight:500}.page-title{font-size:18px;font-weight:600;color:var(--text-dark);letter-spacing:-.02em;line-height:1.4}.progress-badge{display:flex;align-items:center;gap:var(--spacing-xs);padding:0;background:transparent}.progress-label{font-size:12px;color:var(--text-muted)}.progress-value{font-size:13px;font-weight:500;color:var(--text-dark)}.btn-toggle-ai{display:flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;color:var(--text-muted);border:1px solid var(--border-light);border-radius:var(--radius-sm);font-size:13px;font-weight:400;cursor:pointer;transition:all var(--transition-fast)}.btn-toggle-ai:hover{background:var(--bg-elevated);color:var(--text-dark)}.btn-toggle-ai svg{width:14px;height:14px}#main-content{grid-area:content;display:flex;flex-direction:column;overflow:hidden;height:100%}.content-wrapper{grid-area:content;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-white)}.progress-bar-container{padding:var(--spacing-sm) var(--spacing-lg);background:var(--bg-white);border-bottom:1px solid var(--border-light)}.progress-bar{height:2px;background:var(--border-light);border-radius:1px;margin-bottom:var(--spacing-sm)}.progress-fill{height:100%;background:var(--text-dark);border-radius:1px;transition:width .5s ease}.progress-bar-container{position:relative}.step-indicator{display:flex;flex-direction:column;align-items:center;gap:2px}.step-dot{width:6px;height:6px;background:var(--border-light);border-radius:50%;transition:all var(--transition-fast)}.step-indicator.active .step-dot,.step-indicator.completed .step-dot{background:var(--text-dark)}.step-label{font-size:11px;color:var(--text-muted)}.step-indicator.active .step-label{color:var(--text-dark);font-weight:500}.worksheet-scroll-area{flex:1;overflow-y:auto;padding:var(--spacing-lg) var(--spacing-md);background:var(--bg-white);scrollbar-width:none;-ms-overflow-style:none}.worksheet-scroll-area::-webkit-scrollbar{display:none}.worksheet-guide{display:flex;align-items:flex-start;gap:12px;max-width:800px;margin:0 auto 20px;padding:14px 18px;background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-md)}.worksheet-guide-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--accent-primary)}.worksheet-guide-body{flex:1;min-width:0}.worksheet-guide-title{font-size:14px;font-weight:600;color:var(--text-dark);margin:0 0 4px}.worksheet-guide-desc{font-size:13px;line-height:1.6;color:var(--text-muted);margin:0}.worksheet-guide-desc strong{color:var(--accent-primary);font-weight:600}.step-section{background:var(--bg-white);padding:var(--spacing-lg) 0;margin-bottom:0;border-bottom:1px solid var(--border-light);max-width:800px;margin-left:auto;margin-right:auto}.step-section:last-child{border-bottom:none}.step-section.locked{opacity:.5;pointer-events:none}.step-header-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.step-title-group{display:flex;align-items:center;gap:var(--spacing-md)}.step-badge{background:var(--accent-primary);color:#fff;font-size:12px;font-weight:600;padding:3px 10px;border:none;border-radius:var(--radius-sm);letter-spacing:.02em}.step-title{font-size:18px;font-weight:600;color:var(--text-dark);letter-spacing:-.01em;white-space:nowrap}.key-badge{background:#fef3c7;color:#92400e;font-size:11px;font-weight:500;padding:2px 8px;border-radius:3px}.step-meta-group{display:flex;align-items:center;gap:var(--spacing-sm)}.duration-tag,.points-tag{font-size:12px;padding:2px 8px;background:var(--bg-elevated);color:var(--text-muted);border-radius:var(--radius-sm)}.points-tag{color:var(--accent-primary);font-weight:500}.step-description{font-size:14px;color:var(--text-muted);margin-bottom:12px;line-height:1.6}.step-learn-hint{font-size:13px;color:var(--text-muted);margin-bottom:var(--spacing-md);cursor:pointer;transition:color var(--transition-fast);background:none;border:none;padding:0;text-align:left;font-family:inherit;display:block;width:auto}.step-learn-hint:hover{color:var(--primary);text-decoration:underline}.substep-card{background:var(--bg-white);border:none;border-radius:0;padding:20px 0 20px 16px;margin-bottom:0;border-bottom:1px solid var(--border-light);border-left:3px solid var(--border-light)}.substep-card:last-child{border-bottom:none}.substep-card:hover{background:var(--bg-white)}.substep-card.locked{opacity:.4;pointer-events:none}.substep-card.completed{background:var(--bg-white);border-bottom:1px solid var(--border-light)}.substep-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.substep-label{font-size:15px;font-weight:600;color:var(--text-dark)}.substep-label .hint{font-weight:400;color:var(--text-muted);font-size:13px}.substep-status{font-size:12px;padding:0;background:transparent;color:var(--text-muted);display:inline-flex;align-items:center;gap:3px}.substep-status svg{vertical-align:middle;flex-shrink:0}.substep-card.completed .substep-status{background:transparent}.substep-status.feedback-done,.substep-status.completed{color:var(--text-secondary)}.substep-body{margin-bottom:var(--spacing-md)}.substep-actions{display:flex;justify-content:flex-end;padding-top:var(--spacing-md);border-top:none}.btn-substep-submit{background:transparent;color:var(--text-dark);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:6px 12px;font-size:13px;font-weight:400;cursor:pointer;transition:background var(--transition-fast)}.btn-substep-submit:hover:not(:disabled){background:var(--bg-elevated)}.btn-substep-submit:disabled{opacity:.4;cursor:not-allowed}.btn-substep-submit.btn-complete{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue);opacity:1!important;visibility:visible!important}.btn-substep-submit.btn-complete:hover:not(:disabled){background:#1a91c0}.btn-substep-submit.btn-complete:disabled{background:#b0bec5;border-color:#b0bec5;color:#fff;opacity:1!important;visibility:visible!important;pointer-events:auto}.btn-substep-submit.btn-complete.btn-enabled{background:var(--accent-success);border-color:var(--accent-success);animation:pulse-button 1s ease-in-out 2}.btn-substep-submit.btn-complete.btn-enabled:hover{background:#0d6b5d}.btn-substep-submit.btn-submitting{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue);opacity:.8;cursor:wait}.btn-substep-submit.btn-submitted{display:inline-flex;align-items:center;gap:4px;opacity:1}@keyframes pulse-button{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.btn-dev-reset{background:transparent;color:var(--text-muted);border:1px dashed var(--border-light);border-radius:var(--radius-sm);padding:6px 10px;font-size:12px;cursor:pointer;transition:all var(--transition-fast);margin-left:8px}.btn-dev-reset:hover{background:#fff3cd;border-color:#ffc107;color:#856404}body[data-role=student] .btn-dev-reset{display:none!important}.substep-actions{display:flex;align-items:center;gap:8px;margin-top:12px}.substep-status.status-submitted{background:#e8f5e9;color:var(--text-muted);font-weight:500;padding:2px 8px;border-radius:var(--radius-sm)}.substep-feedback{display:none!important}.feedback-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:6px}.ai-badge{background:transparent;color:var(--text-muted);font-size:11px;font-weight:500;padding:0}.level-badge{display:flex;align-items:center;gap:4px;margin-left:auto}.level-value{font-size:11px;font-weight:500;color:var(--text-dark)}.level-text{font-size:11px;color:var(--text-muted)}.feedback-content{font-size:14px;color:var(--text-dark);line-height:1.6;margin-bottom:6px}.btn-more-chat{background:transparent;border:none;color:var(--text-muted);font-size:12px;font-weight:400;cursor:pointer;padding:0}.btn-more-chat:hover{color:var(--text-dark)}.substep-feedback.evaluation-delivered{display:block!important;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #86efac;border-radius:12px;padding:16px;margin-top:var(--spacing-md)}.eval-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.eval-level-badge{padding:3px 8px;border-radius:10px;font-weight:600;font-size:12px}.eval-level-badge.level-0{background:#fee2e2;color:#dc2626}.eval-level-badge.level-1{background:#fef3c7;color:#d97706}.eval-level-badge.level-2{background:#dbeafe;color:#2563eb}.eval-level-badge.level-3{background:#dcfce7;color:#16a34a}.eval-header .eval-xp{font-size:12px;color:#7c3aed;font-weight:600}.eval-comment{font-size:13px;color:var(--text-secondary);line-height:1.5}.eval-comment p{margin:0}.eval-xp .xp-divider,.eval-xp .xp-max{color:var(--text-muted)}.eval-xp-dual{display:flex;flex-direction:column;gap:4px;margin-left:12px;font-size:13px}.eval-xp-dual .xp-breakdown{display:flex;gap:6px;color:var(--text-muted)}.eval-xp-dual .xp-breakdown .xp-label{font-weight:500;min-width:60px}.eval-xp-dual .xp-breakdown .xp-value{font-weight:600;color:var(--text-secondary)}.eval-xp-dual .xp-total{display:flex;align-items:baseline;gap:4px;margin-top:4px;padding-top:4px;border-top:1px solid var(--border-color)}.eval-xp-dual .xp-total .xp-earned{font-weight:700;color:#7c3aed;font-size:16px}.eval-xp-dual .xp-total .xp-divider,.eval-xp-dual .xp-total .xp-max{color:var(--text-muted)}.instructor-comment{background:#fff;border-radius:8px;padding:12px;margin-top:12px}.instructor-comment .comment-label{font-size:12px;font-weight:600;color:#7c3aed;display:block;margin-bottom:6px}.instructor-comment p{margin:0;font-size:14px;color:var(--text-dark);line-height:1.6}.ai-feedback-summary{margin-top:12px;padding-top:12px;border-top:1px dashed #d1d5db}.ai-feedback-summary .feedback-label{font-size:12px;font-weight:500;color:var(--text-muted);display:block;margin-bottom:6px}.ai-feedback-summary p{margin:0;font-size:13px;color:var(--text-muted);line-height:1.5}.field-group{margin-bottom:var(--spacing-lg)}.field-label{display:block;font-size:13px;font-weight:500;color:var(--text-muted);margin-bottom:var(--spacing-xs)}.field-question{font-size:15px;color:var(--text-dark);margin:0 0 var(--spacing-sm) 0;line-height:1.5}.field-input{width:100%;padding:var(--spacing-sm) 0;border:none;border-bottom:1px solid #d1d5db;border-radius:0;font-size:15px;font-family:inherit;background:transparent;transition:border-color var(--transition-fast)}.field-input:focus{outline:none;border-bottom-color:var(--text-dark);box-shadow:none}.field-input::placeholder{color:#9ca3af}.field-input.inline{width:auto;flex:1}.field-input.small{max-width:80px}.field-textarea{width:100%;padding:4px 0;border:none;border-radius:0;font-size:15px;font-family:inherit;background:transparent;background-image:repeating-linear-gradient(to bottom,transparent 0px,transparent 31px,#d1d5db 31px,#d1d5db 32px);background-position:0 4px;resize:none;min-height:96px;line-height:32px;overflow:hidden;overflow-wrap:break-word;word-wrap:break-word;white-space:pre-wrap;box-sizing:border-box}.field-textarea.textarea-1line{min-height:40px}.field-textarea.textarea-2line{min-height:72px}.field-textarea.textarea-3line{min-height:104px}.field-textarea.textarea-4line{min-height:136px}.field-textarea.textarea-5line{min-height:168px}.field-textarea:focus{outline:none;background-image:repeating-linear-gradient(to bottom,transparent 0px,transparent 31px,var(--text-dark) 31px,var(--text-dark) 32px)}.field-row{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.field-textarea-sm,textarea.field-textarea-sm,.field-input.field-textarea-sm{width:100%;border:none;border-radius:0;font-size:15px;font-family:inherit;background:transparent;background-image:repeating-linear-gradient(to bottom,transparent 0px,transparent 31px,#d1d5db 31px,#d1d5db 32px);background-position:0 0;line-height:32px;padding:0;min-height:32px;resize:none!important;overflow:hidden;box-sizing:border-box}.field-textarea-sm:focus,textarea.field-textarea-sm:focus,.field-input.field-textarea-sm:focus{outline:none;background-image:repeating-linear-gradient(to bottom,transparent 0px,transparent 31px,var(--text-dark) 31px,var(--text-dark) 32px)}.candidate-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-md)}.evaluation-table-wrapper{overflow-x:auto;margin-bottom:var(--spacing-lg)}.evaluation-table{width:100%;border-collapse:collapse;font-size:14px}.evaluation-table th,.evaluation-table td{padding:var(--spacing-md);text-align:center;border-bottom:1px solid var(--border-light)}.evaluation-table th{background:transparent;font-weight:500;color:var(--text-muted);border-bottom:1px solid var(--border-light)}.criterion-cell{text-align:left!important;font-weight:500;background:transparent;color:var(--text-dark)}.score-bar{display:inline-flex;gap:0;border-radius:6px;overflow:hidden;border:1px solid var(--border-light)}.score-btn{width:28px;height:28px;border:none;border-right:1px solid var(--border-light);background:transparent;color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;padding:0;line-height:28px}.score-btn:last-child{border-right:none}.score-btn:hover{background:var(--bg-elevated);color:var(--text-dark)}.score-btn.selected{background:#e5e7eb;color:#374151}[data-mode=readonly] .score-btn{pointer-events:none}.total-row{background:transparent;border-top:2px solid var(--border-light)}.score-total{font-weight:600;color:var(--text-dark)}.persona-card{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-md);overflow:hidden}.persona-header{display:flex;gap:var(--spacing-lg);padding:var(--spacing-lg);background:#f9fafb;border-bottom:1px solid var(--border-light)}.persona-avatar-placeholder{width:64px;height:64px;background:#e5e7eb;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#6b7280}.persona-avatar-placeholder svg{width:32px;height:32px}.persona-basic-info{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm)}.persona-basic-info .field-input{background:#fff;border:1px solid #e5e7eb;border-radius:4px;padding:var(--spacing-sm) var(--spacing-md)}.persona-body{padding:var(--spacing-lg)}.persona-goals-pains{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.goals-section .field-input,.pains-section .field-input{margin-bottom:var(--spacing-sm)}.pain-label{color:var(--text-dark)}.pain-input{border-left:2px solid #9ca3af;padding-left:var(--spacing-sm)}.persona-footer{padding:var(--spacing-lg);background:#f9fafb;display:flex;justify-content:flex-end}.empathy-map{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.empathy-quadrant{border-radius:var(--radius-md);padding:var(--spacing-lg);border:1px solid var(--border-light);background:var(--bg-white)}.empathy-quadrant.thinks,.empathy-quadrant.says,.empathy-quadrant.does,.empathy-quadrant.feels{background:#fafafa;border-left:3px solid #9ca3af}.quadrant-label{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.quadrant-emoji{font-size:18px}.quadrant-title{font-size:14px;font-weight:600;color:var(--text-dark)}.quadrant-hint{font-size:11px;color:var(--text-muted)}.quadrant-inputs{display:flex;flex-direction:column;gap:var(--spacing-sm)}.empathy-input{width:100%;padding:6px 0;border:none;border-bottom:1px solid #d1d5db;border-radius:0;font-size:14px;font-family:inherit;background:transparent;resize:none;overflow:hidden;overflow-wrap:break-word;word-wrap:break-word;white-space:pre-wrap;min-height:24px;line-height:24px;box-sizing:border-box}.empathy-input:focus{outline:none;background:transparent;border-bottom-color:var(--text-dark)}.validation-plan{display:flex;flex-direction:column;gap:var(--spacing-lg)}.plan-section .field-input{margin-bottom:var(--spacing-sm)}.step-submit-area{display:flex;justify-content:flex-end;padding-top:var(--spacing-md);border-top:none;margin-top:var(--spacing-md);opacity:1!important;visibility:visible!important;position:relative;z-index:10}.btn-step-submit{background:var(--text-dark);color:#fff;border:none;border-radius:var(--radius-sm);padding:8px 16px;font-size:13px;font-weight:500;cursor:pointer;transition:background var(--transition-fast)}.btn-step-submit:hover:not(:disabled){background:#555}.btn-step-submit:disabled{opacity:.4;cursor:not-allowed}.right-panel{grid-area:aipanel;background:var(--bg-white);border-left:1px solid var(--border-light);display:flex;flex-direction:column;overflow:hidden}.app-layout.ai-expanded{grid-template-columns:0px 1fr var(--right-panel-expanded-width, 50vw)}.app-layout.ai-expanded .left-panel{overflow:hidden;opacity:0;pointer-events:none;padding:0;border:none;transition:opacity .25s ease}.app-layout.ai-expanded .right-panel.expanded{position:static;top:auto;right:auto;width:auto;height:auto;z-index:auto;box-shadow:none}.app-layout.ai-expanded .ai-messages{max-width:800px;margin:0 auto}.app-layout.ai-expanded .ai-input-area{max-width:800px;width:100%;margin:0 auto;padding:16px 24px;box-sizing:border-box}.app-layout.ai-expanded .ai-quick-actions{max-width:800px;margin:0 auto;justify-content:center}.resize-divider{position:fixed;top:var(--header-height);width:4px;height:calc(100vh - var(--header-height));cursor:col-resize;z-index:110;background:transparent}.resize-divider:hover,.resize-divider:active{background:var(--accent-primary)}.right-panel.expanded{position:fixed;right:0;top:var(--header-height);width:calc(100% - var(--left-panel-width));height:calc(100vh - var(--header-height));z-index:100;box-shadow:var(--shadow-lg)}.right-panel.expanded .ai-messages{max-width:800px;margin:0 auto}.right-panel.expanded .message-content{max-width:600px}.right-panel.expanded .ai-input-area{max-width:800px;width:100%;margin:0 auto;padding:16px 24px;box-sizing:border-box}.right-panel.expanded .ai-input{flex:1;width:100%}.right-panel.expanded .ai-quick-actions{max-width:800px;margin:0 auto;justify-content:center}.ai-panel-controls{display:flex;gap:2px}.btn-ai-control{background:transparent;border:none;padding:4px;cursor:pointer;color:var(--text-muted);border-radius:var(--radius-sm);transition:background var(--transition-fast)}.btn-ai-control:hover{background:var(--bg-elevated);color:var(--text-dark)}.btn-ai-control svg{width:14px;height:14px}.ai-panel-header{display:flex;justify-content:space-between;align-items:center;padding:13px var(--spacing-md);border-bottom:1px solid var(--border-light);min-height:50px;box-sizing:border-box}.ai-title{display:flex;align-items:center;gap:var(--spacing-sm)}.ai-avatar{width:24px;height:24px;background:transparent;display:flex;align-items:center;justify-content:center;font-size:20px;line-height:1}.message-avatar{width:24px;height:24px;background:transparent;display:flex;align-items:center;justify-content:center;font-size:20px;line-height:1;flex-shrink:0}.ai-name{font-size:14px;font-weight:500;color:var(--text-dark)}.btn-collapse-ai{background:transparent;border:none;padding:4px;cursor:pointer;color:var(--text-muted);border-radius:var(--radius-sm)}.btn-collapse-ai:hover{background:var(--bg-elevated)}.btn-collapse-ai svg{width:16px;height:16px}.ai-context-banner{display:flex;align-items:center;gap:var(--spacing-sm);padding:6px var(--spacing-md);background:var(--bg-elevated);font-size:12px;border-bottom:1px solid var(--border-light)}.context-step{font-weight:500;color:var(--text-dark)}.context-step.learning-mode{background:linear-gradient(135deg,#7c3aed,#6366f1);color:#fff;padding:2px 8px;border-radius:var(--radius-sm)}.context-title{color:var(--text-muted)}.ai-message.learning-intro{background:transparent;border:none;border-radius:0;margin-bottom:var(--spacing-md)}.ai-message.learning-intro .message-avatar{background:#10a37f;color:#fff}.learning-quick-actions{margin-top:var(--spacing-md);display:flex;gap:var(--spacing-sm)}.btn-learning-start{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;background:linear-gradient(135deg,#7c3aed,#6366f1);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 2px 8px #7c3aed4d}.btn-learning-start:hover{transform:translateY(-2px);box-shadow:0 4px 16px #7c3aed66}.btn-learning-start:active{transform:translateY(0)}.ai-messages{flex:1;overflow-y:auto;padding:var(--spacing-lg);scrollbar-width:none;-ms-overflow-style:none}.ai-messages::-webkit-scrollbar{display:none}.ai-message{display:flex;gap:12px;margin-bottom:var(--spacing-xl);max-width:100%;padding-right:var(--spacing-sm)}.ai-message .message-avatar{width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;border-radius:4px;margin-top:2px}.ai-message.assistant .message-avatar{background:#10a37f;color:#fff;font-size:14px}.ai-message.user .message-avatar{background:var(--accent-primary);border-radius:4px;color:#fff;font-size:12px;font-weight:600}.message-content{background:transparent;border-radius:0;padding:0;font-size:15px;line-height:1.7;max-width:calc(100% - 40px);min-width:0;color:var(--text-primary)}.ai-message.assistant .message-content{background:transparent;color:var(--text-primary)}.message-content p{margin-bottom:12px}.message-content p:last-child{margin-bottom:0}.message-hint{font-size:13px;color:var(--text-muted);margin-top:8px}.message-content .turn-info{font-size:12px;color:var(--text-muted);margin-bottom:4px;padding-bottom:4px;border-bottom:1px solid var(--border-light)}.ai-message.user{flex-direction:row-reverse}.ai-message.user .message-content{background:#f7f7f8;color:var(--text-primary);padding:10px 14px;border-radius:18px 18px 4px}.ai-message.resource-info .message-content{background:transparent;border-left:none}.ai-message.resource-info .resource-detail h4{font-size:15px;font-weight:600;margin-bottom:var(--spacing-sm);color:var(--text-dark)}.ai-message.resource-info .definition{font-size:13px;line-height:1.6;margin-bottom:var(--spacing-md)}.ai-message.resource-info .key-points h5{font-size:12px;font-weight:600;margin-bottom:var(--spacing-xs);color:var(--text-muted)}.ai-message.resource-info .key-points ul{margin:0;padding-left:20px}.ai-message.resource-info .key-points li{font-size:13px;margin-bottom:4px}.typing-indicator{display:flex;align-items:center;gap:4px;padding:4px 0}.typing-indicator span{width:5px;height:5px;background:var(--text-muted);border-radius:50%;animation:typing 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}.streaming-text .cursor{display:inline;animation:blink 1s infinite;color:var(--accent-primary);font-weight:400}.related-resources{display:flex;flex-wrap:wrap;gap:6px;margin-top:var(--spacing-sm)}.resource-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:var(--bg-elevated);border:none;border-radius:var(--radius-sm);font-size:11px;cursor:pointer;color:var(--text-muted);transition:background var(--transition-fast)}.resource-tag:hover{background:var(--border-light);color:var(--text-dark)}.resource-tag.concept{border-left:2px solid var(--accent-warning)}.resource-tag.case{border-left:2px solid var(--accent-success)}.resource-tag.misconception{border-left:2px solid var(--accent-error)}.resources-section{margin-top:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-sm)}.resources-group{display:flex;flex-direction:column;gap:6px}.resources-label{font-size:11px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.resources-buttons{display:flex;flex-wrap:wrap;gap:6px}.resources-group.learning .resources-label{color:var(--accent-ai)}.resources-group.misconceptions .resources-label{color:var(--accent-error)}.ai-quick-actions{display:flex;gap:6px;padding:8px var(--spacing-md);border-top:1px solid var(--border-light);flex-wrap:wrap}.quick-action-btn{padding:4px 10px;background:transparent;border:1px solid var(--border-light);border-radius:var(--radius-sm);font-size:12px;cursor:pointer;color:var(--text-muted);transition:all var(--transition-fast)}.quick-action-btn:hover{background:var(--bg-elevated);color:var(--text-dark)}.ai-input-area{display:flex;align-items:flex-end;gap:var(--spacing-sm);padding:12px var(--spacing-md);border-top:1px solid var(--border-light);background:var(--bg-white)}.ai-input{flex:1;padding:12px 16px;border:1px solid var(--border-light);border-radius:24px;font-size:15px;font-family:inherit;background:var(--bg-elevated);resize:none;height:48px;min-height:48px;max-height:200px;line-height:1.5;overflow-y:hidden;transition:height .15s ease;box-sizing:border-box}.ai-input:focus{outline:none;border-color:var(--accent-primary, #2383e2);box-shadow:0 0 0 3px #2383e226;background:var(--bg-white)}.btn-send-ai{background:var(--text-dark);color:#fff;border:none;border-radius:50%;width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--transition-fast),transform .1s ease;flex-shrink:0}.btn-send-ai:hover{background:#555;transform:scale(1.05)}.btn-send-ai:active{transform:scale(.95)}.btn-send-ai svg{width:18px;height:18px}.chat-table{width:100%;border-collapse:collapse;margin:12px 0;font-size:14px;background:var(--bg-white);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-light)}.chat-table th,.chat-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border-light)}.chat-table th{background:var(--bg-elevated);font-weight:600;color:var(--text-dark)}.chat-table tr:last-child td{border-bottom:none}.chat-table tr:hover td{background:var(--bg-hover)}.chat-h2,.chat-h3,.chat-h4{margin:16px 0 8px;font-weight:600;color:var(--text-dark);line-height:1.3}.chat-h2{font-size:18px;border-bottom:1px solid var(--border-light);padding-bottom:6px}.chat-h3{font-size:16px}.chat-h4{font-size:15px;color:var(--text-muted)}.loading-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.loading-spinner{background:var(--bg-white);border-radius:var(--radius-lg);padding:var(--spacing-xl);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);box-shadow:var(--shadow-lg)}.spinner{width:40px;height:40px;border:3px solid var(--border-light);border-top-color:var(--accent-ai);border-radius:50%;animation:spin 1s linear infinite}.inline-loading{display:flex;align-items:center;gap:12px;padding:16px 0}.loading-icon-bounce{animation:bounce 1s ease-in-out infinite}.loading-icon-spin{animation:wobble .8s ease-in-out infinite;display:inline-block}@keyframes wobble{0%,to{transform:translate(0)}25%{transform:translate(-3px)}75%{transform:translate(3px)}}.chuckchuck-icon{font-size:28px;display:inline-block}.loading-text{color:var(--text-muted);font-size:14px}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.streaming-feedback .cursor{animation:blink .7s step-end infinite;color:var(--accent-ai)}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.mobile-header{display:none}.mobile-backdrop{position:fixed;inset:0;background:#0006;z-index:250}.mobile-hamburger{background:none;border:none;cursor:pointer;padding:4px;color:var(--text-dark);display:flex;align-items:center;justify-content:center}.mobile-header-title{font-weight:600;font-size:16px;color:var(--text-dark);display:flex;align-items:center;gap:8px}.mobile-logo-img{width:28px;height:28px;object-fit:contain;border-radius:6px}.mobile-sidebar-close{display:none}@media(max-width:1200px){.app-layout,.app-layout.ai-collapsed{grid-template-columns:var(--left-panel-width) 1fr;grid-template-areas:"sidebar content"}.right-panel{position:fixed;right:0;top:var(--header-height);width:var(--right-panel-width);height:calc(100vh - var(--header-height));z-index:100;box-shadow:var(--shadow-lg);transform:translate(100%);transition:transform var(--transition-normal)}.right-panel.open{transform:translate(0)}.app-layout.ai-expanded{grid-template-columns:0px 1fr var(--right-panel-expanded-width, 50vw)}.app-layout.ai-expanded .right-panel{position:static;transform:none;width:auto;height:auto;box-shadow:none}}@media(max-width:768px){.header{padding:0 12px}.header-left{gap:8px}.header .mobile-hamburger-inline{display:flex}.header .user-email-display{display:none}.header-title{font-size:12px}.mobile-header{display:none!important}.app-layout,.app-layout.ai-collapsed{grid-template-columns:1fr;grid-template-rows:1fr;grid-template-areas:"content"}.app-layout.ai-expanded{grid-template-columns:0px 0px 1fr}.app-layout.ai-expanded .resize-divider{display:none}.left-panel{position:fixed;left:0;top:0;width:var(--left-panel-width);height:100vh;z-index:300;transform:translate(-100%);transition:transform var(--transition-normal)}.left-panel.open{transform:translate(0)}.right-panel{position:fixed;right:0;top:var(--header-height);width:100%;max-width:var(--right-panel-width);height:calc(100vh - var(--header-height));z-index:200;box-shadow:var(--shadow-lg);transform:translate(100%);transition:transform var(--transition-normal)}.right-panel.open{transform:translate(0)}.mobile-sidebar-close{display:flex;position:absolute;top:16px;right:12px;background:none;border:none;cursor:pointer;padding:4px;color:var(--text-muted);z-index:1}.mobile-sidebar-close:hover{color:var(--text-dark)}.empathy-map,.persona-goals-pains{grid-template-columns:1fr}}.user-level{font-size:12px;font-weight:500;color:var(--text-muted);display:block;margin-bottom:2px}.user-currency{display:flex;align-items:center;gap:4px}.user-xp{font-size:11px;color:var(--accent-primary);font-weight:600}.currency-divider{color:var(--text-muted);font-size:8px}.user-gold{font-size:11px;color:#f5a623;font-weight:600}.user-badges-bar{display:flex;align-items:center;gap:6px;padding:6px 16px 6px 20px;border-bottom:1px solid var(--border-light);text-decoration:none;cursor:pointer;transition:background var(--transition-fast)}.user-badges-bar:hover{background:var(--bg-sidebar-hover)}.user-badges-bar .badge-icon{font-size:15px;transition:transform var(--transition-fast)}.user-badges-bar .badge-icon:hover{transform:scale(1.15)}.user-badges-bar .badge-more{font-size:10px;color:var(--text-muted);background:var(--bg-elevated);padding:1px 5px;border-radius:8px;font-weight:500}.user-badges-bar .no-badges{font-size:11px;color:var(--text-muted);font-style:italic}.badges-view-all{margin-left:auto;font-size:10px;color:var(--text-muted);white-space:nowrap;transition:color var(--transition-fast)}.user-badges-bar:hover .badges-view-all{color:var(--text-dark)}.badge-bronze{color:#cd7f32}.badge-silver{color:silver}.badge-gold{color:gold}.badge-diamond{color:#b9f2ff}.level-progress{width:100%;height:4px;background:var(--bg-elevated);border-radius:2px;margin-top:8px;overflow:hidden}.level-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-success));transition:width var(--transition-normal);border-radius:2px}.notification-dropdown{position:fixed;top:60px;right:20px;width:320px;max-height:400px;background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:9999;display:none;overflow:hidden}.notification-dropdown.open{display:block}.notification-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border-light)}.notification-header h4{font-size:14px;font-weight:600;color:var(--text-dark);margin:0}.btn-read-all{font-size:12px;color:var(--accent-primary);background:none;border:none;cursor:pointer}.btn-read-all:hover{text-decoration:underline}.notification-list{max-height:320px;overflow-y:auto}.notification-item{display:flex;flex-direction:column;border-bottom:1px solid var(--border-light);transition:background var(--transition-fast);position:relative}.notification-item:hover{background:var(--bg-elevated)}.notification-item.unread{background:#2eaadc0d}.notification-item.expanded{background:var(--bg-elevated)}.notification-item[data-type=peer_review_request],.notification-item[data-type=feedback_received]{flex-direction:row;gap:12px;padding:12px 16px;cursor:pointer}.notification-header{display:flex;gap:12px;padding:12px 16px;cursor:pointer}.notification-detail{padding:0 16px 12px 48px;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.notification-detail-message{font-size:13px;color:var(--text-dark);margin-bottom:8px;line-height:1.5}.notification-detail-gold{font-size:16px;font-weight:600;color:var(--gold);margin-bottom:12px}.notification-detail-badge,.notification-detail-level{font-size:14px;font-weight:500;margin-bottom:12px}.btn-notification-dismiss{background:var(--accent-primary);color:#fff;border:none;padding:6px 16px;border-radius:4px;font-size:12px;cursor:pointer;transition:background .2s}.btn-notification-dismiss:hover{background:var(--accent-primary-hover)}.notification-item.unread:before{content:"";position:absolute;left:8px;top:20px;width:6px;height:6px;background:var(--accent-primary);border-radius:50%}.notification-icon{font-size:20px;flex-shrink:0}.notification-content{flex:1;min-width:0}.notification-title{font-size:13px;font-weight:500;color:var(--text-dark);margin-bottom:2px}.notification-message{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notification-time{font-size:11px;color:var(--text-placeholder);margin-top:4px}.notification-empty{padding:32px 16px;text-align:center;color:var(--text-muted);font-size:13px}.peer-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;opacity:0;visibility:hidden;transition:opacity var(--transition-normal),visibility var(--transition-normal)}.peer-modal-overlay.open{opacity:1;visibility:visible}.peer-modal{background:var(--bg-white);border-radius:var(--radius-lg);width:100%;max-width:520px;max-height:90vh;overflow:hidden;box-shadow:var(--shadow-lg);transform:translateY(20px);transition:transform var(--transition-normal)}.peer-modal-overlay.open .peer-modal{transform:translateY(0)}.peer-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-light)}.peer-modal-header h3{font-size:16px;font-weight:600;color:var(--text-dark);margin:0;display:flex;align-items:center;gap:8px}.btn-modal-close{background:none;border:none;padding:4px;cursor:pointer;color:var(--text-muted);border-radius:var(--radius-sm)}.btn-modal-close:hover{background:var(--bg-elevated);color:var(--text-dark)}.peer-modal-body{padding:20px;max-height:60vh;overflow-y:auto}.submission-preview{background:var(--bg-elevated);border-radius:var(--radius-md);padding:16px;margin-bottom:20px}.submission-preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.submission-author{display:flex;align-items:center;gap:8px}.author-avatar{width:28px;height:28px;background:var(--text-muted);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:500}.author-name{font-size:14px;font-weight:500;color:var(--text-dark)}.submission-task{font-size:12px;color:var(--text-muted)}.submission-content{font-size:14px;color:var(--text-dark);line-height:1.6;white-space:pre-wrap}.score-selection{margin-bottom:20px}.score-label{font-size:14px;font-weight:500;color:var(--text-dark);margin-bottom:12px}.score-options{display:flex;gap:8px}.score-option{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;background:var(--bg-elevated);border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.score-option:hover{background:var(--bg-white);border-color:var(--border-light)}.score-option.selected{background:var(--bg-white);border-color:var(--accent-primary)}.score-emoji{font-size:24px}.score-text{font-size:11px;color:var(--text-muted);text-align:center}.score-xp{font-size:10px;color:var(--accent-primary);font-weight:500}.score-gold{font-size:10px;color:#f5a623;font-weight:600}.feedback-input-group{margin-bottom:20px}.feedback-input-group label{display:block;font-size:14px;font-weight:500;color:var(--text-dark);margin-bottom:8px}.feedback-textarea{width:100%;min-height:100px;padding:12px;border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:14px;font-family:inherit;resize:vertical;transition:border-color var(--transition-fast)}.feedback-textarea:focus{outline:none;border-color:var(--text-muted)}.feedback-textarea::placeholder{color:var(--text-placeholder)}.peer-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 20px;border-top:1px solid var(--border-light)}.btn-modal-cancel{padding:8px 16px;background:transparent;border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:13px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.btn-modal-cancel:hover{background:var(--bg-elevated);color:var(--text-dark)}.btn-modal-submit{padding:8px 16px;background:var(--text-dark);border:none;border-radius:var(--radius-md);font-size:13px;color:#fff;cursor:pointer;transition:background var(--transition-fast)}.btn-modal-submit:hover:not(:disabled){background:#555}.btn-modal-submit:disabled{opacity:.4;cursor:not-allowed}.received-feedback{background:var(--bg-elevated);border-left:3px solid var(--accent-primary);border-radius:var(--radius-md);padding:16px;margin-bottom:20px}.feedback-stage{display:flex;align-items:center;gap:8px;margin-bottom:8px}.stage-emoji{font-size:20px}.stage-name{font-size:14px;font-weight:600;color:var(--text-dark)}.feedback-text{font-size:14px;color:var(--text-dark);line-height:1.6}.pending-evaluations-section{padding:12px 16px;border-bottom:1px solid var(--border-light)}.pending-label{font-size:11px;color:var(--text-muted);margin-bottom:8px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.pending-list{display:flex;flex-direction:column;gap:6px}.pending-item{display:flex;align-items:center;gap:8px;padding:8px;background:var(--bg-elevated);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.pending-item:hover{background:var(--bg-sidebar-hover)}.pending-item-icon{font-size:16px}.pending-item-text{flex:1;font-size:12px;color:var(--text-dark)}.pending-item-badge{font-size:10px;padding:2px 6px;background:var(--accent-primary);color:#fff;border-radius:var(--radius-sm)}.peer-review-prompt{display:none;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid var(--accent-primary);border-radius:var(--radius-md);padding:16px;margin-top:16px;text-align:center}.peer-review-prompt.show{display:block;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.peer-review-prompt p{font-size:14px;color:var(--text-dark);margin-bottom:12px}.btn-peer-review{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:13px;font-weight:500;cursor:pointer;transition:background var(--transition-fast)}.btn-peer-review:hover{background:var(--accent-primary-hover)}.evaluation-result{display:flex;flex-direction:column;align-items:center;padding:32px 20px;text-align:center}.result-emoji{font-size:48px;margin-bottom:16px}.result-title{font-size:18px;font-weight:600;color:var(--text-dark);margin-bottom:8px}.result-message{font-size:14px;color:var(--text-muted);margin-bottom:16px}.result-xp{font-size:20px;font-weight:600;color:var(--accent-primary)}.result-gold{font-size:20px;font-weight:600;color:#f5a623}.peer-review-banner{display:flex;justify-content:space-between;align-items:center;background:var(--text-dark);color:#fff;padding:12px 20px;border-radius:var(--radius-md);margin-bottom:20px}.peer-review-banner-content{display:flex;align-items:center;gap:10px}.peer-review-icon{font-size:24px}.peer-review-title{font-size:16px;font-weight:600}.btn-exit-review{background:#ffffff26;border:none;color:#fff;padding:8px 16px;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;transition:background .2s}.btn-exit-review:hover{background:#ffffff4d}.peer-worksheet-content{background:var(--bg-white);border:none;border-radius:var(--radius-lg);padding:24px;margin-bottom:24px}.peer-author-info{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border-light)}.author-avatar-lg{width:48px;height:48px;background:var(--text-dark);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:20px}.author-details{display:flex;flex-direction:column}.author-name-lg{font-size:18px;font-weight:600;color:var(--text-dark)}.author-subtitle{font-size:14px;color:var(--text-muted)}.peer-worksheet-fields{display:flex;flex-direction:column;gap:16px}.peer-field{background:var(--bg-elevated);border-radius:var(--radius-md);padding:16px}.peer-field-label{font-size:13px;font-weight:600;color:var(--text-muted);margin-bottom:8px}.peer-field-value{font-size:15px;color:var(--text-dark);line-height:1.6;white-space:pre-wrap}.empty-content{text-align:center;color:var(--text-muted);padding:40px;font-style:italic}.inline-evaluation-section{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:24px}.received-feedback-inline{background:var(--bg-elevated);border-left:3px solid var(--accent-primary);padding:16px 20px;margin-bottom:24px;border-radius:0 var(--radius-md) var(--radius-md) 0}.received-feedback-inline .feedback-stage{display:flex;align-items:center;gap:8px;margin-bottom:8px}.received-feedback-inline .stage-emoji{font-size:20px}.received-feedback-inline .stage-name{font-size:14px;font-weight:600;color:var(--text-dark)}.received-feedback-inline .feedback-text{font-size:14px;color:var(--text-muted);line-height:1.5}.gratitude-comment-section{background:var(--bg-elevated);border-radius:var(--radius-md);margin-top:20px;padding:16px}.gratitude-comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.gratitude-comment-label{font-size:13px;font-weight:500;color:var(--text-dark)}.btn-toggle-gratitude{background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:12px;padding:4px 8px;transition:color .15s}.btn-toggle-gratitude:hover{color:var(--text-dark)}.btn-close-comment{background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:14px;padding:4px}.gratitude-feedback-box{background:var(--bg-white);border-radius:var(--radius-sm);padding:12px;margin-bottom:12px}.feedback-badge{font-size:12px;color:var(--text-muted);margin-bottom:4px}.feedback-message{font-size:14px;color:var(--text-dark);margin:0;line-height:1.4}.gratitude-reply{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.reply-label{font-size:12px;color:var(--text-muted)}.gratitude-buttons{display:flex;gap:6px}.btn-gratitude-option{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:6px 10px;font-size:12px;cursor:pointer;transition:all .15s}.btn-gratitude-option:hover{border-color:var(--accent-primary)}.btn-gratitude-option.selected{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.btn-send-gratitude{background:var(--text-dark);color:#fff;border:none;border-radius:var(--radius-sm);padding:6px 14px;font-size:12px;cursor:pointer;margin-left:auto}.btn-send-gratitude:disabled{background:var(--border-light);color:var(--text-muted);cursor:not-allowed}.btn-send-gratitude:not(:disabled):hover{background:#555}.gratitude-success-simple{display:flex;justify-content:space-between;align-items:center;padding:12px;background:var(--accent-success-light);border-radius:var(--radius-sm)}.gratitude-success-simple span{font-size:13px;color:var(--accent-success);font-weight:500}.btn-close-success{background:var(--accent-success);color:#fff;border:none;border-radius:var(--radius-sm);padding:4px 12px;font-size:12px;cursor:pointer}.gratitude-sent-badge{font-size:12px;color:var(--accent-success);font-weight:500;padding:8px 12px;background:var(--accent-success-light);border-radius:var(--radius-sm)}.gratitude-pending-badge{font-size:10px;color:#fff;background:var(--accent-warning);padding:2px 6px;border-radius:3px;margin-left:6px}.gratitude-completed-info{padding-top:8px}.gratitude-comment-section.completed{opacity:.85}.gratitude-comment-section.completed .gratitude-comment-label{color:var(--text-muted)}.investment-sent-badge{font-size:14px;color:var(--accent-success);font-weight:600;padding:16px 20px;background:var(--accent-success-light);border-radius:var(--radius-md);text-align:center}.evaluation-title{font-size:18px;font-weight:600;color:var(--text-dark);margin-bottom:20px;text-align:center}.investment-options{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}.investment-option{display:flex;flex-direction:column;align-items:center;padding:16px 12px;background:var(--bg-elevated);border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all .2s}.investment-option:hover{border-color:var(--accent-primary);transform:translateY(-2px)}.investment-option.selected{border-color:var(--accent-primary);background:#667eea1a}.option-emoji{font-size:32px;margin-bottom:8px}.option-name{font-size:14px;font-weight:600;color:var(--text-dark);margin-bottom:4px}.option-desc{font-size:11px;color:var(--text-muted);text-align:center}.option-gold{font-size:12px;color:#f5a623;font-weight:600;text-align:center}.feedback-input-section{margin-bottom:20px}.feedback-label{display:block;font-size:14px;font-weight:500;color:var(--text-dark);margin-bottom:8px}.feedback-textarea-inline{width:100%;min-height:100px;padding:12px;border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:14px;resize:vertical;font-family:inherit}.feedback-textarea-inline:focus{outline:none;border-color:var(--accent-primary)}.evaluation-actions{display:flex;justify-content:flex-end;gap:12px}.btn-cancel-review{padding:12px 24px;background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:14px;cursor:pointer;transition:all .2s}.btn-cancel-review:hover{background:var(--bg-sidebar-hover)}.btn-submit-review{padding:12px 24px;background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-submit-review:hover:not(:disabled){background:var(--accent-primary-hover)}.btn-submit-review:disabled{opacity:.5;cursor:not-allowed}.evaluation-success{text-align:center;padding:40px}.success-emoji{font-size:64px;margin-bottom:16px}.success-title{font-size:24px;font-weight:600;color:var(--text-dark);margin-bottom:8px}.success-message{font-size:14px;color:var(--text-muted);margin-bottom:16px}.success-xp{font-size:20px;font-weight:600;color:var(--accent-primary)}.success-gold{font-size:20px;font-weight:600;color:#f5a623;margin-bottom:20px}.btn-confirm-success{padding:10px 32px;background:var(--text-dark);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:background var(--transition-fast)}.btn-confirm-success:hover{background:#555}.step-section.peer-review-mode{border:1px solid var(--border-light);box-shadow:none}@media(max-width:768px){.investment-options{grid-template-columns:repeat(2,1fr)}.peer-review-banner{flex-direction:column;gap:12px;text-align:center}}.peer-readonly{background-color:var(--bg-elevated)!important;border-color:var(--border-light)!important;color:var(--text-dark)!important;cursor:default!important}.peer-readonly:focus{outline:none!important;box-shadow:none!important}.badge-modal-overlay{position:fixed;inset:0;background:#0f0f0f99;display:flex;align-items:center;justify-content:center;z-index:2000;opacity:0;visibility:hidden;transition:opacity .15s ease,visibility .15s ease}.badge-modal-overlay.open{opacity:1;visibility:visible}.badge-modal{background:var(--bg-white);border-radius:var(--radius-lg);width:100%;max-width:480px;max-height:80vh;overflow:hidden;box-shadow:#0f0f0f0d 0 0 0 1px,#0f0f0f1a 0 5px 10px,#0f0f0f33 0 15px 40px;transform:translateY(10px);transition:transform .15s ease}.badge-modal-overlay.open .badge-modal{transform:translateY(0)}.badge-modal-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--border-light)}.badge-modal-header h2{font-size:14px;font-weight:600;color:var(--text-dark);margin:0}.btn-close-modal{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-muted);font-size:18px;cursor:pointer;transition:background .1s ease}.btn-close-modal:hover{background:var(--bg-elevated);color:var(--text-dark)}.badge-modal-content{padding:16px;max-height:calc(80vh - 56px);overflow-y:auto}.badges-view-more{font-size:10px;color:var(--text-muted);cursor:pointer;white-space:nowrap}.user-badges-section:hover .badges-view-more{color:var(--text-dark)}.badge-grid{display:flex;flex-direction:column;gap:8px}.badge-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--bg-white);border-radius:var(--radius-md);transition:background .1s ease}.badge-item:hover{background:var(--bg-elevated)}.badge-item.not-earned{opacity:.5}.badge-item-icon{font-size:28px;flex-shrink:0}.badge-item-info{flex:1;min-width:0}.badge-item-name{font-size:13px;font-weight:500;color:var(--text-dark);margin-bottom:2px}.badge-item-desc{font-size:11px;color:var(--text-muted);line-height:1.4}.badge-item-progress{flex-shrink:0;text-align:right}.badge-tier-display{font-size:11px;color:var(--text-muted);margin-bottom:2px}.badge-progress-bar{width:60px;height:3px;background:var(--bg-elevated);border-radius:2px;overflow:hidden}.badge-progress-fill{height:100%;background:var(--text-muted);border-radius:2px;transition:width .2s ease}.badge-item:not(.not-earned) .badge-progress-fill{background:var(--accent-primary)}.tier-indicator{font-size:10px;letter-spacing:1px}.badge-empty{text-align:center;padding:32px 16px;color:var(--text-muted);font-size:13px}.badge-page{flex:1;flex-direction:column;overflow-y:auto;padding:var(--spacing-lg);background:var(--bg-white)}.myactivity-content{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:32px}.activity-section{display:flex;flex-direction:column;gap:14px}.activity-section-title{font-size:20px;font-weight:700;color:var(--text-primary);margin:0}.activity-section-title-row{display:flex;align-items:center;justify-content:space-between}.activity-stats-grid{display:grid;grid-template-columns:7fr 3fr;gap:20px}.activity-stats-col{display:flex;flex-direction:column;gap:10px}.myactivity-card{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:16px 20px}.activity-level-card{display:flex;align-items:center;gap:0}.level-left{flex:1;min-width:0;padding-right:20px;border-right:1px solid var(--border-light)}.level-right{display:flex;gap:20px;padding-left:20px;flex-shrink:0}.level-display{display:flex;align-items:center;gap:8px;margin-bottom:8px}.level-icon-large{font-size:24px;line-height:1;flex-shrink:0}.level-name{font-size:14px;font-weight:700;color:var(--text-primary)}.level-xp-row{display:flex;align-items:center;gap:8px}.level-xp-progress{flex:1;height:5px;background:var(--bg-elevated);border-radius:3px;overflow:hidden}.level-xp-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--accent-primary),#a78bfa);transition:width .4s ease}.level-xp-text{font-size:11px;color:var(--text-muted);white-space:nowrap;font-weight:500}.level-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.level-stat-value{font-size:20px;font-weight:700;color:var(--text-primary)}.level-stat-label{font-size:11px;color:var(--text-muted)}.activity-gold-card{display:flex;flex-direction:column;justify-content:center}.gold-display{display:flex;align-items:center;justify-content:center;gap:8px;padding:4px 0}.gold-sparkle-icon{color:#f59e0b}.gold-amount{font-size:28px;font-weight:800;background:linear-gradient(135deg,#f59e0b,#d97706);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.gold-unit{font-size:14px;font-weight:600;color:var(--text-muted);align-self:flex-end;padding-bottom:6px}.gold-desc{font-size:12px;color:var(--text-muted);text-align:center;margin:0}.user-quick-info-arrow{font-size:12px;color:var(--text-muted);transition:transform .2s ease}.user-quick-info:hover .user-quick-info-arrow{transform:translate(2px)}.badge-content{max-width:1200px;margin:0 auto}.badge-progress-summary{font-size:13px;font-weight:500;color:var(--text-muted);padding:4px 10px;background:var(--bg-elevated);border-radius:var(--radius-sm)}.badge-page-inner{max-width:800px;margin:0 auto;padding-bottom:48px}.badge-page-header{margin-bottom:32px}.btn-back-to-worksheet{display:inline-flex;align-items:center;gap:4px;padding:8px 12px;background:transparent;border:none;border-radius:var(--radius-sm);font-size:13px;color:var(--text-muted);cursor:pointer;transition:all .15s ease}.btn-back-to-worksheet:hover{background:var(--bg-elevated);color:var(--text-dark)}.badge-page-hero{text-align:center;margin-bottom:40px}.badge-page-title{font-size:28px;font-weight:700;color:var(--text-dark);margin:0 0 12px;line-height:1.3}.badge-page-gold{font-size:14px;font-weight:600;background:linear-gradient(135deg,#f59e0b,#d97706);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;padding:4px 10px;border:1px solid rgba(245,166,35,.3);border-radius:var(--radius-sm)}.badge-page-subtitle{font-size:15px;color:var(--text-muted);margin:0}.badge-category-tabs{display:flex;justify-content:center;gap:8px;margin-bottom:32px;flex-wrap:wrap}.badge-category-tab{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;background:var(--bg-white);border:1px solid var(--border-light);border-radius:24px;font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all .2s ease}.badge-category-tab:hover{border-color:var(--accent-primary);color:var(--accent-primary);background:#7c3aed0a}.badge-category-tab.active{background:linear-gradient(135deg,#7c3aed,#8b5cf6);color:#fff;border-color:transparent;box-shadow:0 2px 8px #7c3aed4d}.badge-category-tab .tab-icon{font-size:14px;display:flex;align-items:center}.badge-category-tab .tab-count{font-size:11px;opacity:.7}.badge-cards-container{display:flex;flex-direction:column;gap:20px}.badge-type-group{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-lg);overflow:visible}.badge-type-header{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border-light);border-radius:var(--radius-lg) var(--radius-lg) 0 0;background:var(--bg-white)}.badge-type-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:18px;background:#7c3aed14;border-radius:50%;flex-shrink:0}.badge-type-title{font-size:16px;font-weight:700;color:var(--text-dark)}.badge-type-desc{font-size:13px;color:var(--text-secondary, var(--text-muted));margin-left:auto;line-height:1.4}.badge-tier-list{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;padding:20px;overflow:visible}.badge-tier-card{display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px 14px;background:var(--bg-white);border:1px solid var(--border-light);border-radius:12px;transition:all .2s ease;text-align:center;position:relative}.badge-tier-card:hover{border-color:var(--accent-primary);transform:translateY(-3px);box-shadow:0 4px 12px #0000000f}.badge-tier-card.earned{background:linear-gradient(135deg,#34c7590a,#34c75914);border-color:#34c75966}.badge-tier-card.earned:hover{border-color:var(--accent-success);box-shadow:0 4px 12px #34c7591f}.badge-tier-card.active{background:linear-gradient(135deg,#7c3aed08,#7c3aed12);border-color:var(--border-light)}.badge-tier-card.active:hover{border-color:var(--accent-primary);box-shadow:0 4px 12px #7c3aed1f}.badge-tier-card.locked{opacity:.45;border-style:dashed}.badge-tier-card.locked:hover{transform:none;box-shadow:none;border-color:var(--border-light)}.badge-tooltip{display:none;position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);width:280px;padding:14px 16px;background:var(--bg-white);border:1px solid var(--border-light);border-radius:12px;box-shadow:0 8px 24px #0000001f;z-index:100;text-align:left;pointer-events:none}.badge-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--bg-white)}.badge-tooltip:before{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:7px solid transparent;border-top-color:var(--border-light)}.badge-tier-card:hover .badge-tooltip,.badge-tier-card.locked:hover .badge-tooltip{display:block}.badge-tooltip-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.badge-tooltip-name{font-size:14px;font-weight:600;color:var(--text-primary)}.badge-tooltip-status{font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px}.badge-tooltip-status.earned{background:#34c7591f;color:#22863a}.badge-tooltip-status.active{background:#7c3aed1a;color:var(--accent-primary)}.badge-tooltip-status.locked{background:var(--bg-elevated);color:var(--text-muted)}.badge-tooltip-tier{font-size:12px;color:var(--text-secondary);margin-bottom:10px}.badge-tooltip-divider{height:1px;background:var(--border-light);margin-bottom:10px}.badge-tooltip-row{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:6px}.badge-tooltip-row:last-child{margin-bottom:0}.badge-tooltip-label{font-size:11px;color:var(--text-muted);flex-shrink:0;white-space:nowrap}.badge-tooltip-value{font-size:12px;color:var(--text-primary);font-weight:500;text-align:right}.badge-card-icon{width:52px;height:52px;display:flex;align-items:center;justify-content:center;font-size:28px;background:var(--bg-elevated);border-radius:50%;flex-shrink:0;position:relative}.badge-tier-card.earned .badge-card-icon{background:#34c7591a;box-shadow:0 0 0 3px #34c75933}.badge-tier-card.active .badge-card-icon{background:#7c3aed14;box-shadow:0 0 0 3px #7c3aed26}.badge-tier-card.locked .badge-card-icon{filter:grayscale(.6)}.badge-card-info{width:100%}.badge-card-name{display:flex;align-items:center;justify-content:center;gap:5px;font-size:14px;font-weight:600;color:var(--text-dark);margin-bottom:4px}.badge-tier-medal{font-size:13px}.badge-card-condition{font-size:12px;color:var(--text-muted);margin-bottom:8px;line-height:1.5}.badge-earned-date{font-size:11px;color:var(--accent-success);font-weight:500;margin-bottom:4px}.badge-card-progress{display:flex;flex-direction:column;gap:5px;width:100%}.badge-progress-track{width:100%;height:6px;background:var(--bg-elevated);border-radius:3px;overflow:hidden}.badge-progress-fill-page{height:100%;background:var(--border-light);border-radius:3px;transition:width .5s cubic-bezier(.4,0,.2,1)}.badge-tier-card.active .badge-progress-fill-page{background:linear-gradient(90deg,#7c3aed,#a78bfa)}.badge-tier-card.earned .badge-progress-fill-page{background:linear-gradient(90deg,#22c55e,#4ade80)}.badge-progress-text{font-size:11px;color:var(--text-muted);text-align:center;font-weight:500}.badge-card-reward{margin-top:4px}.badge-reward-gold{font-size:11px;font-weight:600;color:#f5a623}.badge-earned-check{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--accent-success);color:#fff;font-size:12px;font-weight:700}@media(max-width:768px){.badge-tier-list{grid-template-columns:repeat(2,1fr)}.activity-stats-grid{grid-template-columns:1fr}.activity-level-card{flex-direction:column}.level-left{padding-right:0;border-right:none;border-bottom:1px solid var(--border-light);padding-bottom:12px;margin-bottom:12px}.level-right{padding-left:0}.gold-amount{font-size:24px}.myactivity-card{padding:16px}}@media(max-width:480px){.badge-page{padding:16px 12px 32px}.badge-page-title{font-size:20px}.badge-tier-list{grid-template-columns:repeat(2,1fr);gap:8px;padding:12px}.badge-tier-card{padding:12px 8px}.badge-card-icon{width:40px;height:40px;font-size:22px}.badge-card-name{font-size:12px}.badge-card-condition{font-size:10px}.badge-category-tabs{gap:4px}.badge-category-tab{padding:6px 10px;font-size:12px}}.content-tabs{display:flex!important;flex-direction:row!important;gap:4px;padding:8px 24px;background:var(--bg-main);border-bottom:1px solid var(--border-light);flex-shrink:0;z-index:10;width:100%;box-sizing:border-box}.content-tab{display:inline-flex!important;flex-direction:row!important;align-items:center;justify-content:center;gap:6px;padding:8px 16px;background:transparent;border:none;border-radius:var(--radius-md);font-family:var(--font-family);font-size:14px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;flex-shrink:0;writing-mode:horizontal-tb;text-orientation:mixed}.content-tab:hover,.content-tab.active{background:var(--bg-elevated);color:var(--text-dark)}.content-tab .tab-icon{font-size:16px;flex-shrink:0}.content-tab .tab-label{font-weight:500;white-space:nowrap}.content-tab .tab-progress{white-space:nowrap}.content-tab.worksheet-tab{position:relative}.content-tab.worksheet-tab.active{background:var(--accent-primary);color:#fff}.content-tab.worksheet-tab.active:hover{background:var(--accent-primary-hover)}.tab-progress{display:inline-flex;align-items:center;justify-content:center;padding:2px 6px;background:#0000001a;border-radius:10px;font-size:11px;font-weight:600}.content-tab.worksheet-tab.active .tab-progress{background:#fff3}.content-page{display:none;padding:0;flex:1;overflow-y:auto;min-height:0;scrollbar-width:none;-ms-overflow-style:none}.content-page::-webkit-scrollbar{display:none}.content-page.active{display:block;overflow-y:auto}.reading-page{background:var(--bg-main);flex:1}.reading-page-inner{max-width:800px;margin:0 auto;padding:32px 24px 64px}.reading-toc{background:var(--bg-elevated);border-radius:var(--radius-lg);padding:16px 20px;margin-bottom:32px}.toc-header{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.toc-link{display:block;padding:6px 0;color:var(--text-dark);text-decoration:none;font-size:14px;transition:color var(--transition-fast)}.toc-link:hover{color:var(--accent-primary)}.reading-content{line-height:1.7}.reading-section{margin-bottom:48px;scroll-margin-top:80px}.reading-section h2{font-size:24px;font-weight:700;color:var(--text-dark);margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid var(--border-light)}.reading-section h3{font-size:18px;font-weight:600;color:var(--text-dark);margin:24px 0 12px}.reading-section p{font-size:16px;color:var(--text-dark);margin-bottom:16px}.reading-section ul,.reading-section ol{margin:16px 0;padding-left:24px}.reading-section li{font-size:16px;color:var(--text-dark);margin-bottom:8px}.reading-callout{display:flex;gap:12px;padding:16px;background:var(--bg-elevated);border-radius:var(--radius-lg);margin:24px 0}.reading-callout .callout-icon{font-size:20px;flex-shrink:0}.reading-callout .callout-content{flex:1}.reading-callout .callout-content strong{display:block;font-size:14px;font-weight:600;color:var(--text-dark);margin-bottom:4px}.reading-callout .callout-content p{font-size:14px;color:var(--text-muted);margin:0}.reading-callout.tip{background:#f0f9ff;border-left:3px solid #0284c7}.reading-callout.warning{background:#fffbeb;border-left:3px solid #f59e0b}.reading-callout.success{background:var(--accent-success-light);border-left:3px solid var(--accent-success)}.reading-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin:24px 0}.reading-card{background:var(--bg-elevated);border-radius:var(--radius-lg);padding:16px;border:1px solid var(--border-light)}.reading-card h4{font-size:14px;font-weight:600;color:var(--text-dark);margin-bottom:8px}.reading-card p{font-size:13px;color:var(--text-muted);margin:0}.reading-card .card-desc{font-size:12px;color:var(--text-muted);margin:8px 0;line-height:1.5}.reading-card .card-question{font-size:12px;color:var(--accent-primary);margin:8px 0;font-style:italic}.reading-card .card-examples{font-size:12px;color:var(--text-dark);margin:8px 0 0;padding-left:16px}.reading-card .card-examples li{margin-bottom:4px}.reading-callout.critical{background:linear-gradient(135deg,#fffef7,#fffbeb);border-left:4px solid #f59e0b;box-shadow:0 2px 8px #f59e0b1a}.reading-callout.critical .callout-icon{font-size:24px}.reading-callout.critical .callout-content strong{color:#92400e}.reading-table{width:100%;border-collapse:collapse;margin:20px 0;font-size:13px;background:var(--bg-elevated);border-radius:var(--radius-lg);overflow:hidden}.reading-table th,.reading-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-light)}.reading-table th{background:var(--bg-subtle);font-weight:600;color:var(--text-dark);font-size:12px;text-transform:uppercase;letter-spacing:.5px}.reading-table td{color:var(--text-muted)}.reading-table td:last-child{color:var(--accent-primary);font-weight:500}.reading-table tbody tr:hover{background:var(--bg-hover)}.reading-table tbody tr:last-child td{border-bottom:none}.reading-cta{margin-top:48px;padding-top:32px;border-top:1px solid var(--border-light);text-align:center}.btn-start-worksheet{display:inline-flex;align-items:center;gap:8px;padding:16px 32px;background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-lg);font-family:var(--font-family);font-size:16px;font-weight:600;cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-md)}.btn-start-worksheet:hover{background:var(--accent-primary-hover);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.video-page{background:var(--bg-main);flex:1}.video-page-inner{max-width:900px;margin:0 auto;padding:32px 24px}.video-list{display:flex;flex-direction:column;gap:24px}.video-card{background:var(--bg-main);border:1px solid var(--border-light);border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow var(--transition-fast)}.video-card:hover{box-shadow:var(--shadow-md)}.video-thumbnail{position:relative;width:100%;aspect-ratio:16 / 9;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center}.video-thumbnail .play-icon{width:64px;height:64px;background:#000000b3;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;color:#fff}.video-info{padding:16px}.video-title{font-size:16px;font-weight:600;color:var(--text-dark);margin-bottom:8px}.video-meta{display:flex;gap:16px;font-size:13px;color:var(--text-muted)}.video-player-area{margin-bottom:24px}.video-placeholder{width:100%;aspect-ratio:16 / 9;background:linear-gradient(135deg,var(--bg-elevated) 0%,#e9e9e7 100%);border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}.video-placeholder-icon{font-size:48px;opacity:.5}.video-placeholder p{font-size:14px;color:var(--text-muted);margin:0}.video-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-elevated);border-radius:var(--radius-md);margin-bottom:8px;cursor:pointer;transition:all var(--transition-fast)}.video-item:hover{background:var(--bg-sidebar-hover)}.video-status{font-size:12px;color:var(--text-muted)}.video-item .video-title{flex:1;font-size:14px;font-weight:500;color:var(--text-dark)}.video-duration{font-size:12px;color:var(--text-muted);font-variant-numeric:tabular-nums}.video-downloads{margin-top:24px;padding-top:24px;border-top:1px solid var(--border-light)}.btn-download{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-md);font-family:var(--font-family);font-size:14px;color:var(--text-dark);cursor:pointer;transition:all var(--transition-fast)}.btn-download:hover{background:var(--bg-sidebar-hover);border-color:var(--text-muted)}.resources-page{background:var(--bg-main);flex:1}.resources-page-inner{max-width:800px;margin:0 auto;padding:32px 24px}.resources-section{margin-bottom:32px}.resources-section-title{font-size:14px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px}.resource-list{display:flex;flex-direction:column;gap:8px}.resource-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-elevated);border-radius:var(--radius-md);text-decoration:none;transition:all var(--transition-fast)}.resource-item:hover{background:#f7f7f5;transform:translate(4px)}.resource-icon{font-size:20px;flex-shrink:0}.resource-name{font-size:14px;font-weight:500;color:var(--text-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.resource-desc{font-size:12px;color:var(--text-muted);margin-left:8px}.resource-arrow{color:var(--text-muted);font-size:14px}.resources-section h3.resources-section-title{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:600;color:var(--text-dark);margin-bottom:16px}.btn-resource-action{padding:6px 12px;background:transparent;border:1px solid var(--border-light);border-radius:var(--radius-sm);font-family:var(--font-family);font-size:12px;font-weight:500;color:var(--text-dark);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.btn-resource-action:hover{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}@media(max-width:768px){.content-tabs{padding:8px 16px;gap:2px}.content-tab{padding:6px 12px;font-size:13px}.content-tab .tab-icon{font-size:14px}.reading-page-inner,.video-page-inner,.resources-page-inner{padding:24px 16px}.reading-section h2{font-size:20px}.reading-section p,.reading-section li{font-size:15px}}@media(max-width:480px){.content-tabs{display:flex!important;flex-direction:row!important;padding:6px 12px;overflow-x:auto;-webkit-overflow-scrolling:touch}.content-tab{display:inline-flex!important;flex-direction:row!important;padding:6px 10px;font-size:12px;flex-shrink:0}.content-tab .tab-label{display:none}.content-tab .tab-icon{font-size:18px}.content-tab.worksheet-tab .tab-label{display:inline}.reading-toc{padding:12px 16px}.toc-link{font-size:13px}.btn-start-worksheet{width:100%;justify-content:center}.reading-grid{grid-template-columns:1fr;gap:12px}.reading-card{padding:12px}.reading-cta p{font-size:14px}}.resource-accordion{margin-bottom:8px;border-radius:var(--radius-md)}.resource-accordion .resource-item{cursor:pointer;border-radius:var(--radius-md)}.resource-accordion.open .resource-item{border-radius:var(--radius-md) var(--radius-md) 0 0;background:#f7f7f5}.resource-accordion .resource-arrow{font-size:12px;color:var(--text-muted);transition:transform var(--transition-fast)}.resource-accordion.open .resource-arrow{transform:rotate(180deg)}.resource-detail{max-height:0;overflow:hidden;transition:max-height .3s ease;background:var(--bg-elevated);border-radius:0 0 var(--radius-md) var(--radius-md)}.resource-accordion.open .resource-detail{max-height:500px}.resource-detail-content{padding:20px 24px;border-top:1px solid var(--border-light)}.resource-detail-desc{font-size:14px;line-height:1.7;color:var(--text-dark);margin-bottom:16px}.resource-detail-desc p{margin-bottom:12px}.resource-detail-desc p:last-child{margin-bottom:0}.resource-detail-desc ul{margin:12px 0;padding-left:20px}.resource-detail-desc li{margin-bottom:6px}.resource-detail-desc strong{color:var(--text-dark)}.btn-resource-action-main{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;background:#f8f7ff;color:var(--accent-primary);border:1px solid #e4e0f4;border-radius:10px;font-family:var(--font-family);font-size:12px;font-weight:700;cursor:pointer;transition:all .2s ease;margin-top:8px;letter-spacing:.01em}.btn-resource-action-main:hover{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary);box-shadow:0 2px 8px #7c3aed40;transform:translateY(-1px)}.btn-resource-action-main .btn-icon{font-size:14px}.resource-item.clickable{cursor:pointer}.resource-item.clickable:hover{background:#f7f7f5}.resource-detail-desc h4{font-size:15px;font-weight:700;color:var(--text-dark);margin:20px 0 12px;padding-bottom:8px;border-bottom:1px solid var(--border-light)}.resource-detail-desc h4:first-child{margin-top:0}.resource-detail-desc h5{font-size:14px;font-weight:600;color:var(--text-dark);margin:8px 0}.resource-quadrant{background:var(--bg-subtle);border-radius:var(--radius-md);padding:12px 16px;margin:12px 0;border-left:3px solid var(--accent-primary)}.resource-quadrant p{margin:6px 0;font-size:13px}.resource-quadrant em{color:var(--accent-primary)}.resource-table{width:100%;border-collapse:collapse;margin:12px 0;font-size:13px;background:#fff;border-radius:var(--radius-md);overflow:hidden;box-shadow:0 1px 3px #0000000d}.resource-table th,.resource-table td{padding:10px 14px;text-align:left;border:1px solid var(--border-light);vertical-align:top}.resource-table th{background:var(--bg-subtle);font-weight:600;color:var(--text-dark);font-size:12px}.resource-table td{color:var(--text-muted);line-height:1.6}.example-empathy-map{background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:16px;margin:12px 0}.example-empathy-map p{margin:8px 0}.insight-box{background:linear-gradient(135deg,#fffef7,#fffbeb);border-left:4px solid #f59e0b;border-radius:var(--radius-md);padding:12px 16px;margin-top:12px;font-size:13px;line-height:1.6}.insight-box strong{color:#92400e}.resource-accordion.open .resource-detail{max-height:2000px}.related-concepts-container{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-light)}.related-concepts-label{font-size:11px;color:var(--text-muted);margin-bottom:8px;font-weight:500}.related-concepts-list{display:flex;flex-direction:column;gap:4px}.related-concept-item{background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-sm);overflow:hidden}.concept-header{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background var(--transition-fast)}.concept-header:hover{background:var(--bg-sidebar-hover)}.concept-icon{font-size:14px}.concept-name{flex:1;font-size:13px;font-weight:500;color:var(--text-dark)}.concept-toggle{font-size:10px;color:var(--text-muted);transition:transform var(--transition-fast)}.concept-detail{padding:0 12px 12px;border-top:1px solid var(--border-light);background:var(--bg-white)}.concept-definition{font-size:13px;line-height:1.6;color:var(--text-secondary);margin-top:8px}.concept-citation{font-size:11px;color:var(--text-muted);margin-top:8px;font-style:italic}.concept-loading{font-size:12px;color:var(--text-muted);padding:8px 0}.concept-error{font-size:12px;color:var(--error-color);padding:8px 0}.misconceptions-section{margin-top:12px;padding-top:8px;border-top:1px solid var(--border-light)}.misconception-item{font-size:12px;color:var(--accent-error);padding:4px 8px;background:#ef44440d;border-left:2px solid var(--accent-error);margin-top:4px;border-radius:0 var(--radius-xs) var(--radius-xs) 0}.related-concepts-simple{margin-top:8px;padding-top:8px;border-top:1px solid var(--border-light)}.concept-item-simple{margin-bottom:4px}.concept-title{font-size:13px;color:var(--accent-ai);cursor:pointer;padding:4px 0;transition:opacity .15s}.concept-title:hover{opacity:.7}.concept-content{font-size:12px;color:var(--text-muted);padding:8px 0 8px 20px;line-height:1.5;border-left:2px solid var(--border-light);margin-left:8px}.concept-definition{margin-bottom:4px}.concept-citation{font-size:11px;color:var(--text-light);font-style:italic}.feedback-divider{border:none;border-top:1px solid var(--border-light);margin:12px 0}.related-concepts-buttons{display:flex;flex-wrap:wrap;gap:6px}.related-concept-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:400;color:var(--text-dark);background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-family)}.related-concept-btn:hover{background:var(--bg-sidebar-hover);border-color:var(--text-muted)}.concept-modal-overlay{position:fixed;inset:0;background:#0006;display:flex;justify-content:center;align-items:center;z-index:2000;padding:24px}.concept-modal-content{background:var(--bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:520px;max-height:80vh;overflow:hidden;position:relative}.concept-modal-close{position:absolute;top:12px;right:12px;width:28px;height:28px;border:none;background:transparent;font-size:20px;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.concept-modal-close:hover{background:var(--bg-elevated);color:var(--text-dark)}.concept-modal-header{padding:24px 24px 16px;border-bottom:1px solid var(--border-light)}.concept-modal-header .concept-icon{font-size:28px;display:block;margin-bottom:8px}.concept-modal-header h2{font-size:18px;font-weight:600;color:var(--text-dark);margin:0 0 4px}.concept-modal-header .concept-citation{font-size:12px;color:var(--text-muted);font-style:italic}.concept-modal-body{padding:16px 24px 24px;overflow-y:auto;max-height:calc(80vh - 120px)}.concept-modal-body .concept-definition{font-size:14px;line-height:1.7;color:var(--text-dark);margin-bottom:16px}.concept-keywords{display:flex;flex-wrap:wrap;gap:6px}.keyword-tag{display:inline-block;padding:3px 8px;font-size:11px;color:var(--text-muted);background:var(--bg-elevated);border-radius:var(--radius-sm)}.sync-indicator{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:11px;border-radius:var(--radius-sm);transition:all .2s ease}.sync-indicator.synced{color:var(--accent-success);background:var(--accent-success-light)}.sync-indicator.pending{color:var(--accent-warning);background:#c277191a}.sync-indicator.saving{color:var(--accent-primary);background:#7c3aed1a}.sync-indicator.error{color:var(--accent-error);background:#e03e3e1a}.sync-icon{font-weight:700}.sync-icon.saving{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.learn-progress-bar{display:flex;align-items:center;gap:var(--spacing-sm);padding:8px 12px;background:linear-gradient(135deg,#f5f3ff,#eef2ff);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);border:1px solid #e0e7ff}.learn-progress-bar .progress-dots{font-size:16px;letter-spacing:4px;color:#7c3aed}.learn-progress-bar .progress-text{font-size:12px;color:var(--text-muted);margin-left:auto}.learn-progress-bar.completed{background:linear-gradient(135deg,#dcfce7,#d1fae5);border-color:#86efac}.learn-progress-bar.completed .progress-dots{color:#22c55e}.learn-completion-actions{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid #e5e7eb}.btn-start-worksheet{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-light);border-radius:var(--radius-sm);font-size:14px;font-weight:500;cursor:pointer;transition:background var(--transition-fast)}.btn-start-worksheet:hover{background:var(--bg-hover)}.objective-completed-badge{display:flex;align-items:center;gap:8px;margin-top:var(--spacing-md);padding:12px 16px;background:linear-gradient(135deg,#dcfce7,#d1fae5);border:1px solid #86efac;border-radius:var(--radius-md);animation:badgeFadeIn .4s ease-out}.objective-completed-badge .badge-icon{font-size:18px;flex-shrink:0}.objective-completed-badge .badge-text{font-size:14px;font-weight:500;color:#166534;line-height:1.4}@keyframes badgeFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.sources-used{margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px dashed #e5e7eb;font-size:11px;color:var(--text-muted)}.sources-used .sources-label{color:var(--text-secondary);font-weight:500}.source-tag{display:inline-block;background:#f3f4f6;padding:2px 6px;border-radius:4px;margin-left:4px}.completion-message{margin-top:var(--spacing-md);animation:completionFadeIn .5s ease-out}.completion-badge{display:flex;align-items:center;gap:8px;padding:12px 16px;background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:var(--radius-md);margin-bottom:12px}.completion-badge .badge-icon{font-size:24px}.completion-badge .badge-text{font-size:16px;font-weight:700;color:#92400e}.completion-summary{color:var(--text-secondary);font-size:14px;line-height:1.6;margin:0}@keyframes completionFadeIn{0%{opacity:0;transform:translateY(10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}#ai-input:disabled{cursor:not-allowed;color:var(--text-muted)}#btn-send-ai:disabled{cursor:not-allowed}.app-layout.simulator-mode .right-panel{display:none}.app-layout.simulator-mode .center-panel{width:calc(100% - var(--left-panel-width))}.simulator-page{height:100%;overflow:hidden}.simulator-embed{height:100%;background:linear-gradient(180deg,#f8fafc,#f1f5f9,#e2e8f0);border-radius:12px;overflow:hidden;border:1px solid #e2e8f0}.simulator-app-inline{height:100%;display:flex;flex-direction:column;color:#1e293b;position:relative}.simulator-dashboard{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#fff,#f8fafc,#f1f5f9);z-index:100}.dashboard-content{text-align:center;padding:40px;max-width:500px}.dashboard-icon{font-size:72px;margin-bottom:16px;animation:pulse 2s ease-in-out infinite;border-radius:10px}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.dashboard-title{font-size:32px;font-weight:800;color:#1e293b;margin:0 0 8px}.dashboard-subtitle{font-size:16px;color:#64748b;margin:0 0 32px}.dashboard-info{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px;margin-bottom:24px;box-shadow:0 2px 8px #0000000a}.info-item{display:flex;align-items:center;gap:12px;padding:8px 0;color:#475569;font-size:14px}.info-icon{font-size:20px}.dashboard-tips{background:#fefce8;border:1px solid #fef08a;border-radius:12px;padding:16px 20px;margin-bottom:32px;text-align:left}.tips-title{font-size:14px;font-weight:600;color:#854d0e;margin-bottom:12px}.tips-list{margin:0;padding-left:20px;color:#713f12;font-size:13px;line-height:1.8}.btn-start-simulator{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;padding:16px 48px;font-size:18px;font-weight:700;border-radius:50px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 20px #6366f166}.btn-start-simulator:hover{transform:translateY(-2px);box-shadow:0 8px 30px #6366f180}.btn-start-simulator:active{transform:translateY(0)}.simulator-main-content{display:flex;flex-direction:column;height:100%}.simulator-header-inline{display:flex;justify-content:space-between;align-items:center;padding:10px 24px;background:#ffffffe6;border-bottom:1px solid #e2e8f0;flex-shrink:0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.simulator-logo{font-size:18px;font-weight:700;color:#6366f1;margin:0}.timer-display{display:flex;align-items:center;gap:8px;font-size:24px;font-weight:600;font-family:Monaco,monospace}.timer-icon{font-size:20px}.timer-current{color:#1e293b}.timer-separator{color:#94a3b8}.timer-total{color:#64748b}.time-limit-badge{padding:8px 16px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:20px;color:#475569;font-size:14px;font-weight:500}.stage-container-inline{flex:1;display:flex;flex-direction:column;padding:0;overflow:hidden;position:relative}.countdown-overlay{position:absolute;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.countdown-number{font-size:120px;font-weight:900;color:#fff;text-shadow:0 4px 20px rgba(0,0,0,.5)}.countdown-number.pop{animation:countdownPop .5s ease-out}@keyframes countdownPop{0%{transform:scale(.5);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.mc-area{display:flex;align-items:center;justify-content:center;gap:16px;padding:12px 24px;background:#ffffffe6;border-bottom:1px solid #e2e8f0;flex-shrink:0}.mc-avatar-container{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #6366f14d;flex-shrink:0}.mc-avatar-placeholder{font-size:24px}.mc-lottie-container{width:100%;height:100%}.mc-speech-bubble{background:linear-gradient(135deg,#fff,#f8fafc);border:2px solid #6366f1;border-radius:16px;padding:16px 24px;max-width:600px;position:relative;box-shadow:0 4px 12px #6366f126}.mc-speech-bubble:before{content:"";position:absolute;left:-8px;top:50%;transform:translateY(-50%);border:8px solid transparent;border-right-color:#fff;border-left:none}.mc-speech-bubble:after{content:"";position:absolute;left:-10px;top:50%;transform:translateY(-50%);border:9px solid transparent;border-right-color:#6366f1;border-left:none;z-index:-1}.mc-text{font-size:15px;color:#1e293b;line-height:1.6;white-space:pre-line}.mc-area.hidden{display:none}.mc-text.typing:after{content:"|";animation:mc-blink .7s infinite}@keyframes mc-blink{0%,50%{opacity:1}51%,to{opacity:0}}.judges-panel-inline{position:relative;flex:1;display:flex;align-items:center;justify-content:center;min-height:0}.judges-panel-inline.judges-fullscreen{padding:20px}.stage-lights-inline{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-around;pointer-events:none;height:100%}.stage-lights-inline .light{width:150px;height:100%;background:radial-gradient(ellipse at top,rgba(99,102,241,.15),transparent 60%);opacity:.5;transition:opacity .5s}.judges-row-inline{display:flex;justify-content:center;align-items:flex-end;gap:40px;position:relative;z-index:1;transition:all .6s cubic-bezier(.4,0,.2,1);padding:40px 60px;width:100%;max-width:1400px}.judges-panel-inline.camera-wide .judges-row-inline{transform:scale(1)}.judges-panel-inline.camera-closeup .judges-row-inline{transform:scale(1.15)}.sim-bottom-area{background:linear-gradient(to top,#fffffff2,#fffc);padding:10px 32px 14px;border-top:1px solid #e2e8f0;flex-shrink:0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.judge-card-inline{flex:1;max-width:220px;min-width:150px;text-align:center;transition:all .5s cubic-bezier(.4,0,.2,1);opacity:.7;transform:scale(.95);position:relative}.judge-card-inline.active{opacity:.9;transform:scale(1)}.judge-card-inline.focused{opacity:1!important;transform:scale(1.3) translateY(-20px)!important;z-index:10}.judge-card-inline.focused .judge-image-wrapper-inline{border-color:#6366f1!important;box-shadow:0 8px 32px #6366f166,0 4px 16px #6366f133!important}.judge-card-inline.focused .judge-name-inline{font-size:20px;color:#6366f1}.judge-card-inline.focused .judge-comment-inline{font-size:16px;color:#1e293b}.judge-card-inline.dimmed{opacity:.3;transform:scale(.8);filter:blur(1px)}.judge-image-wrapper-inline{width:160px;height:160px;margin:0 auto 12px;border-radius:50%;overflow:hidden;border:4px solid #e2e8f0;background:#fff;transition:all .5s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #0000001a}.judge-card-inline.active .judge-image-wrapper-inline{border-color:#6366f1;box-shadow:0 8px 24px #6366f140}.judge-image-inline{width:100%;height:100%;object-fit:cover}.judge-name-inline{font-size:16px;font-weight:600;color:#4f46e5;transition:all .4s ease;margin-bottom:6px}.judge-comment-inline{font-size:14px;color:#64748b;font-style:italic;min-height:24px;padding:0 8px}.judge-thought-bubble{position:absolute;top:-60px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:16px;padding:10px 16px;min-width:150px;max-width:200px;box-shadow:0 4px 20px #f59e0b4d;animation:bubble-appear .4s ease-out;z-index:100}.judge-thought-bubble:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translate(-50%);border:10px solid transparent;border-top-color:#fde68a;border-bottom:none}.judge-thought-bubble .thought-text{font-size:13px;font-weight:600;color:#92400e;line-height:1.4;text-align:center;display:block}.judge-thought-bubble.fade-out{animation:bubble-fade .5s ease-out forwards}@keyframes bubble-appear{0%{opacity:0;transform:translate(-50%) translateY(10px) scale(.8)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}@keyframes bubble-fade{0%{opacity:1;transform:translate(-50%) translateY(0) scale(1)}to{opacity:0;transform:translate(-50%) translateY(-10px) scale(.8)}}.judge-card-inline.thinking-highlight{opacity:1!important;transform:scale(1.15)!important;z-index:20}.judge-card-inline.thinking-highlight .judge-image-wrapper-inline{border-color:#f59e0b!important;box-shadow:0 0 30px #f59e0b80!important}.transcript-section-inline{background:#fff;border-radius:12px;padding:10px 16px;margin-bottom:10px;border:1px solid #e2e8f0;box-shadow:0 2px 8px #0000000d}.transcript-label{font-size:11px;color:#94a3b8;margin-bottom:4px}.transcript-box-inline{min-height:40px;max-height:60px;overflow-y:auto;font-size:16px;line-height:1.5;color:#1e293b;text-align:center}.transcript-cursor{display:inline-block;width:2px;height:16px;background:#6366f1;margin-left:2px;animation:blink 1s infinite}.keywords-section-inline{margin-bottom:16px}.keywords-label{font-size:12px;color:#fff9;margin-bottom:8px}.keywords-list-inline{display:flex;flex-wrap:wrap;gap:8px}.keyword-tag-inline{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:20px;font-size:13px;color:#fffc;transition:all .3s}.keyword-tag-inline.checked{background:#ffd70033;border-color:gold;color:gold}.sim-section-indicator{display:flex;justify-content:space-between;align-items:center;padding:8px 16px;margin-bottom:8px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:8px;color:#fff}.sim-section-label{font-size:15px;font-weight:600;letter-spacing:.5px}.sim-timer-display{font-family:"Press Start 2P",Courier New,monospace;font-size:12px;background:#fff3;padding:4px 12px;border-radius:4px}.sim-progress-section{margin-bottom:8px}.sim-progress-bar{height:4px;background:#e2e8f0;border-radius:2px;overflow:hidden}.sim-progress-fill{height:100%;background:linear-gradient(90deg,#6366f1,#8b5cf6);width:0%;transition:width .3s}.sim-progress-fill.warning{background:linear-gradient(90deg,#f59e0b,#f97316)}.sim-progress-fill.danger{background:linear-gradient(90deg,#ef4444,#dc2626)}.controls-section-inline{display:flex;justify-content:center;gap:12px;padding:8px 0}.btn-control-inline{display:flex;align-items:center;gap:8px;padding:14px 32px;border:none;border-radius:30px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s}.btn-start-inline{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;box-shadow:0 4px 12px #6366f14d}.btn-start-inline:hover:not(:disabled){transform:scale(1.05);box-shadow:0 8px 24px #6366f166}.btn-start-inline:disabled{opacity:.5;cursor:not-allowed}.btn-start-inline.recording{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 15px #ef444400}}.btn-stop-inline{background:#fff;border:2px solid #e2e8f0;color:#64748b}.btn-stop-inline:hover:not(:disabled){background:#fef2f2;border-color:#ef4444;color:#ef4444}.btn-stop-inline:disabled{opacity:.3;cursor:not-allowed}.sim-modal-overlay{position:absolute;inset:0;background:#0f172acc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100}.sim-modal-content{background:#fff;border:1px solid #e2e8f0;border-radius:20px;padding:24px;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 24px 48px #0003}.sim-modal-title{font-size:24px;font-weight:700;color:#1e293b;text-align:center;margin-bottom:24px}.feedback-sequence-inline{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.feedback-item-inline{display:grid;grid-template-columns:60px 1fr auto;align-items:center;gap:12px;padding:14px 16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;animation:fadeInUp .5s ease forwards}.feedback-judge-name{font-size:13px;font-weight:600;color:#475569;white-space:nowrap}.feedback-comment{font-size:13px;color:#64748b;font-style:italic;line-height:1.4;min-width:0}.feedback-score-area{display:flex;align-items:center;gap:8px;white-space:nowrap;flex-shrink:0}.feedback-grade{display:inline-block;padding:3px 10px;background:#e0e7ff;color:#4338ca;border-radius:6px;font-size:12px;font-weight:600}.feedback-points{font-size:18px;font-weight:700;color:#1e293b}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.feedback-avatar-inline{width:50px;height:50px;border-radius:50%;object-fit:cover;border:2px solid #e2e8f0}.feedback-content-inline{flex:1}.feedback-name-inline{font-size:14px;font-weight:600;color:#4f46e5;margin-bottom:4px}.feedback-text-inline{font-size:14px;color:#64748b;font-style:italic}.feedback-score-inline{font-size:24px;font-weight:700;color:#6366f1}.final-score-inline{text-align:center;padding:20px;background:linear-gradient(135deg,#f0f9ff,#e0e7ff);border-radius:16px;margin-bottom:16px;border:1px solid #c7d2fe}.final-score-inline .score-label{font-size:14px;color:#64748b;margin-bottom:8px}.score-value-inline{font-size:48px;font-weight:700;color:#6366f1;line-height:1}.score-comment-inline{font-size:16px;color:#64748b;margin-top:8px}.sim-modal-actions{display:flex;justify-content:center;gap:16px}.btn-retry-inline,.btn-close-inline{padding:12px 32px;border:none;border-radius:25px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s}.btn-retry-inline{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;box-shadow:0 4px 12px #6366f14d}.btn-retry-inline:hover{transform:scale(1.05);box-shadow:0 8px 20px #6366f166}.btn-close-inline{background:#f8fafc;color:#64748b;border:1px solid #e2e8f0}.btn-close-inline:hover{background:#f1f5f9;color:#475569}.btn-leaderboard-inline{padding:12px 24px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#1e293b}.btn-leaderboard-inline:hover{background:linear-gradient(135deg,#f59e0b,#d97706);transform:scale(1.02)}.mic-test-screen{display:flex;justify-content:center;align-items:center;min-height:500px;padding:40px 20px}.mic-test-content{max-width:440px;width:100%;text-align:center}.mic-test-title{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:8px}.mic-test-title h2{font-size:22px;font-weight:700;color:#1e293b;margin:0}.mic-test-title svg{color:#6366f1}.mic-test-subtitle{color:#64748b;font-size:14px;margin:0 0 28px;line-height:1.5}.mic-test-status{display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 20px;border-radius:12px;margin-bottom:20px;font-size:14px;font-weight:500}.mic-test-status.connected{background:#f5f3ff;border:1px solid #e4e0f4;color:#6d5cae}.mic-test-status.connected svg{color:#7c3aed;flex-shrink:0}.mic-test-status.disconnected{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.mic-test-status.disconnected svg{color:#dc2626;flex-shrink:0}.mic-test-status-msg{text-align:left}.mic-test-status-msg span{display:block;font-weight:600}.mic-test-status-msg p{margin:4px 0 0;font-size:13px;font-weight:400;opacity:.8}.btn-mic-retry{display:inline-block;padding:8px 20px;background:#f8fafc;color:#475569;border:1px solid #e2e8f0;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;margin-bottom:20px;transition:all .2s ease}.btn-mic-retry:hover{background:#f1f5f9;border-color:#cbd5e1}.mic-test-device{text-align:left;margin-bottom:20px}.mic-test-device-label{display:block;font-size:13px;font-weight:600;color:#475569;margin-bottom:6px}.mic-test-select-wrapper{position:relative}.mic-test-device-select{width:100%;padding:10px 36px 10px 14px;font-size:14px;font-family:var(--font-family);color:#1e293b;background:#fff;border:1px solid #e2e8f0;border-radius:10px;appearance:none;cursor:pointer;transition:border-color .2s}.mic-test-device-select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.mic-test-select-arrow{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:#94a3b8;pointer-events:none}.mic-test-volume{text-align:left;margin-bottom:28px}.mic-test-volume-label{display:block;font-size:13px;font-weight:600;color:#475569;margin-bottom:8px}.mic-test-volume-container{width:100%;height:12px;background:#f1f5f9;border-radius:6px;overflow:hidden;border:1px solid #e2e8f0}.mic-test-volume-bar{height:100%;min-width:0;border-radius:6px;transition:width .1s ease-out}.mic-test-volume-hint{margin:8px 0 0;font-size:13px;color:#94a3b8}.mic-test-actions{display:flex;flex-direction:column;gap:10px;align-items:center}.btn-mic-start{width:100%;padding:14px 32px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:700;font-family:var(--font-family);cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #6366f14d}.btn-mic-start:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #6366f166}.btn-mic-start:disabled{opacity:.5;cursor:not-allowed}.btn-mic-back{padding:10px 24px;background:transparent;color:#64748b;border:none;border-radius:8px;font-size:14px;font-weight:500;font-family:var(--font-family);cursor:pointer;transition:all .2s ease}.btn-mic-back:hover{color:#475569;background:#f8fafc}.stage-container-inline.rpg-layout{display:flex;flex-direction:column;height:100%}.rpg-top-area{position:relative;height:200px;background:linear-gradient(180deg,#f1f5f999,#e2e8f066);display:flex;align-items:flex-end;padding:16px 20px;gap:16px}.mc-character-wrapper{flex-shrink:0;position:relative;width:320px;height:220px;overflow:hidden}.mc-character-wrapper lottie-player{width:800px!important;height:400px!important;position:absolute;top:30px;left:-20px}.dialogue-area{flex:1;display:flex;align-items:flex-end}.dialogue-box-white{background:#fffffff2;border:1px solid #e2e8f0;border-radius:12px;padding:16px 20px;box-shadow:0 4px 16px #00000014;position:relative;width:100%}.dialogue-text{color:#374151;font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;font-size:15px;font-weight:500;line-height:1.7;margin:0;padding-right:20px}.dialogue-cursor{position:absolute;bottom:12px;right:16px;color:#6366f1;font-size:12px;animation:cursor-bounce .8s infinite}@keyframes cursor-bounce{0%,to{transform:translateY(0);opacity:1}50%{transform:translateY(3px);opacity:.5}}.rpg-dialogue-cursor.visible{opacity:1}@keyframes rpg-cursor-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(3px)}}.rpg-dialogue-box.mc-speaking{border-color:#c7d2fe}.rpg-dialogue-box.mc-speaking .rpg-dialogue-header{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.rpg-dialogue-box.student-speaking{border-color:#86efac}.rpg-dialogue-box.student-speaking .rpg-dialogue-header{background:linear-gradient(135deg,#22c55e,#16a34a)}.rpg-dialogue-box.judge-speaking{border-color:#fcd34d}.rpg-dialogue-box.judge-speaking .rpg-dialogue-header{background:linear-gradient(135deg,#f59e0b,#d97706)}.rpg-middle-area{flex:1;display:flex;align-items:center;justify-content:center;padding:16px;position:relative}.rpg-middle-area.judges-panel-inline{background:transparent}.rpg-bottom-area{padding:12px 20px;background:linear-gradient(0deg,rgba(34,197,94,.15) 0%,transparent 100%);flex-shrink:0;min-height:60px}.user-dialogue-area{position:relative;height:180px;background:linear-gradient(0deg,#f0fdf499,#dcfce766);display:flex;align-items:flex-end;padding:16px 20px;gap:16px;flex-direction:row}.user-dialogue-box-area{flex:1;display:flex;align-items:flex-end}.user-dialogue-box{background:#fffffff2;border:2px solid #86efac;border-radius:12px;padding:16px 20px;box-shadow:0 4px 16px #22c55e26;position:relative;width:100%;min-height:60px;max-height:100px;overflow-y:auto}.user-dialogue-text{color:#374151;font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;font-size:15px;font-weight:500;line-height:1.7;margin:0;white-space:pre-wrap;word-break:keep-all}.user-character-wrapper{flex-shrink:0;position:relative;width:280px;height:200px;overflow:hidden}.user-character-wrapper lottie-player{width:800px!important;height:400px!important;position:absolute;top:10px;left:-420px}.user-dialogue-area.speaking .user-dialogue-box{border-color:#22c55e;box-shadow:0 0 24px #22c55e59}.user-dialogue-area.speaking .user-character-wrapper{animation:user-pulse 1.5s ease-in-out infinite}@keyframes user-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.user-dialogue-box::-webkit-scrollbar{width:4px}.user-dialogue-box::-webkit-scrollbar-track{background:#f1f5f9;border-radius:2px}.user-dialogue-box::-webkit-scrollbar-thumb{background:#86efac;border-radius:2px}.rpg-user-speech{display:flex;align-items:center;gap:12px;background:#ffffffe6;border-radius:12px;padding:12px 20px;border:2px solid #86efac;box-shadow:0 4px 16px #22c55e33}.rpg-user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#22c55e,#16a34a);display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-mic-icon{font-size:18px}.rpg-voice-wave{display:flex;align-items:center;gap:3px;height:24px}.rpg-voice-wave span{width:4px;height:8px;background:#22c55e;border-radius:2px;animation:rpg-wave .8s ease-in-out infinite}.rpg-voice-wave span:nth-child(1){animation-delay:0s}.rpg-voice-wave span:nth-child(2){animation-delay:.1s}.rpg-voice-wave span:nth-child(3){animation-delay:.2s}.rpg-voice-wave span:nth-child(4){animation-delay:.3s}.rpg-voice-wave span:nth-child(5){animation-delay:.4s}@keyframes rpg-wave{0%,to{height:8px}50%{height:20px}}.rpg-voice-label{color:#166534;font-size:14px;font-weight:600}.rpg-user-dialogue{display:flex;align-items:flex-start;gap:12px;flex-direction:row}.rpg-user-dialogue.rpg-user-dialogue-left{flex-direction:row}.rpg-user-avatar-wrapper{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0}.user-profile-circle{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#22c55e,#16a34a);border:3px solid #86efac;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #22c55e4d}.user-profile-initial{color:#fff;font-size:20px;font-weight:700}.rpg-user-dialogue-box{border-color:#86efac!important;box-shadow:0 2px 12px #22c55e26!important}.rpg-user-dialogue-box .rpg-dialogue-text{color:#166534}.rpg-voice-indicator{display:flex;align-items:center;justify-content:center}.voice-wave-mini{display:flex;align-items:center;gap:2px;height:16px}.voice-wave-mini span{width:3px;height:6px;background:#22c55e;border-radius:2px;animation:rpg-wave .6s ease-in-out infinite}.voice-wave-mini span:nth-child(1){animation-delay:0s}.voice-wave-mini span:nth-child(2){animation-delay:.15s}.voice-wave-mini span:nth-child(3){animation-delay:.3s}.rpg-user-dialogue.speaking .user-profile-circle{animation:user-speaking-pulse 1.5s ease-in-out infinite}@keyframes user-speaking-pulse{0%,to{box-shadow:0 4px 12px #22c55e4d}50%{box-shadow:0 4px 24px #22c55e99}}.inline-results-area{width:100%;height:100%;display:flex;flex-direction:column;padding:16px 24px;overflow-y:auto;background:linear-gradient(180deg,#f8fafcfa,#f1f5f9f2)}.results-header{text-align:center;padding:8px 0 16px;border-bottom:2px solid #e2e8f0;margin-bottom:16px}.results-title{font-size:20px;font-weight:700;color:#1e293b}.results-feedback-list{flex:1;display:flex;flex-direction:column;gap:10px;overflow-y:auto;padding-right:8px}.inline-feedback-item{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:12px 16px;animation:fadeInUp .3s ease-out;box-shadow:0 2px 8px #0000000d}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.inline-feedback-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid #e2e8f0;flex-shrink:0}.inline-feedback-content{flex:1;min-width:0}.inline-feedback-name{font-size:14px;font-weight:700;color:#6366f1;margin-bottom:4px}.inline-feedback-text{font-size:13px;color:#475569;line-height:1.5;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.inline-feedback-score{font-size:18px;font-weight:700;color:#22c55e;flex-shrink:0}.results-total{text-align:center;padding:16px;margin-top:16px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:12px;color:#fff}.total-score-label{font-size:14px;opacity:.9;margin-bottom:4px}.total-score-value{font-size:32px;font-weight:800;margin-bottom:4px}.total-score-comment{font-size:14px;opacity:.95}.results-actions{display:flex;gap:12px;justify-content:center;margin-top:16px;padding-top:16px;border-top:1px solid #e2e8f0}.results-actions .btn-retry-inline,.results-actions .btn-leaderboard-inline{padding:10px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;border:none}.results-actions .btn-retry-inline{background:#f1f5f9;color:#475569}.results-actions .btn-retry-inline:hover{background:#e2e8f0}.results-actions .btn-leaderboard-inline{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.results-actions .btn-leaderboard-inline:hover{transform:scale(1.02)}.rpg-bottom-area.sim-bottom-area{background:linear-gradient(to top,#f1f5f9fa,#f8fafcf2);border-top:2px solid #e2e8f0;padding:10px 20px 14px;flex-shrink:0}.rpg-user-transcript{margin:8px 0}.rpg-transcript-box{background:#fffffff2;border:2px solid #86efac;border-radius:12px;padding:10px 16px;position:relative;box-shadow:0 2px 12px #22c55e26}.rpg-transcript-label{display:flex;align-items:center;gap:6px;margin-bottom:6px}.rpg-user-icon{font-size:14px}.rpg-transcript-label span:last-child{font-size:12px;font-weight:600;color:#166534}.rpg-transcript-text{color:#1e293b;font-size:14px;line-height:1.6;margin:0;min-height:24px}.rpg-user-transcript.speaking .rpg-transcript-box{border-color:#22c55e;background:#f0fdf4f2}.rpg-user-speech:not([style*="display: none"])+.rpg-transcript-box{border-color:#22c55e;background:#f0fdf4f2}.rpg-bottom-area .controls-section-inline{gap:12px;margin-top:8px}.vn-dialogue-area{position:relative;display:flex;align-items:flex-end;padding:16px 24px;gap:16px;flex-shrink:0}.vn-character{flex-shrink:0;transition:all .5s cubic-bezier(.4,0,.2,1)}.vn-character.mc-character{transform:translate(0)}.vn-character.mc-character.slide-left{transform:translate(-150px)}.vn-avatar-frame{position:relative;width:120px;height:150px;border-radius:12px;overflow:hidden;background:linear-gradient(135deg,#1e1b4b,#312e81);border:3px solid #6366f1;box-shadow:0 8px 32px #6366f166,0 0 0 1px #ffffff1a}.vn-avatar{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative}.mc-lottie-container{position:absolute;inset:0;z-index:1}.mc-fallback-avatar{font-size:56px;z-index:0;display:none}.vn-avatar.has-lottie .mc-fallback-avatar,.vn-avatar.has-lottie .mc-cartoon-host{display:none}.mc-host-frame{background:linear-gradient(135deg,#1e293b,#334155);border-color:#f59e0b;box-shadow:0 8px 32px #f59e0b4d,0 0 0 2px #f59e0b33,inset 0 1px #ffffff1a}.mc-cartoon-host{position:relative;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding-bottom:5px}.mc-host-body{position:relative;width:90px;height:50px;margin-top:auto}.mc-suit{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:85px;height:45px;background:linear-gradient(180deg,#1e3a5f,#0f172a);border-radius:12px 12px 0 0;border:2px solid #334155;border-bottom:none}.mc-suit:before{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:20px;height:30px;background:#f8fafc;border-radius:0 0 3px 3px;clip-path:polygon(30% 0,70% 0,100% 100%,0 100%)}.mc-tie{position:absolute;bottom:15px;left:50%;transform:translate(-50%);width:12px;height:25px;background:linear-gradient(180deg,#dc2626,#991b1b);clip-path:polygon(50% 0,100% 15%,80% 100%,50% 85%,20% 100%,0 15%);z-index:2}.mc-host-face{position:absolute;bottom:40px;left:50%;transform:translate(-50%);width:55px;height:60px;background:linear-gradient(180deg,#fcd9b6,#f5c69a);border-radius:50% 50% 45% 45%;border:2px solid #e5b896}.mc-hair{position:absolute;top:-8px;left:50%;transform:translate(-50%);width:58px;height:30px;background:linear-gradient(180deg,#1c1917,#292524);border-radius:50% 50% 20% 20%;z-index:-1}.mc-hair:before{content:"";position:absolute;top:5px;left:5px;width:48px;height:15px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);border-radius:50%}.mc-eyes{position:absolute;top:20px;left:50%;transform:translate(-50%);width:40px;display:flex;justify-content:space-between}.mc-eye{width:8px;height:10px;background:#1c1917;border-radius:50%;position:relative}.mc-eye:after{content:"";position:absolute;top:2px;left:2px;width:3px;height:3px;background:#fff;border-radius:50%}.mc-eyebrows{position:absolute;top:14px;left:50%;transform:translate(-50%);width:44px;display:flex;justify-content:space-between}.mc-eyebrow{width:10px;height:3px;background:#44403c;border-radius:2px}.mc-eyebrow.left{transform:rotate(-8deg)}.mc-eyebrow.right{transform:rotate(8deg)}.mc-nose{position:absolute;top:30px;left:50%;transform:translate(-50%);width:6px;height:8px;background:#e5b896;border-radius:0 0 50% 50%}.mc-smile{position:absolute;bottom:12px;left:50%;transform:translate(-50%);width:20px;height:8px;border:3px solid #c2410c;border-top:none;border-radius:0 0 20px 20px;background:#7c2d12}.mc-microphone{position:absolute;bottom:25px;right:8px;z-index:10;animation:mc-mic-bounce 2s ease-in-out infinite}@keyframes mc-mic-bounce{0%,to{transform:rotate(-15deg)}50%{transform:rotate(-10deg)}}.mc-mic-head{width:18px;height:22px;background:linear-gradient(135deg,#374151,#1f2937);border-radius:50% 50% 40% 40%;border:2px solid #4b5563;position:relative}.mc-mic-head:before{content:"";position:absolute;top:3px;left:3px;width:10px;height:12px;background:repeating-linear-gradient(0deg,#6b7280 0px 2px,#4b5563 2px 4px);border-radius:50%}.mc-mic-handle{width:6px;height:18px;background:linear-gradient(180deg,#4b5563,#374151);margin:0 auto;border-radius:0 0 3px 3px}.mc-character.speaking .mc-smile{animation:mc-talk .3s ease-in-out infinite alternate}@keyframes mc-talk{0%{height:8px;width:20px}to{height:12px;width:18px}}.mc-eye{animation:eye-blink 4s ease-in-out infinite}@keyframes eye-blink{0%,45%,55%,to{height:10px}48%,52%{height:2px}}.vn-dialogue-box{flex:1;max-width:700px;background:linear-gradient(180deg,#0f172af2,#1e293bfa);border:2px solid #6366f1;border-radius:16px;padding:0;position:relative;box-shadow:0 8px 32px #00000080,0 0 0 1px #6366f14d,inset 0 1px #ffffff1a;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);overflow:hidden}.vn-nameplate{position:absolute;top:-14px;left:20px;background:linear-gradient(135deg,#6366f1,#8b5cf6);padding:6px 20px;border-radius:8px;box-shadow:0 4px 12px #6366f166;z-index:10}.vn-name{color:#fff;font-size:14px;font-weight:700;letter-spacing:.5px;text-shadow:0 1px 2px rgba(0,0,0,.3)}.vn-text-container{padding:28px 24px 20px;position:relative;min-height:80px}.vn-text{color:#f1f5f9;font-size:16px;line-height:1.8;white-space:pre-line;margin:0;text-shadow:0 1px 2px rgba(0,0,0,.5)}.vn-text-cursor{position:absolute;bottom:12px;right:16px;color:#6366f1;font-size:14px;animation:vn-cursor-bounce .8s ease-in-out infinite;opacity:0;transition:opacity .3s}.vn-text-cursor.visible{opacity:1}@keyframes vn-cursor-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(4px)}}.vn-text.typing:after{content:"▌";color:#6366f1;animation:vn-typing-blink .6s infinite;margin-left:2px}@keyframes vn-typing-blink{0%,50%{opacity:1}51%,to{opacity:0}}.vn-voice-indicator{position:absolute;top:50%;right:24px;transform:translateY(-50%);display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,#22c55ee6,#16a34af2);padding:12px 24px;border-radius:50px;box-shadow:0 8px 32px #22c55e66,0 0 0 2px #22c55e4d;animation:voice-pulse 2s ease-in-out infinite}@keyframes voice-pulse{0%,to{box-shadow:0 8px 32px #22c55e66,0 0 0 2px #22c55e4d}50%{box-shadow:0 8px 48px #22c55e99,0 0 0 4px #22c55e80}}.voice-icon{font-size:24px;animation:voice-icon-pulse 1s ease-in-out infinite}@keyframes voice-icon-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.voice-wave{display:flex;gap:3px;align-items:center;height:24px}.voice-wave span{width:4px;background:#fff;border-radius:2px;animation:voice-wave-bar .5s ease-in-out infinite}.voice-wave span:nth-child(1){animation-delay:0s;height:8px}.voice-wave span:nth-child(2){animation-delay:.1s;height:16px}.voice-wave span:nth-child(3){animation-delay:.2s;height:24px}.voice-wave span:nth-child(4){animation-delay:.1s;height:16px}.voice-wave span:nth-child(5){animation-delay:0s;height:8px}@keyframes voice-wave-bar{0%,to{transform:scaleY(.5)}50%{transform:scaleY(1)}}.voice-label{color:#fff;font-size:14px;font-weight:600;letter-spacing:.5px}.vn-dialogue-box.mc-speaking{border-color:#6366f1}.vn-dialogue-box.student-speaking{border-color:#22c55e}.vn-dialogue-box.student-speaking .vn-nameplate{background:linear-gradient(135deg,#22c55e,#16a34a)}.vn-dialogue-box.judge-speaking{border-color:#f59e0b}.vn-dialogue-box.judge-speaking .vn-nameplate{background:linear-gradient(135deg,#f59e0b,#d97706)}.vn-dialogue-area.hidden{opacity:0;pointer-events:none;transform:translateY(20px);transition:all .3s ease}.stage-container-inline.vn-mode{display:flex;flex-direction:column}.stage-container-inline.vn-mode .judges-panel-inline{flex:1;min-height:200px}.stage-container-inline.vn-mode .sim-bottom-area{position:relative;z-index:150}.stage-container-inline.vn-mode .judges-row-inline{padding:20px 40px}.leaderboard-modal-overlay{position:fixed;inset:0;background:#000c;display:none;justify-content:center;align-items:center;z-index:10000;animation:fadeIn .3s ease}.leaderboard-modal-overlay.active{display:flex}.leaderboard-modal{background:linear-gradient(180deg,#1a1a2e,#16213e,#0f0f23);border:4px solid #fbbf24;border-radius:16px;width:90%;max-width:600px;max-height:85vh;overflow:hidden;box-shadow:0 0 30px #fbbf244d,0 0 60px #fbbf241a,inset 0 0 60px #0000004d;animation:scaleIn .3s ease}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.leaderboard-header{background:var(--bg-white);padding:var(--spacing-lg) var(--spacing-xl);display:flex;justify-content:center;align-items:center;gap:var(--spacing-md);border-bottom:1px solid var(--border-light)}.leaderboard-stars{display:none}.leaderboard-title{font-family:var(--font-family);font-size:24px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;margin:0}.leaderboard-tabs{display:flex;background:var(--bg-white);padding:var(--spacing-sm);gap:var(--spacing-xs);justify-content:center;border-bottom:1px solid var(--border-light)}.leaderboard-tab{background:transparent;border:1px solid var(--border-light);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);color:var(--text-muted);font-family:var(--font-family);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.leaderboard-tab:hover{border-color:var(--text-muted);color:var(--text-primary)}.leaderboard-tab.active{background:var(--text-primary);border-color:var(--text-primary);color:#fff}.leaderboard-table-container{padding:16px;max-height:400px;overflow-y:auto}.leaderboard-table{width:100%;border-collapse:collapse;font-family:Courier New,monospace}.leaderboard-table thead tr{background:#6366f133;border-bottom:2px solid #6366f1}.leaderboard-table th{padding:12px 8px;text-align:left;color:#818cf8;font-size:12px;font-weight:600;letter-spacing:1px}.leaderboard-table tbody tr{border-bottom:1px solid rgba(99,102,241,.2);transition:all .2s ease}.leaderboard-table tbody tr:hover{background:#6366f11a}.leaderboard-table tbody tr.highlight{background:#fbbf2426;border:1px solid rgba(251,191,36,.3)}.leaderboard-table td{padding:14px 8px;color:#e2e8f0;font-size:14px}.col-rank{width:80px;text-align:center}.col-player{width:40%}.col-score{width:100px;text-align:center}.col-team{width:30%}.rank-medal{font-size:20px;display:inline-block;min-width:32px;text-align:center}.rank-number{color:#64748b;font-weight:600}.player-name{font-weight:600;color:#f1f5f9}.player-name.current-user{color:#fbbf24;text-shadow:0 0 10px rgba(251,191,36,.5)}.score-xp{font-weight:700;color:#34d399;font-family:"Press Start 2P",Courier New,monospace;font-size:12px}.team-name{color:#94a3b8;font-size:13px}.leaderboard-footer{background:#0f0f23;padding:16px 20px;border-top:2px solid #334155;display:flex;justify-content:space-between;align-items:center}.leaderboard-my-rank{display:flex;align-items:center;gap:12px;color:#e2e8f0;font-family:Courier New,monospace}.leaderboard-my-rank .my-rank-label{color:#94a3b8;font-size:12px}.leaderboard-my-rank .my-rank-value{color:#fbbf24;font-size:18px;font-weight:700}.leaderboard-my-rank .my-score-value{color:#34d399;font-weight:600}.btn-leaderboard-close{background:linear-gradient(180deg,#ef4444,#dc2626);border:2px solid #f87171;border-radius:8px;padding:12px 32px;color:#fff;font-family:"Press Start 2P",Courier New,monospace;font-size:11px;cursor:pointer;transition:all .2s ease;text-shadow:1px 1px 2px rgba(0,0,0,.5)}.btn-leaderboard-close:hover{background:linear-gradient(180deg,#f87171,#ef4444);transform:scale(1.05)}.leaderboard-table-container::-webkit-scrollbar{width:8px}.leaderboard-table-container::-webkit-scrollbar-track{background:#1a1a2e}.leaderboard-table-container::-webkit-scrollbar-thumb{background:#6366f1;border-radius:4px}.leaderboard-table-container::-webkit-scrollbar-thumb:hover{background:#818cf8}.leaderboard-empty{text-align:center;padding:40px 20px;color:#64748b}.leaderboard-empty-icon{font-size:48px;margin-bottom:16px}.leaderboard-empty-text{font-size:14px;color:#94a3b8}.inline-leaderboard-area{width:100%;height:100%;display:flex;flex-direction:column;padding:20px 24px;overflow-y:auto;background:linear-gradient(180deg,#f8fafcfa,#f1f5f9f2)}.inline-leaderboard-header{text-align:center;margin-bottom:16px}.inline-leaderboard-stars{font-size:24px;margin-bottom:8px;animation:twinkle 1.5s ease-in-out infinite}@keyframes twinkle{0%,to{opacity:1}50%{opacity:.5}}.inline-leaderboard-title{font-size:24px;font-weight:800;color:#1e293b;margin:0;letter-spacing:-.02em}.inline-leaderboard-subtitle{font-size:12px;color:#64748b;margin-top:4px}.inline-leaderboard-my-score{display:flex;align-items:center;gap:16px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:12px;padding:16px 20px;margin-bottom:16px;box-shadow:0 4px 12px #6366f14d}.my-score-rank{font-size:28px;font-weight:800;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.2)}.my-score-info{display:flex;flex-direction:column}.my-score-info .my-score-label{font-size:12px;color:#fffc}.my-score-info .my-score-value{font-size:20px;font-weight:700;color:#fff}.inline-leaderboard-list{flex:1;display:flex;flex-direction:column;gap:8px;overflow-y:auto;padding-right:4px}.inline-leaderboard-item{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:12px 16px;animation:fadeInUp .3s ease-out both;transition:transform .2s ease,box-shadow .2s ease}.inline-leaderboard-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.inline-leaderboard-item.current-user{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;animation:highlightPulse 2s ease-in-out infinite}@keyframes highlightPulse{0%,to{box-shadow:0 0 #f59e0b66}50%{box-shadow:0 0 0 8px #f59e0b00}}.leaderboard-rank{min-width:40px;font-size:18px;font-weight:700;color:#64748b;text-align:center}.inline-leaderboard-item:nth-child(1) .leaderboard-rank,.inline-leaderboard-item:nth-child(2) .leaderboard-rank,.inline-leaderboard-item:nth-child(3) .leaderboard-rank{font-size:22px}.leaderboard-name{flex:1;font-size:14px;font-weight:600;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inline-leaderboard-item.current-user .leaderboard-name{color:#92400e}.leaderboard-team{font-size:11px;color:#94a3b8;background:#f1f5f9;padding:4px 8px;border-radius:4px}.inline-leaderboard-item.current-user .leaderboard-team{background:#92400e1a;color:#92400e}.leaderboard-score{font-size:14px;font-weight:700;color:#6366f1;min-width:60px;text-align:right}.inline-leaderboard-item.current-user .leaderboard-score{color:#b45309}.inline-leaderboard-actions{display:flex;gap:12px;margin-top:16px;padding-top:16px;border-top:1px solid #e2e8f0}.inline-leaderboard-actions .btn-retry-inline,.inline-leaderboard-actions .btn-share-inline{flex:1;padding:12px 16px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.inline-leaderboard-actions .btn-retry-inline{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.inline-leaderboard-actions .btn-retry-inline:hover{transform:translateY(-2px);box-shadow:0 4px 12px #6366f166}.inline-leaderboard-actions .btn-share-inline{background:#fff;color:#64748b;border:1px solid #e2e8f0}.inline-leaderboard-actions .btn-share-inline:hover{background:#f8fafc;color:#1e293b;border-color:#cbd5e1}.inline-leaderboard-list::-webkit-scrollbar{width:6px}.inline-leaderboard-list::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.inline-leaderboard-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.inline-leaderboard-list::-webkit-scrollbar-thumb:hover{background:#94a3b8}.results-loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:24px;color:#64748b;font-size:14px}.loading-spinner{width:20px;height:20px;border:2px solid #e2e8f0;border-top-color:#6366f1;border-radius:50%;animation:spin 1s linear infinite}.toast-container{position:fixed;top:70px;left:50%;transform:translate(-50%);z-index:99999;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-primary, #fff);border:1px solid var(--border-light, #e5e5e5);border-radius:8px;box-shadow:0 4px 12px #00000026;font-size:14px;color:var(--text-primary, #37352f);pointer-events:auto;transform:translate(120%);opacity:0;transition:transform .3s ease,opacity .3s ease;max-width:360px}.toast.show{transform:translate(0);opacity:1}.toast.hide{transform:translate(120%);opacity:0}.toast-icon{font-size:18px;flex-shrink:0}.toast-message{flex:1;line-height:1.4}.toast-message strong{font-weight:600}.toast-close{background:none;border:none;font-size:18px;color:var(--text-secondary, #787774);cursor:pointer;padding:0 4px;line-height:1}.toast-close:hover{color:var(--text-primary, #37352f)}.toast-mention{border-left:4px solid var(--accent-primary, #2383e2);background:#f7fafc}.toast-success{border-left:4px solid #10b981}.toast-error{border-left:4px solid #ef4444}.team-workspace-header{display:flex;align-items:center;gap:16px;padding:16px 24px;border-bottom:1px solid var(--border-color, #e5e5e5);background:var(--bg-secondary, #fafafa)}.team-workspace-title{display:flex;align-items:center;gap:8px}.team-workspace-title h2{margin:0;font-size:18px;font-weight:600}.team-view-tabs{display:flex;gap:4px;margin-left:auto;margin-right:16px}.team-view-tab{padding:6px 12px;font-size:13px;font-weight:500;border:none;border-radius:6px;background:transparent;color:var(--text-secondary, #787774);cursor:pointer;transition:all .15s ease}.team-view-tab:hover{background:var(--bg-hover, rgba(0, 0, 0, .04))}.team-view-tab.active{background:var(--accent-primary, #2383e2);color:#fff}.team-channel-chat{display:flex;flex-direction:column;height:calc(100vh - 160px);background:#fff}.channel-chat-header{display:flex;align-items:center;gap:4px;padding:12px 24px;border-bottom:1px solid var(--border-color, #e5e5e5);font-size:16px;font-weight:600}.channel-chat-header .channel-hash{color:var(--text-tertiary, #a0a0a0);font-weight:400}.channel-chat-messages{flex:1;overflow-y:auto;padding:16px 24px;display:flex;flex-direction:column;gap:8px}.channel-message{display:flex;gap:12px;padding:8px 12px;border-radius:8px;transition:background .1s ease}.channel-message:hover{background:var(--bg-hover, rgba(0, 0, 0, .02))}.channel-message-avatar{width:40px;height:40px;border-radius:50%;background:var(--accent-primary, #2383e2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;flex-shrink:0}.channel-message-avatar.ai{background:linear-gradient(135deg,#10b981,#059669)}.channel-message-body{flex:1;min-width:0}.channel-message-header{display:flex;align-items:baseline;gap:8px;margin-bottom:4px}.channel-message-author{font-weight:600;font-size:14px;color:var(--text-primary, #37352f)}.channel-message-author.ai{color:#10b981}.channel-message-time{font-size:11px;color:var(--text-tertiary, #a0a0a0)}.channel-message-content{font-size:14px;line-height:1.5;color:var(--text-primary, #37352f);word-wrap:break-word}.channel-message-content .mention{background:#2383e21a;color:var(--accent-primary, #2383e2);padding:0 4px;border-radius:4px;font-weight:500}.channel-chat-input-area{display:flex;gap:12px;padding:16px 24px;border-top:1px solid var(--border-color, #e5e5e5);background:var(--bg-secondary, #fafafa)}.channel-chat-input{flex:1;padding:12px 16px;font-size:14px;border:1px solid var(--border-color, #e5e5e5);border-radius:8px;resize:none;font-family:inherit;background:#fff}.channel-chat-input:focus{outline:none;border-color:var(--accent-primary, #2383e2);box-shadow:0 0 0 3px #2383e21a}.btn-send-main{width:44px;height:44px;border:none;border-radius:8px;background:var(--accent-primary, #2383e2);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s ease}.btn-send-main:hover{background:var(--accent-primary-hover, #1a6bc0)}.btn-send-main svg{width:20px;height:20px}.channel-typing-indicator{padding:4px 24px;font-size:12px;color:var(--text-tertiary, #a0a0a0);min-height:20px}.channel-chat-messages .chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--text-secondary, #787774)}.channel-chat-messages .chat-empty p{margin:4px 0}.channel-chat-messages .chat-empty .hint{font-size:13px;color:var(--text-tertiary, #a0a0a0)}.channel-item.active{background:#2383e21a;color:var(--accent-primary, #2383e2)}.channel-item.active .channel-hash{color:var(--accent-primary, #2383e2)}.sidebar-member.active{background:#2383e21a}.team-chat-floating{position:fixed;bottom:20px;right:20px;width:380px;max-height:500px;background:#fff;border-radius:12px;box-shadow:0 8px 30px #00000026;display:none;flex-direction:column;z-index:1000;overflow:hidden}.floating-chat-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--accent-primary, #2383e2);color:#fff}.floating-chat-title{display:flex;align-items:center;gap:4px;font-weight:600}.btn-close-chat{background:none;border:none;color:#fff;font-size:20px;cursor:pointer;padding:0 4px;line-height:1}.floating-chat-messages{flex:1;overflow-y:auto;padding:12px;max-height:350px}.floating-chat-input-area{display:flex;gap:8px;padding:12px;border-top:1px solid var(--border-color, #e5e5e5)}.floating-chat-input{flex:1;padding:10px 12px;font-size:14px;border:1px solid var(--border-color, #e5e5e5);border-radius:8px;resize:none;font-family:inherit}.btn-send-float{padding:8px 16px;background:var(--accent-primary, #2383e2);color:#fff;border:none;border-radius:8px;font-size:14px;cursor:pointer}.btn-send-float:hover{background:var(--accent-primary-hover, #1a6bc0)}.float-chat-message{padding:8px 12px;border-radius:8px;margin-bottom:8px;background:var(--bg-secondary, #f7f7f7)}.float-chat-message.mine{background:#2383e21a}.float-chat-message.ai{background:#10b9811a}.float-msg-header{display:flex;align-items:baseline;gap:8px;margin-bottom:4px}.float-msg-author{font-weight:600;font-size:13px;color:var(--text-primary, #37352f)}.float-msg-author.ai-author{color:#10b981}.float-msg-time{font-size:11px;color:var(--text-tertiary, #a0a0a0)}.float-msg-content{font-size:13px;line-height:1.4;color:var(--text-primary, #37352f);word-wrap:break-word}.floating-chat-messages .chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;color:var(--text-secondary, #787774);padding:20px}.floating-chat-messages .chat-empty p{margin:4px 0;font-size:13px}.team-page.discord-style{height:100%;overflow:hidden}.team-page.discord-style #team-workspace-content{height:100%}.discord-chat-container{display:flex;flex-direction:column;height:100%;background:#36393f}.discord-channel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#36393f;border-bottom:1px solid #202225;min-height:48px}.discord-channel-header .channel-info{display:flex;align-items:center;gap:4px;font-size:16px;font-weight:600;color:#fff}.discord-channel-header .channel-hash{color:#72767d;font-weight:400}.discord-channel-header .channel-actions{display:flex;gap:8px}.btn-channel-action{width:32px;height:32px;border:none;border-radius:4px;background:transparent;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.btn-channel-action:hover{background:#ffffff1a}.discord-messages{flex:1;overflow-y:auto;padding:16px;background:#36393f}.discord-message{display:flex;gap:16px;padding:4px 0;margin-bottom:16px}.discord-message:hover{background:#04040512;margin-left:-16px;margin-right:-16px;padding-left:16px;padding-right:16px}.discord-avatar{width:40px;height:40px;border-radius:50%;background:#5865f2;color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;flex-shrink:0}.discord-avatar.ai{background:linear-gradient(135deg,#10b981,#059669)}.discord-message-body{flex:1;min-width:0}.discord-message-header{display:flex;align-items:baseline;gap:8px;margin-bottom:4px}.discord-author{font-weight:600;font-size:15px;color:#fff}.discord-author.ai{color:#10b981}.discord-timestamp{font-size:12px;color:#72767d}.discord-content{font-size:15px;line-height:1.4;color:#dcddde;word-wrap:break-word}.discord-content .mention{background:#5865f24d;color:#dee0fc;padding:0 4px;border-radius:4px;font-weight:500}.discord-typing{padding:8px 16px;font-size:12px;color:#72767d;min-height:24px;background:#36393f}.discord-input-area{display:flex;align-items:flex-end;gap:8px;padding:16px;background:#36393f}.btn-attach{width:44px;height:44px;border:none;border-radius:8px;background:#40444b;color:#b9bbbe;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.btn-attach:hover{background:#4f545c;color:#dcddde}.btn-attach svg{width:20px;height:20px}.input-wrapper{flex:1;background:#40444b;border-radius:8px;padding:0 16px}.discord-input{width:100%;padding:12px 0;font-size:15px;border:none;background:transparent;color:#dcddde;resize:none;font-family:inherit;max-height:200px}.discord-input::placeholder{color:#72767d}.discord-input:focus{outline:none}.btn-emoji{width:44px;height:44px;border:none;border-radius:8px;background:transparent;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s}.btn-emoji:hover{transform:scale(1.1)}.btn-send-discord{width:44px;height:44px;border:none;border-radius:8px;background:#5865f2;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.btn-send-discord:hover{background:#4752c4}.btn-send-discord svg{width:20px;height:20px}.discord-messages .chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;color:#72767d}.discord-messages .chat-empty p{margin:8px 0}.discord-messages .chat-empty .hint{font-size:14px;color:#4f545c}.worksheet-modal{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.worksheet-modal-content{width:90%;max-width:900px;max-height:90vh;background:#fff;border-radius:12px;display:flex;flex-direction:column;overflow:hidden}.worksheet-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e5e5e5}.worksheet-modal-header h3{margin:0;font-size:18px}.btn-close-worksheet{width:32px;height:32px;border:none;border-radius:6px;background:transparent;font-size:20px;cursor:pointer;color:#787774}.btn-close-worksheet:hover{background:#f0f0f0}.worksheet-modal .team-worksheet-area{flex:1;overflow-y:auto;padding:20px}.team-page.discord-style~.right-panel,body:has(.team-page.discord-style[style*=block]) .right-panel{display:none!important}.inline-toast{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#f7f6f3;border:1px solid #e8e7e4;border-radius:6px;font-size:13px;color:#787774;margin-top:12px;animation:toastFadeIn .3s ease-out}.inline-toast.fade-out{animation:toastFadeOut .5s ease-out forwards}.inline-toast-icon{font-size:14px}.inline-toast-text{flex:1}.inline-toast-text strong{color:#37352f;font-weight:500}@keyframes toastFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes toastFadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-8px)}}.level-up-modal{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}.level-up-modal.show{opacity:1;visibility:visible}.level-up-modal.hide{opacity:0}.level-up-backdrop{position:absolute;inset:0;background:#0009}.level-up-content{position:relative;background:#fff;border-radius:16px;padding:40px 48px;text-align:center;box-shadow:0 20px 60px #0000004d;transform:scale(.8);transition:transform .3s cubic-bezier(.34,1.56,.64,1);max-width:360px;width:90%;overflow:hidden}.level-up-modal.show .level-up-content{transform:scale(1)}.level-up-confetti{position:absolute;inset:0;pointer-events:none;overflow:hidden}.confetti-piece{position:absolute;width:10px;height:10px;top:-20px;border-radius:2px;animation:confettiFall 2s ease-out forwards}@keyframes confettiFall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(400px) rotate(720deg);opacity:0}}.level-up-icon-container{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:16px}.level-up-icon-old{font-size:36px;opacity:.5}.level-up-arrow{font-size:24px;color:#666}.level-up-icon-new{font-size:48px;animation:iconBounce .6s ease-out}@keyframes iconBounce{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.level-up-title{font-size:28px;font-weight:700;color:gold;margin:0 0 12px;text-shadow:0 2px 4px rgba(0,0,0,.1);animation:titlePulse .8s ease-out}@keyframes titlePulse{0%{transform:scale(.5);opacity:0}60%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.level-up-level{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.level-up-number{font-size:32px;font-weight:700;color:#2eaadc}.level-up-name{font-size:18px;font-weight:600;color:#37352f}.level-up-message{font-size:14px;color:#6b6b6b;margin:0 0 24px}.level-up-button{background:linear-gradient(135deg,#2eaadc,#1a8bb9);color:#fff;border:none;padding:12px 32px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.level-up-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #2eaadc66}.badge-earned-toast{position:fixed;bottom:24px;right:24px;background:#fff;border-radius:12px;padding:16px 20px;display:flex;align-items:center;gap:12px;box-shadow:0 8px 24px #00000026;z-index:9999;transform:translate(120%);transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.badge-earned-toast.show{transform:translate(0)}.badge-toast-icon{font-size:32px}.badge-toast-title{font-size:12px;color:#6b6b6b;margin-bottom:2px}.badge-toast-name{font-size:15px;font-weight:600;color:#37352f}.xp-animation{position:absolute;right:8px;top:-8px;font-size:16px;font-weight:700;color:#fff;background:linear-gradient(135deg,#10b981,#059669);padding:4px 12px;border-radius:16px;box-shadow:0 2px 8px #10b98166,0 0 16px #10b98133;animation:xpPopFloat 1.8s cubic-bezier(.34,1.56,.64,1) forwards;pointer-events:none;z-index:1000;white-space:nowrap;letter-spacing:.5px}.xp-animation:before{content:"✨";margin-right:4px;font-size:12px}@keyframes xpPopFloat{0%{opacity:0;transform:translateY(10px) scale(.5)}15%{opacity:1;transform:translateY(-5px) scale(1.2)}30%{transform:translateY(-10px) scale(1)}70%{opacity:1;transform:translateY(-25px) scale(1)}to{opacity:0;transform:translateY(-40px) scale(.9)}}.btn-expert-edit{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;color:var(--text-muted);background:transparent;border:1px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.btn-expert-edit:hover{color:var(--accent-primary);border-color:var(--accent-primary);background:#7c3aed0d}.btn-expert-edit .edit-icon{font-size:14px}.editor-overlay{position:fixed;inset:0;background:#0f0f0f99;display:flex;align-items:center;justify-content:center;z-index:9999}.editor-modal{width:90%;max-width:720px;max-height:85vh;background:var(--bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden}.editor-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-light)}.editor-header h3{font-size:16px;font-weight:600;color:var(--text-primary)}.editor-header-actions{display:flex;gap:8px}.btn-editor-save{padding:6px 16px;font-size:13px;font-weight:500;color:#fff;background:var(--accent-primary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.btn-editor-save:hover{background:var(--accent-primary-hover)}.btn-editor-close{padding:6px 12px;font-size:13px;color:var(--text-muted);background:transparent;border:1px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.btn-editor-close:hover{background:var(--bg-elevated)}.editor-body{flex:1;overflow-y:auto;padding:16px 20px}.editor-block{margin-bottom:16px;border:1px solid var(--border-light);border-radius:var(--radius-md);background:var(--bg-white)}.block-header{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--bg-elevated);border-bottom:1px solid var(--border-light)}.block-number{width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#fff;background:var(--accent-primary);border-radius:50%}.block-title{flex:1;font-size:13px;font-weight:600;color:var(--text-primary)}.btn-block-edit,.btn-block-search{padding:4px 10px;font-size:11px;font-weight:500;color:var(--text-muted);background:transparent;border:1px solid var(--border-light);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.btn-block-edit:hover{color:var(--accent-primary);border-color:var(--accent-primary)}.btn-block-search{color:var(--accent-success);border-color:var(--accent-success)}.btn-block-search:hover{background:var(--accent-success-light)}.block-content{padding:12px 14px}.empty-block{font-size:13px;color:var(--text-muted);font-style:italic}.block-list{list-style:none;margin:0;padding:0}.block-list-item{padding:6px 0;font-size:13px;color:var(--text-primary);border-bottom:1px solid var(--border-light)}.block-list-item:last-child{border-bottom:none}.block-content .criteria-item{display:flex;flex-direction:column;gap:2px}.block-content .criteria-name{font-weight:500;color:var(--text-primary)}.block-content .criteria-desc{font-size:12px;color:var(--text-muted)}.coaching-hints-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.coaching-hint-item{padding:8px 10px;background:var(--bg-elevated);border-radius:var(--radius-sm)}.level-label{display:block;font-size:11px;font-weight:600;color:var(--accent-primary);margin-bottom:4px}.level-hint{font-size:12px;color:var(--text-primary);line-height:1.4}.reference-item{display:flex;align-items:center;gap:8px}.ref-type{font-size:10px;font-weight:500;color:#fff;background:var(--accent-primary);padding:2px 6px;border-radius:10px}.ref-name{font-weight:500}.ref-source{font-size:12px;color:var(--text-muted)}.misconception-item{display:flex;align-items:flex-start;gap:8px}.misc-warning{color:var(--accent-warning);font-size:14px}.question-item{padding-left:16px;position:relative}.question-item:before{content:"•";position:absolute;left:0;color:var(--accent-primary)}.editor-error{padding:20px;text-align:center;color:var(--accent-error);font-size:14px}.curriculum-editor-inline{margin:12px 0;border:1px solid var(--border-light);border-radius:var(--radius-md);background:var(--bg-elevated)}.editor-toggle{display:flex;align-items:center;gap:8px;padding:10px 14px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition-fast)}.editor-toggle:hover{background:#00000008}.toggle-icon{font-size:16px;color:var(--text-muted)}.toggle-text{flex:1;font-size:13px;font-weight:500;color:var(--text-primary)}.toggle-arrow{font-size:10px;color:var(--text-muted);transition:transform var(--transition-fast)}.editor-content{border-top:1px solid var(--border-light);padding:12px 14px;background:var(--bg-white)}.editor-loading{text-align:center;padding:20px;color:var(--text-muted);font-size:13px}.editor-loading .error{color:var(--accent-error)}.editor-toggle .preview-eval-btn{padding:4px 10px;background:#37352f14;color:var(--text-primary, #37352f);border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:background .1s ease;margin-left:auto;margin-right:8px}.editor-toggle .preview-eval-btn:hover:not(:disabled){background:#37352f29}.editor-toggle .preview-eval-btn:disabled{opacity:.5;cursor:not-allowed}.preview-eval-result{margin-top:12px}.preview-eval-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.preview-level-badge{padding:4px 12px;color:#fff;border-radius:12px;font-size:14px;font-weight:600}.preview-label{color:var(--text-muted);font-size:12px}.preview-feedback{background:var(--bg-elevated);border-left:3px solid var(--accent-primary);padding:12px 16px;border-radius:0 var(--radius-md) var(--radius-md) 0;color:var(--text-primary);line-height:1.6;font-size:14px;white-space:pre-wrap}.preview-error{padding:12px 16px;background:#fee2e2;border-left:3px solid var(--accent-error);border-radius:0 var(--radius-md) var(--radius-md) 0;color:#991b1b;font-size:14px}.editor-blocks .editor-block{margin-bottom:12px;border:1px solid var(--border-light);border-radius:var(--radius-sm);background:var(--bg-white)}.editor-blocks .editor-block:last-child{margin-bottom:0}.editor-blocks .block-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-elevated);border-bottom:1px solid var(--border-light)}.editor-blocks .block-number{width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:#fff;background:var(--accent-primary);border-radius:50%}.editor-blocks .block-title{font-size:12px;font-weight:600;color:var(--text-primary)}.editor-blocks .block-content{padding:10px 12px}.editor-blocks .block-list{list-style:none;margin:0;padding:0}.editor-blocks .block-list li{padding:4px 0;font-size:12px;color:var(--text-primary);line-height:1.5}.editor-blocks .block-list li strong{font-weight:500}.editor-blocks .criteria-desc{display:block;font-size:11px;color:var(--text-muted);margin-top:2px}.coaching-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.coaching-item{padding:6px 8px;background:var(--bg-elevated);border-radius:var(--radius-sm)}.level-badge{display:inline-block;font-size:10px;font-weight:600;padding:1px 6px;border-radius:8px;margin-right:6px}.level-badge.level-탁월{background:#dcfce7;color:#166534}.level-badge.level-우수{background:#dbeafe;color:#1e40af}.level-badge.level-보통{background:#fef3c7;color:#92400e}.level-badge.level-미흡{background:#fee2e2;color:#991b1b}.levels-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.level-item{padding:10px;background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-sm)}.level-item.level-item-탁월{border-left:3px solid #22c55e}.level-item.level-item-우수{border-left:3px solid #3b82f6}.level-item.level-item-보통{border-left:3px solid #f59e0b}.level-item.level-item-미흡{border-left:3px solid #ef4444}.level-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.level-score{font-size:10px;color:var(--text-muted)}.level-criteria-list{margin:0;padding-left:16px;font-size:11px;line-height:1.5;color:var(--text-secondary)}.level-criteria-list li{margin-bottom:4px}.level-item .coaching-hint{margin-top:8px;padding-top:6px;border-top:1px dashed var(--border-light);font-size:10px;color:var(--text-muted)}.levels-form{display:flex;flex-direction:column;gap:12px}.level-edit-section{padding:10px;background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-sm)}.level-edit-section[data-level=탁월]{border-left:3px solid #22c55e}.level-edit-section[data-level=우수]{border-left:3px solid #3b82f6}.level-edit-section[data-level=보통]{border-left:3px solid #f59e0b}.level-edit-section[data-level=미흡]{border-left:3px solid #ef4444}.level-edit-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.level-score-edit{font-size:11px;color:var(--text-muted)}.level-score-edit input{width:40px;padding:2px 4px;border:1px solid var(--border-light);border-radius:3px;font-size:11px;text-align:center}.level-criteria-container{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.level-criteria-item{display:flex;gap:6px;align-items:center}.level-criteria-input{flex:1;padding:6px 8px;border:1px solid var(--border-light);border-radius:var(--radius-sm);font-size:12px}.btn-add-level-criteria{font-size:11px;padding:4px 8px}.checklist-list{list-style:none;padding:0;margin:0}.checklist-list li{padding:6px 0;font-size:12px;color:var(--text-secondary);border-bottom:1px dashed var(--border-light)}.checklist-list li:last-child{border-bottom:none}.checklist-form{display:flex;flex-direction:column;gap:8px}.checklist-items-container{display:flex;flex-direction:column;gap:6px}.checklist-edit-item{display:flex;gap:6px;align-items:center}.checklist-input{flex:1;padding:6px 8px;border:1px solid var(--border-light);border-radius:var(--radius-sm);font-size:12px}.hint-text{font-size:11px;color:var(--text-primary);line-height:1.4}.refs-container{display:flex;flex-direction:column;gap:8px}.ref-card{padding:10px 12px;background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-sm)}.ref-header{display:flex;align-items:center;gap:6px;margin-bottom:6px}.ref-badge{font-size:11px;font-weight:500;color:#37352f;background:#f1f1ef;padding:3px 8px;border-radius:4px}.ref-badge.ref-concept{background:#e3e2e0;color:#37352f}.ref-badge.ref-case{background:#dbeddb;color:#1e5128}.ref-badge.ref-method{background:#fadec9;color:#8b4513}.ref-badge.ref-framework{background:#e8deee;color:#5a3d7a}.ref-name{font-size:13px;font-weight:600;color:var(--text-primary)}.ref-name-en{font-size:11px;color:var(--text-muted)}.ref-definition{font-size:12px;line-height:1.5;color:var(--text-secondary);margin-bottom:6px}.ref-source{font-size:10px;color:var(--text-muted)}.refs-actions{display:flex;gap:8px;margin-top:8px;padding-top:8px;border-top:1px dashed var(--border-light)}.btn-ref-search,.btn-ref-add{padding:5px 10px;font-size:11px;border:1px solid var(--border-light);border-radius:var(--radius-sm);background:#fff;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.btn-ref-search:hover:not(:disabled),.btn-ref-add:hover:not(:disabled){background:var(--bg-elevated);color:var(--accent-primary);border-color:var(--accent-primary)}.btn-ref-search:disabled,.btn-ref-add:disabled{opacity:.5;cursor:not-allowed}.misc-list li{display:flex;flex-wrap:wrap;align-items:flex-start;gap:6px;margin-bottom:8px}.misc-icon{color:var(--accent-warning)}.misc-text{flex:1}.misc-badge{font-size:10px;padding:1px 6px;border-radius:8px;font-weight:500}.misc-badge.misc-auto{background:#e8f4fc;color:#4a90d9}.misc-concept{font-size:11px;color:#999}.misc-correction{display:block;width:100%;font-size:12px;color:#666;margin-top:2px;padding-left:20px}.misc-view-container{display:flex;flex-direction:column;gap:8px}.misc-suggest-actions{margin-top:8px;text-align:right}.btn-misc-suggest{padding:6px 12px;font-size:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.btn-misc-suggest:hover{opacity:.9;transform:translateY(-1px)}.btn-misc-suggest:disabled{opacity:.6;cursor:not-allowed;transform:none}.misc-edit-actions{display:flex;gap:8px;margin-top:8px}.misc-suggest-results{margin-top:12px;padding:12px;background:#f8f9ff;border:1px dashed var(--accent-primary);border-radius:var(--radius-md)}.misc-suggest-header{font-size:13px;font-weight:600;color:var(--text-dark);margin-bottom:8px}.btn-add-selected{margin-top:8px;padding:6px 12px;font-size:12px;background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer}.btn-add-selected:hover{background:var(--accent-primary-hover)}.loading-text{font-size:12px;color:var(--text-muted);font-style:italic}.error-text{font-size:12px;color:var(--accent-error, #dc3545)}.misc-suggest-item{padding:12px;border-bottom:1px solid var(--border-light)}.misc-suggest-item:last-child{border-bottom:none}.misc-suggest-checkbox{display:flex;gap:10px;cursor:pointer}.misc-suggest-checkbox input[type=checkbox]{margin-top:4px}.misc-suggest-content{flex:1}.misc-pattern{font-size:14px;color:var(--text-dark);margin:4px 0}.misc-correction-text{font-size:12px;color:#666;margin:0}.questions-list li{font-style:italic;color:var(--text-muted)}.empty-text{font-size:12px;color:var(--text-muted);font-style:italic}.block-actions{margin-left:auto}.btn-block-edit,.btn-block-save,.btn-block-cancel{padding:3px 8px;font-size:11px;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.btn-block-edit{background:transparent;color:var(--text-muted);border:1px solid var(--border-light)}.btn-block-edit:hover{background:var(--bg-elevated);color:var(--text-primary)}.btn-block-save{background:var(--accent-primary);color:#fff;margin-right:4px}.btn-block-save:hover{background:var(--accent-primary-dark, #0066cc)}.btn-block-cancel{background:transparent;color:var(--text-muted);border:1px solid var(--border-light)}.btn-block-cancel:hover{background:var(--bg-elevated)}.edit-form{padding:8px 0}.edit-form label{display:block;font-size:11px;font-weight:500;color:var(--text-muted);margin-bottom:6px}.edit-form textarea{width:100%;padding:8px 10px;font-size:12px;font-family:inherit;line-height:1.5;border:1px solid var(--border-light);border-radius:var(--radius-sm);resize:vertical;min-height:80px}.edit-form textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #0066cc1a}.criteria-form .criteria-items-container{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.criteria-form .criteria-item{display:flex!important;flex-direction:row!important;gap:10px;align-items:center;width:100%;background:none!important;padding:0!important;border:none!important}.criteria-form .criteria-item .criteria-name,.criteria-form .criteria-item input.criteria-name{flex:0 0 180px!important;width:180px!important;height:auto!important;min-height:unset!important;max-height:unset!important;padding:10px 12px!important;font-size:14px!important;font-weight:500;line-height:1.4!important;border:1px solid var(--border-light)!important;border-radius:var(--radius-sm)!important;background:#fff!important;box-sizing:border-box!important}.criteria-form .criteria-item .criteria-desc,.criteria-form .criteria-item input.criteria-desc{flex:1!important;height:auto!important;min-height:unset!important;max-height:unset!important;padding:10px 12px!important;font-size:14px!important;line-height:1.4!important;border:1px solid var(--border-light)!important;border-radius:var(--radius-sm)!important;background:#fff!important;box-sizing:border-box!important}.criteria-form input:focus{outline:none;border-color:var(--accent-primary)}.criteria-form .btn-remove-item{flex-shrink:0}.btn-add-item{padding:4px 10px;font-size:11px;color:var(--accent-primary);background:transparent;border:1px dashed var(--accent-primary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.btn-add-item:hover{background:#0066cc0d}.btn-remove-item{width:20px;height:20px;padding:0;font-size:14px;color:var(--text-muted);background:transparent;border:none;cursor:pointer;border-radius:50%}.btn-remove-item:hover{color:var(--accent-error);background:#ef44441a}.coaching-form .coaching-edit-item{display:flex;align-items:center;gap:10px;margin-bottom:8px}.coaching-form .coaching-edit-item label{min-width:40px;margin-bottom:0}.coaching-form .coaching-edit-item input{flex:1;padding:6px 8px;font-size:12px;border:1px solid var(--border-light);border-radius:var(--radius-sm)}.coaching-form .coaching-edit-item input:focus{outline:none;border-color:var(--accent-primary)}.editor-toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%);padding:10px 20px;background:#333;color:#fff;font-size:13px;border-radius:var(--radius-md);box-shadow:0 4px 12px #00000026;z-index:9999;animation:toastIn .3s ease}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.refs-edit-form .ref-edit-item{padding:10px;margin-bottom:10px;background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-sm)}.refs-edit-form .ref-edit-row{display:flex;gap:8px;margin-bottom:8px;align-items:center}.refs-edit-form .ref-type{width:90px;padding:6px 28px 6px 10px;font-size:12px;font-weight:500;color:#37352f;background:#f1f1ef;border:none;border-radius:4px;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2337352f' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.refs-edit-form .ref-type:hover{background-color:#e8e8e6}.refs-edit-form .ref-type:focus{outline:none;box-shadow:0 0 0 2px #37352f1a}.refs-edit-form .ref-name{flex:1;padding:6px 8px;font-size:12px;border:1px solid var(--border-light);border-radius:var(--radius-sm)}.refs-edit-form .ref-definition{width:100%;padding:6px 8px;font-size:12px;font-family:inherit;border:1px solid var(--border-light);border-radius:var(--radius-sm);margin-bottom:6px;resize:vertical;min-height:50px}.refs-edit-form .ref-source{width:100%;padding:6px 8px;font-size:11px;border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-muted)}.refs-edit-form input:focus,.refs-edit-form select:focus,.refs-edit-form textarea:focus{outline:none;border-color:var(--accent-primary)}.misc-edit-form .misc-items-container{display:flex;flex-direction:column;gap:12px;margin-bottom:12px}.misc-edit-form .misc-edit-item{padding:12px;background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-sm)}.misc-edit-form .misc-edit-row{display:flex;gap:8px;margin-bottom:8px;align-items:center}.misc-edit-form .misc-desc{flex:1;padding:10px 12px;font-size:14px;border:1px solid var(--border-light);border-radius:var(--radius-sm)}.misc-edit-form .misc-correction{width:100%;padding:10px 12px;font-size:13px;border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-secondary)}.misc-edit-form input:focus{outline:none;border-color:var(--accent-primary)}.refs-search-row{display:flex;gap:8px;margin:12px 0;padding:10px;background:#f9f9f8;border-radius:var(--radius-sm)}.rag-search-input{flex:1;padding:8px 12px;font-size:13px;border:1px solid var(--border-light);border-radius:var(--radius-sm);background:#fff}.rag-search-input:focus{outline:none;border-color:var(--accent-primary)}.rag-search-input::placeholder{color:#999}.refs-items-container{margin-bottom:8px}.refs-edit-actions{display:flex;gap:8px;margin-top:8px}.btn-rag-search{padding:8px 16px;font-size:12px;font-weight:500;color:#fff;background:var(--accent-primary);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.btn-rag-search:hover{background:var(--accent-primary-hover)}.btn-rag-search:disabled{background:#ccc;cursor:not-allowed}.misc-edit-form .misc-edit-item{display:flex;gap:8px;margin-bottom:8px;align-items:center}.misc-edit-form .misc-desc{flex:1;padding:8px 10px;font-size:12px;border:1px solid var(--border-light);border-radius:var(--radius-sm)}.misc-edit-form .misc-desc:focus{outline:none;border-color:var(--accent-primary)}.rag-search-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000}.rag-search-modal-content{background:#fff;width:90%;max-width:600px;max-height:80vh;border-radius:var(--radius-lg);box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column}.rag-search-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-light)}.rag-search-modal-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.btn-close-modal{width:28px;height:28px;border:none;background:none;font-size:20px;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.btn-close-modal:hover{background:var(--bg-elevated);color:var(--text-primary)}.rag-search-results{flex:1;overflow-y:auto;padding:12px 20px}.rag-result-item{padding:12px;margin-bottom:8px;border:1px solid var(--border-light);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.rag-result-item:hover{border-color:var(--accent-primary);background:#fafafa}.rag-result-checkbox{display:flex;align-items:flex-start;gap:12px;cursor:pointer}.rag-result-checkbox input[type=checkbox]{margin-top:4px;width:16px;height:16px;cursor:pointer}.rag-result-content{flex:1}.rag-result-content strong{font-size:13px;color:var(--text-primary)}.rag-result-content .ref-name-en{font-size:11px;color:var(--text-muted);margin-left:4px}.rag-result-source{display:block;font-size:11px;color:var(--text-muted);margin-top:4px}.rag-result-definition{margin:8px 0 0;font-size:12px;color:#555;line-height:1.5}.rag-search-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid var(--border-light)}.rag-search-modal-footer .btn-secondary{padding:8px 16px;font-size:13px;background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.rag-search-modal-footer .btn-secondary:hover{background:var(--bg-elevated)}.rag-search-modal-footer .btn-primary{padding:8px 16px;font-size:13px;background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.rag-search-modal-footer .btn-primary:hover{background:var(--accent-primary-hover)}.worksheet-submit-section{margin-top:40px;padding:24px;background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-lg);text-align:center}.submit-section-inner{max-width:400px;margin:0 auto}.submit-status{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:12px}.submit-status .status-icon{font-size:24px}.submit-status .status-text{font-size:16px;font-weight:600;color:var(--text-primary)}.submit-progress{margin-bottom:20px;font-size:14px;color:var(--text-muted)}.submit-progress strong{color:var(--accent-primary);font-size:18px}.btn-worksheet-submit{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 32px;font-size:15px;font-weight:500;color:#fff;background:var(--text-dark);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background .15s ease}.btn-worksheet-submit:hover{background:#2d2c29}.btn-worksheet-submit:active{background:#1a1a18}.btn-worksheet-submit:disabled{background:#d1d1cf;color:#9b9a97;cursor:not-allowed}.btn-worksheet-submit.submitted{background:var(--accent-success)}.submit-note{margin-top:12px;font-size:12px;color:var(--text-muted)}.worksheet-submit-section.submitted{background:#f0f9f7;border-color:var(--accent-success)}.worksheet-submit-section.submitted .status-icon:after{content:"✅"}.worksheet-submit-section.submitted .status-text{color:var(--accent-success)}.delivery-banner{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#d1fae5;color:#065f46;border-radius:8px;margin-bottom:16px;font-weight:500}.delivery-banner-icon{font-size:20px}.delivery-banner-close{background:none;border:none;font-size:20px;color:#065f46;cursor:pointer;padding:0 4px;line-height:1;margin-left:auto}.delivery-banner-close:hover{color:#064e3b}body[data-role=student][data-delivered=false] .eval-section,body[data-role=student][data-delivered=false] .eval-level-badge,body[data-role=student][data-delivered=false] .eval-xp{display:none}body[data-role=student][data-delivered=true] .evaluation-delivered{display:block!important;background:#f0f9ff;border:1px solid #bae6fd}body[data-role=student][data-delivered=true] textarea,body[data-role=student][data-delivered=true] input[type=text]{pointer-events:none}body[data-role=student][data-delivered=true] .btn-substep-submit,body[data-role=student][data-delivered=true] .btn-dev-reset,body[data-role=student][data-delivered=true] .btn-worksheet-submit,body[data-role=student][data-delivered=true] .worksheet-submit-section{display:none!important}body[data-role=instructor] .eval-section,body[data-role=instructor] .eval-level-badge,body[data-role=instructor] .eval-xp{display:flex}.worksheet-component[data-mode=readonly] .edit-only,[data-role=instructor] .edit-only{display:none!important}.worksheet-component[data-mode=readonly] .step-section.locked,.worksheet-component[data-mode=readonly] .substep-card.locked{opacity:1;pointer-events:auto}.worksheet-component[data-mode=readonly] .substep-feedback{display:block!important}.worksheet-component[data-mode=readonly] .substep-feedback.edit-only{display:none!important}.instructor-only{display:none}[data-role=instructor] .instructor-only{display:inline-block}.feedback-header{display:flex;align-items:center;gap:var(--spacing-sm, 8px);margin-bottom:6px}.ai-level,.instructor-level,.final-level{display:inline-block;font-size:11px;font-weight:500;padding:2px 8px;border-radius:4px;margin-right:6px}.ai-level{background:#e3f2fd;color:#1976d2}.instructor-level{background:#fce4ec;color:#c2185b}.final-level{background:#e8f5e9;color:#388e3c}.earned-xp{font-size:11px;color:var(--text-muted, #787774);margin-left:auto}.ai-feedback,.instructor-comment{font-size:14px;color:var(--text-dark, #37352f);line-height:1.6;margin:8px 0;padding:8px 12px;background:var(--bg-subtle, #fafafa);border-radius:4px}.ai-feedback strong,.instructor-comment strong{font-weight:600;color:var(--accent-primary, #7c3aed);margin-right:4px}.ai-feedback:empty,.instructor-comment:empty,.ai-level:empty,.instructor-level:empty,.final-level:empty,.earned-xp:empty{display:none}.btn-edit-eval{padding:4px 10px;font-size:11px;border-radius:4px;cursor:pointer;border:1px solid var(--border-light, #e5e5e5);background:var(--bg-main, #fff);color:var(--text-secondary, #666);margin-left:auto}.btn-edit-eval:hover{background:var(--bg-hover, #f5f5f5)}.substep-feedback.instructor-feedback-area{display:block!important;background:var(--bg-subtle, #fafafa);border-left:3px solid var(--accent-primary, #2383e2);padding:12px 16px;margin-top:var(--spacing-md, 16px)}.substep-feedback.instructor-feedback-area .instructor-only{display:inline-block}.inline-edit-ui{margin-top:var(--spacing-sm, 8px);padding:var(--spacing-sm, 8px);background:var(--bg-main, #fff);border-radius:var(--radius-sm, 4px);border:1px solid var(--border-light, #e5e5e5)}.inline-edit-ui .level-buttons,.level-buttons{display:flex;gap:6px;margin-bottom:var(--spacing-sm, 8px)}.inline-edit-ui .level-btn,.level-btn{flex:1;padding:8px;font-size:12px;border:1px solid var(--border-light, #e5e5e5);border-radius:var(--radius-sm, 4px);background:var(--bg-main, #fff);cursor:pointer}.inline-edit-ui .level-btn:hover,.level-btn:hover{background:var(--bg-hover, #f5f5f5)}.inline-edit-ui .level-btn.selected,.inline-edit-ui .level-btn.active,.level-btn.selected,.level-btn.active{background:var(--text-primary, #37352f);color:#fff;border-color:var(--text-primary, #37352f)}.inline-edit-ui .edit-feedback-text,.edit-feedback-text{width:100%;padding:8px;font-size:13px;border:1px solid var(--border-light, #e5e5e5);border-radius:var(--radius-sm, 4px);resize:vertical;min-height:60px;margin-bottom:var(--spacing-sm, 8px);pointer-events:auto}.inline-edit-ui .edit-actions,.edit-actions{display:flex;justify-content:flex-end;gap:8px}.inline-edit-ui .btn-cancel,.inline-edit-ui .btn-save,.btn-cancel,.btn-save{padding:6px 12px;font-size:12px;border-radius:var(--radius-sm, 4px);cursor:pointer}.inline-edit-ui .btn-cancel,.btn-cancel{background:var(--bg-main, #fff);border:1px solid var(--border-light, #e5e5e5);color:var(--text-secondary, #666)}.inline-edit-ui .btn-save,.btn-save{background:var(--text-primary, #37352f);border:1px solid var(--text-primary, #37352f);color:#fff}.skeleton-loading{padding:24px}.skeleton-card{background:var(--bg-white);border-radius:var(--radius-lg);padding:20px;margin-bottom:16px}.skeleton-line{height:16px;background:linear-gradient(90deg,#f0f0ed 25%,#e8e8e5,#f0f0ed 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px;margin-bottom:12px}.skeleton-line.title{width:40%;height:20px;margin-bottom:16px}.skeleton-line.medium{width:80%}.skeleton-textarea{height:80px;background:linear-gradient(90deg,#f0f0ed 25%,#e8e8e5,#f0f0ed 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px;margin-bottom:16px}.skeleton-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:12px}.skeleton-grid .skeleton-textarea{height:100px}.page-loading{padding:var(--spacing-xl)}.page-skeleton-header{height:32px;width:200px;background:linear-gradient(90deg,#f0f0ed 25%,#e8e8e5,#f0f0ed 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm);margin-bottom:var(--spacing-lg)}.page-skeleton-content{display:flex;flex-direction:column;gap:var(--spacing-md)}.page-skeleton-line{height:16px;background:linear-gradient(90deg,#f0f0ed 25%,#e8e8e5,#f0f0ed 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.fade-in{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.lounge-page{display:flex;height:calc(100vh - 60px);background:var(--bg-main, #ffffff);overflow:hidden}.lounge-chat-area{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden;background:var(--bg-main, #ffffff)}.lounge-chat-header{display:flex;align-items:center;gap:8px;padding:12px 24px;border-bottom:1px solid var(--border-color, #e5e5e5);flex-shrink:0}.lounge-chat-channel-name{font-size:16px;font-weight:600;color:var(--text-primary, #37352f)}.lounge-chat-channel-desc{font-size:13px;color:var(--text-tertiary, #a0a0a0);margin-left:8px;padding-left:8px;border-left:1px solid var(--border-color, #e5e5e5)}.lounge-messages{flex:1;min-height:0;overflow-y:auto;padding:16px 24px;display:flex;flex-direction:column;gap:0}.lounge-welcome{text-align:center;padding:40px 20px;color:var(--text-secondary, #6b6b6b)}.lounge-welcome-icon{width:64px;height:64px;border-radius:50%;background:var(--bg-secondary, #f7f6f3);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:var(--text-tertiary, #a0a0a0)}.lounge-welcome h3{font-size:18px;font-weight:600;color:var(--text-primary, #37352f);margin:0 0 8px}.lounge-welcome p{font-size:14px;margin:4px 0}.lounge-welcome-hint{color:var(--text-tertiary, #a0a0a0);font-size:13px!important}.lounge-message-group{border-radius:6px;transition:background .1s ease;margin-top:4px;position:relative}.lounge-message-group:first-child{margin-top:0}.lounge-message-group:hover{background:var(--bg-hover, rgba(0, 0, 0, .02))}.lounge-message{display:flex;gap:12px;padding:2px 12px;border-radius:6px}.lounge-message-avatar{width:36px;height:36px;border-radius:50%;background:var(--accent-primary, #7c3aed);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;flex-shrink:0}.lounge-message.ai .lounge-message-avatar{background:linear-gradient(135deg,#10b981,#059669)}.lounge-message.grouped{padding-top:0;padding-bottom:0;margin-top:-2px}.lounge-message-gutter{width:36px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.lounge-message-time-hover{display:none;font-size:10px;color:var(--text-tertiary, #999);white-space:nowrap}.lounge-message.grouped:hover .lounge-message-time-hover{display:block}.lounge-message-content{flex:1;min-width:0;position:relative}.lounge-message-header{display:flex;align-items:baseline;gap:8px;margin-bottom:2px}.lounge-message-name{font-weight:600;font-size:14px;color:var(--text-primary, #37352f)}.lounge-message.ai .lounge-message-name{color:#10b981}.lounge-message.ai-ta{background:#fffbeb;border-left:3px solid #f59e0b;border-radius:6px;margin:4px 0;padding-left:12px}.lounge-message.ai-ta .lounge-message-avatar{background:linear-gradient(135deg,#f59e0b,#d97706)}.lounge-message.ai-ta .lounge-message-name,.lounge-message.ai-ta .ta-name{color:#b45309;font-weight:600}.lounge-message.ai-personal{background:#f5f3ff;border-left:3px solid #8b5cf6;border-radius:6px;margin:4px 0;padding-left:12px}.lounge-message.ai-personal .lounge-message-avatar{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.lounge-message.ai-personal .lounge-message-name,.lounge-message.ai-personal .personal-name{color:#6d28d9;font-weight:600}.lounge-message.private-chuck{background:#f5f3ff;border-left:3px solid #c4b5fd;border-radius:6px;margin:4px 0;padding-left:12px}.lounge-ai-badge{display:inline-flex;align-items:center;gap:3px;font-size:10px;padding:1px 6px;border-radius:9px;font-weight:500;line-height:1.4;vertical-align:middle;margin-left:4px}.lounge-ai-badge.ta-badge{background:#fef3c7;color:#92400e}.lounge-ai-badge.personal-badge{background:#ede9fe;color:#5b21b6}.lounge-message-time{font-size:11px;color:var(--text-tertiary, #a0a0a0)}.lounge-message-body{font-size:14px;line-height:1.375;color:var(--text-primary, #37352f);word-wrap:break-word;margin:0;padding:0}.lounge-message-body p{margin:0;padding:0}.lounge-message-body .mention{background:#7c3aed1a;color:var(--accent-primary, #7c3aed);padding:0 4px;border-radius:4px;font-weight:500}.lounge-message-body .inline-code{background:var(--bg-secondary, #f7f6f3);padding:2px 6px;border-radius:4px;font-family:Fira Code,monospace;font-size:13px}.lounge-message.streaming .lounge-message-body{background:linear-gradient(90deg,#f0f0ed 25%,#e8e8e5,#f0f0ed 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:6px;min-height:20px}.lounge-typing-indicator{padding:4px 24px 8px;font-size:12px;color:var(--text-tertiary, #a0a0a0);flex-shrink:0}.lounge-chat-input-area{display:flex;align-items:center;gap:8px;padding:12px 16px;border-top:1px solid var(--border-color, #e5e5e5);flex-shrink:0}.lounge-chat-input{flex:1;padding:10px 14px;border:1px solid var(--border-color, #e5e5e5);border-radius:8px;font-size:14px;font-family:var(--font-family, "Pretendard", sans-serif);background:var(--bg-main, #ffffff);color:var(--text-primary, #37352f);outline:none;transition:border-color .15s ease}.lounge-chat-input:focus{border-color:var(--text-secondary, #6b6b6b)}.lounge-chat-input:disabled{opacity:.5;cursor:not-allowed}.lounge-chat-btn{width:36px;height:36px;border:none;background:none;border-radius:8px;color:var(--text-tertiary, #a0a0a0);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .1s ease,background .1s ease}.lounge-chat-btn:hover:not(:disabled){background:var(--bg-hover, rgba(0, 0, 0, .04));color:var(--text-primary, #37352f)}.lounge-chat-btn:disabled{opacity:.3;cursor:not-allowed}.lounge-member-sidebar{width:var(--right-panel-width, 360px);flex-shrink:0;background:var(--bg-secondary, #f7f6f3);border-left:1px solid var(--border-color, #e5e5e5);padding:16px;height:calc(100vh - 60px);overflow-y:auto}.lounge-member-header{display:flex;align-items:center;gap:8px;padding:8px;margin-bottom:8px;font-size:13px;font-weight:600;color:var(--text-primary, #37352f)}.lounge-member-section{margin-bottom:16px}.lounge-member-label{font-size:11px;font-weight:600;text-transform:uppercase;color:var(--text-tertiary, #a0a0a0);padding:0 8px 6px;letter-spacing:.5px}.lounge-member-item{display:flex;align-items:center;gap:8px;padding:4px 8px;border-radius:6px}.lounge-member-item:hover{background:var(--bg-hover, rgba(0, 0, 0, .04))}.lounge-member-status{width:8px;height:8px;border-radius:50%;flex-shrink:0}.lounge-member-status.online{background:#10b981}.lounge-member-status.offline{background:var(--text-tertiary, #a0a0a0)}.lounge-member-name{font-size:13px;color:var(--text-primary, #37352f)}.lounge-member-empty{padding:16px 8px;font-size:13px;color:var(--text-tertiary, #a0a0a0);text-align:center}.lounge-pinned-section{padding-bottom:12px;margin-bottom:12px;border-bottom:1px solid var(--border-color, #e5e5e5)}.lounge-pinned-section .lounge-member-label{display:flex;align-items:center;gap:4px}.lounge-pinned-item{padding:6px 8px;border-radius:6px;margin-top:4px;cursor:default}.lounge-pinned-item:hover{background:var(--bg-hover, rgba(0, 0, 0, .04))}.lounge-pinned-author{display:block;font-size:11px;font-weight:600;color:var(--text-secondary, #6b6b6b);margin-bottom:2px}.lounge-pinned-content{display:block;font-size:12px;color:var(--text-primary, #37352f);line-height:1.4;word-break:break-word}.lounge-pin-indicator{color:var(--text-secondary, #6b6b6b);flex-shrink:0}.lounge-pin-btn{width:24px;height:24px;border:1px solid var(--border-color, #e5e5e5);border-radius:6px;background:var(--bg-main, #ffffff);color:var(--text-tertiary, #a0a0a0);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .1s ease}.lounge-pin-btn:hover{border-color:var(--text-secondary, #6b6b6b);color:var(--text-secondary, #6b6b6b)}@media(max-width:768px){.lounge-member-sidebar{display:none}.lounge-page{height:calc(100vh - 60px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.lounge-action-bar{position:absolute;right:8px;bottom:-12px;display:flex;align-items:center;gap:0;background:var(--bg-primary, #fff);border:1px solid var(--border-color, #e5e5e5);border-radius:6px;padding:0 2px;opacity:0;pointer-events:none;transition:opacity .1s ease;z-index:2;box-shadow:0 1px 4px #00000014}.lounge-message-group:hover>.lounge-action-bar{opacity:1;pointer-events:auto}.lounge-action-bar-item{border:none;background:none;cursor:pointer;font-size:16px;line-height:1;padding:4px 5px;border-radius:4px;transition:background .1s ease;display:flex;align-items:center;justify-content:center}.lounge-action-bar-item:hover{background:var(--bg-hover, rgba(0, 0, 0, .06));transform:scale(1.2)}.lounge-action-bar-pin{color:var(--text-tertiary, #a0a0a0);border-left:1px solid var(--border-color, #e5e5e5);margin-left:2px}.lounge-action-bar-pin:hover{color:var(--text-primary, #37352f)}.lounge-reaction-bar{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.lounge-reaction-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border:1px solid var(--border-color, #e5e5e5);border-radius:12px;background:var(--bg-secondary, #f7f6f3);cursor:pointer;font-size:13px;transition:all .1s ease}.lounge-reaction-chip:hover{border-color:var(--text-secondary, #6b6b6b)}.lounge-reaction-chip.active{background:#0000000a;border-color:var(--text-secondary, #6b6b6b)}.lounge-reaction-chip-emoji{font-size:14px}.lounge-reaction-chip-count{font-size:12px;color:var(--text-secondary, #6b6b6b);font-weight:500}.lounge-file-image{margin-top:6px;max-width:360px;border-radius:8px;overflow:hidden}.lounge-file-image img{width:100%;height:auto;display:block;border-radius:8px;cursor:pointer;transition:opacity .15s ease}.lounge-file-image img:hover{opacity:.9}.lounge-file-card{display:inline-flex;align-items:center;gap:8px;margin-top:6px;padding:8px 12px;border:1px solid var(--border-color, #e5e5e5);border-radius:8px;background:var(--bg-secondary, #f7f6f3);color:var(--text-primary, #37352f);text-decoration:none;font-size:13px;transition:border-color .15s ease}.lounge-file-card:hover{border-color:var(--text-secondary, #6b6b6b)}.lounge-file-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}@keyframes lounge-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.lounge-spin{animation:lounge-spin 1s linear infinite}.team-worksheet-area{flex:1;overflow-y:auto;padding:var(--spacing-lg);background:var(--bg-white);scrollbar-width:none;-ms-overflow-style:none}.team-worksheet-area::-webkit-scrollbar{display:none}#team-page,#team-list-view,#team-workspace-content,#team-list,#right-panel-team{scrollbar-width:none;-ms-overflow-style:none}#team-page::-webkit-scrollbar,#team-list-view::-webkit-scrollbar,#team-workspace-content::-webkit-scrollbar,#team-list::-webkit-scrollbar,#right-panel-team::-webkit-scrollbar{display:none}#right-panel-team{flex-direction:column}#right-panel-team .team-panel-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border-light);background:var(--bg-white)}#right-panel-team .team-title{display:flex;align-items:center;gap:8px}#right-panel-team .team-avatar{font-size:18px}#right-panel-team .team-name{font-size:14px;font-weight:600;color:var(--text-primary)}#right-panel-team .team-members-section{border-bottom:1px solid var(--border-light);max-height:180px;overflow-y:auto}#right-panel-team .team-section-header{display:flex;align-items:center;padding:12px 16px 8px;gap:6px}#right-panel-team .team-section-header.collapsible{cursor:pointer;-webkit-user-select:none;user-select:none}#right-panel-team .team-section-header.collapsible:hover{background:var(--bg-hover)}#right-panel-team .team-section-header h4{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin:0}#right-panel-team .team-section-header .connection-status{margin-left:auto;margin-right:8px}#right-panel-team .team-section-header .section-toggle{font-size:10px;color:var(--text-muted);transition:transform .2s ease}#right-panel-team .team-section-header .section-toggle.collapsed{transform:rotate(-90deg)}#right-panel-team .team-members-list{padding:0 16px 12px;transition:max-height .2s ease,opacity .2s ease}#right-panel-team .team-members-list.collapsed{max-height:0!important;padding:0 16px;overflow:hidden;opacity:0}#right-panel-team .team-chat-section{flex:1;display:flex;flex-direction:column;min-height:0}#right-panel-team .team-chat-messages{flex:1;overflow-y:auto;padding:12px 16px;scrollbar-width:none;-ms-overflow-style:none}#right-panel-team .team-chat-messages::-webkit-scrollbar{display:none}.team-list-container{padding:48px 96px;max-width:800px;margin:0 auto}.team-empty-state{text-align:center;padding:48px;color:var(--text-muted)}.team-empty-state p{font-size:15px;margin-bottom:24px}.team-actions{display:flex;gap:12px;justify-content:center}.team-card{background:var(--bg-white);border:1px solid var(--border-light);border-radius:8px;padding:20px;margin-bottom:12px;transition:box-shadow .15s ease}.team-card:hover{box-shadow:0 2px 8px #0f0f0f1a}.team-card-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.team-name{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.team-badge{font-size:11px;padding:2px 8px;border-radius:3px;font-weight:500}.team-badge.leader{background:#fdecc8;color:#9d5b13}.team-card-meta{display:flex;gap:16px;font-size:13px;color:var(--text-muted);margin-bottom:16px}.btn-enter-team{width:100%}.team-step-section{margin-bottom:var(--spacing-xl)}.team-step-section .substep-card{border-bottom:1px solid var(--border-light);padding-bottom:var(--spacing-md);margin-bottom:var(--spacing-md)}.team-substep .substep-body{margin-top:var(--spacing-sm)}.field-save-error{border-color:#ef4444!important;box-shadow:0 0 0 2px #ef444433!important;transition:border-color .3s,box-shadow .3s}.field-locked{background:#fef9ec!important;border-color:#f59e0b!important;cursor:not-allowed;opacity:.8}.empathy-map-card{background:var(--bg-white);padding:var(--spacing-xl) var(--spacing-lg);margin-bottom:var(--spacing-md);border-bottom:1px solid var(--border-light);border:none;border-radius:0}.empathy-map-card:last-child{border-bottom:none}.empathy-map-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-sm)}.empathy-map-header h3{font-size:20px;font-weight:600;color:var(--text-dark);letter-spacing:-.01em;margin:0}.assignee-selector{position:relative}.assigned-badge{font-size:12px;padding:4px 10px;border-radius:4px;background:#e8f5e9;color:var(--accent-success);border:none;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .15s ease}.assigned-badge:hover{filter:brightness(.95)}.assigned-badge.unassigned{background:#fafafa;color:var(--text-muted)}.assigned-badge .dropdown-arrow{font-size:8px;opacity:.6}.assignee-dropdown{position:absolute;top:100%;right:0;margin-top:4px;min-width:150px;background:var(--bg-white);border:1px solid var(--border-light);border-radius:6px;box-shadow:0 4px 12px #0000001a;z-index:100;overflow:hidden}.assignee-option{padding:10px 14px;font-size:13px;color:var(--text-primary);cursor:pointer;transition:background .1s ease}.assignee-option:hover{background:var(--bg-elevated)}.assignee-option.selected{background:#2eaadc1a;color:var(--accent-primary);font-weight:500}.interviewee-info{display:flex;gap:12px;margin-bottom:16px}.interviewee-field{flex:1}.empathy-map-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.empathy-field{position:relative}.empathy-field label{display:block;font-size:13px;font-weight:500;color:var(--text-primary);margin-bottom:6px}.empathy-field.locked .notion-textarea{background:var(--bg-elevated);border-color:var(--accent-warning)}.editing-indicator{position:absolute;bottom:8px;right:8px;font-size:11px;color:var(--accent-warning);background:#ffffffe6;padding:2px 8px;border-radius:4px;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:.7}50%{opacity:1}}.notion-textarea.updated{animation:flashUpdate .5s ease}@keyframes flashUpdate{0%{background:#fff3cd}to{background:var(--bg-white)}}.reflection-section{margin-top:var(--spacing-lg)}.reflection-section .step-title{font-size:20px;font-weight:600;color:var(--text-dark)}.reflection-section .substep-title{font-size:15px;font-weight:500;color:var(--text-dark);margin-bottom:var(--spacing-md)}.hypothesis-fields{display:flex;flex-direction:column;gap:var(--spacing-lg)}.hypothesis-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.hypothesis-field label{font-size:14px;font-weight:500;color:var(--text-primary)}.hypothesis-field .notion-textarea{min-height:64px}.discovery-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.discovery-item{display:flex;align-items:flex-start;gap:var(--spacing-sm)}.discovery-number{font-size:15px;font-weight:500;color:var(--text-primary);min-width:24px;padding-top:4px}.discovery-item .reflection-field{flex:1}.discovery-item .notion-textarea{min-height:64px}.revision-plan,.reflection-fields{display:flex;flex-direction:column;gap:var(--spacing-lg)}.plan-field,.reflection-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.plan-field label,.reflection-field label{font-size:14px;font-weight:500;color:var(--text-primary)}.plan-field .notion-textarea,.reflection-field .notion-textarea{min-height:96px}.notion-input,.notion-select{width:100%;padding:6px 0;font-size:14px;line-height:24px;color:var(--text-primary);background:transparent;border:none;border-bottom:1px solid #d1d5db;border-radius:0;transition:border-color .15s ease}.notion-input:focus,.notion-select:focus{outline:none;border-bottom-color:var(--text-dark)}.notion-input::placeholder{color:var(--text-placeholder)}.notion-textarea{width:100%;padding:4px 0;font-size:15px;line-height:32px;color:var(--text-primary);background:transparent;background-image:repeating-linear-gradient(to bottom,transparent 0px,transparent 31px,#d1d5db 31px,#d1d5db 32px);background-position:0 4px;border:none;border-radius:0;resize:none;overflow:hidden;min-height:96px;box-sizing:border-box}.notion-textarea:focus{outline:none;background-image:repeating-linear-gradient(to bottom,transparent 0px,transparent 31px,var(--text-dark) 31px,var(--text-dark) 32px)}.notion-textarea::placeholder{color:var(--text-placeholder)}.btn-notion{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;font-size:14px;font-weight:500;color:#fff;background:var(--accent-primary);border:none;border-radius:4px;cursor:pointer;transition:background .15s ease}.btn-notion:hover{background:var(--accent-primary-hover)}.btn-notion-secondary{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;font-size:14px;font-weight:500;color:var(--text-primary);background:var(--bg-white);border:1px solid var(--border-light);border-radius:4px;cursor:pointer;transition:background .15s ease}.btn-notion-secondary:hover{background:var(--bg-sidebar-hover)}.team-members-panel{background:var(--bg-white);border:1px solid var(--border-light);border-radius:8px;padding:16px}.team-members-panel h4{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin:0 0 12px}.team-member{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--border-light)}.team-member:last-child{border-bottom:none}.member-status{width:8px;height:8px;border-radius:50%;background:#ccc}.member-status.online{background:var(--accent-success)}.member-name{flex:1;font-size:14px;color:var(--text-primary)}.team-member.offline .member-name{color:var(--text-muted)}.leader-badge{font-size:10px;padding:2px 6px;background:#fdecc8;color:#9d5b13;border-radius:3px}.section-badge{font-size:10px;padding:2px 6px;background:var(--bg-elevated);color:var(--text-muted);border-radius:3px}.team-chat-panel{flex:1;display:flex;flex-direction:column;background:var(--bg-white);border:1px solid var(--border-light);border-radius:8px;overflow:hidden}.team-chat-header{padding:12px 16px;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;align-items:center}.team-chat-header h4{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin:0}.btn-ai-mention{font-size:12px;padding:4px 8px;background:#e8f4f8;color:var(--accent-primary);border:none;border-radius:4px;cursor:pointer}.btn-ai-mention:hover{background:#d1ebf3}.team-chat-messages{flex:1;overflow-y:auto;padding:16px}.chat-message{padding:2px 0}.team-message-group .chat-message.grouped{padding-top:0;padding-bottom:0;margin-top:-2px}.user-message-wrapper.grouped{position:relative}.user-avatar-placeholder{width:36px;flex-shrink:0}.message-time-hover{display:none;position:absolute;left:-36px;top:50%;transform:translateY(-50%);font-size:10px;color:var(--text-tertiary, #999);white-space:nowrap}.user-message-wrapper.grouped:hover .message-time-hover{display:block}.user-message-wrapper{display:flex;align-items:flex-start;gap:10px}.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--accent-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;flex-shrink:0}.user-message-content{flex:1;min-width:0}.user-message-header{display:flex;align-items:baseline;gap:8px;margin-bottom:2px}.user-message-name{font-size:14px;font-weight:600;color:var(--text-primary)}.user-message-body{font-size:14px;line-height:1.375;color:var(--text-primary);word-wrap:break-word;margin:0;padding:0}.chat-message.ai-message{display:flex;justify-content:flex-end}.ai-message-wrapper{display:flex;align-items:flex-start;gap:10px;max-width:85%}.ai-message-avatar{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0}.ai-message-content{flex:1;min-width:0}.ai-message-header{display:flex;align-items:baseline;gap:8px;margin-bottom:4px;justify-content:flex-end}.ai-message-name{font-size:14px;font-weight:600;color:var(--accent-primary)}.ai-message-body{font-size:14px;line-height:1.5;color:var(--text-primary);background:linear-gradient(135deg,#e8f4f8,#f0e6fa);padding:10px 14px;border-radius:12px 0 12px 12px;white-space:pre-wrap;word-break:break-word}.message-time{font-size:11px;color:var(--text-muted)}.ai-message-body strong,.user-message-body strong,.float-msg-content strong{font-weight:600}.ai-message-body em,.user-message-body em,.float-msg-content em{font-style:italic}.ai-message-body del,.user-message-body del,.float-msg-content del{text-decoration:line-through;opacity:.7}.inline-code{font-family:SF Mono,Monaco,Consolas,monospace;font-size:.9em;background:#0000000d;padding:2px 6px;border-radius:4px;color:#e74c3c}.chat-message.streaming .typing-cursor{animation:blink .7s infinite;color:var(--accent-primary)}#team-typing-indicator{display:none;padding:8px 16px;font-size:12px;color:var(--text-muted);font-style:italic}.system-message{display:flex;align-items:center;gap:8px;padding:10px 14px;margin:8px 0;background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:8px;font-size:13px;color:var(--text-muted)}.system-message.offline-notice{background:var(--bg-elevated);border-color:var(--border-light);color:var(--text-muted)}.system-message .system-icon{font-size:16px}.connection-status{display:flex;align-items:center;gap:6px;padding:4px 10px;font-size:11px;color:var(--text-muted)}.connection-status .status-dot{width:8px;height:8px;border-radius:50%;background:var(--accent-error)}.connection-status.connected .status-dot{background:var(--accent-success)}.system-message.connection-prompt{flex-direction:column;align-items:flex-start;gap:10px;background:var(--bg-elevated);border-color:var(--border-light);color:var(--text-primary)}.system-message.connection-prompt .prompt-content{display:flex;align-items:center;gap:12px;width:100%}.btn-reconnect{padding:6px 12px;background:var(--accent-primary);color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:background .2s}.btn-reconnect:hover{background:#6d28d9}.btn-reconnect:disabled{background:#c4b5fd;cursor:not-allowed}.system-message.success-notice{background:var(--bg-elevated);border-color:var(--border-light);color:var(--accent-success)}#team-modal{display:none;position:fixed;inset:0;z-index:1000;align-items:center;justify-content:center}.modal-overlay{position:absolute;inset:0;background:#0f0f0f99}.notion-modal{position:relative;background:var(--bg-white);border-radius:8px;box-shadow:0 8px 24px #0f0f0f33;max-width:420px;width:90%;max-height:90vh;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-light)}.modal-header h2{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.modal-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:none;border:none;font-size:20px;color:var(--text-muted);cursor:pointer;border-radius:4px}.modal-close:hover{background:var(--bg-sidebar-hover)}.modal-body{padding:20px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:500;color:var(--text-primary);margin-bottom:6px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 20px;border-top:1px solid var(--border-light)}.invite-code-display{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px;background:var(--bg-elevated);border-radius:8px}.invite-code{font-size:28px;font-weight:700;font-family:SF Mono,Monaco,monospace;letter-spacing:4px;color:var(--text-primary)}.btn-copy{padding:8px;background:none;border:1px solid var(--border-light);border-radius:4px;cursor:pointer;font-size:16px}.btn-copy:hover{background:var(--bg-sidebar-hover)}.toast-notification{position:fixed;bottom:24px;left:50%;transform:translate(-50%) translateY(100px);background:var(--text-primary);color:#fff;padding:12px 24px;border-radius:8px;font-size:14px;opacity:0;transition:transform .3s ease,opacity .3s ease;z-index:2000}.toast-notification.show{transform:translate(-50%) translateY(0);opacity:1}#connection-status{display:none;position:fixed;top:60px;left:50%;transform:translate(-50%);padding:8px 16px;background:#fff;border:1px solid var(--border-light);border-radius:6px;box-shadow:0 4px 12px #0f0f0f0d;z-index:1000}.status-disconnected{color:var(--accent-warning)}.status-failed{color:var(--accent-error)}.main-tabs{display:flex;gap:0;border-bottom:1px solid var(--border-light);margin-bottom:0}.main-tab{padding:12px 24px;font-size:14px;font-weight:500;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .15s ease,border-color .15s ease}.main-tab:hover{color:var(--text-primary)}.main-tab.active{color:var(--text-primary);border-bottom-color:var(--accent-primary)}@media(max-width:900px){.team-worksheet-area{padding:24px 16px}.empathy-map-grid{grid-template-columns:1fr}.team-list-container{padding:24px}}.team-discord-section .nav-section-content{padding:0}.team-no-team{padding:12px;text-align:center}.team-no-team-msg{font-size:12px;color:var(--text-muted);margin-bottom:12px}.btn-team-action{display:block;width:100%;padding:8px 12px;margin-bottom:8px;font-size:12px;font-weight:500;color:#fff;background:var(--accent-primary);border:none;border-radius:4px;cursor:pointer;transition:background .15s ease}.btn-team-action:hover{background:var(--accent-primary-hover)}.btn-team-action.secondary{color:var(--text-primary);background:var(--bg-elevated)}.btn-team-action.secondary:hover{background:var(--bg-sidebar-hover)}.team-header-bar{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-bottom:1px solid var(--border-light)}.team-name-display{font-size:13px;font-weight:600;color:var(--text-primary)}.btn-team-settings{width:24px;height:24px;padding:0;font-size:12px;background:none;border:none;border-radius:4px;cursor:pointer;opacity:.6;transition:opacity .15s ease}.btn-team-settings:hover{opacity:1;background:var(--bg-sidebar-hover)}.team-channels{padding:8px 0}.channel-category{display:flex;align-items:center;justify-content:space-between;padding:8px 12px 4px;font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.btn-add-channel{width:18px;height:18px;padding:0;border:none;background:transparent;color:var(--text-muted);font-size:14px;font-weight:500;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s,background .15s,color .15s}.team-channels:hover .btn-add-channel{opacity:1}.btn-add-channel:hover{background:var(--bg-hover);color:var(--text-primary)}.channel-item{display:flex;align-items:center;gap:6px;padding:6px 12px;margin:1px 8px;font-size:14px;color:var(--text-muted);border-radius:4px;cursor:pointer;transition:background .1s ease,color .1s ease}.channel-item:hover{background:var(--bg-sidebar-hover);color:var(--text-primary)}.channel-item.active{background:#2eaadc26;color:var(--accent-primary)}.channel-hash{font-size:16px;font-weight:500;opacity:.6}.channel-name{flex:1}.channel-unread{min-width:16px;height:16px;padding:0 5px;font-size:10px;font-weight:700;color:#fff;background:var(--accent-error);border-radius:8px;text-align:center;line-height:16px}.floating-chat-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--border-light);background:var(--bg-elevated);border-radius:12px 12px 0 0}.floating-chat-title{display:flex;align-items:center;gap:6px;font-size:15px;font-weight:600;color:var(--text-primary)}.floating-chat-title .channel-hash{color:var(--text-muted);font-size:18px}.btn-close-chat{width:28px;height:28px;padding:0;font-size:20px;color:var(--text-muted);background:none;border:none;border-radius:4px;cursor:pointer;line-height:1}.floating-chat-input{flex:1;padding:10px 12px;font-size:13px;border:1px solid var(--border-light);border-radius:8px;resize:none;min-height:40px;max-height:100px;font-family:inherit}.btn-send-float{padding:10px 16px;font-size:13px;font-weight:500;color:#fff;background:var(--accent-primary);border:none;border-radius:8px;cursor:pointer;transition:background .15s ease}.btn-send-float:hover{background:var(--accent-primary-hover)}.float-chat-message{margin-bottom:16px}.float-chat-message.mine{text-align:right}.float-chat-message.ai{background:#f0f9ff;margin:0 -16px 16px;padding:12px 16px}.float-msg-header{display:flex;gap:8px;align-items:baseline;margin-bottom:4px}.float-chat-message.mine .float-msg-header{justify-content:flex-end}.float-msg-author{font-size:13px;font-weight:600;color:var(--text-primary)}.float-msg-author.ai-author{color:var(--accent-primary)}.float-msg-time{font-size:11px;color:var(--text-muted)}.float-msg-content{font-size:14px;line-height:1.5;color:var(--text-primary);white-space:pre-wrap}.chat-empty{text-align:center;padding:40px 20px;color:var(--text-muted)}.chat-empty p{margin:0 0 8px}.chat-empty .hint{font-size:12px}.mention{color:var(--accent-primary);font-weight:500;background:#2eaadc1a;padding:1px 4px;border-radius:3px}.team-sidebar-modal{display:none;position:fixed;inset:0;z-index:1000;align-items:center;justify-content:center}.team-sidebar-modal .modal-overlay{position:absolute;inset:0;background:#0f0f0f99}.team-sidebar-modal .notion-modal{position:relative;background:var(--bg-white);border-radius:8px;box-shadow:0 8px 24px #0f0f0f33;max-width:400px;width:90%}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border-light)}.setting-value{font-size:14px;font-weight:500;color:var(--text-primary)}.btn-danger{width:100%;padding:10px 16px;font-size:13px;color:var(--accent-error);background:transparent;border:1px solid var(--accent-error);border-radius:6px;cursor:pointer;transition:all .15s ease}.btn-danger:hover{background:var(--accent-error);color:#fff}.team-members-section{padding:8px 0;border-top:1px solid var(--border-light)}.members-category{display:flex;justify-content:space-between;padding:8px 12px 4px;font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.members-category.offline-category{margin-top:8px}.members-category.collapsible{cursor:pointer;-webkit-user-select:none;user-select:none}.members-category.collapsible:hover{background:var(--bg-sidebar-hover);border-radius:4px}.category-toggle{font-size:10px;color:var(--text-muted);transition:transform .2s ease;display:inline-block;width:14px}.category-toggle.collapsed{transform:rotate(-90deg)}.sidebar-members-list.collapsed{display:none}.members-count{font-weight:600;color:var(--text-muted)}.sidebar-members-list{padding:0 8px}.sidebar-member{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:4px;cursor:pointer}.sidebar-member:hover{background:var(--bg-sidebar-hover)}.member-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.member-status-dot.online{background:#43b581}.member-status-dot.offline{background:#747f8d}.sidebar-member-name{font-size:14px;color:var(--text-primary)}.sidebar-member:has(.member-status-dot.offline) .sidebar-member-name{color:var(--text-muted)}.sidebar-member-role{font-size:10px;padding:2px 6px;background:#fdecc8;color:#9d5b13;border-radius:3px}.dm-unread-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;font-size:11px;font-weight:600;color:#fff;background:#ed4245;border-radius:9px;margin-left:auto}.team-invite-section{padding:8px 12px 12px;border-top:1px solid var(--border-light)}.btn-invite-members{width:100%;padding:8px;font-size:12px;color:var(--primary-color);background:var(--bg-elevated);border:1px solid var(--primary-color);border-radius:4px;cursor:pointer;transition:all .15s ease}.btn-invite-members:hover{background:var(--primary-color);color:#fff}.team-chat-floating{display:none;position:fixed;bottom:24px;left:290px;width:380px;height:480px;background:#fff!important;border:1px solid var(--border-light);border-radius:12px;box-shadow:0 8px 32px #0000004d;flex-direction:column;z-index:99999!important}.team-chat-floating.open{display:flex}.floating-chat-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border-light);background:var(--bg-elevated);border-radius:12px 12px 0 0}.floating-chat-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text-primary)}.floating-chat-title .channel-hash{color:var(--text-muted)}.btn-close-chat{width:28px;height:28px;padding:0;font-size:18px;color:var(--text-muted);background:none;border:none;border-radius:4px;cursor:pointer}.btn-close-chat:hover{background:var(--bg-sidebar-hover);color:var(--text-primary)}.floating-chat-messages{flex:1;overflow-y:auto;padding:16px}.floating-chat-input-area{display:flex;gap:8px;padding:12px;border-top:1px solid var(--border-light)}.floating-chat-input{flex:1;padding:10px 12px;font-size:13px;border:1px solid var(--border-light);border-radius:8px;resize:none;min-height:40px;max-height:100px}.floating-chat-input:focus{outline:none;border-color:var(--accent-primary)}.btn-ai-help{padding:8px 12px;font-size:12px;color:var(--accent-primary);background:#2eaadc1a;border:none;border-radius:6px;cursor:pointer;white-space:nowrap}.btn-ai-help:hover{background:#2eaadc33}.skeleton-container{padding:24px}.skeleton-card{background:var(--bg-white);padding:20px;margin-bottom:12px;border-bottom:1px solid var(--border-light)}.skeleton-line{height:16px;background:linear-gradient(90deg,var(--bg-elevated) 25%,#e8e8e8 50%,var(--bg-elevated) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px;margin-bottom:12px}.skeleton-line.title{width:40%;height:20px}.skeleton-line.short{width:60%}.skeleton-line.full{width:100%}.skeleton-button{width:100%;height:40px;background:linear-gradient(90deg,var(--bg-elevated) 25%,#e8e8e8 50%,var(--bg-elevated) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px;margin-top:16px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.team-error-state{text-align:center;padding:48px 24px;color:var(--text-muted)}.team-error-state p{font-size:15px;margin-bottom:8px}.team-error-state .error-detail{font-size:12px;color:var(--accent-error);margin-bottom:24px}.team-hint{font-size:12px;color:var(--text-muted);margin-top:24px}.team-workspace-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--border-light);background:var(--bg-white)}.team-workspace-title{display:flex;align-items:center;gap:12px}.team-workspace-title h2{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.team-workspace-badge{font-size:12px;padding:4px 8px;background:var(--bg-elevated);color:var(--text-muted);border-radius:4px}.btn-leave-team{padding:8px 14px;font-size:13px;color:var(--text-muted);background:transparent;border:1px solid var(--border-light);border-radius:6px;cursor:pointer;transition:all .15s ease}.btn-leave-team:hover{color:var(--text-primary);border-color:var(--text-muted);background:var(--bg-sidebar-hover)}.expanded-team-chat-container{display:flex;flex-direction:column;background:var(--bg-white);border:none;border-radius:0;margin:0;height:calc(100vh - 120px);box-shadow:none}#expanded-team-chat{height:100%}.expanded-chat-header{display:flex;justify-content:flex-start;align-items:center;padding:16px 24px;border-bottom:1px solid var(--border-light);background:var(--bg-white);border-radius:0}.expanded-chat-title{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:600;color:var(--text-primary)}.expanded-chat-title .team-avatar{font-size:20px}.expanded-chat-controls{display:flex;gap:8px}.expanded-chat-controls .btn-ai-control{padding:8px;background:transparent;border:1px solid var(--border-light);border-radius:6px;cursor:pointer;transition:all .15s ease}.expanded-chat-controls .btn-ai-control:hover{background:var(--bg-sidebar-hover);border-color:var(--text-muted)}.expanded-chat-controls .btn-ai-control svg{width:18px;height:18px;color:var(--text-muted)}.expanded-chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:12px}.expanded-chat-messages::-webkit-scrollbar{width:6px}.expanded-chat-messages::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}.expanded-chat-input-area{display:flex;gap:12px;padding:16px 24px;border-top:1px solid var(--border-light);background:var(--bg-white);border-radius:0}.expanded-chat-input{flex:1;padding:12px 16px;border:1px solid var(--border-light);border-radius:8px;font-size:14px;resize:none;background:var(--bg-white);transition:border-color .15s ease}.expanded-chat-input:focus{outline:none;border-color:var(--accent-blue)}.expanded-chat-input-area .btn-send-ai{padding:12px 16px;background:var(--accent-blue);border:none;border-radius:8px;cursor:pointer;transition:background .15s ease}.expanded-chat-input-area .btn-send-ai:hover{background:#0056d6}.expanded-chat-input-area .btn-send-ai svg{width:18px;height:18px;color:#fff}.btn-chat-toggle{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:var(--bg-sidebar);border:1px solid var(--border-light);border-radius:6px;font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.btn-chat-toggle:hover{background:var(--bg-sidebar-hover);border-color:var(--border-medium);color:var(--text-primary)}.chat-box{display:flex;flex-direction:column;height:100%;background:#36393f;border-radius:8px;overflow:hidden}.channel-tabs{display:flex;gap:4px;padding:8px 12px;background:#2f3136;border-bottom:1px solid #202225}.channel-tabs button{padding:6px 12px;background:transparent;border:none;border-radius:4px;color:#8e9297;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease}.channel-tabs button:hover{background:#40444b;color:#dcddde}.channel-tabs button.active{background:#40444b;color:#fff}.message-list{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px}.message{display:flex;flex-direction:column;gap:4px}.message-author{font-size:14px;font-weight:600;color:#fff}.message-content{font-size:14px;color:#dcddde;line-height:1.4;word-break:break-word}.message.ai-message .message-author{color:#7289da}.message.ai-message .message-content{background:#7289da1a;padding:8px 12px;border-radius:4px;border-left:3px solid #7289da}.mention{background:#7289da4d;color:#7289da;padding:0 2px;border-radius:3px;font-weight:500;cursor:pointer}.mention:hover{background:#7289da80;text-decoration:underline}.mention.ai-mention{background:#faa61a4d;color:#faa61a}.typing-indicator{padding:8px 16px;font-size:12px;color:#8e9297;font-style:italic}.chat-input-wrapper{display:flex;gap:8px;padding:12px 16px;background:#40444b;border-top:1px solid #202225}.chat-input{flex:1;padding:10px 14px;background:#40444b;border:none;border-radius:8px;color:#dcddde;font-size:14px;font-family:inherit}.chat-input::placeholder{color:#72767d}.chat-input:focus{outline:none}.send-btn{padding:8px 16px;background:#7289da;border:none;border-radius:4px;color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s ease}.send-btn:hover{background:#677bc4}.send-btn:disabled{background:#4f545c;cursor:not-allowed}.btn-chat-toggle.active{background:var(--accent-blue);border-color:var(--accent-blue);color:#fff}.btn-chat-toggle.active:hover{background:#0056d6}.btn-connect-workspace{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 16px;margin-bottom:12px;font-size:14px;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--accent-primary) 0%,#6366f1 100%);border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #2eaadc4d}.btn-connect-workspace:hover{transform:translateY(-1px);box-shadow:0 4px 12px #2eaadc66}.btn-connect-workspace:active{transform:translateY(0)}.btn-connect-workspace.connecting{background:linear-gradient(135deg,#9ca3af,#6b7280);cursor:wait;box-shadow:none}.btn-connect-workspace.connected{background:linear-gradient(135deg,#10b981,#059669);cursor:default;box-shadow:0 2px 8px #10b9814d}.btn-connect-workspace.error{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 2px 8px #f59e0b4d}.btn-connect-workspace:disabled{cursor:default}.btn-connect-workspace:disabled:hover{transform:none}.spinner-small{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.toast-notification.success{background:#10b981}.toast-notification.error{background:#ef4444}.toast-notification.warning{background:#f59e0b}.toast-notification.info{background:var(--accent-primary)}.connection-status-badge{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 16px;margin-bottom:12px;font-size:13px;font-weight:500;color:#10b981;background:#10b9811a;border:1px solid rgba(16,185,129,.3);border-radius:8px}.connection-status-badge .status-dot{width:8px;height:8px;background:#10b981;border-radius:50%;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.invite-search-results{max-height:200px;overflow-y:auto;border:1px solid var(--border-color);border-radius:8px;margin-top:8px;background:var(--bg-secondary)}.invite-search-results .search-hint,.invite-search-results .search-loading,.invite-search-results .search-empty,.invite-search-results .search-error{padding:16px;text-align:center;color:var(--text-muted);font-size:13px}.invite-search-results .search-error{color:var(--error-color, #e53935)}.invite-user-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--border-color);transition:background .15s}.invite-user-item:last-child{border-bottom:none}.invite-user-item:hover{background:var(--bg-hover)}.invite-user-item .user-info{display:flex;flex-direction:column;gap:2px}.invite-user-item .user-name{font-weight:500;color:var(--text-primary)}.invite-user-item .user-email{font-size:12px;color:var(--text-muted)}.btn-invite-user{padding:6px 12px;font-size:12px;font-weight:500;color:#fff;background:var(--primary-color);border:none;border-radius:6px;cursor:pointer;transition:all .15s}.btn-invite-user:hover{background:var(--primary-hover)}.btn-invite-user:disabled,.btn-invite-user.invited{background:var(--text-muted);cursor:not-allowed}.invite-code-section{text-align:center}.invite-code-display{display:inline-flex;align-items:center;gap:8px;padding:12px 16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px}.invite-code{font-family:monospace;font-size:18px;font-weight:600;letter-spacing:2px;color:var(--primary-color)}.btn-copy,.btn-copy-small{padding:4px 8px;font-size:14px;background:transparent;border:1px solid var(--border-color);border-radius:4px;cursor:pointer;transition:all .15s}.btn-copy:hover,.btn-copy-small:hover{background:var(--bg-hover)}.btn-copy-small{padding:2px 6px;font-size:12px;margin-left:8px}.setting-item{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border-color)}.setting-label{font-size:13px;color:var(--text-muted)}.setting-value{font-weight:500;color:var(--text-primary)}.simulator-app-inline{--sim-bg-stage: #0d0d1a;--sim-bg-panel: linear-gradient(180deg, #1a1a2e 0%, #16213e 100%);--sim-bg-card: #1e1e2e;--sim-bg-card-hover: #2a2a3e;--sim-text-primary: #ffffff;--sim-text-secondary: #b0b0c0;--sim-text-muted: #6b6b7b;--sim-accent-gold: #ffd700;--sim-accent-gold-glow: rgba(255, 215, 0, .6);--sim-accent-blue: #4a90d9;--sim-accent-green: #4caf50;--sim-accent-red: #e03e3e;--sim-spotlight-active: rgba(255, 215, 0, .15);--sim-spotlight-glow: 0 0 40px rgba(255, 215, 0, .6)}.simulator-app{display:flex;flex-direction:column;height:100vh;background:var(--bg-stage)}.simulator-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-xl);background:#1a1a2ef2;border-bottom:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-left .logo{font-size:20px;font-weight:700;color:var(--accent-gold);letter-spacing:-.5px}.header-center{display:flex;align-items:center}.timer-display{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);background:#0000000f;border-radius:var(--radius-lg);font-size:18px;font-weight:600;font-variant-numeric:tabular-nums}.timer-icon{font-size:16px}.timer-current{color:var(--text-primary)}.timer-separator{color:var(--text-muted)}.timer-total{color:var(--text-secondary)}.header-right{display:flex;align-items:center;gap:var(--spacing-md)}.time-select{padding:var(--spacing-sm) var(--spacing-md);background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;cursor:pointer}.time-select:focus{outline:none;border-color:var(--accent-gold)}.btn-back{padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-md);color:var(--text-secondary);font-size:14px;cursor:pointer;transition:var(--transition-fast)}.btn-back:hover{background:#ffffff1a;color:var(--text-primary)}.stage-container{flex:1;display:flex;flex-direction:column;padding:var(--spacing-xl);overflow-y:auto}.judges-panel{position:relative;display:flex;flex-direction:column;align-items:center;padding:var(--spacing-2xl) var(--spacing-xl);background:var(--bg-panel);border-radius:var(--radius-xl);margin-bottom:var(--spacing-xl);min-height:320px}.stage-lights{position:absolute;top:0;left:0;right:0;height:100%;pointer-events:none;overflow:hidden}.light{position:absolute;top:-50%;width:200px;height:300%;background:radial-gradient(ellipse at center top,rgba(255,215,0,.1) 0%,transparent 70%);opacity:.3;transition:opacity var(--transition-slow)}.light-left{left:10%;transform:rotate(-15deg)}.light-center{left:50%;transform:translate(-50%)}.light-right{right:10%;transform:rotate(15deg)}.judges-row{display:flex;justify-content:center;align-items:flex-end;gap:var(--spacing-xl);z-index:1}.judge-card{position:relative;width:180px;display:flex;flex-direction:column;align-items:center;transition:all var(--transition-slow);filter:brightness(.6);transform:scale(.9)}.judge-card.active{filter:brightness(1);transform:scale(1.1);z-index:10}.judge-card.active .judge-image-wrapper{box-shadow:var(--spotlight-glow)}.judge-card.reacting{animation:spotlight .4s ease}@keyframes spotlight{0%{transform:scale(1);filter:brightness(1)}50%{transform:scale(1.15);filter:brightness(1.2)}to{transform:scale(1.1);filter:brightness(1)}}.judge-image-wrapper{width:160px;height:200px;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-card);border:2px solid rgba(255,255,255,.1);transition:all var(--transition-slow)}.judge-card.active .judge-image-wrapper{border-color:var(--accent-gold)}.judge-image{width:100%;height:100%;object-fit:cover;object-position:center top}.judge-info{margin-top:var(--spacing-md);text-align:center}.judge-name{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.judge-comment{font-size:13px;color:var(--text-secondary);font-style:italic;min-height:20px;opacity:0;transition:opacity var(--transition-normal)}.judge-card.active .judge-comment,.judge-card.reacting .judge-comment{opacity:1}.transcript-section{margin-bottom:var(--spacing-lg)}.transcript-label{font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.transcript-box{padding:var(--spacing-lg);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);min-height:80px;max-height:120px;overflow-y:auto}.transcript-text{font-size:16px;line-height:1.6;color:var(--text-primary)}.transcript-cursor{display:inline-block;width:2px;height:18px;background:var(--accent-gold);margin-left:2px;animation:blink 1s infinite;vertical-align:middle}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.keywords-section{margin-bottom:var(--spacing-lg)}.keywords-label{font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.keywords-list{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.keyword-tag{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);font-size:14px;color:var(--text-secondary);transition:all var(--transition-fast)}.keyword-tag.checked{background:#4caf5026;border-color:var(--accent-green);color:var(--accent-green)}.keyword-tag.checked .keyword-check{color:var(--accent-green)}.progress-section{margin-bottom:var(--spacing-xl)}.progress-bar{height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden}.progress-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--accent-blue),var(--accent-gold));border-radius:4px;transition:width var(--transition-normal)}.progress-fill.warning{background:linear-gradient(90deg,var(--accent-gold),#ff9800)}.progress-fill.danger{background:linear-gradient(90deg,#ff9800,var(--accent-red))}.controls-section{display:flex;justify-content:center;gap:var(--spacing-lg)}.btn-control{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);border:none;border-radius:var(--radius-lg);font-size:16px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-start{background:linear-gradient(135deg,var(--accent-gold),#ffc107);color:#1a1a2e}.btn-start:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 20px #ffd70066}.btn-start:disabled{opacity:.5;cursor:not-allowed}.btn-stop{background:#ffffff1a;color:var(--text-primary);border:1px solid rgba(255,255,255,.2)}.btn-stop:hover:not(:disabled){background:#e03e3e33;border-color:var(--accent-red)}.btn-stop:disabled{opacity:.3;cursor:not-allowed}.btn-icon{font-size:18px}.btn-start.recording{background:var(--accent-red);animation:pulse 1.5s infinite}@keyframes pulse{0%,to{box-shadow:0 0 #e03e3e66}50%{box-shadow:0 0 0 10px #e03e3e00}}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-content{width:90%;max-width:600px;max-height:90vh;background:var(--bg-card);border-radius:var(--radius-xl);padding:var(--spacing-xl);overflow-y:auto}.modal-title{font-size:24px;font-weight:700;text-align:center;margin-bottom:var(--spacing-xl);color:var(--accent-gold)}.feedback-sequence{display:flex;flex-direction:column;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.feedback-item{display:flex;gap:var(--spacing-md);padding:var(--spacing-lg);background:#ffffff0d;border-radius:var(--radius-lg);opacity:0;transform:translateY(20px);animation:fadeInUp .5s ease forwards}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}.feedback-avatar{width:60px;height:60px;border-radius:var(--radius-md);object-fit:cover}.feedback-content{flex:1}.feedback-name{font-size:14px;font-weight:600;color:var(--accent-gold);margin-bottom:var(--spacing-xs)}.feedback-text{font-size:14px;color:var(--text-primary);line-height:1.6}.feedback-score{font-size:24px;font-weight:700;color:var(--accent-gold);align-self:center}.final-score{text-align:center;padding:var(--spacing-xl);background:linear-gradient(135deg,#ffd7001a,#ffc1070d);border:1px solid var(--accent-gold);border-radius:var(--radius-lg);margin-bottom:var(--spacing-xl)}.score-label{font-size:14px;color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.score-value{font-size:48px;font-weight:700;color:var(--accent-gold);margin-bottom:var(--spacing-sm)}.score-comment{font-size:16px;color:var(--text-primary)}.modal-actions{display:flex;justify-content:center;gap:var(--spacing-md)}.btn-retry,.btn-close{padding:var(--spacing-md) var(--spacing-xl);border:none;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:var(--transition-fast)}.btn-retry{background:var(--accent-gold);color:#1a1a2e}.btn-retry:hover{transform:translateY(-2px)}.btn-close{background:#ffffff1a;color:var(--text-primary)}.btn-close:hover{background:#fff3}@media(max-width:768px){.simulator-header{flex-wrap:wrap;gap:var(--spacing-md)}.header-center{order:3;width:100%;justify-content:center}.judges-row{gap:var(--spacing-md)}.judge-card{width:140px}.judge-image-wrapper{width:120px;height:150px}}.leaderboard-layout{grid-template-columns:var(--left-panel-width) 1fr}.leaderboard-scroll-area{flex:1;overflow-y:auto;padding:var(--spacing-lg) calc(var(--spacing-md) + var(--spacing-lg));background:var(--bg-main)}.leaderboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg);max-width:1200px;margin:0 auto}.lb-card{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-lg);overflow:hidden}.activity-card{grid-column:1;grid-row:1}.leaderboard-card{grid-column:2;grid-row:1}.card-header{display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-lg);height:46px;box-sizing:border-box;border-bottom:1px solid var(--border-light);background:var(--bg-white)}.card-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:15px;font-weight:600;color:var(--text-primary);margin:0}.card-icon{font-size:18px}.card-content{padding:var(--spacing-md)}.leaderboard-tabs{display:flex;gap:var(--spacing-xs);border-bottom:none;padding:0;background:transparent}.lb-tab-btn{padding:4px 12px;font-size:12px;font-weight:500;color:var(--text-muted);background:transparent;border:none;border-radius:20px;cursor:pointer;transition:all var(--transition-fast)}.lb-tab-btn:hover{background:var(--bg-sidebar-hover);color:var(--text-secondary)}.lb-tab-btn.active{background:#8b5cf6;color:#fff;border:none}.my-rank-banner{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);margin-bottom:var(--spacing-md);background:#8b5cf60a;border:1px solid rgba(139,92,246,.25);border-radius:var(--radius-lg);color:var(--text-primary)}.my-rank-info{display:flex;align-items:center;gap:var(--spacing-md)}.my-rank-label{font-size:13px;font-weight:500;color:var(--text-muted)}.my-rank-number{font-size:28px;font-weight:700;color:#8b5cf6}.my-rank-percentile{font-size:13px;font-weight:500;color:#8b5cf6;background:#8b5cf614;padding:4px 12px;border-radius:20px}.leaderboard-list{display:flex;flex-direction:column;gap:2px;max-height:500px;overflow-y:auto}.leaderboard-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:10px var(--spacing-md);border-radius:var(--radius-md);transition:background var(--transition-fast)}.leaderboard-item:hover{background:var(--bg-sidebar-hover)}.leaderboard-item.is-me{background:#8b5cf60f;border:1px solid rgba(139,92,246,.15)}.rank{min-width:36px;height:28px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:var(--text-muted);flex-shrink:0}.rank-1,.rank-2,.rank-3{font-size:20px}.user-info{flex:1;display:flex;align-items:baseline;gap:var(--spacing-xs);min-width:0}.user-name{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-level{font-size:12px;color:var(--text-muted);flex-shrink:0}.user-stats{display:flex;align-items:baseline;gap:var(--spacing-sm);flex-shrink:0}.stat-xp{font-size:13px;font-weight:600;color:#8b5cf6}.stat-gold{font-size:12px;color:var(--accent-warning);font-weight:500}.activity-feed{display:flex;flex-direction:column;gap:2px;max-height:500px;overflow-y:auto}.activity-item{display:flex;gap:var(--spacing-sm);padding:8px var(--spacing-sm);border-radius:var(--radius-md);transition:background var(--transition-fast)}.activity-item:hover{background:var(--bg-sidebar-hover)}.activity-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:16px;border-radius:50%;background:var(--bg-elevated);flex-shrink:0}.activity-icon.worksheet{background:#ecfdf5;color:#059669}.activity-icon.investment{background:#fffbeb;color:#d97706}.activity-icon.gratitude{background:#fdf2f8;color:#db2777}.activity-icon.badge{background:#f5f3ff;color:#7c3aed}.activity-icon.level{background:#eff6ff;color:#2563eb}.activity-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.activity-text{font-size:13px;color:var(--text-primary);line-height:1.5}.activity-text strong{font-weight:600}.activity-text .highlight{color:#8b5cf6;font-weight:500}.activity-text .gold-amount{color:var(--accent-warning);font-weight:600}.xp-badge{display:inline-block;font-size:11px;font-weight:600;color:#8b5cf6;background:#f5f3ff;padding:1px 6px;border-radius:10px;margin-left:4px}.activity-time{display:block;font-size:11px;color:var(--text-muted)}.activity-details{font-size:12px;color:var(--text-muted);background:var(--bg-elevated);padding:6px 10px;border-radius:var(--radius-sm);margin-top:4px}.load-more-btn{width:100%;padding:var(--spacing-sm);margin-top:var(--spacing-sm);font-size:13px;font-weight:500;color:var(--text-muted);background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.load-more-btn:hover{background:var(--bg-sidebar-hover);color:var(--text-primary)}.refresh-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;color:var(--text-muted);transition:all var(--transition-fast)}.refresh-btn:hover{background:var(--bg-sidebar-hover);color:var(--text-primary)}.refresh-btn svg{transition:transform .3s ease}.refresh-btn:active svg{transform:rotate(180deg)}.my-rank-card{margin:var(--spacing-md);padding:var(--spacing-md);background:linear-gradient(135deg,#8b5cf6,#a78bfa);border-radius:var(--radius-lg);color:#fff;cursor:pointer;transition:transform var(--transition-fast)}.my-rank-card:hover{transform:translateY(-2px)}.rank-label{font-size:11px;opacity:.8;margin-bottom:var(--spacing-xs)}.rank-info{display:flex;align-items:baseline;gap:var(--spacing-sm)}.rank-number{font-size:24px;font-weight:700}.rank-percentile{font-size:13px;opacity:.9}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);text-align:center;color:var(--text-muted);font-size:14px}.empty-icon{font-size:48px;margin-bottom:var(--spacing-md);opacity:.5}.empty-text{font-size:14px;color:var(--text-muted)}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl);color:var(--text-muted);font-size:13px}.skeleton{background:linear-gradient(90deg,var(--bg-elevated) 0px,#e8e8e8 40px,var(--bg-elevated) 80px);background-size:200px 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}.skeleton-leaderboard-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md)}.skeleton-rank{width:32px;height:32px;border-radius:50%}.skeleton-user{flex:1;display:flex;flex-direction:column;gap:6px}.skeleton-name{width:80px;height:14px}.skeleton-level{width:60px;height:12px}.skeleton-stats{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.skeleton-xp{width:50px;height:14px}.skeleton-gold{width:30px;height:12px}.skeleton-activity-item{display:flex;gap:var(--spacing-md);padding:var(--spacing-sm)}.skeleton-activity-icon{width:32px;height:32px;border-radius:50%}.skeleton-activity-content{flex:1;display:flex;flex-direction:column;gap:6px}.skeleton-activity-text{width:100%;height:14px}.skeleton-activity-time{width:40px;height:11px}@media(max-width:1024px){.leaderboard-grid{grid-template-columns:1fr}.leaderboard-card,.activity-card{grid-column:1;grid-row:auto}}@media(max-width:768px){.leaderboard-layout{grid-template-columns:1fr}.leaderboard-layout>.left-panel{display:none}.leaderboard-scroll-area{padding:var(--spacing-md)}}.page-container{display:flex;flex-direction:column;height:100%;overflow:hidden}.page-container>.page-header{flex-shrink:0;grid-area:unset}.page-header{margin-bottom:var(--spacing-lg);flex-shrink:0}.page-header h1{font-size:24px;font-weight:600;color:var(--text-primary);margin:0}.page-subtitle{color:var(--text-muted);font-size:15px;letter-spacing:-.01em}.dashboard-content{padding:var(--spacing-lg);height:100%;overflow-y:auto}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.dashboard-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-lg)}.dashboard-card .card-icon{font-size:32px}.dashboard-card .card-content h3{font-size:12px;color:var(--text-muted);text-transform:uppercase;margin-bottom:var(--spacing-xs)}.dashboard-card .card-value{font-size:24px;font-weight:600;color:var(--text-primary)}.dashboard-section{margin-top:var(--spacing-lg)}.dashboard-section h2{font-size:16px;font-weight:600;margin-bottom:var(--spacing-md)}.progress-overview .empty-state{padding:var(--spacing-xl);text-align:center;color:var(--text-muted);background:var(--bg-elevated);border-radius:var(--radius-md)}.course-intro-content{padding:var(--spacing-lg)}.intro-section{margin-bottom:var(--spacing-xl)}.intro-section h2{font-size:18px;font-weight:600;margin-bottom:var(--spacing-md);color:var(--text-primary)}.intro-card p{margin-bottom:var(--spacing-md);line-height:1.7}.goal-list{list-style:none;padding:0}.goal-list li{position:relative;padding-left:var(--spacing-lg);margin-bottom:var(--spacing-sm)}.goal-list li:before{content:"✓";position:absolute;left:0;color:var(--accent-success);font-weight:700}.curriculum-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.phase-card{padding:var(--spacing-md);background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-md)}.phase-card h3{font-size:14px;font-weight:600;color:var(--accent-primary);margin-bottom:var(--spacing-xs)}.phase-card p{font-size:12px;color:var(--text-muted);margin-bottom:var(--spacing-xs)}.phase-desc{font-size:13px;color:var(--text-primary)}.eval-card{padding:var(--spacing-lg);background:var(--bg-elevated);border-radius:var(--radius-lg)}.eval-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--border-light)}.eval-item:last-child{border-bottom:none}.eval-label{font-weight:500}.eval-value{color:var(--accent-primary);font-weight:600}.resources-content{max-width:1200px;margin:0 auto}.resources-content .page-description{color:var(--text-secondary);margin-bottom:var(--spacing-lg)}.resource-filters{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);flex-wrap:wrap}.filter-btn{padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;font-size:13px;transition:all var(--transition-fast)}.filter-btn:hover{background:var(--bg-sidebar-hover)}.filter-btn.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.resource-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.resource-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-md);transition:all var(--transition-fast)}.resource-item:hover{border-color:var(--accent-primary);background:#7c3aed08}.resource-icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;background:var(--bg-elevated);color:var(--accent-primary);flex-shrink:0}.resource-info{flex:1;min-width:0}.resource-title{font-size:16px;font-weight:600;margin-bottom:4px}.resource-desc{font-size:13px;color:var(--text-muted);margin:0 0 4px;padding-left:0}.resource-week{display:inline-block;font-size:11px;padding:2px 6px;background:var(--bg-elevated);border-radius:var(--radius-sm);color:var(--text-muted)}.btn-download{padding:var(--spacing-sm) var(--spacing-md);background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:12px;white-space:nowrap}.btn-download:hover{background:var(--accent-primary-hover)}.settings-scroll-area{flex:1;overflow-y:auto;padding:var(--spacing-lg) calc(var(--spacing-md) + var(--spacing-lg));background:var(--bg-main)}.settings-body{max-width:1200px;margin:0 auto}.settings-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.settings-row .settings-section{margin-bottom:0}.settings-section{margin-bottom:var(--spacing-xl)}.settings-section-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:15px;font-weight:600;margin-bottom:var(--spacing-md);color:var(--text-primary)}.settings-card{padding:var(--spacing-md);background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-lg)}.profile-card{padding:0;overflow:hidden}.profile-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg)}.settings-avatar{width:52px;height:52px;font-size:20px;cursor:default}.profile-name{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.profile-email{font-size:13px;color:var(--text-muted)}.profile-role{font-size:12px;color:var(--text-muted);margin-top:4px}.view .settings-scroll-area{padding:0}.profile-actions{border-top:1px solid var(--border-light)}.profile-actions:first-child{border-top:none}.profile-action-item{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:12px var(--spacing-lg);background:none;border:none;border-bottom:1px solid var(--border-light);cursor:pointer;font-size:14px;color:var(--text-primary);transition:background var(--transition-fast);text-align:left}.profile-action-item:last-child{border-bottom:none}.profile-action-item:hover:not(:disabled){background:var(--bg-elevated)}.profile-action-item:disabled{opacity:.55;cursor:not-allowed}.profile-action-item svg{color:var(--text-muted);flex-shrink:0}.profile-action-item span:nth-child(2){flex:1}.profile-action-item.danger{color:var(--accent-error)}.profile-action-item.danger svg{color:var(--accent-error)}.action-badge{font-size:11px;color:var(--text-muted);background:var(--bg-elevated);padding:2px 8px;border-radius:10px;font-weight:500}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) 0;border-bottom:1px solid var(--border-light)}.setting-item:last-child{border-bottom:none}.setting-info{flex:1}.setting-label{display:block;font-weight:500;margin-bottom:var(--spacing-xs)}.setting-desc{display:block;font-size:12px;color:var(--text-muted)}.toggle-switch{position:relative;display:inline-block;width:44px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--border-light);transition:var(--transition-fast);border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background:#fff;transition:var(--transition-fast);border-radius:50%}.toggle-switch input:checked+.toggle-slider{background:var(--accent-primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.chevron.collapsed{transform:rotate(-90deg)}.nav-section-content.collapsed{display:none}.notifications-scroll-area{flex:1;overflow-y:auto;padding:var(--spacing-lg) calc(var(--spacing-md) + var(--spacing-lg));background:var(--bg-main)}.notifications-body{max-width:1200px;margin:0 auto}.btn-mark-all{display:flex;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:500;color:#8b5cf6;background:#8b5cf614;border:1px solid rgba(139,92,246,.2);border-radius:20px;cursor:pointer;transition:all var(--transition-fast)}.btn-mark-all:hover{background:#8b5cf626}.notif-filters{display:flex;align-items:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg)}.notif-filters .btn-mark-all{margin-left:auto}.notif-filter-btn{padding:6px 16px;font-size:13px;font-weight:500;color:var(--text-muted);background:transparent;border:1px solid var(--border-light);border-radius:20px;cursor:pointer;transition:all var(--transition-fast)}.notif-filter-btn:hover{background:var(--bg-elevated);color:var(--text-secondary)}.notif-filter-btn.active{background:#8b5cf6;color:#fff;border-color:#8b5cf6}.notif-list{display:flex;flex-direction:column;gap:2px}.notif-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px var(--spacing-lg);color:var(--text-muted);text-align:center}.notif-empty svg{margin-bottom:var(--spacing-md);opacity:.4}.notif-empty p{font-size:14px}.notif-item{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);overflow:hidden}.notif-item:hover{border-color:#8b5cf64d;box-shadow:0 1px 4px #0000000a}.notif-item.unread{background:#8b5cf608;border-color:#8b5cf626}.notif-item-main{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg)}.notif-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0;margin-top:2px}.notif-content{flex:1;min-width:0}.notif-title-row{display:flex;align-items:center;gap:var(--spacing-sm)}.notif-title{font-size:14px;font-weight:600;color:var(--text-primary)}.notif-unread-dot{width:8px;height:8px;border-radius:50%;background:#8b5cf6;flex-shrink:0}.notif-message{font-size:13px;color:var(--text-secondary);margin-top:2px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notif-meta{display:flex;align-items:center;gap:var(--spacing-sm);margin-top:6px}.notif-time{font-size:12px;color:var(--text-muted)}.notif-detail-gold{font-size:12px;font-weight:600;color:var(--accent-warning)}.notif-detail-badge{font-size:12px;font-weight:500;color:#7c3aed;background:#f5f3ff;padding:1px 8px;border-radius:10px}.notif-detail-level{font-size:12px;font-weight:500;color:#d97706;background:#fffbeb;padding:1px 8px;border-radius:10px}.notif-actions{flex-shrink:0}.notif-action-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;color:var(--text-muted);transition:all var(--transition-fast)}.notif-action-btn:hover{background:var(--bg-elevated);color:#059669;border-color:#059669}.notif-expanded{padding:0 var(--spacing-lg) var(--spacing-md) calc(36px + var(--spacing-md) + var(--spacing-lg));border-top:1px solid var(--border-light)}.notif-expanded p{font-size:13px;color:var(--text-secondary);line-height:1.6;margin-top:var(--spacing-sm)}.notif-data{margin-top:var(--spacing-sm)}.notif-gold-detail{font-size:13px;font-weight:600;color:var(--accent-warning)}.notif-badge-detail{font-size:13px;font-weight:500;color:#7c3aed}.notif-level-detail{font-size:13px;font-weight:500;color:#d97706}@media(max-width:768px){.notifications-scroll-area{padding:var(--spacing-md)}.notif-item-main{padding:var(--spacing-sm) var(--spacing-md)}.notif-expanded{padding-left:calc(36px + var(--spacing-sm) + var(--spacing-md));padding-right:var(--spacing-md)}}.week2-container{display:flex;flex-direction:column;height:100%;overflow:hidden}.week2-header{flex-shrink:0;display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);margin-bottom:0;border-bottom:1px solid var(--border-light);background:var(--bg-white)}.page-header-right{display:flex;align-items:center;gap:var(--spacing-md)}.sync-indicator{display:flex;align-items:center;gap:var(--spacing-xs);font-size:12px;color:var(--accent-success)}.progress-badge{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-elevated);border-radius:var(--radius-md);font-size:12px}.progress-label{color:var(--text-muted)}.progress-value{font-weight:600;color:var(--accent-primary)}.content-wrapper{flex:1;overflow-y:auto;display:flex;flex-direction:column}.content-tabs{display:flex;align-items:center;gap:var(--spacing-md);padding:12px max(var(--spacing-lg),calc((100% - 800px)/2));border-bottom:1px solid var(--border-light);background:var(--bg-white);flex-shrink:0;position:sticky;top:0;z-index:10}.content-tab{display:flex;align-items:center;gap:var(--spacing-xs);padding:6px var(--spacing-md);background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:13px;color:var(--text-muted);transition:all var(--transition-fast)}.content-tab:hover{background:var(--bg-elevated);color:var(--text-primary)}.content-tab.active{background:var(--accent-primary);color:#fff}.tab-icon{font-size:14px;display:flex;align-items:center}.tab-progress{font-size:11px;padding:2px 6px;background:#fff3;border-radius:var(--radius-sm)}.progress-bar-container{padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-elevated);border-bottom:1px solid var(--border-light)}.progress-bar{height:4px;background:var(--border-light);border-radius:2px;overflow:hidden;margin-bottom:var(--spacing-sm)}.progress-fill{height:100%;background:var(--accent-primary);transition:width var(--transition-normal)}.step-indicators{display:flex;justify-content:space-between}.step-indicator{display:flex;align-items:center;gap:var(--spacing-xs);font-size:11px;color:var(--text-muted)}.step-indicator.active{color:var(--accent-primary)}.step-dot{width:8px;height:8px;border-radius:50%;background:var(--border-light)}.step-indicator.active .step-dot{background:var(--accent-primary)}.week2-tab-content{flex:1;overflow-y:auto;padding:var(--spacing-lg)}.week2-tab-content .content-page{display:block}.week2-tab-content .simulator-page{height:calc(100vh - 200px);min-height:600px}.week2-tab-content .simulator-page .simulator-embed,.week2-tab-content .simulator-page .simulator-app-inline{height:100%;position:relative}.reading-page-inner{max-width:800px;margin:0 auto}.reading-toc{padding:var(--spacing-md);background:var(--bg-elevated);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg)}.toc-header{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;margin-bottom:var(--spacing-sm)}.toc-link{display:block;padding:var(--spacing-xs) 0;color:var(--accent-primary);text-decoration:none;font-size:13px}.toc-link:hover{text-decoration:underline}.reading-content{line-height:1.8}.reading-section{margin-bottom:var(--spacing-xl)}.reading-section h2{font-size:20px;font-weight:600;margin-bottom:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--border-light)}.reading-section h3{font-size:16px;font-weight:600;margin:var(--spacing-lg) 0 var(--spacing-sm)}.reading-callout{display:flex;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-md);margin:var(--spacing-md) 0}.reading-callout.tip{background:#e8f4fd;border-left:4px solid #0ea5e9}.reading-callout.warning{background:linear-gradient(135deg,#fffef7,#fffbeb);border-left:4px solid #f59e0b}.reading-callout.success{background:var(--accent-success-light);border-left:4px solid var(--accent-success)}.callout-icon{font-size:20px}.callout-content strong{display:block;margin-bottom:var(--spacing-xs)}.reading-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md);margin:var(--spacing-md) 0}.reading-card{padding:var(--spacing-md);background:var(--bg-elevated);border-radius:var(--radius-md)}.reading-card h4{font-size:14px;margin-bottom:var(--spacing-sm)}.card-desc{font-size:13px;color:var(--text-muted)}.reading-cta{text-align:center;padding:var(--spacing-xl);background:var(--bg-elevated);border-radius:var(--radius-lg);margin-top:var(--spacing-xl)}.btn-start-worksheet{padding:var(--spacing-md) var(--spacing-xl);background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;margin-top:var(--spacing-sm)}.btn-start-worksheet:hover{background:var(--accent-primary-hover)}.video-page-inner{max-width:800px;margin:0 auto}.video-section{margin-bottom:var(--spacing-xl)}.video-section h3{font-size:16px;font-weight:600;margin-bottom:var(--spacing-md)}.video-placeholder{background:var(--bg-elevated);border-radius:var(--radius-lg);padding:var(--spacing-xl);text-align:center}.video-embed{color:var(--text-muted)}.slide-item,.video-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm)}.slide-icon,.video-thumb{font-size:24px}.slide-info,.video-info{flex:1}.slide-title,.video-title{font-weight:500;margin-bottom:var(--spacing-xs)}.slide-desc,.video-duration{font-size:12px;color:var(--text-muted)}.btn-download-slide{padding:var(--spacing-sm) var(--spacing-md);background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:12px;cursor:pointer}.resources-page-inner{max-width:800px;margin:0 auto}.resources-desc{color:var(--text-muted);margin-bottom:var(--spacing-lg)}.resource-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm)}.resource-type-icon{font-size:24px}.resource-content{flex:1}.resource-title{font-size:14px;font-weight:500;margin-bottom:var(--spacing-xs)}.resource-description{font-size:12px;color:var(--text-muted)}.btn-resource-link{padding:var(--spacing-sm) var(--spacing-md);background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:12px;text-decoration:none;cursor:pointer}.recommended-section{margin-top:var(--spacing-xl)}.recommended-section h3{font-size:16px;font-weight:600;margin-bottom:var(--spacing-md)}.book-list{display:flex;gap:var(--spacing-md)}.book-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-elevated);border-radius:var(--radius-md);flex:1}.book-cover{font-size:32px}.book-title{font-weight:500;margin-bottom:var(--spacing-xs)}.book-author{font-size:12px;color:var(--text-muted)}.worksheet-page-inner{max-width:800px;margin:0 auto}.worksheet-steps-nav{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.step-nav-btn{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;font-size:13px;transition:all var(--transition-fast)}.step-nav-btn:hover{border-color:var(--accent-primary)}.step-nav-btn.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.step-nav-btn.completed{background:var(--accent-success-light);border-color:var(--accent-success)}.step-num{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:#0000001a;border-radius:50%;font-size:11px;font-weight:600}.step-nav-btn.active .step-num{background:#ffffff4d}.worksheet-step{padding:var(--spacing-lg);background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-lg)}.step-header{margin-bottom:var(--spacing-lg)}.step-header h3{font-size:18px;font-weight:600;margin-bottom:var(--spacing-xs)}.step-desc{color:var(--text-muted);font-size:14px}.worksheet-fields{display:flex;flex-direction:column;gap:var(--spacing-lg)}.field-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.field-group label{font-weight:500;font-size:14px}.field-row{display:flex;gap:var(--spacing-md)}.field-row .field-group{flex:1}.substep-body textarea{width:100%;border:none;border-radius:0;font-size:15px;font-family:inherit;padding:4px 0;line-height:32px;resize:none;background-color:transparent;background-image:repeating-linear-gradient(to bottom,transparent 0px,transparent 31px,#d1d5db 31px,#d1d5db 32px);background-position:0 4px;overflow:hidden;overflow-wrap:break-word;white-space:pre-wrap;box-sizing:border-box;min-height:40px}.substep-body textarea:focus{outline:none;background-image:repeating-linear-gradient(to bottom,transparent 0px,transparent 31px,var(--text-dark) 31px,var(--text-dark) 32px)}.two-column-table{display:flex;flex-direction:column}.two-column-header{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);padding:var(--spacing-xs) 0;font-weight:600;font-size:13px;color:var(--text-secondary)}.two-column-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.two-column-row textarea{min-height:48px}.label-table{width:100%;border-collapse:collapse}.label-table th,.label-table td{border:none;padding:var(--spacing-xs) var(--spacing-sm);vertical-align:top}.label-table th{font-weight:600;font-size:15px;color:var(--text-secondary);text-align:center;white-space:nowrap;width:1%}.label-table thead th{white-space:normal;width:auto;padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border-light)}.label-table td input{width:100%;border:none;border-bottom:1px solid #d1d5db;border-radius:0;background:transparent;padding:var(--spacing-sm) 0;min-height:32px;resize:none;font-size:15px;font-family:inherit}.label-table td select{width:100%;border:none;border-bottom:1px solid #d1d5db;border-radius:0;background:transparent;padding:var(--spacing-sm) 0;min-height:32px;font-size:15px;cursor:pointer}.label-table td input:focus,.label-table td select:focus{outline:none;border-bottom-color:var(--text-dark)}.empathy-grid-2x2{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.empathy-cell{display:flex;flex-direction:column}.empathy-cell-header{padding:var(--spacing-xs) 0;font-weight:600;font-size:13px;color:var(--text-secondary);text-align:center}.empathy-cell textarea{min-height:80px}.worksheet-nav-buttons{display:flex;justify-content:space-between;margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--border-light)}.btn-prev,.btn-next,.btn-submit{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-size:14px;cursor:pointer;transition:all var(--transition-fast)}.btn-prev{background:var(--bg-elevated);border:1px solid var(--border-light);color:var(--text-primary)}.btn-next{background:var(--accent-primary);border:none;color:#fff;margin-left:auto}.btn-submit{background:var(--accent-success);border:none;color:#fff;margin-left:auto}.btn-next:hover,.btn-submit:hover{opacity:.9}.simulator-container{max-width:800px;margin:0 auto}.simulator-header{text-align:center;margin-bottom:var(--spacing-xl)}.simulator-header h2{font-size:24px;margin-bottom:var(--spacing-sm)}.simulator-intro{display:flex;flex-direction:column;gap:var(--spacing-lg)}.intro-card{padding:var(--spacing-lg);background:var(--bg-elevated);border-radius:var(--radius-lg)}.intro-card h3{font-size:16px;margin-bottom:var(--spacing-md)}.feature-list{list-style:none;margin-top:var(--spacing-md)}.feature-list li{padding:var(--spacing-sm) 0}.simulator-start-section{text-align:center}.start-options{display:flex;justify-content:center;gap:var(--spacing-md)}.btn-start-pitch{padding:var(--spacing-md) var(--spacing-xl);background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer}.btn-view-leaderboard{padding:var(--spacing-md) var(--spacing-xl);background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:14px;cursor:pointer}.simulator-placeholder{margin-top:var(--spacing-xl);padding:var(--spacing-xl);background:var(--bg-elevated);border-radius:var(--radius-lg);text-align:center}.placeholder-text{font-size:18px;color:var(--text-muted);margin-bottom:var(--spacing-sm)}.placeholder-desc{font-size:14px;color:var(--text-muted)}.view .page-header{padding-left:0;padding-top:0;margin-top:-20px}.course-intro-content{max-width:1200px;margin:0 auto;padding:24px}.course-header{margin-bottom:48px;padding-bottom:24px;border-bottom:1px solid var(--border-light)}.course-header h1{font-size:32px;font-weight:700;color:var(--text-dark);margin-bottom:8px;letter-spacing:-.02em}.course-header .tagline{font-size:18px;color:var(--text-muted)}.course-intro-content .section{margin-bottom:48px}.course-intro-content .section h2{font-size:22px;font-weight:600;color:var(--text-dark);margin-bottom:20px}.course-intro-content .section h3{font-size:17px;font-weight:600;color:var(--text-dark);margin:24px 0 4px}.course-intro-content .section p{font-size:16px;line-height:1.7;color:var(--text-dark);margin-top:0;margin-bottom:16px}.course-intro-content .section-body{padding-left:16px}.info-table{width:100%;border-collapse:collapse;font-size:15px;margin-bottom:20px}.info-table th,.info-table td{padding:12px 16px;text-align:left;border:1px solid var(--border-light)}.info-table th{background:var(--bg-elevated);font-weight:600;color:var(--text-dark);width:180px;white-space:nowrap}.info-table td{color:var(--text-dark)}.curriculum-table{width:100%;border-collapse:collapse;font-size:14px;margin-bottom:20px}.curriculum-table th,.curriculum-table td{padding:10px 12px;text-align:left;border:1px solid var(--border-light);vertical-align:top}.curriculum-table th{background:var(--bg-elevated);font-weight:600}.curriculum-table th.week-col{width:50px}.curriculum-table th.topic-col{width:180px}.curriculum-table tr.anchor-row{background:#f59e0b14}.curriculum-table tr.anchor-row td:first-child:after{content:" "}.phase-header-row td{background:var(--accent-primary);color:#fff;font-weight:600;font-size:15px}.simple-list{list-style:none;padding:0;margin:0 0 20px}.simple-list li{padding:6px 0;font-size:16px;color:var(--text-dark);display:flex;gap:8px;line-height:1.6}.simple-list li:before{content:"•";color:var(--accent-primary)}.simple-list .num{font-weight:600;color:var(--accent-primary);min-width:24px}.quote-box{background:var(--bg-elevated);border-left:3px solid var(--accent-primary);padding:16px 20px;margin:20px 0;font-size:17px;font-style:italic;color:var(--text-dark)}.phase-diagram{background:var(--bg-elevated);border-radius:var(--radius-md);padding:16px 20px;font-size:15px;line-height:1.5;overflow-x:auto;margin-bottom:20px;white-space:pre}.faq-item{margin-bottom:20px}.faq-item .question{font-weight:600;font-size:16px;color:var(--text-dark);margin-bottom:6px}.faq-item .answer{font-size:15px;color:var(--text-muted);padding-left:16px;line-height:1.6}.cta-section{text-align:center;padding:32px 0;border-top:1px solid var(--border-light);margin-top:48px}.btn-start{display:inline-flex;align-items:center;gap:8px;background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-md);padding:12px 24px;font-size:16px;font-weight:600;text-decoration:none;cursor:pointer}.btn-start:hover{background:var(--accent-primary-hover)}.instructor-preview .section-editable{position:relative;padding-top:8px}.section-edit-btn{position:absolute;top:4px;right:0;display:inline-flex;align-items:center;gap:4px;padding:6px 12px;font-size:13px;font-weight:500;color:var(--accent-primary);background:#fff;border:1px solid var(--border-light);border-radius:6px;cursor:pointer;transition:all .15s;z-index:1}.section-edit-btn:hover{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.section-edit-panel{background:var(--bg-elevated, #f9f9f8);border:1px solid var(--border-light);border-radius:8px;padding:24px;margin-bottom:32px}.section-edit-panel h3{font-size:17px;font-weight:600;color:var(--text-dark);margin:0 0 20px;padding-bottom:12px;border-bottom:1px solid var(--border-light)}.edit-form{display:flex;flex-direction:column;gap:14px}.edit-field{display:flex;flex-direction:column;gap:4px}.edit-field label{font-size:13px;font-weight:600;color:var(--text-muted)}.edit-field input,.edit-field textarea{padding:8px 12px;border:1px solid var(--border-light);border-radius:6px;font-size:14px;color:var(--text-dark);background:#fff}.edit-field input:focus,.edit-field textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #2563eb1a}.edit-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.edit-row-phase{display:flex;align-items:center;gap:10px}.edit-list-item{display:flex;align-items:center;gap:8px;margin-bottom:6px}.edit-list-item input{flex:1;padding:6px 10px;border:1px solid var(--border-light);border-radius:6px;font-size:14px}.edit-list-item input:focus{outline:none;border-color:var(--accent-primary)}.btn-remove-sm{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:none;border:1px solid transparent;border-radius:6px;color:var(--text-muted);cursor:pointer;flex-shrink:0}.btn-remove-sm:hover{color:#ef4444;background:#fef2f2;border-color:#fecaca}.btn-add-sm{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;font-size:13px;color:var(--accent-primary);background:none;border:1px dashed var(--border-light);border-radius:6px;cursor:pointer;margin-top:4px}.btn-add-sm:hover{background:#2563eb0d;border-color:var(--accent-primary)}.ksa-edit-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}.ksa-edit-col h4{font-size:14px;font-weight:600;color:var(--text-dark);margin:0 0 12px}.eval-edit-section{margin-bottom:20px}.eval-edit-section h4{font-size:15px;font-weight:600;margin:0 0 10px}.eval-category-header{display:flex;align-items:center;gap:6px;margin-bottom:10px}.eval-cat-num{font-size:15px;font-weight:600;flex-shrink:0}.category-name-input{font-size:15px;font-weight:600;padding:4px 8px;border:1px solid var(--border-light);border-radius:6px;width:160px}.category-name-input:focus{outline:none;border-color:var(--accent-primary)}.eval-subtotal{font-size:13px;color:var(--text-muted);flex-shrink:0}.eval-edit-item{display:flex;align-items:center;gap:8px;margin-bottom:8px}.eval-edit-item input{padding:6px 10px;border:1px solid var(--border-light);border-radius:6px;font-size:14px}.eval-edit-item input:focus{outline:none;border-color:var(--accent-primary)}.eval-edit-item .weight-input{width:60px;text-align:center}.eval-edit-item .weight-unit{font-size:13px;color:var(--text-muted);flex-shrink:0}.eval-edit-item .desc-input{flex:1}.eval-total{padding:10px 0;font-size:14px;color:var(--text-muted)}.eval-total strong.valid{color:#22c55e}.eval-total strong.invalid{color:#ef4444}.faq-edit-item{margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--border-light)}.faq-edit-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}.faq-edit-row .faq-label{font-weight:600;font-size:14px;min-width:24px;color:var(--text-dark)}.faq-edit-row input{flex:1;padding:6px 10px;border:1px solid var(--border-light);border-radius:6px;font-size:14px}.faq-edit-row input:focus{outline:none;border-color:var(--accent-primary)}.ref-edit-item{display:flex;align-items:center;gap:8px;margin-bottom:8px}.ref-edit-item input{padding:6px 10px;border:1px solid var(--border-light);border-radius:6px;font-size:14px}.ref-edit-header{font-size:13px;font-weight:600;color:var(--text-muted);margin-bottom:2px}.ref-edit-item input:first-child,.ref-edit-header span:first-child{flex:2}.ref-edit-item input:nth-child(2),.ref-edit-header span:nth-child(2){flex:1}.ref-edit-item input:nth-child(3),.ref-edit-header span:nth-child(3){flex:1}.ref-edit-item input:focus{outline:none;border-color:var(--accent-primary)}.edit-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-light)}.btn-cancel-sm{display:inline-flex;align-items:center;gap:4px;padding:8px 16px;font-size:13px;color:var(--text-muted);background:#fff;border:1px solid var(--border-light);border-radius:6px;cursor:pointer}.btn-cancel-sm:hover{background:var(--bg-elevated)}.btn-save-sm{display:inline-flex;align-items:center;gap:4px;padding:8px 16px;font-size:13px;font-weight:600;color:#fff;background:var(--accent-primary);border:1px solid var(--accent-primary);border-radius:6px;cursor:pointer}.btn-save-sm:hover{background:var(--accent-primary-hover, #1d4ed8)}.btn-save-sm:disabled{opacity:.6;cursor:not-allowed}.view-header-desc{font-size:13px;color:var(--text-muted);margin-top:4px}.error-modal-backdrop{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:9999}.error-modal{background:#fff;border-radius:12px;padding:28px 32px 24px;max-width:420px;width:90%;box-shadow:0 8px 32px #0000002e}.error-modal h4{margin:0 0 12px;font-size:17px;font-weight:700;color:#dc3545}.error-modal p{margin:0 0 20px;font-size:14px;line-height:1.6;color:#333;word-break:keep-all}.error-modal .btn-primary{display:block;margin-left:auto;padding:8px 24px;background:var(--accent-primary, #6c5ce7);color:#fff;border:none;border-radius:6px;font-size:14px;cursor:pointer}.error-modal.info-modal h4{color:var(--accent-primary, #6c5ce7)}.curriculum-phase-edit{padding:6px 0;margin-bottom:4px}@media(max-width:768px){.ksa-edit-grid,.edit-row-2{grid-template-columns:1fr}.edit-row-phase{grid-template-columns:1fr 1fr}.eval-edit-item,.ref-edit-item{flex-wrap:wrap}}.harness-dashboard{padding:0 var(--spacing-lg) var(--spacing-lg);max-width:1200px;margin:0 auto}.harness-dashboard>.harness-section:first-child{padding-top:0}.harness-section{background:var(--bg-white);padding:var(--spacing-lg) 0;margin-bottom:var(--spacing-md);border:none;border-radius:0;border-bottom:1px solid var(--border-light)}.harness-section.no-border{border-bottom:none}.harness-dashboard .section-title{font-size:18px;font-weight:600;color:var(--text-dark);margin-top:0;margin-bottom:var(--spacing-md);letter-spacing:-.02em;line-height:1.4;display:flex;align-items:center;gap:var(--spacing-sm)}.harness-dashboard .section-title .section-title-en{font-size:13px;font-weight:400;color:var(--text-muted);letter-spacing:0}.harness-dashboard .section-title .meta-badge{font-size:13px;font-weight:500;vertical-align:middle}.profile-header{display:flex;justify-content:space-between;align-items:center}.profile-info{display:flex;flex-direction:column;gap:var(--spacing-xs)}.profile-name{font-size:22px;font-weight:600;color:var(--text-dark);letter-spacing:-.02em}.profile-meta{display:flex;gap:var(--spacing-sm)}.meta-badge{font-size:14px;color:var(--text-muted);padding:2px var(--spacing-sm);background:var(--bg-elevated);border-radius:var(--radius-sm)}.profile-xp{display:flex;flex-direction:column;align-items:flex-end}.xp-value{font-size:28px;font-weight:700;color:var(--accent-primary)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-md)}.stat-item{text-align:center;padding:var(--spacing-md);background:var(--bg-elevated);border-radius:var(--radius-md)}.stat-value{font-size:22px;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs);letter-spacing:-.01em}.stat-label{font-size:14px;color:var(--text-muted)}.trend-indicator[data-trend=improving]{color:var(--accent-success)}.trend-indicator[data-trend=stable]{color:var(--text-muted)}.trend-indicator[data-trend=declining]{color:var(--accent-error)}.timeline-container{display:flex;align-items:center;gap:0;overflow-x:auto;padding:var(--spacing-md) 0}.timeline-week{display:flex;flex-direction:column;align-items:center;min-width:60px}.timeline-dot{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#fff;margin-bottom:var(--spacing-xs)}.timeline-dot.completed{background:var(--accent-success)}.timeline-dot.current{background:var(--accent-primary)}.timeline-dot.pending{background:var(--border-light);color:var(--text-muted)}.timeline-label{font-size:11px;color:var(--text-muted)}.timeline-connector{width:20px;height:2px;background:var(--border-light);margin-top:-20px}.timeline-connector.completed{background:var(--accent-success)}.two-column-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg)}.column-card{padding:var(--spacing-md);background:var(--bg-elevated);border-radius:var(--radius-md)}.column-title{font-size:16px;font-weight:600;color:var(--text-dark);letter-spacing:-.01em;margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border-light)}.column-content{font-size:14px;color:var(--text-primary);line-height:1.6}.milestone-list{list-style:none;padding:0;margin:0}.milestone-item{padding:var(--spacing-xs) 0;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-light)}.milestone-item:last-child{border-bottom:none}.milestone-label{color:var(--text-primary)}.milestone-xp{font-size:12px;color:var(--accent-success);font-weight:500}.canvas-stats{display:flex;gap:var(--spacing-lg);margin-bottom:var(--spacing-md)}.canvas-stat{display:flex;flex-direction:column;align-items:center}.canvas-stat-value{font-size:20px;font-weight:600;color:var(--text-primary)}.canvas-stat-label{font-size:12px;color:var(--text-muted)}.canvas-changed-block{font-size:13px;color:var(--text-muted)}.changed-value{color:var(--accent-primary);font-weight:500}.insight-block{margin-bottom:var(--spacing-lg)}.insight-block:last-child{margin-bottom:0}.insight-title{font-size:14px;font-weight:500;color:var(--text-dark);margin-bottom:var(--spacing-sm)}.insight-list{list-style:none;padding:0;margin:0}.insight-list li{padding:var(--spacing-xs) 0;font-size:14px;color:var(--text-primary);border-bottom:1px solid var(--border-light)}.insight-list li:last-child{border-bottom:none}.insight-list li:before{content:"•";color:var(--accent-primary);margin-right:var(--spacing-sm)}.chat-summary{font-size:13px;color:var(--text-primary);line-height:1.4;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-elevated);border-radius:var(--radius-md);max-height:400px;overflow-y:auto}.chat-summary h3{font-size:13px;font-weight:600;color:var(--text-primary);margin:var(--spacing-xs) 0;padding:var(--spacing-xs) 0;cursor:pointer;display:flex;align-items:center;gap:6px;border-bottom:1px solid var(--border-light)}.chat-summary h3:first-child{margin-top:0}.chat-summary h3:before{content:"▼";font-size:9px;color:var(--text-muted);transition:transform .15s}.chat-summary h3.collapsed:before{transform:rotate(-90deg)}.chat-summary .collapsible-content{overflow:hidden;transition:max-height .2s ease-out}.chat-summary .collapsible-content.collapsed{max-height:0!important;padding:0;margin:0}.chat-summary h4{font-size:12px;font-weight:600;color:var(--text-secondary);margin:var(--spacing-xs) 0 4px 0}.chat-summary p{margin:0 0 var(--spacing-xs) 0}.chat-summary ul{margin:0 0 var(--spacing-xs) 0;padding-left:16px}.chat-summary li{margin-bottom:2px;line-height:1.3}.chat-summary em{font-size:11px;color:var(--text-muted)}.canvas-trend-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}@media(max-width:768px){.canvas-trend-grid{grid-template-columns:1fr}}.canvas-trend-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-elevated);border-radius:var(--radius-sm);transition:background .12s}.canvas-trend-item:hover{background:#ededec}.canvas-trend-info{display:flex;align-items:center;gap:var(--spacing-sm);flex:1;min-width:0}.canvas-trend-icon{font-size:14px;flex-shrink:0}.canvas-trend-name{font-size:14px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.canvas-trend-level{font-size:11px;font-weight:600;padding:2px 8px;border-radius:3px;margin:0 var(--spacing-sm);flex-shrink:0}.canvas-trend-level.green{background:#dcfce7;color:#15803d}.canvas-trend-level.blue{background:#dbeafe;color:#1d4ed8}.canvas-trend-level.orange{background:#fef3c7;color:#d97706}.canvas-trend-level.red{background:#fecaca;color:#dc2626}.canvas-trend-level.gray{background:#f3f4f6;color:#9ca3af}.canvas-trend-chart{width:80px;height:24px;flex-shrink:0}.canvas-trend-chart svg{width:100%;height:100%}.canvas-trend-chart .trend-line{fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.canvas-trend-chart .trend-line.green{stroke:#15803d}.canvas-trend-chart .trend-line.blue{stroke:#1d4ed8}.canvas-trend-chart .trend-line.orange{stroke:#d97706}.canvas-trend-chart .trend-line.red{stroke:#dc2626}.canvas-trend-chart .trend-line.gray{stroke:#9ca3af}.canvas-trend-legend{display:flex;justify-content:center;gap:var(--spacing-md);margin-top:var(--spacing-sm);padding:var(--spacing-xs);font-size:11px;color:var(--text-muted)}.canvas-trend-legend .legend-item{display:flex;align-items:center;gap:4px}.canvas-trend-legend .legend-dot{font-size:8px}.canvas-trend-legend .legend-dot.green{color:#15803d}.canvas-trend-legend .legend-dot.blue{color:#1d4ed8}.canvas-trend-legend .legend-dot.orange{color:#d97706}.canvas-trend-legend .legend-dot.red{color:#dc2626}.canvas-trend-legend .legend-dot.gray{color:#9ca3af}.canvas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-sm)}@media(max-width:768px){.canvas-grid{grid-template-columns:repeat(2,1fr)}}.canvas-block:hover{box-shadow:0 2px 8px #0000000f;transform:translateY(-1px)}.canvas-block.level-green{border-color:#15803d;background:#f0fdf4}.canvas-block.level-blue{border-color:#1d4ed8;background:#eff6ff}.canvas-block.level-orange{border-color:#d97706;background:#fffbeb}.canvas-block.level-red{border-color:#dc2626;background:#fef2f2}.canvas-block.level-none{border-color:#e5e7eb;background:#f9fafb}.canvas-block .block-header{display:flex;align-items:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm)}.canvas-block .block-icon{font-size:16px}.canvas-block .block-name{font-size:13px;font-weight:500;color:var(--text-primary)}.canvas-block .block-level-row{display:flex;align-items:center;gap:var(--spacing-sm)}.canvas-block .block-level-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:3px}.canvas-block .block-level-num{font-size:12px;color:var(--text-muted)}.canvas-block .block-content-preview{font-size:11px;color:var(--text-secondary);margin-top:var(--spacing-sm);line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.canvas-legend{display:flex;justify-content:center;gap:var(--spacing-md);margin-top:var(--spacing-md);padding:var(--spacing-sm);font-size:12px;color:var(--text-muted)}.canvas-legend .legend-item{display:flex;align-items:center;gap:4px}.canvas-legend .legend-dot{font-size:10px}.canvas-legend .legend-dot.green{color:#15803d}.canvas-legend .legend-dot.blue{color:#1d4ed8}.canvas-legend .legend-dot.orange{color:#d97706}.canvas-legend .legend-dot.red{color:#dc2626}.harness-dashboard .activity-grid{display:grid!important;grid-template-columns:repeat(3,1fr)!important;gap:var(--spacing-md);align-items:stretch;position:relative}@media(max-width:768px){.harness-dashboard .activity-grid{grid-template-columns:1fr!important}}.harness-dashboard .activity-card{background:var(--bg-elevated);border-radius:var(--radius-md);padding:var(--spacing-md);min-height:auto;position:relative!important;grid-column:auto!important;grid-row:auto!important}.activity-card-title{font-size:15px;font-weight:600;color:var(--text-dark);letter-spacing:-.01em;margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--border-light)}.activity-card-content{font-size:13px}.gamification-level{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.level-icon{font-size:20px}.level-title{font-size:14px;font-weight:500;color:var(--text-primary)}.gamification-stats{display:flex;gap:var(--spacing-lg);margin-bottom:var(--spacing-sm)}.gami-stat{display:flex;flex-direction:column;align-items:center}.gami-stat-value{font-size:18px;font-weight:600;color:var(--accent-primary)}.gami-stat-label{font-size:11px;color:var(--text-muted)}.badge-list{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.badge-item{font-size:18px;opacity:.3}.badge-item.earned{opacity:1}.team-contribution{text-align:center;margin-bottom:var(--spacing-sm)}.contribution-score{font-size:32px;font-weight:700;color:var(--accent-primary)}.contribution-level{font-size:12px;color:var(--text-muted)}.contribution-level.excellent{color:var(--accent-success)}.contribution-level.good{color:var(--accent-primary)}.contribution-level.average{color:var(--text-muted)}.contribution-level.needs_improvement{color:var(--accent-error)}.team-breakdown{display:flex;flex-direction:column;gap:var(--spacing-xs)}.breakdown-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) 0;border-bottom:1px solid var(--border-light)}.breakdown-item:last-child{border-bottom:none}.breakdown-label{font-size:12px;color:var(--text-secondary)}.breakdown-value{font-size:13px;font-weight:500;color:var(--text-primary)}.pitch-best-score{text-align:center;margin-bottom:var(--spacing-xs)}.best-score-value{font-size:32px;font-weight:700;color:var(--accent-success)}.best-score-label{font-size:12px;color:var(--text-muted);display:block}.pitch-stats{display:flex;justify-content:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xs)}.pitch-stat{display:flex;flex-direction:column;align-items:center}.pitch-stat-value{font-size:16px;font-weight:600;color:var(--text-primary)}.pitch-stat-label{font-size:11px;color:var(--text-muted)}.judge-averages{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);justify-content:center}.judge-item{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-xs);font-size:11px}.judge-name{font-size:16px}.judge-score{color:var(--text-muted)}.empty-state{color:var(--text-muted);font-style:italic}@media(max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.two-column-grid{grid-template-columns:1fr}.canvas-grid{grid-template-columns:repeat(2,1fr)}}.insight-grid-2col{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}@media(max-width:768px){.insight-grid-2col{grid-template-columns:1fr}}.insight-block-notebook{background:transparent;border-radius:0;padding:var(--spacing-md) 0;min-height:auto;border-bottom:1px solid var(--border-light)}.insight-block-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border-light)}.insight-block-icon{font-size:16px}.insight-block-title{font-size:15px;font-weight:600;color:var(--text-dark);letter-spacing:-.01em}.insight-block-content{font-size:14px;color:var(--text-primary);line-height:1.6}.notebook-lines{background-image:repeating-linear-gradient(to bottom,transparent 0px,transparent 27px,var(--border-light) 27px,var(--border-light) 28px);background-position:0 4px;padding-bottom:var(--spacing-xs)}.notebook-lines:has(.notebook-line.empty:only-child){background-image:none}.notebook-line{line-height:28px;min-height:28px;padding:0;font-size:15px;color:var(--text-primary)}.notebook-line.empty{color:var(--text-muted);font-style:italic}.dashboard-two-column{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg)}@media(max-width:768px){.dashboard-two-column{grid-template-columns:1fr}}.dashboard-column{min-width:0}.column-header{font-size:18px;font-weight:600;color:var(--text-dark);letter-spacing:-.02em;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--accent-primary)}.dashboard-column .stats-grid{grid-template-columns:repeat(3,1fr)}.dashboard-column .canvas-trend-grid{grid-template-columns:1fr}.dashboard-column .canvas-grid{grid-template-columns:repeat(3,1fr)}.dashboard-column .insight-grid-2col{grid-template-columns:1fr}.dashboard-column .two-column-grid{grid-template-columns:1fr 1fr;gap:var(--spacing-md)}@media(max-width:1024px){.dashboard-column .canvas-grid{grid-template-columns:repeat(2,1fr)}.dashboard-column .two-column-grid{grid-template-columns:1fr}}.block-feedback-summary{font-size:12px;color:var(--text-secondary);margin-top:var(--spacing-xs);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}html,body,*{font-family:Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}#root{height:100vh;overflow:hidden}.login-container{width:100%;max-width:400px;padding:24px}.login-page{min-height:100vh;display:flex;justify-content:center;align-items:center;background:var(--bg-sidebar, #f7f6f3)}.login-card{background:var(--bg-main, #ffffff);border-radius:8px;box-shadow:#0f0f0f0d 0 0 0 1px,#0f0f0f1a 0 3px 6px;padding:48px 40px;width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:32px}.login-logo{font-size:32px;margin-bottom:8px}.login-title{font-size:24px;font-weight:600;color:var(--text-primary, #37352f);margin-bottom:8px}.login-subtitle{font-size:14px;color:var(--text-muted, #787774);margin:0}.university-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;font-size:12px;color:var(--text-muted, #787774);background:var(--bg-sidebar, #f7f6f3);border-radius:20px;margin-top:16px}.login-form{display:flex;flex-direction:column;gap:16px}.login-form .form-group{display:flex;flex-direction:column;gap:6px}.login-form .form-label{font-size:12px;font-weight:500;color:var(--text-muted, #787774);text-transform:uppercase;letter-spacing:.5px}.login-form .form-input{width:100%;padding:10px 12px;font-size:14px;font-family:inherit;color:var(--text-primary, #37352f);background:var(--bg-main, #ffffff);border:1px solid var(--border-light, #e9e9e7);border-radius:4px;outline:none;transition:border-color .12s ease,box-shadow .12s ease}.login-form .form-input:focus{border-color:var(--accent-primary, #2eaadc);box-shadow:0 0 0 3px #2eaadc26}.login-form .form-input::placeholder{color:var(--text-placeholder, #9b9a97)}.password-input-wrapper{position:relative}.password-input-wrapper .form-input{padding-right:40px}.password-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-muted, #787774);padding:4px;display:flex;align-items:center;justify-content:center}.password-toggle:hover{color:var(--text-primary, #37352f)}.login-form .error-message{padding:10px 12px;font-size:13px;color:var(--accent-error, #e03e3e);background:#e03e3e14;border-radius:3px}.btn-login{width:100%;padding:12px 16px;font-size:14px;font-weight:500;font-family:inherit;color:#fff;background:var(--accent-primary, #2eaadc);border:none;border-radius:4px;cursor:pointer;transition:background .12s ease;margin-top:8px;position:relative}.btn-login:hover{background:var(--accent-primary-hover, #0b8ec0)}.btn-login:disabled{background:var(--text-placeholder, #9b9a97);cursor:not-allowed}.btn-login.loading{color:transparent}.btn-login.loading:after{content:"";position:absolute;top:50%;left:50%;width:16px;height:16px;margin:-8px 0 0 -8px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.login-footer{margin-top:24px;text-align:center}.login-footer a{font-size:13px;color:var(--text-muted, #787774);text-decoration:none;transition:color .12s ease}.login-footer a:hover{color:var(--accent-primary, #2eaadc)}.page-footer{position:fixed;bottom:0;left:0;right:0;background:var(--bg-main, #ffffff);border-top:1px solid var(--border-light, #e9e9e7);padding:20px 48px;text-align:center}.footer-content{font-size:13px;color:var(--text-muted, #787774);letter-spacing:.3px}.footer-content .divider{margin:0 20px;opacity:.4}@media(max-width:480px){.login-card{padding:32px 24px}}.sk{background:#f0efed;position:relative;overflow:hidden}.sk:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.5) 50%,transparent 100%);animation:sk-shimmer 1.5s ease-in-out infinite}@keyframes sk-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes sk-cascade{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.sk-text{display:flex;flex-direction:column;gap:8px;margin-top:10px}.sk-mt-8{margin-top:8px}.sk-card{background:#fff;border:1px solid #f0efed;border-radius:8px;padding:16px;animation:sk-cascade .4s ease-out both}.sk-step{background:#fff;border:1px solid #f0efed;border-radius:10px;padding:20px;margin-bottom:16px;animation:sk-cascade .4s ease-out both}.sk-step:nth-child(2){animation-delay:.08s}.sk-step:nth-child(3){animation-delay:.16s}.sk-step:nth-child(4){animation-delay:.24s}.sk-step-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.sk-substep{padding:12px 0;border-top:1px solid #f7f6f5}.sk-substep:first-child{border-top:none}.harness-dashboard .harness-section{animation:sk-cascade .35s ease-out both}.harness-dashboard .harness-section:nth-child(1){animation-delay:0s}.harness-dashboard .harness-section:nth-child(2){animation-delay:.06s}.harness-dashboard .harness-section:nth-child(3){animation-delay:.12s}.harness-dashboard .harness-section:nth-child(4){animation-delay:.18s}.dashboard-two-column{animation:sk-cascade .35s ease-out both;animation-delay:.08s}.canvas-grid .sk-card:nth-child(1){animation-delay:.04s}.canvas-grid .sk-card:nth-child(2){animation-delay:.08s}.canvas-grid .sk-card:nth-child(3){animation-delay:.12s}.canvas-grid .sk-card:nth-child(4){animation-delay:.16s}.canvas-grid .sk-card:nth-child(5){animation-delay:.2s}.canvas-grid .sk-card:nth-child(6){animation-delay:.24s}.stats-grid .stat-item{animation:sk-cascade .3s ease-out both}.stats-grid .stat-item:nth-child(1){animation-delay:.04s}.stats-grid .stat-item:nth-child(2){animation-delay:.1s}.stats-grid .stat-item:nth-child(3){animation-delay:.16s}:root{--bg-main: #ffffff;--bg-sidebar: #f7f6f3;--bg-sidebar-hover: #efefec;--bg-elevated: #f7f6f3;--text-primary: #37352f;--text-muted: #787774;--text-placeholder: #9b9a97;--accent-primary: #7c3aed;--accent-primary-hover: #6d28d9;--border-light: #e9e9e7;--level-red: #e03e3e;--level-red-bg: #fdeaea;--level-orange: #d9730d;--level-orange-bg: #fdf3e7;--level-blue: #2eaadc;--level-blue-bg: #e7f5fa;--level-green: #0f7b6c;--level-green-bg: #e6f5f0;--level-gray: #9b9a97;--level-gray-bg: #f7f6f3;--accent-success: #0f7b6c;--accent-error: #e03e3e;--accent-primary-bg: rgba(124, 58, 237, .1);--bg-secondary: #f7f6f3;--text-secondary: #5c5c5a;--sidebar-width: 260px;--right-panel-width: 360px;--header-height: 56px;--mobile-header-height: 52px;--font-family: "Pretendard Variable", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--shadow-sm: rgba(15, 15, 15, .04) 0px 0px 0px 1px;--shadow-md: rgba(15, 15, 15, .05) 0px 0px 0px 1px, rgba(15, 15, 15, .1) 0px 3px 6px;--shadow-lg: rgba(15, 15, 15, .05) 0px 0px 0px 1px, rgba(15, 15, 15, .1) 0px 5px 10px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}body{font-family:var(--font-family);font-size:14px;line-height:1.5;color:var(--text-primary);background:var(--bg-main)}.sidebar,.main-content,.sidebar *,.main-content *{scrollbar-width:none;-ms-overflow-style:none}.sidebar::-webkit-scrollbar,.main-content::-webkit-scrollbar,.sidebar *::-webkit-scrollbar,.main-content *::-webkit-scrollbar{display:none}.header{height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 36px 0 var(--spacing-lg);border-bottom:1px solid var(--border-light);background:var(--bg-main)}.header-left{display:flex;align-items:center;gap:var(--spacing-md)}.header-logo-img{width:36px;height:36px;object-fit:contain;border-radius:10px}.logo{font-size:18px;font-weight:700;color:var(--accent-primary)}.header-divider{width:1px;height:20px;background:var(--border-light)}.header-title{font-size:14px;font-weight:500;color:var(--text-muted)}.header-right{display:flex;align-items:center;gap:var(--spacing-sm)}.course-selector{padding:6px 12px;border:1px solid var(--border-light);border-radius:var(--radius-sm);font-size:13px;background:var(--bg-main)}.user-info{display:flex;align-items:center;gap:var(--spacing-sm)}.profile-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;flex-shrink:0}.user-name-display{font-size:14px;font-weight:500;color:var(--text-primary)}.user-email-display{font-size:12px;color:var(--text-muted)}.btn-text{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:13px;display:flex;align-items:center;gap:4px;padding:4px 8px;margin-left:48px}.btn-text:hover{color:var(--accent-error)}body[data-role=professor] .app-layout,body[data-role=instructor] .app-layout,body[data-role=admin] .app-layout{display:flex;height:calc(100vh - var(--header-height))}#right-panel-roster{display:flex;flex-direction:column;height:100%;overflow:hidden}#right-panel-roster .panel-header{flex-shrink:0}#right-panel-roster .student-list{height:calc(100vh - var(--header-height) - 230px);max-height:none!important;overflow-y:auto;padding:var(--spacing-sm)}.sidebar{width:var(--sidebar-width);flex-shrink:0;background:var(--bg-sidebar);border-right:1px solid var(--border-light);display:flex;flex-direction:column;overflow-y:auto}.sidebar-nav{flex:1;padding:var(--spacing-md) var(--spacing-sm)}.nav-section{margin-bottom:var(--spacing-lg)}.nav-section-title{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-xs)}.nav-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:8px var(--spacing-md);border-radius:var(--radius-sm);color:var(--text-primary);text-decoration:none;font-size:14px;transition:background .1s}.nav-item:hover{background:var(--bg-sidebar-hover)}.nav-item.active{background:var(--bg-sidebar-hover);font-weight:500}.nav-icon{font-size:16px;width:20px;text-align:center}.badge{margin-left:auto;background:var(--text-muted);color:#fff;font-size:11px;padding:2px 6px;border-radius:10px;font-weight:500}.badge-warning{background:var(--level-orange)}.week-selector{padding:var(--spacing-md);border-top:1px solid var(--border-light)}.week-selector label{display:block;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;margin-bottom:var(--spacing-xs)}.week-selector select{width:100%;padding:8px 12px;border:1px solid var(--border-light);border-radius:var(--radius-sm);font-size:13px;background:var(--bg-main)}.main-content{flex:1;overflow-y:auto;padding:36px 36px 24px;background:var(--bg-main);min-width:0}.view{display:none}.view.active{display:block}.main-content.assignments-mode{padding:0;overflow:hidden;height:calc(100vh - var(--header-height))}.view-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.view-header h2{font-size:20px;font-weight:600}.view-actions{display:flex;align-items:center;gap:var(--spacing-md)}.view-hint{font-size:12px;color:var(--text-muted)}.btn-primary{background:var(--accent-primary);color:#fff;border:none;padding:8px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;transition:background .1s}.btn-primary:hover{background:var(--accent-primary-hover)}.btn-secondary{background:var(--bg-main);color:var(--text-primary);border:1px solid var(--border-light);padding:8px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;transition:background .1s}.btn-secondary:hover{background:var(--bg-elevated)}.stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.stat-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-main);border:1px solid var(--border-light);border-radius:var(--radius-md)}.stat-card[data-level="0"]{border-left:3px solid var(--level-red)}.stat-card[data-level="1"]{border-left:3px solid var(--level-orange)}.stat-card[data-level="2"]{border-left:3px solid var(--level-blue)}.stat-card[data-level="3"]{border-left:3px solid var(--level-green)}.stat-icon{font-size:24px}.stat-value{font-size:24px;font-weight:600}.stat-label{font-size:12px;color:var(--text-muted)}.data-table-wrapper{overflow-x:auto;border:1px solid var(--border-light);border-radius:var(--radius-md)}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:12px var(--spacing-md);text-align:left;border-bottom:1px solid var(--border-light)}.data-table th{background:var(--bg-elevated);font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase}.data-table tr:hover{background:var(--bg-elevated)}.data-table tr:last-child td{border-bottom:none}.student-name{display:flex;align-items:center;gap:10px}.student-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;flex-shrink:0}.xp-badge{display:inline-flex;align-items:center;padding:2px 8px;background:var(--bg-elevated);border-radius:12px;font-size:12px;font-weight:500;color:var(--text-muted)}.level-cell{white-space:nowrap;font-size:13px}.clickable-row{cursor:pointer}.clickable-row:hover{background:var(--bg-sidebar-hover)}.level-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:500}.level-badge.red{background:var(--level-red-bg);color:var(--level-red)}.level-badge.orange{background:var(--level-orange-bg);color:var(--level-orange)}.level-badge.blue{background:var(--level-blue-bg);color:var(--level-blue)}.level-badge.green{background:var(--level-green-bg);color:var(--level-green)}.level-badge.gray{background:var(--level-gray-bg);color:var(--level-gray)}.eval-summary{display:flex;gap:4px}.eval-bar{height:16px;border-radius:2px;min-width:20px;display:flex;align-items:center;justify-content:center;font-size:10px;color:#fff;font-weight:500}.eval-bar.red{background:var(--level-red)}.eval-bar.orange{background:var(--level-orange)}.eval-bar.blue{background:var(--level-blue)}.eval-bar.green{background:var(--level-green)}.search-input{padding:8px 12px;border:1px solid var(--border-light);border-radius:var(--radius-sm);font-size:13px;width:200px}.search-input:focus{outline:none;border-color:var(--accent-primary)}.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-md)}.team-card{background:var(--bg-main);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:var(--spacing-md)}.team-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.team-name{font-size:16px;font-weight:600}.team-status{padding:4px 8px;border-radius:var(--radius-sm);font-size:11px;font-weight:500}.team-status.submitted{background:var(--level-green-bg);color:var(--level-green)}.team-status.ready{background:var(--level-blue-bg);color:var(--level-blue)}.team-status.in_progress{background:var(--level-orange-bg);color:var(--level-orange)}.team-members{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.member-chip{background:var(--bg-elevated);padding:4px 8px;border-radius:var(--radius-sm);font-size:12px}.team-progress{display:flex;align-items:center;gap:var(--spacing-sm)}.progress-bar{flex:1;height:6px;background:var(--bg-elevated);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--accent-primary);transition:width .3s}.progress-text{font-size:12px;color:var(--text-muted)}.level-definition-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.level-card{padding:var(--spacing-md);border-radius:var(--radius-md);text-align:center}.level-card.level-0{background:var(--level-red-bg)}.level-card.level-1{background:var(--level-orange-bg)}.level-card.level-2{background:var(--level-blue-bg)}.level-card.level-3{background:var(--level-green-bg)}.level-header{display:flex;justify-content:center;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.level-score,.level-desc{font-size:12px;color:var(--text-muted)}.chart-section{margin-bottom:var(--spacing-lg)}.chart-section h3{font-size:16px;margin-bottom:var(--spacing-md)}.distribution-chart{display:flex;flex-direction:column;gap:var(--spacing-md)}.distribution-row{display:flex;align-items:center;gap:var(--spacing-md)}.distribution-label{width:80px;font-size:13px;font-weight:500}.distribution-bars{flex:1;display:flex;gap:2px;height:24px}.dist-bar{height:100%;border-radius:2px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:10px;font-weight:500;min-width:20px}.class-summary{margin-bottom:var(--spacing-lg)}.class-summary h3{font-size:16px;margin-bottom:var(--spacing-md)}.distribution-bar{display:flex;height:32px;border-radius:var(--radius-sm);overflow:hidden}.distribution-bar .segment{display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:500}.distribution-bar .segment.red{background:var(--level-red)}.distribution-bar .segment.orange{background:var(--level-orange)}.distribution-bar .segment.blue{background:var(--level-blue)}.distribution-bar .segment.green{background:var(--level-green)}.weakness-summary{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.summary-card{flex:1;display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-md)}.summary-card.warning{background:var(--level-orange-bg);border:1px solid var(--level-orange)}.summary-card.success{background:var(--level-green-bg);border:1px solid var(--level-green)}.summary-icon{font-size:24px}.summary-text strong{display:block;font-size:12px;color:var(--text-muted);margin-bottom:2px}.canvas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.canvas-block-card{padding:var(--spacing-md);border:1px solid var(--border-light);border-radius:var(--radius-md)}.canvas-block-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.canvas-block-title{display:flex;align-items:center;gap:var(--spacing-xs);font-weight:500}.canvas-block-icon{font-size:16px}.canvas-avg{font-size:12px;padding:2px 8px;border-radius:var(--radius-sm)}.canvas-distribution{display:flex;gap:2px;margin-bottom:var(--spacing-sm)}.canvas-dist-bar{flex:1;height:8px;border-radius:2px;background:var(--bg-elevated)}.canvas-weak-count{font-size:12px;color:var(--text-muted)}.misconception-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.misconception-item{padding:var(--spacing-md);border:1px solid var(--border-light);border-radius:var(--radius-md);border-left:3px solid var(--level-orange)}.misconception-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.misconception-student{font-weight:500}.misconception-step{font-size:12px;color:var(--text-muted)}.misconception-type{padding:2px 8px;background:var(--level-orange-bg);color:var(--level-orange);border-radius:var(--radius-sm);font-size:11px;font-weight:500}.misconception-content{font-size:13px;color:var(--text-muted);margin-bottom:var(--spacing-sm)}.misconception-actions{display:flex;gap:var(--spacing-sm)}.submission-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.submission-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);border:1px solid var(--border-light);border-radius:var(--radius-md)}.submission-info{display:flex;align-items:center;gap:var(--spacing-md)}.submission-team-name{font-weight:500}.submission-time{font-size:12px;color:var(--text-muted)}.submission-actions{display:flex;gap:var(--spacing-sm)}.modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center}.modal.hidden{display:none}.modal-overlay{position:absolute;inset:0;background:#00000080}.modal-content{position:relative;background:var(--bg-main);border-radius:var(--radius-lg);width:90%;max-width:600px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.modal-content.modal-small{max-width:400px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-light)}.modal-header h2{font-size:18px;font-weight:600}.modal-close{background:none;border:none;font-size:24px;color:var(--text-muted);cursor:pointer}.modal-body{flex:1;padding:var(--spacing-lg);overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-light)}.form-group{margin-bottom:var(--spacing-md)}.form-group label{display:block;font-size:13px;font-weight:500;margin-bottom:var(--spacing-xs)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:8px 12px;border:1px solid var(--border-light);border-radius:var(--radius-sm);font-size:14px}.toast{position:fixed;bottom:var(--spacing-lg);right:var(--spacing-lg);background:var(--text-primary);color:#fff;padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:2000;animation:slideIn .3s ease}.toast.hidden{display:none}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.placeholder-content{padding:var(--spacing-xl);text-align:center;color:var(--text-muted);background:var(--bg-elevated);border-radius:var(--radius-md)}.weak-students-section h3{font-size:16px;margin-bottom:var(--spacing-md)}.weak-students-list{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md)}.weak-block-group{border:1px solid var(--border-light);border-radius:var(--radius-md);padding:var(--spacing-md)}.weak-block-title{font-size:14px;font-weight:500;margin-bottom:var(--spacing-sm);display:flex;align-items:center;gap:var(--spacing-xs)}.weak-student-chips{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.weak-student-chip{background:var(--level-red-bg);color:var(--level-red);padding:4px 8px;border-radius:var(--radius-sm);font-size:12px;cursor:pointer}.weak-student-chip:hover{background:var(--level-red);color:#fff}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);gap:var(--spacing-md);color:var(--text-muted);text-align:center}.error-state .error-icon{font-size:32px}.btn-retry{padding:8px 16px;background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:13px;color:var(--text-primary);cursor:pointer;transition:all .15s}.btn-icon{width:32px;height:32px;border:none;background:transparent;border-radius:var(--radius-sm);cursor:pointer;font-size:16px;display:inline-flex;align-items:center;justify-content:center;transition:background .15s}.btn-icon:hover{background:var(--bg-elevated)}.empty-state{padding:var(--spacing-xl);text-align:center;color:var(--text-muted)}.empty-state .hint{margin-top:var(--spacing-sm);font-size:12px}.bar-chart{display:flex;flex-direction:column;gap:var(--spacing-md)}.bar-item{display:flex;align-items:center;gap:var(--spacing-md)}.bar-label{width:50px;font-size:13px;font-weight:500;color:var(--text-primary)}.bar-wrapper{flex:1;height:24px;background:var(--bg-elevated);border-radius:var(--radius-sm);overflow:hidden}.bar-fill{height:100%;border-radius:var(--radius-sm);transition:width .3s ease}.bar-value{width:100px;font-size:13px;color:var(--text-muted);text-align:right}.distribution-bar-inner{display:flex;height:32px;border-radius:var(--radius-md);overflow:hidden;background:var(--bg-elevated)}.distribution-bar-inner .dist-segment{display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:500;transition:width .3s ease}.distribution-summary{margin-top:var(--spacing-md);font-size:13px;color:var(--text-muted);text-align:center}#canvas-blocks-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);margin-top:var(--spacing-md)}.canvas-block{background:var(--bg-main);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:var(--spacing-md);transition:all .15s}.canvas-block:hover{box-shadow:var(--shadow-md)}.canvas-block .block-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.canvas-block .block-icon{font-size:18px}.canvas-block .block-name{font-weight:500;font-size:13px}.canvas-block .block-level-display{margin-bottom:var(--spacing-sm)}.canvas-block .level-text{font-size:14px;font-weight:600}.canvas-block .block-weak{font-size:12px;color:var(--text-muted);margin-top:var(--spacing-sm)}.mini-dist{display:flex;height:8px;border-radius:4px;overflow:hidden;background:var(--bg-elevated)}.mini-dist.empty{display:flex;align-items:center;justify-content:center;height:auto;font-size:11px;color:var(--text-muted);background:none}.mini-dist .dist-segment{height:100%}.weakness-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border:1px solid var(--border-light);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm);background:var(--bg-main)}.weakness-item:hover{background:var(--bg-elevated)}.weakness-rank{font-weight:600;color:var(--level-red);width:30px}.weakness-icon{font-size:18px}.weakness-name{flex:1;font-weight:500}.weakness-level{font-weight:500}.weakness-count{font-size:12px;color:var(--text-muted)}.btn-small{padding:6px 12px;font-size:12px;background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s}.btn-small:hover{background:var(--accent-primary-hover)}.misconception-card{background:var(--bg-main);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-md)}.misconception-card:hover{box-shadow:var(--shadow-sm)}.mc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.mc-category{background:var(--accent-primary);color:#fff;padding:4px 10px;border-radius:var(--radius-sm);font-size:12px;font-weight:500}.mc-count{font-size:12px;color:var(--text-muted)}.mc-body{margin-bottom:var(--spacing-md)}.mc-body>div{margin-bottom:var(--spacing-sm);font-size:13px;line-height:1.6}.mc-body strong{color:var(--text-primary)}.mc-actions{display:flex;gap:var(--spacing-sm)}@media(max-width:1024px){#canvas-blocks-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){#canvas-blocks-grid{grid-template-columns:1fr}}.chart-section{background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.section-title{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-md)}.chart-container{position:relative;height:300px;width:100%}.kpi-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.kpi-card-with-chart{background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-md);padding:var(--spacing-md) var(--spacing-md);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);min-height:120px}.kpi-info{flex:0 0 auto}.kpi-label{font-size:12px;color:var(--text-muted);margin-bottom:var(--spacing-sm);font-weight:500}.kpi-value{font-size:26px;font-weight:700;color:var(--text-primary);line-height:1.1}.kpi-meta{display:flex;align-items:center;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.kpi-unit{font-size:13px;color:var(--text-muted)}.kpi-change{font-size:13px;font-weight:600}.kpi-change.positive{color:var(--accent-success)}.kpi-change.negative{color:var(--accent-error)}.kpi-mini-chart{flex:1;max-width:120px;height:50px}.kpi-mini-chart canvas{width:100%!important;height:100%!important}.week-timeline{background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-md)}.timeline-track{display:flex;align-items:center;justify-content:center;gap:0}.timeline-node{display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:all .2s}.timeline-node .node-circle{width:36px;height:36px;border-radius:50%;background:var(--bg-secondary);border:2px solid var(--border-light);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;color:var(--text-muted);transition:all .2s}.timeline-node.active .node-circle{background:#f5c542;border-color:#f5c542;color:#333}.timeline-node:hover .node-circle{border-color:var(--accent-primary);color:var(--accent-primary)}.timeline-node .node-label{margin-top:var(--spacing-xs);font-size:12px;color:var(--text-muted)}.timeline-connector{width:60px;height:2px;background:var(--border-light)}.submission-summary{display:flex;align-items:center;justify-content:center;gap:var(--spacing-lg);background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-md);padding:var(--spacing-md) var(--spacing-lg);margin-bottom:var(--spacing-md)}.summary-item{display:flex;align-items:baseline;gap:var(--spacing-sm)}.summary-label{font-size:14px;color:var(--text-secondary)}.summary-value{font-size:24px;font-weight:700}.summary-item.submitted .summary-value{color:var(--accent-success)}.summary-item.not-submitted .summary-value{color:var(--accent-error)}.summary-unit{font-size:14px;color:var(--text-muted)}.summary-divider{color:var(--border-light);font-size:20px}.assignments-layout{display:grid;grid-template-columns:300px 1fr;gap:var(--spacing-md);min-height:500px}.student-list-panel,.worksheet-detail-panel{background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-md);overflow:hidden}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);border-bottom:1px solid var(--border-light);font-weight:600;font-size:14px;background:var(--bg-secondary)}.filter-select{padding:4px 8px;border:1px solid var(--border-light);border-radius:var(--radius-sm);font-size:12px}.student-list{max-height:450px;overflow-y:auto}.student-item{display:flex;align-items:center;padding:var(--spacing-md);border-bottom:1px solid var(--border-light);cursor:pointer;transition:background .15s}.student-item:hover{background:var(--bg-secondary)}.student-item.selected{background:var(--accent-primary-bg);border-left:3px solid var(--accent-primary)}.student-status-dot{width:10px;height:10px;border-radius:50%;margin-right:var(--spacing-sm)}.student-status-dot.submitted{background:var(--accent-success)}.student-status-dot.not-submitted{background:var(--border-light);border:2px solid var(--text-muted)}.student-item-name{flex:1;font-size:14px}.student-item-status{font-size:12px;color:var(--text-muted)}.worksheet-content{padding:var(--spacing-md);max-height:500px;overflow-y:auto}.worksheet-header{margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-light)}.worksheet-student-name{font-size:18px;font-weight:600;margin-bottom:var(--spacing-xs)}.worksheet-submit-date{font-size:13px;color:var(--text-muted)}.worksheet-section{margin-bottom:var(--spacing-lg)}.worksheet-section-title{display:flex;align-items:center;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-sm);cursor:pointer}.worksheet-section-title:before{content:"▼";font-size:10px;margin-right:var(--spacing-sm);transition:transform .2s}.worksheet-section-title.collapsed:before{transform:rotate(-90deg)}.worksheet-field{background:var(--bg-secondary);border-radius:var(--radius-sm);padding:var(--spacing-md);margin-bottom:var(--spacing-sm)}.worksheet-field-label{font-size:12px;font-weight:600;color:var(--accent-primary);margin-bottom:var(--spacing-xs)}.worksheet-field-content{font-size:14px;line-height:1.6;color:var(--text-primary)}.ai-evaluation-section{background:var(--bg-secondary);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.evaluation-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--border-light)}.evaluation-label{font-size:14px;color:var(--text-secondary)}.evaluation-score{display:flex;align-items:center;gap:var(--spacing-sm)}.evaluation-score input{width:50px;padding:4px 8px;border:1px solid var(--border-light);border-radius:var(--radius-sm);text-align:center;font-weight:600}.evaluation-max{color:var(--text-muted);font-size:13px}.btn-edit-score{padding:4px 8px;font-size:12px;background:transparent;border:1px solid var(--accent-primary);color:var(--accent-primary);border-radius:var(--radius-sm);cursor:pointer}.btn-edit-score:hover{background:var(--accent-primary-bg)}.worksheet-actions{display:flex;gap:var(--spacing-sm);padding-top:var(--spacing-md);border-top:1px solid var(--border-light)}.empty-state{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-muted);font-size:14px}.week-dropdown{padding:8px 16px;border:1px solid var(--border-light);border-radius:var(--radius-sm);font-size:14px;background:#fff;cursor:pointer}.curriculum-tabs{display:flex;gap:var(--spacing-xs);border-bottom:1px solid var(--border-light);margin-bottom:var(--spacing-lg)}.tab-btn{padding:var(--spacing-md) var(--spacing-lg);background:none;border:none;font-size:14px;font-weight:500;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:all .2s}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.curriculum-content{background:#fff;border-radius:var(--radius-md);min-height:400px}.tab-content{display:none;padding:var(--spacing-lg)}.curriculum-body{font-size:14px;line-height:1.8;color:var(--text-primary)}.curriculum-body h2{font-size:20px;font-weight:600;margin-top:var(--spacing-lg);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border-light)}.curriculum-body h3{font-size:16px;font-weight:600;margin-top:var(--spacing-md);margin-bottom:var(--spacing-sm)}.curriculum-body p{margin-bottom:var(--spacing-md)}.curriculum-body ul,.curriculum-body ol{margin-left:var(--spacing-lg);margin-bottom:var(--spacing-md)}.curriculum-body li{margin-bottom:var(--spacing-xs)}.reference-list{list-style:none;margin:0;padding:0}.reference-item{display:flex;align-items:flex-start;padding:var(--spacing-md);border:1px solid var(--border-light);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm);transition:all .15s}.reference-item:hover{background:var(--bg-secondary)}.reference-icon{width:40px;height:40px;background:var(--accent-primary-bg);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;margin-right:var(--spacing-md);font-size:18px}.reference-info{flex:1}.reference-title{font-weight:500;margin-bottom:var(--spacing-xs)}.reference-title a{color:var(--accent-primary);text-decoration:none}.reference-title a:hover{text-decoration:underline}.reference-desc{font-size:13px;color:var(--text-muted)}.loading-state{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-muted);font-size:14px}.curriculum-edit-toolbar{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--border-light);display:flex;justify-content:flex-end}@media(max-width:1024px){.kpi-section,.assignments-layout{grid-template-columns:1fr}.curriculum-tabs{flex-wrap:wrap}}.canvas-section{background:var(--bg-main)}.canvas-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.canvas-summary{font-size:13px;color:var(--text-muted);background:var(--bg-elevated);padding:4px 10px;border-radius:4px}.canvas-grid{display:grid;grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(3,auto);gap:4px;margin-bottom:var(--spacing-md)}.canvas-grid .canvas-block[data-block=problem]{grid-column:1;grid-row:1 / 3}.canvas-grid .canvas-block[data-block=solution]{grid-column:2;grid-row:1}.canvas-grid .canvas-block[data-block=key_metrics]{grid-column:2;grid-row:2}.canvas-grid .canvas-block[data-block=unique_value]{grid-column:3;grid-row:1 / 3}.canvas-grid .canvas-block[data-block=unfair_advantage]{grid-column:4;grid-row:1}.canvas-grid .canvas-block[data-block=channels]{grid-column:4;grid-row:2}.canvas-grid .canvas-block[data-block=customer_segment]{grid-column:5;grid-row:1 / 3}.canvas-grid .canvas-block[data-block=cost]{grid-column:1 / 3;grid-row:3}.canvas-grid .canvas-block[data-block=revenue]{grid-column:3 / 6;grid-row:3}.canvas-block{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-md) var(--spacing-sm);background:var(--bg-main);border:1px solid var(--border-light);border-radius:6px;min-height:80px;transition:all .15s ease;cursor:pointer}.canvas-block:hover{transform:translateY(-1px);box-shadow:0 2px 8px #00000014;border-color:#d1d1d1}.canvas-block.level-excellent{border-color:#15803d;background:#f0fdf4}.canvas-block.level-good{border-color:#1d4ed8;background:#eff6ff}.canvas-block.level-normal{border-color:#d97706;background:#fffbeb}.canvas-block.level-poor{border-color:#dc2626;background:#fef2f2}.canvas-block.level-notstarted{border-color:var(--border-light);background:var(--bg-main)}.block-icon{font-size:20px;margin-bottom:4px}.block-label{font-size:11px;color:var(--text-muted);text-align:center;margin-bottom:4px}.block-status{font-size:14px;margin-bottom:2px}.block-level{font-size:11px;font-weight:600}.block-level.green{color:#15803d}.block-level.blue{color:#1d4ed8}.block-level.orange{color:#d97706}.block-level.red{color:#dc2626}.block-level.gray{color:var(--text-muted)}.canvas-legend{display:flex;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-elevated);border-radius:6px;font-size:12px}.legend-item{display:flex;align-items:center;gap:4px;color:var(--text-muted)}.legend-dot{font-size:10px}.block-progress-section{margin-top:var(--spacing-lg)}.block-progress-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.section-hint{font-size:11px;color:var(--text-muted);background:var(--bg-elevated);padding:2px 8px;border-radius:10px}.block-progress-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm)}.block-progress-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-elevated);border-radius:4px;transition:background .12s}.block-progress-item:hover{background:#ededec}.block-progress-info{display:flex;align-items:center;gap:var(--spacing-sm);flex:1;min-width:0}.block-progress-icon{font-size:18px;flex-shrink:0}.block-progress-name{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap}.block-progress-level{font-size:12px;font-weight:600;padding:2px 8px;border-radius:3px;white-space:nowrap}.block-progress-level.green{background:#dcfce7;color:#15803d}.block-progress-level.blue{background:#dbeafe;color:#1d4ed8}.block-progress-level.orange{background:#fef3c7;color:#d97706}.block-progress-level.red{background:#fecaca;color:#dc2626}.block-progress-level.gray{background:var(--bg-main);color:var(--text-muted)}.block-progress-trend{width:80px;height:30px;flex-shrink:0;margin-left:var(--spacing-sm)}.trend-chart{width:100%;height:100%}.trend-line{fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.trend-line.green{stroke:#22c55e}.trend-line.blue{stroke:#3b82f6}.trend-line.orange{stroke:#f59e0b}.trend-line.red{stroke:#ef4444}.trend-line.gray{stroke:#9ca3af}.block-progress-legend{display:flex;justify-content:center;gap:var(--spacing-md);margin-top:var(--spacing-md);padding:var(--spacing-sm);font-size:12px}@media(max-width:900px){.canvas-grid{grid-template-columns:repeat(3,1fr);grid-template-rows:auto}.canvas-grid .canvas-block[data-block=problem],.canvas-grid .canvas-block[data-block=solution],.canvas-grid .canvas-block[data-block=key_metrics],.canvas-grid .canvas-block[data-block=unique_value],.canvas-grid .canvas-block[data-block=unfair_advantage],.canvas-grid .canvas-block[data-block=channels],.canvas-grid .canvas-block[data-block=customer_segment],.canvas-grid .canvas-block[data-block=cost],.canvas-grid .canvas-block[data-block=revenue]{grid-column:auto;grid-row:auto}.canvas-legend{flex-wrap:wrap}.block-progress-list{grid-template-columns:1fr}}body.curriculum-fullscreen .sidebar{display:none}body.curriculum-fullscreen .main-content{margin-left:0}.assignments-main{padding:0;background:var(--bg-main);min-height:0}.week-timeline-15{margin-bottom:var(--spacing-md);overflow-x:auto;padding:var(--spacing-sm) 0}.week-timeline-15 .timeline-track{display:flex;gap:var(--spacing-xs);min-width:max-content;padding:0 var(--spacing-sm)}.week-timeline-15 .timeline-node{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;transition:all .15s ease;padding:var(--spacing-sm);border-radius:var(--radius-md)}.week-timeline-15 .timeline-node:hover{background:var(--bg-elevated)}.week-timeline-15 .timeline-node.active{background:var(--accent-primary)}.week-timeline-15 .timeline-node.active .node-circle,.week-timeline-15 .timeline-node.active .node-label{color:#fff}.week-timeline-15 .node-circle{width:32px;height:32px;border-radius:50%;background:var(--bg-elevated);border:2px solid var(--border-light);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:var(--text-muted);transition:all .15s ease}.week-timeline-15 .timeline-node.active .node-circle{background:#fff3;border-color:#fff6}.week-timeline-15 .node-label{font-size:11px;color:var(--text-muted)}.worksheet-type-tabs{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);background:var(--bg-elevated);padding:4px;border-radius:var(--radius-md)}.type-tab{flex:1;padding:var(--spacing-sm) var(--spacing-md);border:none;background:transparent;border-radius:var(--radius-sm);font-size:14px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all .15s ease}.type-tab:hover{color:var(--text-primary)}.type-tab.active{background:var(--bg-main);color:var(--accent-primary);box-shadow:var(--shadow-sm)}.worksheet-viewer-container{background:var(--bg-main);overflow:hidden}.viewer-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-elevated);border-bottom:1px solid var(--border-light)}.viewer-student-name{font-size:16px;font-weight:600;color:var(--text-primary)}.viewer-submit-time{font-size:13px;color:var(--text-muted)}.worksheet-viewer{min-height:400px;max-height:calc(100vh - 400px);overflow-y:auto}.worksheet-viewer .empty-state{display:flex;align-items:center;justify-content:center;height:300px;color:var(--text-muted);font-size:14px}#right-panel-roster .student-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);cursor:pointer;transition:background .12s ease}#right-panel-roster .student-item:hover{background:var(--bg-hover)}#right-panel-roster .student-item.active{background:var(--bg-elevated);color:var(--text-primary);border-left:2px solid var(--text-primary)}#right-panel-roster .student-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}#right-panel-roster .student-status-dot.submitted{background:var(--accent-success)}#right-panel-roster .student-status-dot.not-submitted{background:var(--text-muted);border:1px solid var(--border-light)}#right-panel-roster .student-status-dot.delivered{background:var(--accent-primary)}#right-panel-roster .student-name{flex:1;font-size:14px;font-weight:500}#right-panel-roster .student-status{font-size:12px;color:var(--text-muted)}@media(max-width:1024px){.week-timeline-15 .timeline-track{justify-content:flex-start}}.btn-edit-evaluation{background:transparent;border:1px solid var(--border-light);border-radius:4px;padding:4px 8px;font-size:12px;cursor:pointer;color:var(--text-muted);margin-left:auto;transition:all .2s}.btn-edit-evaluation:hover{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--accent-primary)}.evaluation-modal{max-width:480px;width:90%}.evaluation-modal .form-group{margin-bottom:16px}.evaluation-modal label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.evaluation-modal input[type=text],.evaluation-modal select,.evaluation-modal textarea{width:100%;padding:10px 12px;border:1px solid var(--border-light);border-radius:6px;font-size:14px;background:var(--bg-main)}.evaluation-modal input[readonly]{background:var(--bg-elevated);color:var(--text-muted)}.evaluation-modal select{cursor:pointer}.evaluation-modal textarea{resize:vertical;min-height:80px}.ai-feedback-preview{background:var(--bg-elevated);padding:12px;border-radius:6px;font-size:13px;color:var(--text-secondary);max-height:120px;overflow-y:auto;white-space:pre-wrap}.feedback-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.instructor-badge{background:var(--accent-primary);color:#fff;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500}.status-completed{color:var(--accent-success)!important;font-weight:500}.inline-edit-ui{margin-top:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border-light)}.level-buttons{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.level-btn{flex:1;padding:8px 12px;border:2px solid var(--border-light);border-radius:var(--radius-sm);background:var(--bg-main);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease;color:var(--text-muted)}.level-btn:hover{background:var(--bg-elevated);border-color:var(--text-muted);color:var(--text-primary)}.level-btn.active{background:var(--text-primary);border-color:var(--text-primary);color:#fff}.edit-feedback-text{width:100%;min-height:60px;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-light);border-radius:var(--radius-sm);font-size:14px;line-height:1.6;resize:none;overflow:hidden;font-family:inherit}.edit-feedback-text:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #7c3aed1a}.edit-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.edit-actions .btn-cancel{padding:6px 16px;background:var(--bg-main);border:1px solid var(--border-light);border-radius:var(--radius-sm);font-size:13px;color:var(--text-muted);cursor:pointer;transition:all .15s}.edit-actions .btn-cancel:hover{background:var(--bg-elevated);color:var(--text-primary)}.edit-actions .btn-save{padding:6px 16px;background:var(--accent-primary);border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:500;color:#fff;cursor:pointer;transition:background .15s}.edit-actions .btn-save:hover{background:var(--accent-primary-hover)}.delivery-settings-panel{margin:16px 0;padding:16px 20px;background:linear-gradient(135deg,#f8f7ff,#fff);border:1px solid var(--border-light);border-radius:var(--radius-md);box-shadow:0 1px 3px #0000000a}.delivery-settings-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.delivery-icon{font-size:18px}.delivery-title{font-size:14px;font-weight:600;color:var(--text-primary);flex:1}.delivery-status{font-size:11px;font-weight:500;padding:3px 8px;border-radius:10px;background:var(--level-gray-bg);color:var(--level-gray)}.delivery-status.status-gray{background:var(--level-gray-bg);color:var(--level-gray)}.delivery-status.status-blue{background:var(--level-blue-bg);color:var(--level-blue)}.delivery-status.status-green{background:var(--level-green-bg);color:var(--level-green)}.delivery-status.status-red{background:var(--level-red-bg);color:var(--level-red)}.delivery-settings-body{display:flex;flex-wrap:wrap;align-items:center;gap:16px}.delivery-row{display:flex;align-items:center;gap:8px}.delivery-row label{font-size:13px;color:var(--text-muted);white-space:nowrap}.delivery-row select,.delivery-row input[type=datetime-local]{padding:6px 10px;font-size:13px;border:1px solid var(--border-light);border-radius:var(--radius-sm);background:var(--bg-main);color:var(--text-primary)}.delivery-row select:focus,.delivery-row input:focus{outline:none;border-color:var(--accent-primary)}.delivery-preview{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-elevated);border-radius:var(--radius-sm);font-size:12px}.delivery-preview .preview-label{color:var(--text-muted)}.delivery-preview .preview-time{color:var(--accent-primary);font-weight:500}.delivery-actions{display:flex;gap:8px;margin-left:auto}.btn-delivery-save{padding:6px 14px;font-size:13px;font-weight:500;background:var(--bg-main);border:1px solid var(--accent-primary);border-radius:var(--radius-sm);color:var(--accent-primary);cursor:pointer;transition:all .15s}.btn-delivery-save:hover{background:var(--accent-primary-bg)}.btn-delivery-now{padding:6px 14px;font-size:13px;font-weight:500;background:var(--accent-primary);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;transition:background .15s}.btn-delivery-now:hover{background:var(--accent-primary-hover)}@media(max-width:900px){.delivery-settings-body{flex-direction:column;align-items:flex-start}.delivery-actions{margin-left:0;width:100%;justify-content:flex-end}}.student-item .team-info{display:flex;flex-direction:column;flex:1;min-width:0}.student-item .team-members{font-size:11px;color:var(--text-muted)}.readonly-mode input,.readonly-mode textarea,.readonly-mode .notion-input,.readonly-mode .notion-textarea{pointer-events:none}.readonly-mode .assignee-selector,.readonly-mode .assignee-dropdown,.readonly-mode .dropdown-arrow{display:none!important}.readonly-mode .assigned-badge{cursor:default;pointer-events:none}.delivery-settings-compact{padding:12px;border-bottom:1px solid var(--border-light);background:var(--bg-elevated);flex-shrink:0}.delivery-header-compact{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:13px;font-weight:600}.delivery-body-compact{display:flex;flex-direction:column;gap:8px}.delivery-row-compact{display:flex;gap:8px}.delivery-row-compact select,.delivery-row-compact input{flex:1;padding:6px 8px;font-size:12px;border:1px solid var(--border-light);border-radius:var(--radius-sm)}.delivery-actions-compact{display:flex;gap:6px}.delivery-actions-compact .btn-sm{flex:1;padding:6px 10px;font-size:12px;font-weight:500;border-radius:var(--radius-sm);cursor:pointer;background:var(--bg-main);border:1px solid var(--border-light);color:var(--text-secondary)}.delivery-actions-compact .btn-sm.btn-primary{background:var(--text-primary);border-color:var(--text-primary);color:#fff}.delivery-actions-compact .btn-sm.btn-primary:hover{background:#1a1a1a}.submission-summary-compact{display:flex;padding:10px 12px;gap:16px;border-bottom:1px solid var(--border-light);background:var(--bg-main);flex-shrink:0}.submission-summary-compact .summary-item{display:flex;align-items:center;gap:6px}.submission-summary-compact .summary-label{font-size:12px;color:var(--text-muted)}.submission-summary-compact .summary-value{font-size:16px;font-weight:700;color:var(--level-green)}.submission-summary-compact .summary-item.not-submitted .summary-value{color:var(--level-red)}.team-eval-section{margin-top:var(--spacing-md);padding:var(--spacing-sm) 0}.team-eval-header{display:flex;align-items:center;gap:var(--spacing-sm)}.team-eval-title{font-size:13px;font-weight:600;color:var(--text-primary)}.team-eval-feedback{margin-top:var(--spacing-sm);padding:var(--spacing-sm) 0}.team-eval-feedback .feedback-label{font-size:11px;font-weight:600;color:var(--text-muted);margin-bottom:4px;display:flex;align-items:center;gap:6px}.team-eval-feedback .feedback-text{font-size:13px;color:var(--text-primary);line-height:1.6;white-space:pre-wrap}.btn-edit-evaluation,.btn-ai-evaluate{padding:4px 10px;font-size:11px;border-radius:var(--radius-sm);cursor:pointer;border:1px solid var(--border-light);background:var(--bg-main);color:var(--text-secondary);margin-left:auto}.btn-edit-evaluation:hover{background:var(--bg-hover)}.btn-ai-evaluate{background:var(--text-primary);color:#fff;border-color:var(--text-primary);margin-left:0}.btn-ai-evaluate:hover{background:#1a1a1a}.inline-edit-ui{margin-top:var(--spacing-sm);padding:var(--spacing-sm);background:var(--bg-main);border-radius:var(--radius-sm);border:1px solid var(--border-light)}.inline-edit-ui .level-buttons{display:flex;gap:6px;margin-bottom:var(--spacing-sm)}.inline-edit-ui .level-btn{flex:1;padding:8px;font-size:12px;border:1px solid var(--border-light);border-radius:var(--radius-sm);background:var(--bg-main);cursor:pointer}.inline-edit-ui .level-btn:hover{background:var(--bg-hover)}.inline-edit-ui .level-btn.active{background:var(--text-primary);color:#fff;border-color:var(--text-primary)}.inline-edit-ui .edit-feedback-text{width:100%;padding:8px;font-size:13px;border:1px solid var(--border-light);border-radius:var(--radius-sm);resize:vertical;min-height:60px;margin-bottom:var(--spacing-sm);pointer-events:auto}.inline-edit-ui .edit-actions{display:flex;justify-content:flex-end;gap:8px}.inline-edit-ui .btn-cancel,.inline-edit-ui .btn-save{padding:6px 12px;font-size:12px;border-radius:var(--radius-sm);cursor:pointer}.inline-edit-ui .btn-cancel{background:var(--bg-main);border:1px solid var(--border-light);color:var(--text-secondary)}.inline-edit-ui .btn-save{background:var(--text-primary);border:1px solid var(--text-primary);color:#fff}.curriculum-section .nav-section-header{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;color:var(--text-primary);font-weight:500;transition:background .15s}.curriculum-section .nav-section-header:hover{background:var(--bg-sidebar-hover)}.curriculum-section .chevron{width:16px;height:16px;margin-left:auto;transition:transform .2s}.curriculum-section.expanded .chevron{transform:rotate(180deg)}.curriculum-section .nav-section-content{display:none;padding-left:8px}.curriculum-section.expanded .nav-section-content{display:block}.curriculum-section .phase-label{padding:12px 16px 6px;font-size:11px;font-weight:600;color:var(--text-muted);letter-spacing:.3px}.curriculum-section .nav-sub-item{display:flex;align-items:center;gap:10px;padding:8px 16px;color:var(--text-primary);text-decoration:none;font-size:13px;border-radius:4px;margin:2px 8px;transition:background .15s;white-space:nowrap}.curriculum-section .nav-sub-item:hover{background:var(--bg-sidebar-hover)}.curriculum-section .nav-sub-item.active{background:var(--accent-primary-bg);color:var(--accent-primary)}.curriculum-section .nav-sub-item.locked{color:var(--text-muted);cursor:not-allowed}.curriculum-section .week-indicator{width:22px;height:22px;border-radius:50%;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex-shrink:0}.curriculum-section .week-indicator.current{background:var(--accent-primary);color:#fff}.curriculum-section .nav-sub-item.completed .week-indicator{background:var(--accent-success);color:#fff}.curriculum-section .check-icon{color:var(--accent-success);margin-left:auto}.curriculum-section .lock-icon,.curriculum-section .anchor-icon{margin-left:auto;font-size:12px}.curriculum-content-view.active{display:flex;flex-direction:column;height:100%;overflow:hidden}.curriculum-content-view .content-tabs{display:flex;gap:4px;padding:16px 24px;border-bottom:1px solid var(--border-light);background:var(--bg-main);flex-shrink:0}.curriculum-content-view .content-tab{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;background:transparent;border-radius:6px;cursor:pointer;font-size:14px;color:var(--text-muted);transition:all .15s}.curriculum-content-view .content-tab:hover{background:var(--bg-elevated);color:var(--text-primary)}.curriculum-content-view .content-tab.active{background:var(--accent-primary);color:#fff}.curriculum-content{flex:1;overflow-y:auto;padding:24px}.curriculum-content .page-loading{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-muted)}.right-panel{width:var(--right-panel-width);flex-shrink:0;background:var(--bg-main);border-left:1px solid var(--border-light);display:flex;flex-direction:column;height:100%;overflow:hidden}.right-panel.collapsed{display:none}.right-panel.expanded{position:fixed;top:var(--header-height);right:0;width:50%;height:calc(100vh - var(--header-height));z-index:200;box-shadow:var(--shadow-lg)}@media(max-width:1200px){.right-panel{position:fixed;right:0;top:var(--header-height);width:var(--right-panel-width);height:calc(100vh - var(--header-height));z-index:100;box-shadow:var(--shadow-lg);transform:translate(100%);transition:transform .3s ease}.right-panel.open{transform:translate(0)}}.right-panel-content{display:flex;flex-direction:column;height:100%}.team-stats-row{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}.team-stat-card{flex:1;min-width:120px;background:var(--bg-main);border:1px solid var(--border-light);border-radius:8px;padding:16px;text-align:center}.team-stat-card .stat-value{font-size:28px;font-weight:600;color:var(--text-primary)}.team-stat-card .stat-label{font-size:13px;color:var(--text-muted);margin-top:4px}.team-stat-card.stat-green .stat-value{color:var(--level-green)}.team-stat-card.stat-blue .stat-value{color:var(--level-blue)}.team-stat-card.stat-orange .stat-value{color:var(--level-orange)}.team-stat-card.stat-xp .stat-value{color:var(--accent-primary)}.team-list-container{display:flex;flex-direction:column;gap:8px}.team-list-loading,.team-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;color:var(--text-muted);gap:12px}.team-list-empty .empty-icon{font-size:48px}.loading-spinner{width:32px;height:32px;border:3px solid var(--border-light);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}.loading-spinner-sm{width:16px;height:16px;border:2px solid var(--border-light);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.team-card-notion{background:var(--bg-main);border:1px solid var(--border-light);border-radius:8px;overflow:hidden;transition:box-shadow .2s ease}.team-card-notion:hover{box-shadow:0 2px 8px #0000000f}.team-card-notion.expanded{border-color:var(--accent-primary)}.team-card-header{display:flex;align-items:center;padding:12px 16px;cursor:pointer;gap:12px;transition:background .15s ease}.team-card-header:hover{background:var(--bg-sidebar-hover)}.team-card-toggle{flex-shrink:0;width:20px;color:var(--text-muted);font-size:10px}.team-card-info{flex:1;display:flex;align-items:center;gap:8px;min-width:0}.team-card-info .team-name{font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.team-badge{font-size:11px;padding:2px 8px;border-radius:4px;font-weight:500;flex-shrink:0}.team-badge.status-submitted{background:var(--level-green-bg);color:var(--level-green)}.team-badge.status-ready{background:var(--level-blue-bg);color:var(--level-blue)}.team-badge.status-in_progress{background:var(--level-orange-bg);color:var(--level-orange)}.team-badge.status-pending{background:var(--level-gray-bg);color:var(--level-gray)}.team-card-meta{display:flex;gap:16px;color:var(--text-muted);font-size:13px;flex-shrink:0}.meta-item{display:flex;align-items:center;gap:4px}.meta-icon{font-size:12px}.team-card-progress{width:80px;flex-shrink:0}.progress-bar-mini{height:4px;background:var(--border-light);border-radius:2px;overflow:hidden}.progress-fill-mini{height:100%;border-radius:2px;transition:width .3s ease}.team-card-detail{border-top:1px solid var(--border-light);background:var(--bg-elevated);padding:16px}.detail-loading,.detail-error{display:flex;align-items:center;justify-content:center;gap:8px;padding:24px;color:var(--text-muted);font-size:13px}.detail-error{flex-direction:column}.team-detail-content{display:flex;flex-direction:column;gap:16px}.detail-section{background:var(--bg-main);border:1px solid var(--border-light);border-radius:6px;padding:12px}.detail-section-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-light)}.detail-section-header.clickable{cursor:pointer}.detail-section-header.clickable:hover{background:var(--bg-sidebar-hover);margin:-12px -12px 12px;padding:12px;border-radius:6px 6px 0 0}.section-icon{font-size:14px}.section-title{font-size:13px;font-weight:600;color:var(--text-primary);flex:1}.section-toggle{font-size:10px;color:var(--text-muted)}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:13px}.detail-label{color:var(--text-muted)}.detail-value{color:var(--text-primary);font-weight:500}.detail-value.code{font-family:monospace;background:var(--bg-elevated);padding:2px 8px;border-radius:4px}.member-list-inline{display:flex;flex-direction:column;gap:8px}.member-row{display:flex;align-items:center;justify-content:space-between;padding:8px;background:var(--bg-elevated);border-radius:6px}.member-info{display:flex;align-items:center;gap:8px}.member-avatar-sm{width:28px;height:28px;border-radius:50%;background:var(--accent-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600}.member-name{font-size:13px;color:var(--text-primary)}.leader-badge{font-size:10px;background:var(--accent-primary-bg);color:var(--accent-primary);padding:2px 6px;border-radius:4px}.member-contribution{display:flex;align-items:center;gap:8px}.contribution-bar{width:60px;height:6px;background:var(--border-light);border-radius:3px;overflow:hidden}.contribution-fill{height:100%;background:var(--accent-primary);border-radius:3px}.contribution-value{font-size:12px;color:var(--text-muted);min-width:50px;text-align:right}.worksheet-status-grid{display:flex;flex-wrap:wrap;gap:8px}.worksheet-chip{display:flex;align-items:center;gap:4px;padding:6px 10px;border-radius:6px;font-size:12px;background:var(--bg-elevated);border:1px solid var(--border-light)}.worksheet-chip.completed{background:var(--level-green-bg);border-color:var(--level-green);color:var(--level-green)}.worksheet-chip.progress{background:var(--level-orange-bg);border-color:var(--level-orange);color:var(--level-orange)}.worksheet-chip.empty{color:var(--text-muted)}.chip-icon{font-size:10px}.xp-section .xp-summary{display:flex;align-items:baseline;gap:8px;margin-bottom:8px}.xp-total{font-size:24px;font-weight:600;color:var(--accent-primary)}.xp-label{font-size:13px;color:var(--text-muted)}.xp-note{font-size:12px;color:var(--text-muted);font-style:italic}.xp-empty{font-size:13px;color:var(--text-muted);padding:12px 0}.xp-history-table{margin-top:12px;border:1px solid var(--border-light);border-radius:8px;overflow:hidden}.xp-history-table table{width:100%;border-collapse:collapse;font-size:13px}.xp-history-table th,.xp-history-table td{padding:8px 12px;text-align:left;border-bottom:1px solid var(--border-light)}.xp-history-table th{background:var(--bg-sidebar);font-weight:500;color:var(--text-muted);font-size:11px;text-transform:uppercase}.xp-history-table tr:last-child td{border-bottom:none}.xp-history-table .xp-amount{color:var(--accent-primary);font-weight:600}.xp-history-table .xp-date{color:var(--text-muted);font-size:12px}.team-two-column-layout{display:grid;grid-template-columns:340px 1fr;gap:24px;margin-top:20px}.team-analytics-column{display:flex;flex-direction:column;gap:16px;position:sticky;top:20px;align-self:start;max-height:calc(100vh - 200px);overflow-y:auto}.team-list-column{min-width:0}.analytics-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;background:var(--bg-sidebar);border-radius:12px;color:var(--text-muted);gap:8px}.analytics-empty .empty-icon{font-size:32px;opacity:.5}@keyframes skeleton-shimmer{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}.skeleton-card{background:var(--bg-main);border:1px solid var(--border-light);border-radius:12px;padding:16px}.skeleton-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-light)}.skeleton-icon{width:24px;height:24px;border-radius:4px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200px 100%;animation:skeleton-shimmer 1.5s infinite}.skeleton-title{width:120px;height:16px;border-radius:4px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200px 100%;animation:skeleton-shimmer 1.5s infinite}.skeleton-list{display:flex;flex-direction:column;gap:8px}.skeleton-row{height:40px;border-radius:6px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200px 100%;animation:skeleton-shimmer 1.5s infinite}.skeleton-row.short{height:36px}.skeleton-team-card{height:80px;border-radius:12px;margin-bottom:12px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200px 100%;animation:skeleton-shimmer 1.5s infinite}@media(max-width:900px){.team-two-column-layout{grid-template-columns:1fr}.team-analytics-column{position:static;max-height:none;flex-direction:row;flex-wrap:wrap}.analytics-card{flex:1 1 280px}}.team-analytics-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px;margin-bottom:20px}.analytics-card{background:var(--bg-main);border:1px solid var(--border-light);border-radius:12px;padding:16px}.analytics-card.at-risk{border-color:#f59e0b;background:linear-gradient(135deg,#fffbeb 0%,var(--bg-main) 100%)}.analytics-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-light)}.analytics-icon{font-size:18px}.analytics-title{font-weight:600;font-size:14px}.analytics-list{display:flex;flex-direction:column;gap:8px}.ranking-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:6px;background:var(--bg-sidebar);transition:all .2s}.ranking-item:hover{background:var(--bg-hover)}.ranking-item .rank-number{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--accent-primary);color:#fff;border-radius:50%;font-size:12px;font-weight:600}.ranking-item .rank-name{flex:1;font-size:14px;color:var(--text-primary)}.ranking-item .rank-xp{font-size:13px;font-weight:600;color:var(--accent-primary)}.risk-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:6px;background:var(--bg-sidebar);border-left:3px solid #f59e0b}.risk-item .risk-name{font-size:14px;color:var(--text-primary);font-weight:500}.risk-item .risk-reason{font-size:12px;color:#f59e0b;background:#fef3c7;padding:2px 8px;border-radius:4px}.analytics-card.risk-card{border-color:#f59e0b;background:linear-gradient(135deg,#fffbeb 0%,var(--bg-main) 100%)}.xp-ranking-list{display:flex;flex-direction:column;gap:8px}.ranking-row{display:flex;align-items:center;gap:12px;padding:8px;border-radius:6px;background:var(--bg-sidebar);cursor:pointer;transition:all .2s}.ranking-row:hover{transform:translate(4px);box-shadow:0 2px 8px #0000001a}.ranking-row.top-three{background:linear-gradient(135deg,#fef3c7,#fde68a)}.rank-badge{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:12px;font-weight:600;background:var(--text-muted);color:#fff}.rank-badge.rank-1{background:linear-gradient(135deg,#fbbf24,#f59e0b)}.rank-badge.rank-2{background:linear-gradient(135deg,#9ca3af,#6b7280)}.rank-badge.rank-3{background:linear-gradient(135deg,#d97706,#b45309)}.rank-name{flex:1;font-size:13px;font-weight:500}.rank-xp{font-size:13px;font-weight:600;color:var(--accent-primary)}.rank-progress{font-size:12px;color:var(--text-muted);min-width:40px;text-align:right}.at-risk-list{display:flex;flex-direction:column;gap:6px}.at-risk-row{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#fff;border-radius:6px;cursor:pointer;transition:background .2s}.at-risk-row:hover{background:#fef3c7}.at-risk-name{font-size:13px;font-weight:500}.at-risk-progress{font-size:12px;color:#dc2626;font-weight:500}.btn-retry{padding:8px 16px;border:1px solid var(--border-light);border-radius:6px;background:var(--bg-main);color:var(--text-primary);cursor:pointer;font-size:13px}.btn-retry:hover{background:var(--bg-sidebar-hover)}.btn-sm{padding:4px 12px;border:1px solid var(--border-light);border-radius:4px;background:var(--bg-main);color:var(--text-primary);cursor:pointer;font-size:12px}.btn-sm:hover{background:var(--bg-sidebar-hover)}.view-content>.content-tabs{padding-left:0;margin-bottom:20px}.tab-content{display:none}.tab-content.active{display:block}.settings-section{background:#fff;border-radius:12px;border:1px solid var(--border-light);padding:24px;margin-bottom:20px}.settings-section h3{font-size:16px;font-weight:600;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;gap:8px}.settings-section h3 .icon{vertical-align:-3px;margin-right:4px}.form-group{margin-bottom:20px}.form-group:last-child{margin-bottom:0}.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.form-group input[type=text],.form-group input[type=number],.form-group textarea,.form-group select{width:100%;padding:10px 12px;border:1px solid var(--border-light);border-radius:6px;font-size:14px;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #4f46e51a}.form-group textarea{min-height:80px;resize:vertical}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.form-row.three-cols{grid-template-columns:repeat(3,1fr)}.ksa-editor{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.ksa-column{background:var(--bg-sidebar);border-radius:8px;padding:16px}.ksa-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.ksa-header h4{font-size:14px;font-weight:600;margin:0;display:flex;align-items:center;gap:6px}.ksa-badge{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:4px;font-size:12px;font-weight:600;color:#fff}.ksa-badge.knowledge{background:#3b82f6}.ksa-badge.skill{background:#10b981}.ksa-badge.attitude{background:#f59e0b}.ksa-list{display:flex;flex-direction:column;gap:8px;min-height:100px}.ksa-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fff;border-radius:6px;border:1px solid var(--border-light)}.ksa-item input{flex:1;border:none;background:transparent;font-size:13px;outline:none}.ksa-item .btn-remove{padding:2px 6px;border:none;background:none;color:var(--text-muted);cursor:pointer;font-size:16px;opacity:0;transition:opacity .2s}.ksa-item:hover .btn-remove{opacity:1}.ksa-item .btn-remove:hover{color:#dc2626}.btn-add-item{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px;border:2px dashed var(--border-light);border-radius:6px;background:transparent;color:var(--text-muted);font-size:13px;cursor:pointer;transition:all .2s}.btn-add-item:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.week-schedule-list{display:flex;flex-direction:column;gap:8px}.week-schedule-item{display:grid;grid-template-columns:60px 1fr 140px 100px 80px;gap:12px;align-items:center;padding:12px 16px;background:#fff;border:1px solid var(--border-light);border-radius:8px;transition:all .2s}.week-schedule-item.editing{grid-template-columns:60px 1fr 280px 100px 80px;background:#fafafa;border-color:var(--accent-primary)}.week-schedule-item:hover{border-color:var(--accent-primary);box-shadow:0 2px 8px #0000000d}.week-schedule-item.locked{background:var(--bg-sidebar);opacity:.7}.week-number{font-size:14px;font-weight:600;color:var(--accent-primary)}.week-topic{font-size:14px;color:var(--text-primary)}.week-date{font-size:13px;color:var(--text-muted)}.week-status{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500}.week-status.open{background:#dcfce7;color:#16a34a}.week-status.closed{background:#f3f4f6;color:var(--text-muted)}.week-status.upcoming{background:#fef3c7;color:#d97706}.week-actions{display:flex;gap:4px}.week-actions .btn-icon{padding:6px;border:1px solid var(--border-light);border-radius:4px;background:#fff;cursor:pointer;transition:all .2s}.week-actions .btn-icon:hover{background:var(--bg-sidebar);border-color:var(--accent-primary)}.week-date-edit{display:flex;align-items:center;gap:4px}.week-date-edit .date-input{width:120px;padding:4px 8px;font-size:13px;border:1px solid var(--border-light);border-radius:4px;background:#fff}.week-date-edit .date-input:focus{outline:none;border-color:var(--accent-primary)}.evaluation-items{display:flex;flex-direction:column;gap:12px}.evaluation-category{background:#fff;border:1px solid var(--border-light);border-radius:8px;overflow:hidden}.evaluation-category-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-sidebar);border-bottom:1px solid var(--border-light)}.evaluation-category-header h4{font-size:14px;font-weight:600;margin:0;display:flex;align-items:center;gap:8px}.category-badge{display:inline-flex;align-items:center;justify-content:center;padding:2px 10px;border-radius:4px;font-size:13px;font-weight:500;background:var(--bg-elevated);color:var(--text-muted);border:1px solid var(--border-light)}.evaluation-item-list{padding:var(--spacing-sm) var(--spacing-md)}.evaluation-item{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-sm) 0;border-bottom:1px solid var(--border-light)}.evaluation-item:last-child{border-bottom:none}.item-main{display:grid;grid-template-columns:1fr 80px 60px;gap:var(--spacing-sm);align-items:center}.item-name{font-size:14px;font-weight:500;color:var(--text-primary)}.item-criteria{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);padding-left:var(--spacing-sm)}.criteria-tag{font-size:12px;color:var(--text-muted);background:var(--bg-elevated);padding:2px 8px;border-radius:4px}.item-weight{font-size:14px;color:var(--text-muted)}.btn-edit{padding:var(--spacing-xs) var(--spacing-sm);font-size:12px;color:var(--text-muted);background:transparent;border:1px solid var(--border-light);border-radius:var(--radius-sm);cursor:pointer}.btn-edit:hover{background:var(--bg-elevated);color:var(--text-dark)}.evaluation-item.editing{background:var(--bg-elevated);padding:var(--spacing-md);border-radius:var(--radius-md)}.edit-row{margin-bottom:var(--spacing-md);width:100%}.edit-row label{display:block;font-size:12px;color:var(--text-muted);margin-bottom:var(--spacing-xs)}.edit-row .empathy-input{display:block;width:100%;min-width:200px;box-sizing:border-box}.edit-row .empathy-input.auto-width{width:auto;min-width:100px;max-width:100%}.edit-input{display:inline-block;min-width:100px;width:auto;padding:var(--spacing-xs) 0;font-size:14px;border:none;border-bottom:1px solid var(--border-light);background:transparent}.edit-input:focus{outline:none;border-bottom-color:var(--text-dark)}.edit-input-sm{min-width:60px;width:60px}.edit-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end;margin-top:var(--spacing-md)}.edit-actions .btn-cancel{padding:var(--spacing-xs) var(--spacing-md);font-size:13px;color:var(--text-muted);background:transparent;border:1px solid var(--border-light);border-radius:var(--radius-sm);cursor:pointer}.edit-actions .btn-save{padding:var(--spacing-xs) var(--spacing-md);font-size:13px;color:#fff;background:var(--text-dark);border:none;border-radius:var(--radius-sm);cursor:pointer}.total-score-summary{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background:var(--bg-elevated);border-bottom:1px solid var(--border-light)}.total-label{font-size:14px;font-weight:500;color:var(--text-muted)}.total-value{font-size:20px;font-weight:600;color:var(--text-dark)}.total-value.valid{color:var(--accent-success)}.total-value.invalid{color:var(--accent-error)}.settings-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border-light)}.btn-save{display:inline-flex;align-items:center;gap:6px;padding:10px 24px;background:var(--accent-primary);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-save:hover{background:var(--accent-hover)}.btn-save:disabled{background:var(--text-muted);cursor:not-allowed}.btn-cancel{padding:10px 24px;background:#fff;color:var(--text-secondary);border:1px solid var(--border-light);border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:var(--bg-sidebar)}.settings-skeleton .skeleton-line{height:40px;margin-bottom:16px}.settings-skeleton .skeleton-box{height:120px;margin-bottom:20px}.instructor-mobile-header{display:none;align-items:center;gap:12px;height:var(--mobile-header-height);padding:0 16px;background:var(--bg-sidebar);border-bottom:1px solid var(--border-light);flex-shrink:0}.instructor-mobile-header .mobile-hamburger{background:none;border:none;padding:6px;cursor:pointer;color:var(--text-primary);display:flex;align-items:center}.instructor-mobile-header .mobile-header-title{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600;color:var(--text-primary);text-decoration:none}.instructor-mobile-header .mobile-logo-img{width:28px;height:28px;object-fit:contain;border-radius:10px}.header .mobile-hamburger-inline{display:none;background:none;border:none;padding:6px;cursor:pointer;color:var(--text-primary);align-items:center;margin-right:4px}.sidebar-mobile-close{display:none}.mobile-backdrop-instructor{position:fixed;inset:0;background:#0006;z-index:250}@media(min-width:1201px){body[data-role=professor] .app-layout:not(:has(.right-panel)) .main-content,body[data-role=instructor] .app-layout:not(:has(.right-panel)) .main-content,body[data-role=admin] .app-layout:not(:has(.right-panel)) .main-content{padding-right:360px}}@media(max-width:1200px){body[data-role=professor] .main-content,body[data-role=instructor] .main-content,body[data-role=admin] .main-content{padding:28px 28px 20px}}@media(max-width:768px){.header .mobile-hamburger-inline{display:flex}.header{padding:0 12px}.header-left{gap:8px}.header-title{font-size:12px}.header-right .user-email-display{display:none}body[data-role=professor] .app-layout,body[data-role=instructor] .app-layout,body[data-role=admin] .app-layout{height:calc(100vh - var(--header-height))}body[data-role=professor] .sidebar,body[data-role=instructor] .sidebar,body[data-role=admin] .sidebar{position:fixed;left:0;top:0;width:var(--sidebar-width);height:100vh;z-index:300;transform:translate(-100%);transition:transform .3s ease;box-shadow:none}body[data-role=professor] .sidebar.open,body[data-role=instructor] .sidebar.open,body[data-role=admin] .sidebar.open{transform:translate(0);box-shadow:4px 0 24px #00000026}.sidebar-mobile-close{display:flex;align-items:center;justify-content:flex-end;padding:12px 16px 4px}.sidebar-mobile-close button{background:none;border:none;padding:6px;cursor:pointer;color:var(--text-muted);display:flex;align-items:center}.sidebar-mobile-close button:hover{color:var(--text-primary)}body[data-role=professor] .main-content,body[data-role=instructor] .main-content,body[data-role=admin] .main-content{padding:16px}.right-panel{width:100%!important;max-width:360px}.view-header h2{font-size:20px}.view-actions{flex-wrap:wrap;gap:8px}.stats-cards{flex-wrap:wrap}.stats-cards .stat-card{flex:1 1 calc(50% - 8px);min-width:140px}.team-stats-row{flex-wrap:wrap}.team-stats-row .team-stat-card{flex:1 1 calc(50% - 8px);min-width:120px}.misconception-stats{flex-wrap:wrap}.misconception-stats .stat-card{flex:1 1 100%}.evaluation-stats{flex-wrap:wrap}.evaluation-stats .stat-card{flex:1 1 100%}.analysis-summary{flex-wrap:wrap}.analysis-summary .summary-card{flex:1 1 100%}.kpi-grid{grid-template-columns:repeat(2,1fr)!important}.data-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.data-table{min-width:600px}.week-timeline-15 .timeline-track{overflow-x:auto;-webkit-overflow-scrolling:touch;justify-content:flex-start;padding-bottom:8px}.week-timeline-15 .timeline-track:after{min-width:max-content}.canvas-grid{display:flex!important;flex-direction:column;gap:12px}.canvas-grid .canvas-block{grid-column:auto!important;grid-row:auto!important}.ksa-editor{flex-direction:column}.ksa-column{width:100%}.team-two-column-layout{grid-template-columns:1fr!important}.curriculum-content-view .content-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap}.curriculum-content-view .content-tab{white-space:nowrap;flex-shrink:0}.delivery-settings-body,.form-row{flex-direction:column}.form-row .form-group{width:100%}.week-schedule-item{flex-wrap:wrap;gap:8px}}
