:root{--bg-sidebar: #F2F2F1;--bg-sidebar-hover: #E8E8E6;--bg-main: #ffffff;--bg-white: #ffffff;--bg-elevated: #f7f6f3;--text-primary: #2d2b27;--text-dark: #2d2b27;--text-muted: #656360;--text-light: #2d2b27;--text-light-muted: #656360;--text-placeholder: #8a8985;--accent-primary: #8b5cf6;--accent-primary-hover: #7c3aed;--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,.left-panel *{scrollbar-width:none;-ms-overflow-style:none}.left-panel::-webkit-scrollbar,.left-panel *::-webkit-scrollbar{display:none}.content-wrapper,.right-panel{scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.15) transparent}.content-wrapper::-webkit-scrollbar,.right-panel::-webkit-scrollbar{width:5px}.content-wrapper::-webkit-scrollbar-track,.right-panel::-webkit-scrollbar-track{background:transparent}.content-wrapper::-webkit-scrollbar-thumb,.right-panel::-webkit-scrollbar-thumb{background:#0000001f;border-radius:10px}.content-wrapper::-webkit-scrollbar-thumb:hover,.right-panel::-webkit-scrollbar-thumb:hover{background:#00000040}.content-wrapper *,.right-panel *{scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.15) transparent}.content-wrapper *::-webkit-scrollbar,.right-panel *::-webkit-scrollbar{width:5px}.content-wrapper *::-webkit-scrollbar-track,.right-panel *::-webkit-scrollbar-track{background:transparent}.content-wrapper *::-webkit-scrollbar-thumb,.right-panel *::-webkit-scrollbar-thumb{background:#0000001f;border-radius:10px}.content-wrapper *::-webkit-scrollbar-thumb:hover,.right-panel *::-webkit-scrollbar-thumb:hover{background:#00000040}.page-wrapper{display:flex;height:100vh;overflow:hidden}.page-main{flex:1;display:flex;flex-direction:column;min-width:0;height:100vh}.app-layout{display:grid;grid-template-columns:1fr var(--right-panel-width);grid-template-rows:1fr;grid-template-areas:"content aipanel";flex:1;overflow:hidden}.app-layout.ai-collapsed{grid-template-columns:1fr 0;grid-template-areas:"content content"}.header-brand{font-size:18px;font-weight:700;color:var(--text-dark)}.header-course-name{font-size:14px;font-weight:600;color:var(--text-secondary, #6b7280);padding-left:var(--spacing-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:400px}.header-instructor-name{font-weight:400;font-size:13px}.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;overflow:hidden}.header .profile-avatar img{width:100%;height:100%;object-fit:cover}.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-profile-wrapper{position:relative}.header-profile-trigger{display:flex;align-items:center;gap:var(--spacing-sm);background:none;border:none;cursor:pointer;border-radius:var(--radius-md);padding:4px 8px;transition:background var(--transition-fast);font-family:inherit}.header-profile-trigger:hover{background:var(--bg-elevated)}.profile-chevron{color:var(--text-muted);transition:transform .2s ease;flex-shrink:0}.profile-chevron.open{transform:rotate(180deg)}.profile-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:220px;background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-lg, 10px);box-shadow:0 8px 24px #0000001f;z-index:1000;padding:6px;animation:dropdown-fade-in .15s ease}@keyframes dropdown-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.profile-dropdown-header{display:flex;align-items:center;gap:10px;padding:10px 8px}.profile-dropdown-header .profile-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden}.profile-dropdown-header .profile-avatar img{width:100%;height:100%;object-fit:cover}.profile-dropdown-info{display:flex;flex-direction:column;min-width:0}.profile-dropdown-name{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-dropdown-email{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-dropdown-divider{height:1px;background:var(--border-light);margin:4px 0}.profile-dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border:none;background:none;border-radius:var(--radius-md);cursor:pointer;font-size:13px;font-family:inherit;color:var(--text-primary);text-decoration:none;transition:background var(--transition-fast)}.profile-dropdown-item:hover{background:var(--bg-elevated)}.profile-dropdown-item.logout{color:inherit}.profile-dropdown-item.logout:hover{background:var(--bg-elevated)}.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{width:var(--left-panel-width);height:100vh;flex-shrink:0;background:var(--bg-sidebar);display:flex;flex-direction:column;overflow:hidden;border-right:1px solid var(--border-light)}.logo-section{display:flex;align-items:center;justify-content:space-between;padding:8px var(--spacing-md) 0;border-bottom:1px solid var(--bg-sidebar);flex-shrink:0;box-sizing:border-box}.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:44px;height:44px;object-fit:contain;border-radius:50%;background:#fff;border:1px solid var(--border-light)}.logo-combined{max-width:60%;height:auto;object-fit:contain}.logo-text{color:var(--text-dark);font-weight:600;font-size:20px}.sidebar-scroll{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.sidebar-scroll::-webkit-scrollbar{display:none}.user-activity-card{display:flex;flex-direction:column;margin:20px 10px 8px;border-radius:12px;background:#fff;text-decoration:none;color:inherit;cursor:pointer;transition:background .15s ease;overflow:hidden}.user-activity-card:hover{background:#fafafa}.user-quick-info{display:flex;flex-direction:column;gap:0;padding:12px var(--spacing-md)}.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:6px;padding-left:20px}.xp-progress-bar{flex:1 1 60px;min-width:40px;max-width:80px;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:10px;font-weight:600;color:#f5a623;white-space:nowrap;flex-shrink:0}.xp-progress-label{font-size:10px;color:var(--text-muted);font-weight:500;white-space:nowrap;flex-shrink:0;min-width: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{padding:16px var(--spacing-sm) 80px;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:8px 10px;margin:0;color:var(--text-secondary);text-decoration:none;font-size:14px;border:none;background:none;width:100%;cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.nav-item:hover{background:var(--bg-sidebar-hover);color:var(--text-primary)}.nav-item.active{background:var(--bg-sidebar-hover);color:var(--text-primary);font-weight:500}.nav-item svg{width:18px;height:18px;flex-shrink:0;opacity:.7}.nav-section{margin:0;padding:0}.nav-section-header{display:flex;align-items:center;gap:var(--spacing-sm);padding:8px 10px;color:var(--text-secondary);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-primary)}.nav-section-header.active{color:var(--text-primary);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:visible}.curriculum-weeks,.lounge-channels{padding-bottom:16px}.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:#e8e7e3;font-weight:600}.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{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:700;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)}.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) 16px;margin-bottom:0;border-bottom:none;max-width:800px;margin-left:auto;margin-right:auto;position:relative}.step-section:after{content:"";display:block;border-bottom:1px solid var(--border-light);position:absolute;bottom:0;left:16px;right:16px}.step-section:last-child:after{display:none}.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}.ws-phase-header{display:flex;justify-content:space-between;align-items:center;padding:12px 0 4px;margin-top:8px}.ws-phase-header:first-child{margin-top:0}.ws-phase-label{font-size:16px;font-weight:700;color:var(--text-dark, #37352f);letter-spacing:.02em}.phase-meta{display:flex;align-items:center;gap:10px}.ws-phase-label:has(.step-badge){display:flex;align-items:center;gap:var(--spacing-md);font-size:18px;font-weight:600;letter-spacing:-.01em}.substep-card.has-phase{padding-top:8px;padding-left:12px}.substep-sub-title{font-size:15px;font-weight:600;color:var(--text-dark, #37352f);margin:20px 0 2px;padding:0}.substep-sub-title:first-child{margin-top:0}.field-instruction{font-size:14px;color:var(--text-secondary, #666);margin:0}.substep-sub-title+.field-instruction{margin-top:2px}.field-guideline{font-size:14px;color:var(--text-secondary, #666);margin:0}.substep-sub-title+.field-guideline{margin-top:2px}.substep-sub-title+.field-group,.substep-sub-title+.field-instruction+.field-group,.substep-sub-title+.field-instruction+.candidate-grid,.substep-sub-title+.field-instruction+.evaluation-table-wrapper,.substep-sub-title+.field-guideline+.field-group,.substep-sub-title+.field-guideline+.candidate-grid,.substep-sub-title+.field-guideline+.evaluation-table-wrapper{margin-top:12px}.numbered-field{display:flex;align-items:flex-start;gap:8px}.numbered-field .field-number{flex-shrink:0;font-size:14px;color:var(--text-secondary, #666);min-width:20px;line-height:36px}.numbered-field .field-input{flex:1}.labeled-field{display:flex;align-items:center;gap:6px;flex:1}.labeled-field.small{flex:0 0 auto}.labeled-field .field-number{flex-shrink:0;font-size:13px;color:var(--text-secondary, #666);white-space:nowrap}.labeled-field .field-input{flex:1}.checkpoint-box{margin-top:16px;padding:12px 16px;background:var(--bg-secondary, #f7f7f5);border-left:3px solid var(--border-medium, #d0d0d0);border-radius:4px;font-size:13px;color:var(--text-secondary, #666)}.checkpoint-box strong{display:block;margin-bottom:6px;font-size:13px;color:var(--text-primary)}.checkpoint-box ul{margin:0;padding-left:20px;list-style:disc}.checkpoint-box li{margin-bottom:2px;line-height:1.5}.substep-card{background:var(--bg-white);border:none;border-radius:0;padding:20px 0;margin-bottom:0;border-bottom:1px 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:#8b5cf6;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:#8b5cf6;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:#8b5cf6;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}.reference-box{background:var(--bg-elevated, #f7f6f3);border:1px solid var(--border-light, #e5e7eb);border-radius:8px;padding:16px 24px;margin-bottom:var(--spacing-lg);text-align:center;line-height:2;font-size:15px;color:var(--text-dark, #2d2b27)}.reference-box p{margin:0}.reference-box .ref-label{display:inline-block;width:52px;text-align:right}.reference-box .blank{display:inline-block;min-width:200px;margin:0 2px}.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)}textarea.field-input{overflow:hidden;resize:none}.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;background-clip:content-box;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)}.criterion-desc{font-size:11px;font-weight:400;color:var(--text-muted, #999);margin-top:1px}.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:1fr var(--right-panel-expanded-width, 50vw)}.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;position:relative;z-index:10;overflow:visible}.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)}.ai-info-icon-wrap{position:relative;display:inline-flex;align-items:center;margin-left:3px;cursor:help}.ai-info-icon{width:11px;height:11px;color:var(--text-muted);opacity:.6}.ai-info-tooltip{display:none;position:absolute;top:calc(100% + 6px);left:0;width:220px;padding:10px 12px;background:#fff;color:var(--text-primary, #333);border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 12px #0000001a;font-size:12px;line-height:1.6;z-index:9999;pointer-events:none}.ai-info-icon-wrap:hover .ai-info-tooltip{display:block}.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,#8b5cf6 0% 100%);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);align-items:center}.ai-message.learning-intro .message-avatar{background:transparent;border:none;border-radius:0;overflow:visible}.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,#8b5cf6 0% 100%);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) 18px}.ai-messages::-webkit-scrollbar-track{margin-top:8px;margin-bottom:8px}.ai-message{display:flex;align-items:flex-start;gap:12px;margin-bottom:var(--spacing-xl);max-width:100%;padding-right:var(--spacing-sm)}.ai-message.has-turn-info{margin-top:8px;flex-wrap:wrap;align-items:center}.ai-message.has-turn-info .message-content{flex-basis:100%;max-width:100%;padding-top:2px;padding-left:12px}.ai-message.has-turn-info .turn-info-header{flex:1;min-width:0}.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}.ai-message.assistant .message-avatar{background:transparent;border:none;border-radius:0;font-size:14px;overflow:visible}.ai-message.user .message-avatar{background:var(--accent-primary);border-radius:4px;color:#fff;font-size:12px;font-weight:600;margin-top:10px}.thinking-dots:after{content:"";animation:thinking-dots 1.4s infinite steps(4,end)}@keyframes thinking-dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}to{content:""}}.message-content{background:transparent;border-radius:0;padding:4px 0 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:#4a4a4a}.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,.turn-info-header .turn-info,.ai-message-body .turn-info{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--text-muted);margin-bottom:0}.chat-section-heading{margin-top:12px;font-weight:600}.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}}.thinking-steps{display:flex;flex-direction:column;gap:6px;padding:8px 0}.thinking-step{display:flex;align-items:flex-start;gap:6px;font-size:.85rem;color:var(--text-secondary);animation:fadeInStep .3s ease-in}.thinking-step.highlight{color:var(--accent-primary);font-weight:500}.thinking-check{flex-shrink:0;font-size:.8rem}.thinking-text{line-height:1.4}@keyframes fadeInStep{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.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:1fr;grid-template-areas:"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: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}.page-wrapper{flex-direction:column}.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: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:8px var(--spacing-md);margin:0 16px 0 30px;border-top:1px solid var(--border-light)}.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;flex-shrink:0;font-size:12px;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;display:flex;align-items:center;gap:6px}.xp-info-trigger{position:relative;display:inline-flex;align-items:center;cursor:pointer;color:var(--text-tertiary, #9ca3af);transition:color .15s}.xp-info-trigger:hover{color:var(--primary, #8b5cf6)}.xp-info-tooltip{display:none;position:absolute;top:calc(100% + 10px);left:0;width:280px;background:var(--bg-white, #fff);color:var(--text-primary, #1f2937);border:1px solid var(--border-light, #e5e7eb);border-radius:8px;padding:12px 14px;font-size:13px;font-weight:400;line-height:1.5;z-index:100;box-shadow:0 4px 12px #0000001a}.xp-info-tooltip:before{content:"";position:absolute;bottom:100%;left:12px;border:6px solid transparent;border-bottom-color:var(--border-light, #e5e7eb)}.xp-info-tooltip:after{content:"";position:absolute;bottom:100%;left:13px;border:5px solid transparent;border-bottom-color:var(--bg-white, #fff)}.xp-info-trigger:hover .xp-info-tooltip{display:block}.xp-info-tooltip-title{font-weight:600;font-size:14px;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--border-light, #e5e7eb)}.xp-info-tooltip-list{list-style:disc;margin:0;padding:0 0 0 16px}.xp-info-tooltip-list li{padding:3px 0;font-size:12.5px;line-height:1.5}.xp-info-tooltip-list li strong{color:var(--primary, #8b5cf6);font-weight:500}.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}.activity-stats-col .myactivity-card{flex:1}.myactivity-card{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:16px 20px}.myactivity-growth-card{display:flex;flex-direction:column;gap:16px}.growth-card-inner{display:flex;gap:24px}.growth-card-left{flex:0 0 75%;min-width:0}.growth-card-right{flex:1;display:flex;flex-direction:row;align-items:center;justify-content:space-evenly;gap:16px;padding-left:24px;border-left:1px solid var(--border-light)}.growth-header{display:flex;align-items:center;gap:20px}.growth-current{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.growth-level-icon{font-size:32px;line-height:1;flex-shrink:0}.growth-level-info{min-width:0}.growth-level-name{font-size:16px;font-weight:700;color:var(--text-primary)}.growth-level-desc{font-size:13px;color:var(--text-muted);margin:2px 0 0}.growth-stats{display:flex;gap:20px;flex-shrink:0}.growth-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.growth-stat-value{font-size:18px;font-weight:700;color:var(--text-primary)}.growth-stat-label{font-size:11px;color:var(--text-muted)}.gami-steps-wide{width:100%;padding:8px 0 4px}.gami-steps-wide .gami-step{flex:1 1 0%!important;min-width:0}.gami-steps-wide .gami-step:last-child{flex:0 0 auto!important}.gami-steps-wide .gami-step-active{flex:5 1 0%!important}.gami-steps-wide .gami-step-line{width:auto!important;flex:1 1 0%!important;min-width:4px;height:4px;border-radius:2px;background:#eef1f5;position:relative;overflow:visible}.gami-steps-wide .gami-step-line-done{background:#d1d5db}.gami-steps-wide .gami-step-line-progress{background:#eef1f5;overflow:visible}.gami-step-line-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--accent-primary),#a78bfa);transition:width .4s ease}.gami-line-xp-text{position:absolute;top:-16px;left:50%;transform:translate(-50%);font-size:11px;font-weight:600;color:#9ca3af;white-space:nowrap}.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-coin-icon{font-size:24px;line-height:1}.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}.activity-feed-card{padding:16px 20px!important}.activity-feed-list{list-style:none;margin:0;padding:0;max-height:400px;overflow-y:auto}.activity-feed-list::-webkit-scrollbar{width:4px}.activity-feed-list::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:2px}.activity-feed-item{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--border-light)}.activity-feed-item:last-child{border-bottom:none}.activity-feed-icon{font-size:20px;line-height:1;flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border-radius:50%}.activity-feed-body{display:flex;flex-direction:column;gap:2px;min-width:0}.activity-feed-text{font-size:14px;color:var(--text-primary);line-height:1.4}.activity-feed-date{font-size:12px;color:var(--text-muted)}.activity-feed-empty{text-align:center;color:var(--text-muted);font-size:14px;padding:24px 0;margin:0}.activity-feed-loading{text-align:center;color:var(--text-muted);font-size:13px;padding:12px 0;margin:0}.activity-feed-more{display:block;width:100%;padding:10px;margin-top:8px;background:none;border:1px solid var(--border-light);border-radius:8px;font-size:13px;color:var(--text-muted);cursor:pointer;transition:all .15s}.activity-feed-more:hover{background:var(--bg-elevated);color:var(--text-primary)}.badge-collection-card{padding:0!important;overflow:visible}.badge-collection{display:grid;grid-template-columns:120px repeat(4,1fr);gap:0}.badge-col-header{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:4px;padding:14px 4px;background:#f8f9fb;border-bottom:1px solid var(--border-light)}.badge-col-header:first-child{border-radius:var(--radius-lg) 0 0 0}.badge-col-header:last-child{border-radius:0 var(--radius-lg) 0 0}.badge-col-tier-icon{font-size:16px;line-height:1}.badge-col-tier-label{font-size:11px;font-weight:600;color:var(--text-muted)}.badge-col-row{display:contents}.badge-col-type{display:flex;align-items:center;gap:8px;padding:16px 12px 16px 24px;border-bottom:1px solid var(--border-light)}.badge-col-type-icon{font-size:18px;line-height:1}.badge-col-type-name{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap}.badge-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:16px 8px;border-bottom:1px solid var(--border-light);position:relative;cursor:pointer;transition:background .15s}.badge-cell:hover{background:var(--bg-elevated)}.badge-cell-icon{font-size:32px;line-height:1;flex-shrink:0;min-width:36px;min-height:36px;aspect-ratio:1;display:flex;align-items:center;justify-content:center;transition:transform .2s}.badge-cell:hover .badge-cell-icon{transform:scale(1.15)}.badge-cell-icon-gray{filter:grayscale(1);opacity:.35}.badge-cell-check{font-size:11px;font-weight:700;color:#fff;background:#10b981;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;line-height:1}.badge-cell-progress{display:flex;flex-direction:column;align-items:center;gap:2px;width:100%;max-width:32px}.badge-cell-progress-bar{width:100%;height:3px;background:#e5e7eb;border-radius:2px;overflow:hidden}.badge-cell-progress-fill{height:100%;background:var(--accent-primary);border-radius:2px;transition:width .3s}.badge-cell-progress-text{font-size:9px;color:var(--text-muted);white-space:nowrap}.badge-cell-empty .badge-cell-icon{font-size:20px;color:#d1d5db}.badge-cell-tooltip{display:none;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:#1f2937;color:#fff;padding:10px 14px;border-radius:8px;font-size:12px;white-space:nowrap;z-index:100;box-shadow:0 4px 12px #00000026;pointer-events:none}.badge-cell-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:#1f2937}.badge-cell:hover .badge-cell-tooltip{display:block}.badge-cell-tooltip-name{font-weight:700;font-size:13px;margin-bottom:4px}.badge-cell-tooltip-desc{color:#9ca3af;font-size:11px;margin-bottom:4px}.badge-cell-tooltip-progress{color:#60a5fa;font-size:11px;font-weight:500}.badge-cell-tooltip-date{color:#10b981;font-size:11px;margin-top:2px}.badge-col-row:last-child .badge-col-type,.badge-col-row:last-child .badge-cell{border-bottom:none}@media(max-width:768px){.badge-collection{grid-template-columns:80px repeat(4,1fr)}.badge-col-type-name{font-size:11px}.badge-cell-icon{font-size:22px}}.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,#8b5cf6,#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,#8b5cf6,#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}.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:8px}.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:10px 16px;background:transparent;border:1px solid var(--border-light, #e0e0e0);border-radius:var(--radius-md);margin-bottom:0;cursor:pointer;transition:all .2s ease}.video-item-active{background:var(--bg-elevated);border-color:var(--border-light)}.video-item:hover{background:var(--bg-elevated)}.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}.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:#8b5cf6}.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}.header-logo-link{display:none;align-items:center}.page-wrapper.simulator-mode .left-panel,.app-layout.simulator-mode .right-panel{display:none}.app-layout.simulator-mode{grid-template-columns:1fr;grid-template-areas:"content"}.page-wrapper.simulator-mode .header-logo-link{display:flex}.simulator-page{height:100%;overflow:hidden}.simulator-page.simulator-scroll,.simulator-page.simulator-scroll .simulator-embed{height:auto;overflow:visible}.simulator-dashboard .dashboard-content{height:auto!important;overflow-y:visible!important}.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{display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#fff,#f8fafc,#f1f5f9);min-height:500px;padding:40px 0}.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,#8b5cf6 0% 100%);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%;min-height:0}@media(max-height:800px){.user-dialogue-area{height:140px;padding:12px 16px}.judges-row-inline{gap:24px;padding:12px 24px}.simulator-header-inline{padding:6px 16px}}@media(max-height:700px){.user-dialogue-area{height:120px;padding:8px 12px}.judges-row-inline{gap:16px;padding:8px 16px}}.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:#8b5cf6;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,#8b5cf6,#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 #8b5cf6;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:#8b5cf6;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:#8b5cf6!important;box-shadow:0 8px 32px #6366f166,0 4px 16px #6366f133!important}.judge-card-inline.focused .judge-name-inline{font-size:20px;color:#8b5cf6}.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:#8b5cf6;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:#7c3aed;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:#8b5cf6;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,#8b5cf6 0% 100%);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,#8b5cf6,#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,#8b5cf6,#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:calc(100% - 48px);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}.sim-modal-content--wide{max-width:720px}.feedback-loading{display:flex;flex-direction:column;align-items:center;gap:16px;padding:48px 0}.feedback-loading-spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#8b5cf6;border-radius:50%;animation:spin .8s linear infinite}.feedback-loading-text{font-size:15px;color:#64748b;margin:0}.feedback-sequence-inline{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.feedback-sequence-inline--scroll{padding:4px 4px 4px 0}.feedback-item--hidden{opacity:0;transform:translateY(16px)}.feedback-item--visible{animation:feedbackReveal .5s ease forwards}@keyframes feedbackReveal{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.feedback-item-inline.feedback-item-inline--card{display:flex;flex-direction:row;align-items:stretch;gap:0;padding:0;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;overflow:hidden}.feedback-card-header{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:12px 16px;background:#f1f5f9;border-right:1px solid #e2e8f0;flex-shrink:0;min-width:90px}.feedback-comment-scroll{flex:1;padding:10px 14px;min-width:0}.feedback-comment-scroll .feedback-comment{font-style:italic;color:#475569;line-height:1.55;font-size:13px;margin:0;width:100%}.feedback-grade--excellent{background:#dcfce7;color:#16a34a}.feedback-grade--good{background:#e0e7ff;color:#4338ca}.feedback-grade--poor{background:#fee2e2;color:#dc2626}.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:6px;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)}}@media(max-width:480px){.feedback-item-inline.feedback-item-inline--card{flex-direction:column}.feedback-card-header{flex-direction:row;border-right:none;border-bottom:1px solid #e2e8f0;padding:8px 14px;min-width:unset}}.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:#7c3aed;margin-bottom:4px}.feedback-text-inline{font-size:14px;color:#64748b;font-style:italic}.feedback-score-inline{font-size:24px;font-weight:700;color:#8b5cf6}.final-score-inline{display:flex;align-items:center;gap:32px;padding:14px 24px;background:linear-gradient(135deg,#f0f9ff,#e0e7ff);border-radius:12px;margin-bottom:16px;border:1px solid #c7d2fe}.final-score-left{display:flex;flex-direction:column;align-items:center;flex-shrink:0}.final-score-inline .score-label{font-size:12px;color:#64748b;margin-bottom:4px}.score-value-inline{font-size:40px;font-weight:700;color:#8b5cf6;line-height:1}.score-comment-inline{font-size:15px;color:#475569;line-height:1.5;flex:1;min-width:0}.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,#8b5cf6,#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:#8b5cf6}.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:#8b5cf6;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:#8b5cf6;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,#8b5cf6,#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:#8b5cf6;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,#8b5cf6,#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:#8b5cf6;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,#8b5cf6,#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 #8b5cf6;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 #8b5cf6;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,#8b5cf6,#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:#8b5cf6;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:#8b5cf6;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:#8b5cf6}.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 #8b5cf6}.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:#8b5cf6;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,#8b5cf6,#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:#8b5cf6;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,#8b5cf6,#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:#8b5cf6;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, #2d2b27);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, #2d2b27)}.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, #2d2b27)}.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, #2d2b27);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, #2d2b27)}.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, #2d2b27);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, #2d2b27);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, #2d2b27);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, #8b5cf6);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, #2d2b27);color:#fff;border-color:var(--text-primary, #2d2b27)}.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, #2d2b27);border:1px solid var(--text-primary, #2d2b27);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-main-col{display:flex;flex-direction:column;flex:1;overflow:hidden}.lounge-header{flex-shrink:0;padding-left:var(--spacing-lg);padding-right:var(--spacing-lg)}.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, #2d2b27)}.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, #2d2b27);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:linear-gradient(135deg,#8b5cf6,#818cf8);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;flex-shrink:0}.lounge-message.is-me .lounge-message-avatar{background:var(--accent-primary, #8b5cf6)}.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, #2d2b27)}.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,#8b5cf6)}.lounge-message.ai-personal .lounge-message-name,.lounge-message.ai-personal .personal-name{color:#8b5cf6;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, #2d2b27);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, #8b5cf6);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, #2d2b27);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, #2d2b27)}.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, #2d2b27)}.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, #2d2b27)}.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, #2d2b27);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, #2d2b27)}.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, #2d2b27);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}.thinking-panel{margin:4px 8px;border-radius:6px;overflow:hidden}.thinking-panel-toggle{display:flex;align-items:center;gap:4px;width:100%;padding:4px 8px;background:none;border:none;cursor:pointer;font-size:11px;color:var(--text-muted, #656360)}.thinking-panel-toggle:hover{color:var(--text-secondary, #4a4a48)}.thinking-steps-list{display:flex;flex-direction:column;gap:1px;padding:0 8px 4px}.thinking-step-item{display:flex;align-items:center;gap:5px;padding:2px 0;font-size:11px;color:var(--text-muted, #656360);animation:thinkingStepIn .2s ease-out}.thinking-step-item.completed{color:var(--text-muted, #b0b0b0)}.thinking-step-icon{display:flex;align-items:center;width:12px;flex-shrink:0;color:var(--text-muted, #656360)}.thinking-step-item:not(.completed) .thinking-step-icon{color:var(--text-secondary, #4a4a48)}.thinking-step-text{line-height:1.3}.thinking-spinner{animation:thinkingSpin 1s linear infinite}@keyframes thinkingSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes thinkingStepIn{0%{opacity:0}to{opacity:1}}.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;background-clip:content-box;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}.chat-message.ai-message+.chat-message.ai-message{margin-top:18px}.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;border:none;border-radius:0;overflow:visible;background:transparent}.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:#8b5cf6}.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-discord-section .team-joined{padding:0;margin:0}.team-discord-section .channel-item:last-child{margin-bottom: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:0}.channel-category{display:flex;align-items:center;justify-content:space-between;padding:4px 12px 2px;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%,#8b5cf6 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}}.sim-stop-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border:none;border-radius:6px;background:#0000000f;color:#94a3b8;cursor:pointer;margin-left:6px;transition:color .15s,background .15s}.sim-stop-btn:hover{color:#64748b;background:#0000001f}.sim-confirm-overlay{position:absolute;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1001}.sim-confirm-dialog{background:#fff;border-radius:14px;padding:28px 32px 20px;box-shadow:0 12px 32px #00000040;text-align:center;min-width:280px}.sim-confirm-text{font-size:16px;font-weight:600;color:#1e293b;margin:0 0 20px}.sim-confirm-actions{display:flex;gap:10px;justify-content:center}.sim-confirm-btn{padding:8px 24px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s}.sim-confirm-btn--cancel{background:#f1f5f9;color:#475569}.sim-confirm-btn--cancel:hover{background:#e2e8f0}.sim-confirm-btn--ok{background:#ef4444;color:#fff}.sim-confirm-btn--ok:hover{background:#dc2626}.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:2}.leaderboard-card{grid-column:2;grid-row:2}.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-sm) var(--spacing-md);margin-bottom:var(--spacing-xs);border-bottom:1px solid var(--border-light)}.my-rank-info{display:flex;align-items:center;gap:var(--spacing-sm)}.my-rank-label{font-size:13px;font-weight:500;color:var(--text-muted)}.my-rank-number{font-size:20px;font-weight:700;color:var(--text-primary)}.my-rank-percentile{font-size:12px;font-weight:500;color:#8b5cf6}.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-dept{font-size:11px;color:var(--text-muted, #9ca3af);flex-shrink:0}.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:#eef2ff;color:#8b5cf6}.activity-icon.investment{background:#fef3c7;color:#b45309}.activity-icon.gratitude{background:#fce7f3;color:#be185d}.activity-icon.badge{background:#f5f3ff;color:#8b5cf6}.activity-icon.level{background:#dbeafe;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}.worksheet-scroll-area .page-header,.settings-scroll-area .page-header,.leaderboard-scroll-area .page-header,.notifications-scroll-area .page-header{padding-left:0;padding-right:0}.page-header h1{font-size:24px;font-weight:700;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:0 var(--spacing-lg) 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;justify-content:flex-start!important;gap:24px;padding:var(--spacing-lg)}.settings-avatar{width:52px;height:52px;font-size:20px;cursor:default}.profile-details{flex:none}.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}.profile-info-list{padding:0 var(--spacing-lg) var(--spacing-md);display:flex;flex-direction:column;gap:6px}.profile-info-item{display:flex;align-items:center;gap:var(--spacing-sm)}.profile-info-label{display:inline-flex;align-items:center;gap:4px;font-size:13px;color:var(--text-muted);min-width:52px}.profile-info-value{font-size:13px;color:var(--text-primary);font-weight:400}.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:default;font-size:14px;color:var(--text-primary)}.profile-action-item:last-child{border-bottom:none}.profile-action-item svg{color:var(--text-muted);flex-shrink:0}.profile-action-item span:nth-child(2){flex:1}.profile-action-btn{margin-left:auto;font-size:12px;font-weight:500;color:var(--accent-primary, #667eea);background:none;border:1px solid var(--accent-primary, #667eea);border-radius:12px;padding:3px 12px;cursor:pointer;font-family:inherit;transition:background .15s,color .15s}.profile-action-btn:hover{background:var(--accent-primary, #667eea);color:#fff}.profile-action-btn.danger{color:var(--accent-error, #e53e3e);border-color:var(--accent-error, #e53e3e)}.profile-action-btn.danger:hover{background:var(--accent-error, #e53e3e);color:#fff}.action-badge{font-size:11px;color:var(--text-muted);background:var(--bg-elevated);padding:2px 8px;border-radius:10px;font-weight:500}.profile-message{padding:10px 16px;border-radius:var(--radius-md);font-size:13px;margin-bottom:var(--spacing-md)}.profile-message-success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.profile-message-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.profile-edit-field{display:flex;align-items:center;gap:8px;width:100%}.profile-edit-field-label{font-size:13px;color:var(--text-muted);white-space:nowrap;min-width:28px}.profile-avatar-edit-section{display:flex;flex-direction:column;align-items:center;gap:8px;padding:var(--spacing-lg)}.avatar-edit-lg{width:96px!important;height:96px!important;font-size:36px!important}.avatar-edit-lg .avatar-overlay{opacity:.6}.avatar-edit-lg:hover .avatar-overlay{opacity:1}.avatar-edit-btns{display:flex;gap:8px;align-items:center}.avatar-edit-btn{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--accent-primary, #667eea);background:none;border:1px solid var(--accent-primary, #667eea);border-radius:12px;padding:2px 8px;cursor:pointer;font-family:inherit;white-space:nowrap;transition:background .15s,color .15s}.avatar-edit-btn:hover{background:var(--accent-primary, #667eea);color:#fff}.avatar-editable{cursor:pointer;position:relative;overflow:hidden}.avatar-editable:hover .avatar-overlay{opacity:1}.avatar-overlay{position:absolute;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;border-radius:50%;color:#fff}.avatar-reset-row{padding:0 var(--spacing-lg) var(--spacing-sm)}.avatar-reset-btn{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--text-muted);background:none;border:none;cursor:pointer;padding:2px 0}.avatar-reset-btn:hover{color:var(--accent-error)}.profile-edit-input{font-size:15px;font-weight:400;color:var(--text-primary);border:1px solid var(--border-light);border-radius:var(--radius-sm, 6px);padding:6px 10px;width:100%;background:var(--bg-surface, white);font-family:inherit}.profile-edit-input:focus{outline:none;border-color:var(--accent-primary, #667eea);box-shadow:0 0 0 2px #667eea26}.profile-edit-input-sm{font-size:13px;font-weight:400;padding:4px 8px;flex:1}.profile-edit-select{font-size:13px;font-weight:500;color:var(--text-primary);border:1px solid var(--border-light);border-radius:var(--radius-sm, 6px);padding:4px 8px;background:var(--bg-surface, white);font-family:inherit;cursor:pointer;flex:1}.profile-edit-select:focus{outline:none;border-color:var(--accent-primary, #667eea)}.profile-email-readonly{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--text-muted);margin-top:4px}.profile-edit-actions{display:flex;gap:var(--spacing-sm);padding:12px var(--spacing-lg);justify-content:flex-end}.profile-save-btn,.profile-cancel-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:var(--radius-md, 8px);font-size:14px;font-weight:500;border:none;cursor:pointer;transition:background .15s,opacity .15s;font-family:inherit}.profile-save-btn{background:var(--accent-primary, #667eea);color:#fff}.profile-save-btn:hover:not(:disabled){opacity:.9}.profile-save-btn:disabled{opacity:.6;cursor:not-allowed}.profile-cancel-btn{background:var(--bg-elevated, #f3f4f6);color:var(--text-secondary)}.profile-cancel-btn:hover:not(:disabled){background:var(--border-light)}.pw-change-form{padding:var(--spacing-md) var(--spacing-lg);display:flex;flex-direction:column;gap:12px}.pw-field{display:flex;flex-direction:column;gap:4px}.pw-field-label{font-size:12px;font-weight:500;color:var(--text-muted)}.pw-input-wrap{position:relative;display:flex;align-items:center}.pw-input-wrap .profile-edit-input{padding-right:36px;font-size:14px;font-weight:400}.pw-toggle-btn{position:absolute;right:8px;background:none;border:none;cursor:pointer;color:var(--text-muted);padding:2px;display:flex;align-items:center}.pw-toggle-btn:hover{color:var(--text-primary)}.delete-info-dialog{background:var(--bg-white);border-radius:12px;box-shadow:0 8px 32px #0000002e;padding:32px 28px 24px;max-width:360px;width:90%;text-align:center;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1001}.delete-info-dialog .modal-overlay{position:fixed}.delete-info-icon{color:var(--accent-primary, #667eea);margin-bottom:16px}.delete-info-text{font-size:14px;line-height:1.6;color:var(--text-secondary);margin:0 0 8px}.delete-info-close-btn{margin-top:16px;padding:8px 32px;border-radius:8px;border:1px solid var(--border-light);background:var(--accent-primary, #667eea);color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:opacity .15s}.delete-info-close-btn:hover{opacity:.85}.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-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)}.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}.msg-tabs{display:flex;gap:0;border-bottom:1px solid var(--border-light);margin-bottom:var(--spacing-md)}.msg-tab{padding:10px 20px;font-size:14px;font-weight:500;color:var(--text-muted);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all var(--transition-fast);display:inline-flex;align-items:center;gap:6px}.msg-tab:hover{color:var(--text-primary)}.msg-tab.active{color:#8b5cf6;border-bottom-color:#8b5cf6}.msg-tab-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:#ef4444;border-radius:9px}.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:10px}.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-guide{font-size:13px;color:var(--text-primary);margin-bottom:12px}.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:10px 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-sender{display:inline-block;font-size:12px;color:var(--accent-primary);font-weight:500;margin-top:2px}.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:#8b5cf6;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;display:flex;align-items:center;gap:4px}.notif-chevron{display:flex;align-items:center;color:var(--text-muted);transition:color var(--transition-fast)}.notif-item:hover .notif-chevron{color:var(--text-secondary)}.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:4px var(--spacing-lg) var(--spacing-sm) 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:#8b5cf6}.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)}}.thread-board{display:flex;flex-direction:column;gap:0}.thread-post-reply{padding:8px 0}.thread-post-reply:last-child{padding-bottom:4px}.thread-post-header{display:flex;align-items:center;gap:6px;margin-bottom:4px}.thread-post-role{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;letter-spacing:.02em}.thread-post-role.instructor{background:#f3e8ff;color:#8b5cf6}.thread-post-role.student{background:#eff6ff;color:#2563eb}.thread-post-name{font-size:13px;font-weight:600;color:var(--text-primary)}.thread-post-email{font-size:11px;color:var(--text-muted);font-weight:400}.thread-post-time{font-size:11px;color:var(--text-muted);margin-left:auto}.thread-post-body{font-size:13px;line-height:1.6;color:var(--text-secondary);white-space:pre-wrap;word-break:break-word}.thread-loading{padding:12px;text-align:center;color:var(--text-muted);font-size:13px}.thread-compose{display:flex;align-items:flex-end;gap:8px;padding:8px 0 4px;margin-top:4px}.thread-compose-input{flex:1;border:1px solid var(--border-color);border-radius:8px;padding:8px 12px;font-size:13px;line-height:1.5;resize:none;background:#f8f9fb;color:var(--text-primary);font-family:inherit;box-sizing:border-box}.thread-compose-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #2563eb14}.thread-compose-btn{flex-shrink:0;padding:8px 16px;font-size:13px;font-weight:500;color:#fff;background:var(--accent-primary);border:none;border-radius:8px;cursor:pointer;white-space:nowrap;transition:background .15s}.thread-compose-btn:hover{background:var(--accent-primary-hover)}.thread-compose-btn:disabled{opacity:.5;cursor:not-allowed}.notif-pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px 0 8px}.notif-page-btn{padding:6px 14px;font-size:13px;font-weight:500;color:var(--text-secondary);background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.notif-page-btn:hover:not(:disabled){border-color:var(--accent-primary);color:var(--accent-primary)}.notif-page-btn:disabled{opacity:.4;cursor:not-allowed}.notif-page-info{font-size:13px;color:var(--text-muted)}.header .btn-support{position:relative;display:flex;align-items:center;justify-content:center;color:var(--text-muted);text-decoration:none;padding:4px;margin-right:4px;line-height:0;height:32px}.header .btn-support:hover{color:var(--text-primary)}.guide-page{display:flex;flex-direction:column;height:100vh;background:#f5f6fa;font-family:Pretendard Variable,Pretendard,-apple-system,BlinkMacSystemFont,sans-serif;color:#1a1a2e}.guide-header{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:56px;background:#fff;border-bottom:1px solid #e5e7eb;flex-shrink:0}.guide-header-left{display:flex;align-items:center;gap:12px}.guide-header-logo{height:28px}.guide-header-title{font-size:18px;font-weight:700;margin:0;color:#1a1a2e}.guide-header-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:none;color:#6b7280;cursor:pointer;border-radius:6px}.guide-header-close:hover{background:#f3f4f6;color:#1a1a2e}.guide-layout{display:grid;grid-template-columns:240px 1fr 300px;flex:1;overflow:hidden}.guide-toc{background:#fff;border-right:1px solid #e5e7eb;padding:24px 0;overflow-y:auto}.guide-toc-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#9ca3af;padding:0 20px;margin:0 0 12px}.guide-toc-categories{display:flex;flex-direction:column;gap:4px}.guide-toc-group{margin-bottom:4px}.guide-toc-category{display:block;font-size:14px;font-weight:700;color:#374151;padding:10px 20px 4px;letter-spacing:.02em}.guide-toc-list{list-style:none;margin:0;padding:0}.guide-toc-item{display:block;width:100%;padding:8px 20px 8px 28px;border:none;background:none;text-align:left;font-size:15px;font-weight:500;color:#6b7280;cursor:pointer;transition:all .15s;border-left:3px solid transparent;font-family:inherit}.guide-toc-item:hover{color:#1a1a2e;background:#f9fafb}.guide-toc-item.active{color:#7c3aed;background:#eef2ff;border-left-color:#7c3aed;font-weight:600}.guide-content{overflow-y:auto;padding:32px 40px;display:flex;flex-direction:column;align-items:center}.guide-content-inner{width:100%;max-width:860px}.guide-category-block{margin-bottom:8px}.guide-category-block:not(:first-child){margin-top:32px}.guide-category-header{font-size:17px;font-weight:700;color:#fff;padding:10px 20px;margin-bottom:24px;background:#8b5cf6;border-radius:6px;letter-spacing:.02em}.guide-article{margin-bottom:40px;scroll-margin-top:16px}.guide-article-title{font-size:22px;font-weight:700;color:#1a1a2e;margin:0 0 20px;padding-bottom:12px;border-bottom:2px solid #e5e7eb}.guide-article-block{margin-bottom:20px}.guide-article-block h3{font-size:17px;font-weight:600;color:#374151;margin:0 0 8px}.guide-article-block p{font-size:16px;color:#6b7280;line-height:1.7;margin:0}.guide-list{margin:10px 0 0;padding:0 0 0 20px;list-style:none}.guide-list li{position:relative;font-size:15px;color:#4b5563;line-height:1.7;padding:3px 0 3px 12px}.guide-list li:before{content:"";position:absolute;left:0;top:14px;width:5px;height:5px;border-radius:50%;background:#9ca3af}.guide-note{display:flex;align-items:flex-start;gap:10px;margin-top:12px;padding:12px 14px;background:#eef2ff;border-left:3px solid #7c3aed;border-radius:0 8px 8px 0;font-size:15px;color:#374151;line-height:1.6}.guide-note-icon{flex-shrink:0;padding:2px 7px;background:#7c3aed;color:#fff;border-radius:4px;font-size:11px;font-weight:700;letter-spacing:.05em}.guide-img-placeholder{margin:16px 0 4px}.guide-img-box{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;background:#f9fafb}.guide-img-box img{display:block;width:100%;height:auto}.guide-img-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-height:200px;padding:32px 16px;color:#9ca3af}.guide-img-fallback-icon{padding:4px 12px;background:#e5e7eb;color:#6b7280;border-radius:4px;font-size:11px;font-weight:700;letter-spacing:.1em}.guide-img-fallback-name{font-size:13px;font-weight:600;color:#6b7280;font-family:SF Mono,Consolas,monospace}.guide-img-fallback-desc{font-size:12px;color:#9ca3af;text-align:center;max-width:320px}.guide-img-placeholder figcaption{font-size:13px;color:#9ca3af;text-align:center;margin-top:8px;font-style:italic}.guide-sidebar{background:#fff;border-left:1px solid #e5e7eb;overflow-y:auto;padding:24px 20px;display:flex;flex-direction:column;gap:24px}.guide-sidebar-title{font-size:15px;font-weight:700;color:#1a1a2e;margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid #e5e7eb}.guide-faq-list{display:flex;flex-direction:column}.guide-faq-item{border-bottom:1px solid #f3f4f6}.guide-faq-item:last-child{border-bottom:none}.guide-faq-question{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;padding:10px 0;border:none;background:none;cursor:pointer;font-size:14px;font-weight:500;color:#374151;text-align:left;font-family:inherit;transition:color .15s}.guide-faq-question:hover{color:#7c3aed}.guide-faq-question svg{flex-shrink:0;color:#9ca3af}.guide-faq-item.open .guide-faq-question{font-weight:600;color:#7c3aed}.guide-faq-answer{padding:0 0 10px}.guide-faq-answer p{font-size:14px;color:#6b7280;line-height:1.6;margin:0}.guide-inquiry-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 16px;font-size:15px;font-weight:600;color:#fff;background:#7c3aed;border:none;border-radius:8px;text-decoration:none;cursor:pointer;transition:background .15s}.guide-inquiry-btn:hover{background:#4338ca}@media(max-width:1024px){.guide-layout{grid-template-columns:1fr 300px}.guide-toc{display:none}}@media(max-width:768px){.guide-layout{grid-template-columns:1fr;grid-template-rows:1fr auto}.guide-sidebar{border-left:none;border-top:1px solid #e5e7eb}.guide-content{padding:20px 16px}}.week2-container{display:flex;flex-direction:column;height:100%;overflow:hidden}.week2-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) max(var(--spacing-lg),calc((100% - 800px)/2));padding-top:calc(var(--spacing-lg) + var(--spacing-md));margin-bottom:0;border-bottom:none;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-sticky{position:sticky;top:0;z-index:10;background:var(--bg-white, #fff);padding:10px 0}.week-lecture-title{font-size:18px;font-weight:600;color:var(--text-dark);text-align:left;max-width:800px;margin:0 auto;padding:4px 0 0;box-sizing:border-box}.content-tabs{display:flex;align-items:center;justify-content:center;gap:20px;max-width:800px;margin:0 auto;padding:10px var(--spacing-lg);background:var(--bg-elevated, #f5f5f4);border-radius:10px;border-bottom:none;box-shadow:none;width:auto}.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}.week2-tab-content .simulator-page .simulator-embed{max-width:800px;margin:0 auto}.app-layout.simulator-mode .week2-tab-content .week-lecture-title{max-width:none;margin:0;padding:8px 16px 4px;background:linear-gradient(180deg,#f8fafc,#f1f5f9);border-radius:12px 12px 0 0;border:1px solid #e2e8f0;border-bottom:none}.app-layout.simulator-mode .week2-tab-content .simulator-page .simulator-embed{max-width:none;border-radius:0 0 12px 12px;border:1px solid #e2e8f0;border-top:none}.week2-tab-content .info-item{padding:4px 0}.reading-page-inner{max-width:800px;margin:0 auto;padding:20px 0 64px}.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);padding-left:16px}.reading-section h2{font-size:17px;font-weight:600;margin-bottom:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--border-light);margin-left:-16px}.reading-section h3{font-size:15px;font-weight:600;margin:var(--spacing-lg) 0 var(--spacing-sm)}.reading-section p,.reading-section li{font-size:14px}.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:#f0f7ff;border-left:none}.reading-callout.warning{background:linear-gradient(135deg,#fffef7,#fffbeb);border-left:none}.reading-callout.success{background:var(--accent-success-light);border-left:none}.reading-callout.critical{border-left:none}.callout-icon{font-size:20px}.callout-content>strong{display:block;margin-bottom:var(--spacing-sm)}.reading-callout .callout-content p strong{display:inline;margin-bottom:0}.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:0;margin-top:var(--spacing-xl);width:100%;box-sizing:border-box}.btn-start-worksheet{padding:14px 36px;background:linear-gradient(135deg,#7c5cf5,#8b5cf6,#818cf8);color:#fff;border:none;border-radius:28px;font-size:15px;font-weight:600;cursor:pointer;margin-top:var(--spacing-sm);box-shadow:0 4px 16px #6366f14d;transition:transform .15s,box-shadow .15s}.btn-start-worksheet:hover{transform:translateY(-1px);box-shadow:0 6px 20px #6366f166}.video-page-inner{max-width:800px;margin:0 auto;padding:20px 0 32px}.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{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-md);margin-bottom:0}.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;padding:20px 0 32px}.resources-page-inner .resources-section{margin-top:0}.resources-section h3.resources-section-title{font-size:14px}.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}.resource-item{gap:10px;padding-left:12px}.resource-item:hover{border-color:#6366f140}.resource-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#6366f114;border-radius:50%}.resource-info{display:flex;flex-direction:column}.resource-desc{margin-left:0;margin-top:2px}.resource-detail-content{padding-left:54px}.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}.two-column-table{display:flex;flex-direction:column}.two-column-header{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);font-weight:600;font-size:14px;color:var(--text-secondary)}.two-column-header .column-header{font-size:14px;margin-bottom:0;border-bottom-width:1px;padding-bottom:4px}.two-column-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.gap-table{width:100%;border-collapse:collapse;table-layout:fixed;border:1px solid var(--border-light, #e0e0e0)}.gap-table th{font-size:13px;font-weight:600;color:var(--text-dark, #333);text-align:center;padding:6px 8px;background:var(--bg-secondary, #f0f2f8);border:1px solid var(--border-light, #e0e0e0)}.gap-table td{padding:0;border:1px solid var(--border-light, #e0e0e0);vertical-align:top}.gap-cell{min-height:32px;padding:8px 10px;font-size:15px;font-family:inherit;line-height:1.6;outline:none;word-break:break-word}.gap-cell:focus{background:var(--bg-hover, #fafafa)}.gap-cell:empty:before{content:"";display:inline-block}.gap-table td input,.gap-table td textarea{width:100%;border:none;border-radius:0;background:transparent;padding:6px 8px;font-size:14px;font-family:inherit;line-height:1.4;resize:none;box-sizing:border-box;field-sizing:content;min-height:32px}.gap-table td input:focus,.gap-table td textarea:focus{outline:none;background:var(--bg-hover, #fafafa)}.gap-table tbody th{font-size:13px;font-weight:600;color:var(--text-dark, #333);text-align:center;padding:6px 8px;background:var(--bg-secondary, #f0f2f8);border:1px solid var(--border-light, #e0e0e0);vertical-align:middle}.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%;padding-top:var(--spacing-sm)}.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 textarea{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;box-sizing:border-box}.label-table td input:focus,.label-table td select:focus,.label-table td textarea:focus{outline:none;border-bottom-color:var(--text-dark)}.assignment-notice{background:var(--bg-secondary, #f0f2f8);border:1px solid var(--border-light, #e0e0e0);border-radius:8px;padding:16px 20px;margin-bottom:var(--spacing-md, 16px)}.assignment-notice-title{font-size:15px;font-weight:700;color:var(--text-dark, #333);margin:0 0 6px}.assignment-notice-desc{font-size:14px;color:var(--text-secondary, #666);margin:0 0 12px;line-height:1.5}.assignment-notice-subtitle{font-size:14px;font-weight:600;color:var(--text-dark, #333);margin:0 0 6px}.assignment-notice-list{margin:0;padding-left:20px;font-size:14px;color:var(--text-secondary, #666);line-height:1.7}.assignment-notice-list li{margin-bottom:2px}.pov-template-box{background:var(--bg-secondary, #f0f2f8);border:1px solid var(--border-light, #e0e0e0);border-radius:8px;padding:20px 24px}.pov-row{display:flex;align-items:center;gap:6px;margin-bottom:16px}.pov-row:last-child{margin-bottom:0}.pov-quote,.pov-suffix{font-size:15px;font-weight:500;color:var(--text-dark, #333);white-space:nowrap;flex-shrink:0}.pov-blank{flex:1;border:none;border-bottom:1px solid #999;border-radius:0;background:transparent;padding:4px 2px;font-size:15px;font-family:inherit;line-height:1.4;resize:none;field-sizing:content;min-height:28px}.pov-blank:focus{outline:none;border-bottom-color:var(--text-dark, #333)}.empathy-grid-2x2,.empathy-grid-external{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.empathy-grid-external .empathy-cell-full{grid-column:1 / -1}.empathy-cell{display:flex;flex-direction:column}.empathy-cell-header{padding:var(--spacing-xs) 0;font-weight:600;font-size:14px;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)}.week2-tab-content .worksheet-submit-section{background:var(--bg-elevated);border:none;border-radius:0;padding:var(--spacing-xl)}.week2-tab-content .worksheet-submit-section .submit-section-inner{max-width:none}.week2-tab-content .btn-worksheet-submit{padding:14px 36px;background:linear-gradient(135deg,#7c5cf5,#8b5cf6,#818cf8);color:#fff;border:none;border-radius:28px;font-size:15px;font-weight:600;box-shadow:0 4px 16px #6366f14d;transition:transform .15s,box-shadow .15s}.week2-tab-content .btn-worksheet-submit:hover{background:linear-gradient(135deg,#7c5cf5,#8b5cf6,#818cf8);transform:translateY(-1px);box-shadow:0 6px 20px #6366f166}.week2-tab-content .btn-worksheet-submit:disabled{background:#d1d1cf;box-shadow:none;transform:none}.view .page-header{padding:16px var(--spacing-lg);margin-top:0;flex-shrink:0}.course-intro-content{max-width:1200px;margin:0 auto;padding:0 24px 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:70px;white-space:nowrap}.curriculum-table th.topic-col{width:160px;white-space:nowrap}.curriculum-table td:first-child{white-space:nowrap}.curriculum-table td:nth-child(2){white-space:nowrap}.curriculum-table tr.anchor-row{background:#f59e0b14}.anchor-badge{display:inline-block;margin-left:6px;font-size:11px;font-weight:600;color:#d97706}.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)}.syllabus-phase-block{margin-bottom:32px}.syllabus-phase-block:last-child{margin-bottom:0}.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) 60px;max-width:1200px;margin:0 auto}.harness-dashboard>.harness-section:first-child{padding-top:0}.harness-dashboard>.page-header{padding-left:0;padding-right: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,.harness-section:has(+.lc-section){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);position:relative}.stat-help-icon{width:11px;height:11px;color:var(--text-muted);cursor:help;vertical-align:middle;margin-left:2px;opacity:.6}.stat-tooltip{display:none;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:#6b7280;color:#fff;font-size:12px;line-height:1.5;padding:8px 12px;border-radius:6px;white-space:nowrap;z-index:100;pointer-events:none}.stat-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:#6b7280}.stat-item.has-tooltip:hover .stat-tooltip{display:block}.stat-value{font-size:22px;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs);letter-spacing:-.01em}.stat-status{display:inline;font-size:13px;font-weight:400;margin-left:6px;color:var(--text-muted)}.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:#9ca3af}.timeline-dot.current{background:var(--accent-primary)}.timeline-dot.pending{background:var(--border-light);color:var(--text-muted)}.timeline-dot.selected{box-shadow:0 0 0 1.5px #4b5563}.timeline-week.selected .timeline-label{color:var(--text-primary, #1a1a1a);font-weight:700}.timeline-week:hover .timeline-dot{transform:scale(1.15);transition:transform .15s}.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:#9ca3af}.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.level-gray{border-color:#e5e7eb;background:#f9fafb;opacity:.7}.canvas-block.selected{box-shadow:0 0 0 2px var(--accent-primary, #2563eb);transform:translateY(-1px)}.canvas-block .week-badge{position:absolute;top:4px;right:4px;font-size:9px;font-weight:700;background:var(--accent-primary, #2563eb);color:#fff;padding:1px 5px;border-radius:3px;line-height:1.4}.canvas-block-detail{margin-top:var(--spacing-sm);border:1px solid var(--border-light);border-radius:var(--radius-md);background:var(--bg-main);padding:var(--spacing-md);animation:slideDown .15s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.block-detail-header{display:flex;align-items:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--border-light)}.block-detail-title{font-size:14px;font-weight:600;flex:1}.block-detail-close{background:none;border:none;cursor:pointer;font-size:14px;color:var(--text-muted);padding:2px 6px;border-radius:4px}.block-detail-close:hover{background:var(--bg-hover)}.block-detail-content{display:flex;gap:var(--spacing-md)}.block-detail-section{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs)}.block-detail-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase}.block-detail-feedback{font-size:12px;color:var(--text-secondary);line-height:1.5;margin:0}.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:#fff;border:1px solid var(--border-light);border-radius:var(--radius-md);padding:var(--spacing-md);box-shadow:0 1px 3px #0000000f;min-height:auto;position:relative!important;grid-column:auto!important;grid-row:auto!important;display:flex;flex-direction:column}.activity-card-title{font-size:15px;font-weight:600;color:var(--text-dark);letter-spacing:-.01em;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border-light)}.activity-card-content{font-size:13px;display:flex;flex-direction:column;flex:1}.gami-desc{font-size:13px;color:var(--text-secondary, #4a4a48);margin:0 0 10px;line-height:1.4}.gami-steps{display:flex;align-items:flex-start;overflow:visible;padding-bottom:12px}.gami-step{display:flex;align-items:center;flex-shrink:0}.gami-step-dot{width:28px;height:28px;border-radius:50%;background:#eef1f5;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s;position:relative;cursor:pointer}.gami-tooltip{display:none;position:absolute;top:calc(100% + 6px);left:50%;transform:translate(-50%);background:#1f2937;color:#fff;font-size:11px;font-weight:500;padding:4px 8px;border-radius:4px;white-space:nowrap;z-index:100;pointer-events:none}.gami-step-dot:hover .gami-tooltip{display:block}.gami-step-icon{font-size:14px;line-height:1;opacity:.4;filter:grayscale(1)}.gami-step-line{width:12px;height:2px;background:#eef1f5;flex-shrink:0}.gami-step-done .gami-step-dot{background:#f3f4f6}.gami-step-done .gami-step-icon{opacity:1;filter:none}.gami-step-line-done{background:#d1d5db}.gami-step-active .gami-step-dot{width:36px;height:36px;background:#e5e7eb;box-shadow:0 1px 4px #0000001a}.gami-step-active .gami-step-icon{font-size:18px;opacity:1;filter:none}.gami-step-info{display:flex;flex-direction:column;margin-left:8px;margin-right:4px;white-space:nowrap}.gami-step-title{font-size:12px;font-weight:700;color:var(--text-dark, #2d2b27)}.gami-step-xp{font-size:11px;font-weight:600;color:#8b5cf6}.gami-level-header{display:flex;align-items:center;justify-content:space-between}.gami-stats-row{display:flex;gap:16px}.gami-stat-chip{display:flex;align-items:baseline;gap:3px}.gami-stat-num{font-size:16px;font-weight:700;color:var(--text-dark, #2d2b27)}.gami-stat-label{font-size:11px;color:var(--text-muted, #656360)}.gami-badge-section{margin-top:4px}.gami-badge-title{font-size:11px;font-weight:600;color:var(--text-muted, #656360);margin-bottom:6px}.gami-badge-row-inline{display:flex;align-items:center;gap:48px}.gami-badge-count-num{font-size:18px;font-weight:700;color:var(--text-dark, #2d2b27);flex-shrink:0}.gami-badge-hint{font-size:12px;color:var(--text-muted, #656360);white-space:nowrap}.gami-badge-icons{display:flex;gap:8px}.gami-badge-item{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:default}.gami-badge-item .gami-badge-icon-wrap{opacity:.2;filter:grayscale(1)}.gami-badge-item .gami-badge-name{opacity:.45}.gami-badge-item.gami-badge-earned .gami-badge-icon-wrap{opacity:1;filter:none}.gami-badge-item.gami-badge-earned .gami-badge-name{opacity:1}.gami-badge-icon-wrap{position:relative;display:inline-flex}.gami-badge-icon{font-size:24px;line-height:1}.gami-badge-num{position:absolute;top:-4px;right:-6px;background:#8b5cf6;color:#fff;font-size:10px;font-weight:700;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;line-height:1}.gami-badge-name{font-size:10px;color:var(--text-muted, #656360)}.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-header-label{font-size:13px;font-weight:600;color:var(--text-secondary, #6b6b6b);margin-bottom:8px}.pitch-top-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}.pitch-mic{font-size:28px;flex-shrink:0;opacity:.3;filter:grayscale(1)}.pitch-score-circle{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#8b5cf6 0% 100%);display:flex;align-items:center;justify-content:center;flex-shrink:0;gap:1px}.pitch-score-circle.pitch-score-empty{background:var(--bg-hover, #e5e7eb)}.pitch-score-empty .pitch-score-num{color:var(--text-muted, #656360)}.pitch-score-num{font-size:22px;font-weight:800;color:#fff;line-height:1}.pitch-score-unit{font-size:11px;font-weight:500;color:#fffc;margin-top:2px}.pitch-meta{display:flex;flex-direction:column;gap:4px}.pitch-meta-label{font-size:13px;font-weight:600;color:var(--text-primary, #2d2b27)}.pitch-meta-stats{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted, #656360)}.pitch-meta-divider{color:var(--border-light, #e5e7eb)}.pitch-trend[data-trend=improving]{color:#16a34a}.pitch-trend[data-trend=declining]{color:#dc2626}.judge-row{display:flex;gap:20px;flex-wrap:wrap}.judge-chip{display:flex;align-items:center;gap:5px;background:var(--bg-hover, #f3f4f6);border-radius:20px;padding:3px 10px 3px 3px}.judge-avatar{width:56px;height:56px;border-radius:50%;object-fit:cover;outline:4px solid #eef1f5;outline-offset:0}.judge-chip-empty{background:transparent;padding:0}.judge-chip-score{font-size:12px;font-weight:600;color:var(--text-primary, #2d2b27)}.pitch-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;flex:1}.pitch-empty-top{display:flex;align-items:center;gap:10px}.judge-row-center{justify-content:center;margin-top:8px}.pitch-empty-text{font-size:13px;color:var(--text-muted, #656360);margin:0}.pitch-empty-sub{font-size:11px;color:var(--text-muted, #656360);margin:4px 0 0;opacity:.7}.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-sm) 0;min-height:auto}.insight-block-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:4px}.insight-block-icon{font-size:16px;display:flex;align-items:center;line-height:1}.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{padding-bottom:0}.notebook-line{line-height:1.6;min-height:auto;padding:0;font-size:15px;color:var(--text-primary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notebook-line.empty{color:var(--text-muted);font-style:italic;font-size:12px;padding-left:var(--spacing-lg)}.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}.kpi-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg)}.kpi-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.kpi-group-label{font-size:13px;font-weight:600;color:var(--text-muted)}.kpi-stats{grid-template-columns:repeat(3,1fr)!important}.dashboard-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.dashboard-cards>.activity-card{margin:0;max-height:420px;overflow:hidden}.dashboard-cards>.activity-card .activity-card-content{overflow-y:auto;min-height:0;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.15) transparent}.dashboard-cards>.activity-card .activity-card-content::-webkit-scrollbar{width:4px}.dashboard-cards>.activity-card .activity-card-content::-webkit-scrollbar-track{background:transparent}.dashboard-cards>.activity-card .activity-card-content::-webkit-scrollbar-thumb{background:#00000026;border-radius:4px}.dashboard-cards>.activity-card .activity-card-content::-webkit-scrollbar-thumb:hover{background:#00000040}.harness-dashboard .activity-card.card-compact{overflow:visible}.harness-dashboard .activity-card.card-compact .activity-card-content{justify-content:center}.dashboard-cards .insight-grid-2col{grid-template-columns:1fr}@media(max-width:768px){.dashboard-cards,.kpi-row{grid-template-columns:1fr}}.inquiry-status-badge{display:inline-block;font-size:11px;padding:2px 8px;border-radius:4px;font-weight:500;white-space:nowrap}.inquiry-status-badge.open{background:#eff6ff;color:#2563eb}.inquiry-status-badge.in_progress{background:#fffbeb;color:#d97706}.inquiry-status-badge.resolved{background:#ecfdf5;color:#059669}.inquiry-status-badge.closed{background:#f3f4f6;color:#6b7280}.inquiry-category-tag{display:inline-block;font-size:11px;padding:2px 6px;border-radius:3px;background:#f1f5f9;color:#64748b;font-weight:400}.inquiry-page{max-width:800px;margin:0 auto}.inquiry-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.inquiry-page-header h2{font-size:18px;font-weight:600;margin:0}.inquiry-create-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#2563eb;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}.inquiry-create-btn:hover{background:#1d4ed8}.inquiry-filters{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}.inquiry-filter-btn{padding:5px 12px;border:1px solid #e2e8f0;background:#fff;border-radius:6px;font-size:12px;color:#64748b;cursor:pointer;transition:all .15s}.inquiry-filter-btn.active{background:#2563eb;color:#fff;border-color:#2563eb}.inquiry-filter-btn .filter-count{margin-left:4px;font-size:11px;opacity:.8}.inquiry-list{display:flex;flex-direction:column;gap:8px}.inquiry-item{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:14px 16px;cursor:pointer;transition:all .15s}.inquiry-item:hover{border-color:#cbd5e1;box-shadow:0 1px 3px #0000000f}.inquiry-item.has-unread{border-left:3px solid #2563eb}.inquiry-item-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.inquiry-item-title{font-size:14px;font-weight:500;color:#1e293b;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inquiry-item-meta{display:flex;align-items:center;gap:12px;font-size:12px;color:#94a3b8}.inquiry-item-preview{font-size:13px;color:#64748b;margin-top:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inquiry-item-student{font-size:12px;color:#475569;font-weight:500}.inquiry-empty{text-align:center;padding:48px 20px;color:#94a3b8}.inquiry-empty svg{margin-bottom:12px;opacity:.5}.inquiry-empty p{font-size:14px;margin:0}.inquiry-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.inquiry-modal{background:#fff;border-radius:12px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #00000026}.inquiry-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #e2e8f0}.inquiry-modal-header h3{font-size:16px;font-weight:600;margin:0}.inquiry-modal-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:none;cursor:pointer;color:#94a3b8;border-radius:4px}.inquiry-modal-close:hover{background:#f1f5f9;color:#475569}.inquiry-modal-body{padding:20px}.inquiry-form-group{margin-bottom:16px}.inquiry-form-group label{display:block;font-size:13px;font-weight:500;color:#374151;margin-bottom:6px}.inquiry-form-group input,.inquiry-form-group select,.inquiry-form-group textarea{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:13px;color:#1e293b;background:#fff;transition:border-color .15s;box-sizing:border-box}.inquiry-form-group input:focus,.inquiry-form-group select:focus,.inquiry-form-group textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb1a}.inquiry-form-group textarea{min-height:120px;resize:vertical;font-family:inherit}.inquiry-file-upload{display:flex;align-items:center;gap:8px}.inquiry-file-upload-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;border:1px dashed #d1d5db;background:#fafafa;border-radius:6px;font-size:12px;color:#64748b;cursor:pointer;transition:all .15s}.inquiry-file-upload-btn:hover{border-color:#2563eb;color:#2563eb}.inquiry-file-list{display:flex;flex-direction:column;gap:4px;margin-top:8px}.inquiry-file-item{display:flex;align-items:center;gap:6px;padding:4px 8px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:4px;font-size:12px;color:#475569}.inquiry-file-item .file-remove{margin-left:auto;cursor:pointer;color:#94a3b8;background:none;border:none;padding:0;font-size:14px}.inquiry-file-item .file-remove:hover{color:#ef4444}.inquiry-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid #e2e8f0}.inquiry-btn-cancel{padding:8px 16px;border:1px solid #d1d5db;background:#fff;color:#374151;border-radius:6px;font-size:13px;cursor:pointer}.inquiry-btn-submit{padding:8px 16px;border:none;background:#2563eb;color:#fff;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer}.inquiry-btn-submit:disabled{opacity:.5;cursor:not-allowed}.inquiry-thread{max-width:800px;margin:0 auto}.inquiry-thread-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:20px}.inquiry-thread-back{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid #e2e8f0;background:#fff;border-radius:6px;cursor:pointer;color:#475569;flex-shrink:0;margin-top:2px}.inquiry-thread-back:hover{background:#f1f5f9}.inquiry-thread-info{flex:1}.inquiry-thread-title{font-size:16px;font-weight:600;color:#1e293b;margin:0 0 6px}.inquiry-thread-meta{display:flex;align-items:center;gap:8px;font-size:12px;color:#94a3b8;flex-wrap:wrap}.inquiry-thread-actions{display:flex;gap:6px;flex-shrink:0}.inquiry-thread-action-btn{padding:6px 12px;border:1px solid #d1d5db;background:#fff;border-radius:6px;font-size:12px;cursor:pointer;color:#475569}.inquiry-thread-action-btn:hover{background:#f1f5f9}.inquiry-thread-action-btn.resolve{background:#ecfdf5;color:#059669;border-color:#a7f3d0}.inquiry-thread-action-btn.close-inquiry{color:#6b7280}.inquiry-messages{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.inquiry-message{padding:12px 16px;border-radius:8px;border:1px solid #e2e8f0;background:#fff}.inquiry-message.from-instructor{background:#f0f9ff;border-color:#bae6fd}.inquiry-message.internal-note{background:#fefce8;border-color:#fde68a;border-style:dashed}.inquiry-message-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:12px}.inquiry-message-sender{font-weight:600;color:#1e293b}.inquiry-message-role{font-size:10px;padding:1px 6px;border-radius:3px;font-weight:500}.inquiry-message-role.student{background:#eff6ff;color:#2563eb}.inquiry-message-role.instructor{background:#fef3c7;color:#d97706}.inquiry-message-role.internal{background:#fef3c7;color:#92400e}.inquiry-message-time{color:#94a3b8;margin-left:auto}.inquiry-message-content{font-size:14px;line-height:1.6;color:#374151;white-space:pre-wrap;word-break:break-word}.inquiry-message-attachments{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.inquiry-attachment-link{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:4px;font-size:12px;color:#2563eb;text-decoration:none;transition:background .15s}.inquiry-attachment-link:hover{background:#e2e8f0}.inquiry-compose{border:1px solid #e2e8f0;border-radius:8px;overflow:hidden;background:#fff}.inquiry-compose-textarea{width:100%;min-height:80px;padding:12px;border:none;font-size:13px;font-family:inherit;resize:vertical;box-sizing:border-box;color:#1e293b}.inquiry-compose-textarea:focus{outline:none}.inquiry-compose-footer{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-top:1px solid #f1f5f9;background:#fafafa}.inquiry-compose-left,.inquiry-compose-right{display:flex;align-items:center;gap:8px}.inquiry-compose-attach{display:flex;align-items:center;gap:4px;padding:4px 8px;border:none;background:none;cursor:pointer;color:#64748b;font-size:12px;border-radius:4px}.inquiry-compose-attach:hover{background:#f1f5f9;color:#2563eb}.inquiry-compose-send{display:flex;align-items:center;gap:4px;padding:6px 14px;background:#2563eb;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer}.inquiry-compose-send:disabled{opacity:.5;cursor:not-allowed}.inquiry-compose-send:not(:disabled):hover{background:#1d4ed8}.inquiry-internal-checkbox{display:flex;align-items:center;gap:4px;font-size:12px;color:#92400e}.inquiry-internal-checkbox input{width:14px;height:14px}.inquiry-search{position:relative;margin-bottom:12px}.inquiry-search input{width:100%;padding:8px 12px 8px 34px;border:1px solid #e2e8f0;border-radius:6px;font-size:13px;box-sizing:border-box}.inquiry-search input:focus{outline:none;border-color:#2563eb}.inquiry-search svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#94a3b8}.inquiry-status-select{padding:4px 8px;border:1px solid #d1d5db;border-radius:4px;font-size:12px;background:#fff;cursor:pointer}@media(max-width:768px){.inquiry-page-header{flex-direction:column;gap:10px;align-items:stretch}.inquiry-create-btn{justify-content:center}.inquiry-thread-header{flex-direction:column}.inquiry-thread-actions{align-self:flex-end}.inquiry-modal{max-width:100%;margin:0;border-radius:12px 12px 0 0;max-height:85vh}.inquiry-modal-overlay{align-items:flex-end;padding:0}}@media print{*{color:#000!important;-webkit-print-color-adjust:exact}.left-panel,.right-panel,.header,.mobile-header,.btn-substep-submit,.btn-dev-reset,.btn-pdf-export,.substep-actions,.curriculum-editor-inline,.team-invite-banner,.worksheet-submit-section,.connection-status,.sync-status,.tab-buttons,.week-tabs,.step-assignee,.btn-submitting,.btn-pdf-team,.content-tabs-sticky,.content-tabs,.week-lecture-title,.page-header,.week2-header,.workspace-header,.points-tag,.duration-tag,.key-badge,.substep-status,.assigned-badge,.phase-meta,.step-toggle,.edit-only,.artifacts-detail-toolbar,.artifact-back-btn,.artifacts-print-btn,footer,nav{display:none!important}html,body,#root,.page-wrapper,.page-main,.app-layout,.app-layout.ai-collapsed,#main-content,.content-wrapper,.week2-container,.worksheet-scroll-area,.week2-main-layout,.week2-tab-content,.content-page,.worksheet-page,.worksheet-component,.unified-worksheet{height:auto!important;max-height:none!important;overflow:visible!important;flex:none!important}body{margin:0!important;padding:0!important}.page-wrapper,.page-main,.app-layout,#main-content,.content-wrapper,.week2-container{display:block!important;width:100%!important;padding:0!important;margin:0!important}.worksheet-scroll-area{padding:8px!important}.step-header{background:none!important;border:none!important;border-bottom:2px solid #333!important;padding:8px 0!important}.step-badge{background:#333!important;color:#fff!important;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}.substep-label{background:none!important;border:none!important;border-bottom:1px solid #ddd!important;padding:6px 0!important;font-weight:600!important}.xp-badge,.status-badge{background:none!important;border:1px solid #999!important;color:#000!important}.substep-card{border:none!important;box-shadow:none!important;padding:8px 0!important}textarea,input,select{border:none!important;background:transparent!important;box-shadow:none!important;outline:none!important;resize:none!important;padding:2px 0!important;font-size:13px!important;line-height:1.6!important}.lc-numbered-row textarea,.lc-numbered-row input{border-bottom:1px solid #ccc!important}.print-header{display:block!important}@page{size:A4;margin:15mm}.step-section,.substep-card{page-break-inside:auto}}.print-header{display:none}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:460px;padding:24px}.login-page{min-height:100vh;display:flex;justify-content:center;align-items:center;background:var(--bg-sidebar, #f7f6f3);overflow:hidden}.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:460px;animation:slideInLeft .6s cubic-bezier(.16,1,.3,1) both}@keyframes slideInLeft{0%{opacity:0;transform:translate(-40px)}to{opacity:1;transform:translate(0)}}@media(prefers-reduced-motion:reduce){.login-card{animation:none}}.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, #2d2b27);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, #2d2b27);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, #2d2b27)}.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:#8b5cf6;border:none;border-radius:4px;cursor:pointer;transition:background .12s ease;margin-top:8px;position:relative}.btn-login:hover{background:#8b5cf6}.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}}.skeleton{background:linear-gradient(90deg,var(--bg-desk, #F1EDE8) 0%,var(--bg-sidebar-hover, #EEEBE5) 20%,var(--bg-main, #FAF9F6) 40%,var(--bg-sidebar-hover, #EEEBE5) 60%,var(--bg-desk, #F1EDE8) 100%);background-size:300% 100%;animation:shimmer 1.8s ease-in-out infinite;opacity:.8}.skeleton-line{height:16px;width:100%;border-radius:var(--radius-sm)}.skeleton-circle{border-radius:50%}.skeleton-rect{border-radius:var(--radius-md)}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}@media(prefers-reduced-motion:reduce){.skeleton{animation:skeleton-pulse 2s ease-in-out infinite}@keyframes skeleton-pulse{0%,to{opacity:.5}50%{opacity:.8}}}[data-media-player]{width:100%;display:inline-flex;align-items:center;position:relative;contain:style;box-sizing:border-box;-webkit-user-select:none;user-select:none}[data-media-player] *{box-sizing:border-box}:where([data-media-player][data-view-type=video]){aspect-ratio:16 / 9}[data-media-player]:focus,[data-media-player]:focus-visible{outline:none}[data-media-player][data-view-type=video][data-started]:not([data-controls]){pointer-events:auto;cursor:none}[data-media-player] slot{display:contents}[data-media-provider]{display:flex;position:relative;box-sizing:border-box;align-items:center;border-radius:inherit;width:100%;aspect-ratio:inherit;overflow:hidden}[data-media-player]:not([data-view-type=audio]) [data-media-provider],[data-media-player][data-fullscreen] [data-media-provider]{height:100%}[data-media-player][data-view-type=audio] [data-media-provider]{display:contents;background-color:unset}[data-media-provider] audio{width:100%}:where(video:not([width]):not([height]),iframe:not([width]):not([height])){width:100%;aspect-ratio:16 / 9}:where([data-media-provider] video),:where([data-media-provider] iframe){aspect-ratio:inherit;display:inline-block;height:auto;object-fit:contain;touch-action:manipulation;border-radius:inherit;width:100%}[data-media-provider] iframe{height:100%}[data-media-player][data-view-type=audio] video,[data-media-player][data-view-type=audio] iframe{display:none}[data-media-player][data-fullscreen] video{height:100%}[data-media-provider] iframe:not([src]){display:none}iframe.vds-youtube[data-no-controls]{height:1000%}.vds-blocker{position:absolute;inset:0;width:100%;height:auto;aspect-ratio:inherit;pointer-events:auto;border-radius:inherit;z-index:1}[data-ended] .vds-blocker{background-color:#000}.vds-icon:focus{outline:none}.vds-google-cast{width:100%;height:100%;display:flex;align-items:center;justify-content:center;flex-direction:column;color:#dedede;font-family:sans-serif;font-weight:500}.vds-google-cast svg{--size: max(18%, 40px);width:var(--size);height:var(--size);margin-bottom:8px}.vds-google-cast-info{font-size:calc(var(--media-height) / 100 * 6)}:where(.vds-buffering-indicator){position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:1}:where(.vds-buffering-indicator) :where(.vds-buffering-icon,.vds-buffering-spinner){opacity:0;pointer-events:none;transition:var(--media-buffering-transition, opacity .2s ease)}:where(.vds-buffering-indicator) :where(.vds-buffering-icon,svg.vds-buffering-spinner,.vds-buffering-spinner svg){width:var(--media-buffering-size, 96px);height:var(--media-buffering-size, 96px)}:where(.vds-buffering-indicator) :where(.vds-buffering-track,circle[data-part=track]){color:var(--media-buffering-track-color, #f5f5f5);opacity:var(--media-buffering-track-opacity, .25);stroke-width:var(--media-buffering-track-width, 8)}:where(.vds-buffering-indicator) :where(.vds-buffering-track-fill,circle[data-part=track-fill]){color:var(--media-buffering-track-fill-color, var(--media-brand));opacity:var(--media-buffering-track-fill-opacity, .75);stroke-width:var(--media-buffering-track-fill-width, 9);stroke-dasharray:100;stroke-dashoffset:var(--media-buffering-track-fill-offset, 50)}:where([data-buffering]) :where(.vds-buffering-icon,.vds-buffering-spinner){opacity:1;animation:var(--media-buffering-animation, vds-buffering-spin 1s linear infinite)}@keyframes vds-buffering-spin{to{transform:rotate(360deg)}}@media(prefers-reduced-motion){:where([data-buffering]) :where(.vds-buffering-icon,.vds-buffering-spinner){animation-duration:8s}}:where(.vds-button){position:relative;display:inline-flex;justify-content:center;align-items:center;user-select:none;appearance:none;background:none;outline:none;border:none;border-radius:var(--media-button-border-radius, 8px);width:var(--media-button-size, 40px);height:var(--media-button-size, 40px);transition:transform .2s ease-out;contain:layout style;cursor:pointer;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation;flex-shrink:0}.vds-button{border:var(--media-button-border);color:var(--media-button-color, var(--media-controls-color, #f5f5f5));padding:var(--media-button-padding, 0px)}:where([data-fullscreen] .vds-button){width:var(--media-fullscreen-button-size, 42px);height:var(--media-fullscreen-button-size, 42px)}@media screen and (max-width:599px){:where([data-fullscreen] .vds-button){width:var(--media-sm-fullscreen-button-size, 42px);height:var(--media-sm-fullscreen-button-size, 42px)}}:where(.vds-button .vds-icon){width:var(--media-button-icon-size, 80%);height:var(--media-button-icon-size, 80%);border-radius:var(--media-button-border-radius, 8px)}:where(.vds-menu-button .vds-icon){display:flex!important}:where(.vds-button[aria-hidden=true]){display:none!important}@media(hover:hover)and (pointer:fine){.vds-button:hover{background-color:var(--media-button-hover-bg, rgb(255 255 255 / .2))}.vds-button:hover{transform:var(--media-button-hover-transform, scale(1.05));transition:var(--media-button-hover-transition, transform .2s ease-in)}.vds-button[aria-expanded=true]{transform:unset}}@media(pointer:coarse){.vds-button:hover{border-radius:var(--media-button-touch-hover-border-radius, 100%);background-color:var(--media-button-touch-hover-bg, rgb(255 255 255 / .2))}}:where(.vds-button:focus){outline:none}:where(.vds-button[data-focus],.vds-button:focus-visible){box-shadow:var(--media-focus-ring)}:where(.vds-live-button){min-width:auto;min-height:auto;width:var(--media-live-button-width, 40px);height:var(--media-live-button-height, 40px);padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;user-select:none;appearance:none;background:none;outline:none;border:none}:where(.vds-live-button-text){font-family:var(--media-font-family, sans-serif);font-size:var(--media-live-button-font-size, 12px);font-weight:var(--media-live-button-font-weight, 600);letter-spacing:var(--media-live-button-letter-spacing, 1.5px);transition:color .3s ease}.vds-live-button-text{background-color:var(--media-live-button-bg, #8a8a8a);border-radius:var(--media-live-button-border-radius, 2px);color:var(--media-live-button-color, #161616);padding:var(--media-live-button-padding, 1px 4px)}:where(.vds-live-button[data-focus] .vds-live-button-text){box-shadow:var(--media-focus-ring)}:where(.vds-live-button[data-edge]){cursor:unset}.vds-live-button[data-edge] .vds-live-button-text{background-color:var(--media-live-button-edge-bg, #dc2626);color:var(--media-live-button-edge-color, #f5f5f5)}@media(pointer:fine){:where(.vds-live-button:hover){background-color:unset}}.vds-button:not([data-paused]) .vds-play-icon,.vds-button[data-ended] .vds-play-icon,.vds-button[data-paused] .vds-pause-icon,.vds-button[data-ended] .vds-pause-icon,.vds-button:not([data-ended]) .vds-replay-icon,.vds-button[data-active] .vds-pip-enter-icon,.vds-button:not([data-active]) .vds-pip-exit-icon,.vds-button[data-active] .vds-fs-enter-icon,.vds-button:not([data-active]) .vds-fs-exit-icon,.vds-button:not([data-active]) .vds-cc-on-icon,.vds-button[data-active] .vds-cc-off-icon,.vds-button:not([data-muted]) .vds-mute-icon,.vds-button:not([data-state=low]) .vds-volume-low-icon,.vds-button:not([data-state=high]) .vds-volume-high-icon{display:none}:where(.vds-captions){--overlay-padding: var(--media-captions-padding, 1%);--cue-color: var(--media-user-text-color, var(--media-cue-color, white));--cue-bg-color: var(--media-user-text-bg, var(--media-cue-bg, rgba(0, 0, 0, .7)));--cue-default-font-size: var(--media-cue-font-size, calc(var(--overlay-height) / 100 * 4.5));--cue-font-size: calc(var(--cue-default-font-size) * var(--media-user-font-size, 1));--cue-line-height: var(--media-cue-line-height, calc(var(--cue-font-size) * 1.2));--cue-padding-x: var(--media-cue-padding-x, calc(var(--cue-font-size) * .6));--cue-padding-y: var(--media-cue-padding-x, calc(var(--cue-font-size) * .4));--cue-padding: var(--cue-padding-y) var(--cue-padding-x);position:absolute;inset:0;z-index:1;contain:layout style;margin:var(--overlay-padding);font-size:var(--cue-font-size);font-family:var(--media-user-font-family, sans-serif);box-sizing:border-box;pointer-events:none;-webkit-user-select:none;user-select:none;word-spacing:normal;word-break:break-word}:where([data-fullscreen][data-orientation=portrait] .vds-captions){--cue-default-font-size: var(--media-cue-font-size, calc(var(--overlay-width) / 100 * 4.5))}:where([data-view-type=audio] .vds-captions){position:relative;margin:0}:where(.vds-captions[aria-hidden=true]){opacity:0;visibility:hidden}.vds-captions[data-example]{opacity:1!important;visibility:visible!important}:where([data-view-type=video] .vds-captions [data-part=cue-display][data-example]){--cue-text-align: center;--cue-width: 100%;--cue-top: 90%;--cue-left: 0%}:where([data-view-type=audio] .vds-captions [data-part=cue-display]){--cue-width: 100%;position:relative!important}:where(.vds-captions [data-part=cue-display]){position:absolute;direction:ltr;overflow:visible;contain:content;top:var(--cue-top);left:var(--cue-left);right:var(--cue-right);bottom:var(--cue-bottom);width:var(--cue-width, auto);height:var(--cue-height, auto);box-sizing:border-box;transform:var(--cue-transform);text-align:var(--cue-text-align);writing-mode:var(--cue-writing-mode, unset);white-space:pre-line;unicode-bidi:plaintext;min-width:min-content;min-height:min-content;background-color:var(--media-user-display-bg, var(--media-cue-display-bg));border-radius:var(--media-cue-display-border-radius)}.vds-captions [data-part=cue-display]{padding:var(--media-cue-display-padding)}:where(.vds-captions[data-dir=rtl] [data-part=cue-display]){direction:rtl}:where(.vds-captions [data-part=cue]){display:inline-block;contain:content;font-variant:var(--media-user-font-variant);border:var(--media-cue-border, unset);border-radius:var(--media-cue-border-radius, 2px);-webkit-backdrop-filter:var(--media-cue-backdrop, blur(8px));backdrop-filter:var(--media-cue-backdrop, blur(8px));line-height:var(--cue-line-height);box-sizing:border-box;box-shadow:var(--media-cue-box-shadow, var(--cue-box-shadow));white-space:var(--cue-white-space, pre-wrap);outline:var(--cue-outline);text-shadow:var(--media-user-text-shadow, var(--cue-text-shadow))}.vds-captions [data-part=cue]{background-color:var(--cue-bg-color);color:var(--cue-color);padding:var(--cue-padding)}:where(.vds-captions [data-part=cue-display][data-vertical] [data-part=cue]){--cue-padding: var(--cue-padding-x) var(--cue-padding-y)}:where(.vds-captions [data-part=region]){--anchor-x-percent: calc(var(--region-anchor-x) / 100);--anchor-x: calc(var(--region-width) * var(--anchor-x-percent));--anchor-y-percent: calc(var(--region-anchor-y) / 100);--anchor-y: calc(var(--region-height) * var(--anchor-y-percent));--vp-anchor-x: calc(var(--region-viewport-anchor-x) * 1%);--vp-anchor-y-percent: calc(var(--region-viewport-anchor-y) / 100);--vp-anchor-y: calc(var(--overlay-height) * var(--vp-anchor-y-percent));position:absolute;display:inline-flex;flex-flow:column;justify-content:flex-start;width:var(--region-width);height:var(--region-height);min-height:0px;max-height:var(--region-height);writing-mode:horizontal-tb;top:var(--region-top, calc(var(--vp-anchor-y) - var(--anchor-y)));left:var(--region-left, calc(var(--vp-anchor-x) - var(--anchor-x)));right:var(--region-right);bottom:var(--region-bottom);overflow:hidden;overflow-wrap:break-word;box-sizing:border-box}:where(.vds-captions [data-part=region][data-scroll=up]){justify-content:end}:where(.vds-captions [data-part=region][data-active][data-scroll=up]){transition:top .433s}:where(.vds-captions [data-part=region]>[data-part=cue-display]){position:relative;width:auto;left:var(--cue-offset);height:var(--cue-height, auto);text-align:var(--cue-text-align);unicode-bidi:plaintext;margin-top:2px}:where(.vds-captions [data-part=region] [data-part=cue]){position:relative;border-radius:0}:where(.vds-chapter-title){--color: var(--media-chapter-title-color, rgba(255 255 255 / .64));display:inline-block;font-family:var(--media-font-family, sans-serif);font-size:var(--media-chapter-title-font-size, 16px);font-weight:var(--media-chapter-title-font-weight, 400);color:var(--color);flex:1 1 0%;padding-inline:6px;overflow:hidden;text-align:start;white-space:nowrap;text-overflow:ellipsis}.vds-chapter-title:before{content:var(--media-chapter-title-separator, "•");display:inline-block;margin-right:var(--media-chapter-title-separator-gap, 6px);color:var(--media-chapter-title-separator-color, var(--color))}.vds-chapter-title:empty:before{content:"";margin:0}:where(.vds-controls),:where(.vds-controls-group){position:relative;display:inline-block;width:100%;box-sizing:border-box}:where([data-view-type=audio] .vds-controls){display:inline-block;max-width:100%}:where([data-view-type=video] .vds-controls){display:flex;position:absolute;flex-direction:column;inset:0;width:100%;height:100%;z-index:10;opacity:0;visibility:hidden;pointer-events:none;padding:var(--media-controls-padding, 0px);transition:var(--media-controls-out-transition, opacity .2s ease-out)}:where([data-view-type=video] .vds-controls[data-visible]){opacity:1;visibility:visible;transition:var(--media-controls-in-transition, opacity .2s ease-in)}:where(.vds-controls-spacer){flex:1 1 0%;pointer-events:none}:where(.vds-gestures){display:contents}:where(.vds-gesture){position:absolute;display:block;contain:content;z-index:0;opacity:0;visibility:hidden;pointer-events:none!important}:where(.vds-icon svg){display:block;width:100%;height:100%;vertical-align:middle}:where(.vds-kb-action.hidden){opacity:0}:where(.vds-kb-text-wrapper){text-align:center;position:absolute;left:0;right:0;top:var(--media-kb-text-top, 10%);z-index:20;pointer-events:none}:where(.vds-kb-text){display:inline-block;font-size:var(--media-kb-text-size, 150%);font-family:var(--media-font-family, sans-serif);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);border-radius:var(--media-kb-border-radius, 2.5px);pointer-events:none}.vds-kb-text{color:var(--media-kb-text-color, var(--default-color));background-color:var(--media-kb-text-bg, var(--default-bg));padding:var(--media-kb-text-padding, 10px 20px)}.light .vds-kb-text{--default-color: #1a1a1a;--default-bg: rgb(240 240 240 / .6)}.dark .vds-kb-text{--default-color: #f5f5f5;--default-bg: rgb(10 10 10 / .6)}:where(.vds-kb-text:empty){display:none}:where(.vds-kb-bezel){--size: var(--media-kb-bezel-size, 52px);position:absolute;left:50%;top:45%;display:flex;flex-direction:column;align-items:center;justify-content:center;width:var(--size);height:var(--size);margin-left:calc(-1 * calc(var(--size) / 2));margin-right:calc(-1 * calc(var(--size) / 2));z-index:20;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background-color:var(--media-kb-bezel-bg, var(--default-bg));animation:var(--media-kb-bezel-animation, vds-bezel-fade .35s linear 1 normal forwards);border-radius:var(--media-kb-bezel-border-radius, calc(var(--size) / 2));pointer-events:none}.vds-kb-bezel:not(:has(svg)){display:none!important}.light .vds-kb-bezel{--default-bg: rgb(255 255 255 / .6)}.dark .vds-kb-bezel{--default-bg: rgb(10 10 10 / .6)}@media(prefers-reduced-motion){:where(.vds-kb-bezel){animation:none}}:where(.vds-kb-bezel:has(slot:empty)){opacity:0}:where(.vds-kb-action[data-action=seek-forward] .vds-kb-bezel){top:45%;left:unset;right:10%}:where(.vds-kb-action[data-action=seek-backward] .vds-kb-bezel){top:45%;left:10%}:where(.vds-kb-icon){--size: var(--media-kb-icon-size, 38px);width:var(--size);height:var(--size)}.vds-kb-icon{color:var(--media-kb-icon-color, var(--default-color))}.light .vds-kb-icon{--default-color: #1a1a1a}.dark .vds-kb-icon{--default-color: #f5f5f5}@keyframes vds-bezel-fade{0%{opacity:1}to{opacity:0;transform:scale(2)}}:where(.vds-menu-items){--color-inverse: var(--media-menu-color-inverse, var(--default-inverse));--color-gray-50: var(--media-menu-color-gray-50, var(--default-gray-50));--color-gray-100: var(--media-menu-color-gray-100, var(--default-gray-100));--color-gray-200: var(--media-menu-color-gray-200, var(--default-gray-200));--color-gray-300: var(--media-menu-color-gray-300, var(--default-gray-300));--color-gray-400: var(--media-menu-color-gray-400, var(--default-gray-400));--text-color: var(--media-menu-text-color, var(--default-text));--text-secondary-color: var(--media-menu-text-secondary-color, var(--default-text-secondary));--root-border: var(--media-menu-border, var(--default-root-border))}.light .vds-menu-items{--default-inverse: black;--default-gray-50: rgb(80 80 80 / .15);--default-gray-100: rgb(80 80 80 / .45);--default-gray-200: rgb(235 235 235 / .6);--default-gray-300: rgb(238 238 238);--default-gray-400: rgb(250 250 250);--default-text: #1a1a1a;--default-text-secondary: #6b6b6b;--default-root-border: 1px solid rgb(10 10 10 / .1)}.dark .vds-menu-items{--default-inverse: white;--default-gray-50: rgb(245 245 245 / .1);--default-gray-100: rgb(245 245 245 / .45);--default-gray-200: rgb(10 10 10 / .6);--default-gray-300: rgb(27 27 27);--default-gray-400: rgb(10 10 10);--default-text: #f5f5f5;--default-text-secondary: #8a8a8a;--default-root-border: 1px solid rgb(255 255 255 / .1)}:where(.vds-menu-items){--font-family: var(--media-font-family, sans-serif);--font-size: var(--media-menu-font-size, 14px);--font-weight: var(--media-menu-font-weight, 500);--root-bg: var(--media-menu-bg, var(--color-gray-400));--root-padding: var(--media-menu-padding, 12px);--root-border-radius: var(--media-menu-border-radius, 4px);--divider: var(--media-menu-divider, 1px solid var(--color-gray-50));--section-bg: var(--media-menu-section-bg, var(--color-gray-300));--section-border: var(--media-menu-section-border);--section-divider: var(--media-menu-section-divider, var(--divider));--top-bar-bg: var(--media-menu-top-bar-bg, var(--color-gray-200));--top-bar-divider: var(--media-menu-divider, transparent);--text-hint-color: var(--media-menu-hint-color, var(--text-secondary-color));--chapter-divider: var(--media-chapters-divider, var(--divider));--chapter-active-bg: var(--media-chapters-item-active-bg, var(--color-gray-50));--chapter-active-border-left: var(--media-chapters-item-active-border-left);--chapter-progress-bg: var(--media-chapters-progress-bg, var(--color-inverse));--chapter-time-font-size: var(--media-chapters-time-font-size, 12px);--chapter-time-font-weight: var(--media-chapters-time-font-weight, 500);--chapter-time-gap: var(--media-chapters-time-gap, 6px);--chapter-duration-bg: var(--media-chapters-duration-bg);--item-border: var(--media-menu-item-border, 0);--item-bg: var(--media-menu-item-bg, transparent);--item-hover-bg: var(--media-menu-item-hover-bg, var(--color-gray-50));--item-icon-size: var(--media-menu-item-icon-size, 18px);--item-padding: var(--media-menu-item-padding, 10px);--item-min-height: var(--media-menu-item-height, 40px);--item-border-radius: var(--media-menu-item-border-radius, 2px);--scrollbar-track-bg: var(--media-menu-scrollbar-track-bg, transparent);--scrollbar-thumb-bg: var(--media-menu-scrollbar-thumb-bg, var(--color-gray-50));--webkit-scrollbar-bg: var(--color-gray-400);--webkit-scrollbar-track-bg: var(--media-menu-scrollbar-track-bg, var(--color-gray-50));--checkbox-bg: var(--media-menu-checkbox-bg, var(--color-gray-100));--checkbox-active-bg: var(--media-menu-checkbox-bg-active, #1ba13f);--checkbox-handle-bg: var(--media-menu-checkbox-handle-bg, #f5f5f5);--checkbox-handle-border: var(--media-menu-checkbox-handle-border);--radio-icon-color: var(--media-menu-radio-icon-color, var(--text-color))}:where(.vds-menu[data-root] media-menu[data-root]){display:contents}:where(.vds-menu){font-family:var(--font-family);font-size:var(--font-size);font-weight:var(--font-weight)}:where(.vds-menu[data-disabled][data-root]){display:none}:where(.vds-menu[data-submenu]){display:inline-block}:where(.vds-menu-items:focus){outline:none}:where(.vds-menu-item:focus,.vds-radio:focus){outline:none}:where(.vds-menu-item:focus-visible,.vds-menu-item[data-focus],.vds-radio:focus-visible,.vds-radio[data-focus]){outline:none;box-shadow:var(--media-focus-ring)}:where(.vds-menu[data-open] .vds-tooltip-content){display:none!important}.vds-menu-items [data-hidden]{display:none!important}@media(prefers-reduced-motion:no-preference){:where(.vds-menu-items){scroll-behavior:smooth}}:where(.vds-menu-items){box-sizing:border-box;min-width:var(--media-menu-min-width, 280px);scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb-bg) var(--scrollbar-track-bg);transform:translateZ(0)}:where(.vds-menu-items)::-webkit-scrollbar{background-color:var(--webkit-scrollbar-bg);border-radius:var(--root-border-radius);height:6px;width:5px}:where(.vds-menu-items)::-webkit-scrollbar-track{background-color:var(--webkit-scrollbar-track-bg);border-radius:4px}:where(.vds-menu-items)::-webkit-scrollbar-thumb{background-color:var(--scrollbar-thumb-bg);border-radius:4px}:where(.vds-menu-items)::-webkit-scrollbar-corner{background-color:var(--scrollbar-thumb-bg)}:where(.vds-menu-button){outline:none;box-sizing:border-box}:where(.vds-menu-button .vds-rotate-icon){transition:transform .2s ease-out}:where(.vds-menu-button[aria-expanded=true] .vds-rotate-icon){transform:rotate(var(--media-menu-icon-rotate-deg, 90deg));transition:transform .2s ease-in}:where(.vds-menu-button){display:inline-flex;align-items:center;justify-content:center}@media(prefers-reduced-motion){:where(.vds-menu-button .vds-rotate-icon){transition:unset}}:where(.vds-menu-items){display:flex;align-items:center;flex-direction:column;font-family:var(--font-family);font-size:var(--font-size);font-weight:var(--font-weight);transition:height .35s ease}@media(prefers-reduced-motion){:where(.vds-menu-items){transition:unset}}:where(.vds-menu-items[data-root]){background-color:var(--root-bg);border-radius:var(--root-border-radius);box-shadow:var(--media-menu-box-shadow);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);height:var(--menu-height, auto);will-change:width,height;overflow-y:auto;overscroll-behavior:contain;opacity:0;z-index:9999999;box-sizing:border-box;max-height:var(--media-menu-max-height, 250px);filter:var( --media-menu-filter, drop-shadow(0 4px 3px rgb(0 0 0 / .07)) drop-shadow(0 2px 2px rgb(0 0 0 / .06)) )}.vds-menu-items[data-root]{border:var(--root-border);padding:var(--root-padding)}:where([data-view-type=video]) :where(.vds-menu-items[data-root]){max-height:var(--media-menu-video-max-height, calc(var(--player-height) * .7))}:where(.vds-menu-items[data-transition=height]){--scrollbar-thumb-bg: rgba(0, 0, 0, 0);pointer-events:none;overflow:hidden}.vds-menu-button[aria-disabled=true],.vds-menu-item[aria-disabled=true],.vds-menu-item[data-disabled]{display:none}:where(.vds-menu-items[data-root]){--enter-transform: translateY(0px);--exit-transform: translateY(12px)}:where(.vds-menu-items[data-root]:not([data-placement])){--enter-transform: translateY(-24px)}:where(.vds-menu-items[data-root][aria-hidden=true]){animation:var(--media-menu-exit-animation, vds-menu-exit .2s ease-out)}:where(.vds-menu-items[data-root][aria-hidden=false]){animation:var(--media-menu-enter-animation, vds-menu-enter .3s ease-out);animation-fill-mode:forwards}:where(.vds-menu-items[data-placement~=bottom]){--enter-transform: translateY(0);--exit-transform: translateY(-12px)}@keyframes vds-menu-enter{0%{opacity:0;transform:var(--exit-transform)}to{opacity:1;transform:var(--enter-transform)}}@keyframes vds-menu-exit{0%{opacity:1;transform:var(--enter-transform)}to{opacity:0;transform:var(--exit-transform)}}@media(prefers-reduced-motion){:where(.vds-menu-items){animation:none;opacity:1}}:where(media-menu-portal){display:contents}:where(.vds-menu-items[data-root]:not([data-placement])){position:fixed;left:16px;right:16px;top:unset;bottom:0;max-height:var(--media-sm-menu-portrait-max-height, 40vh);max-height:var(--media-sm-menu-portrait-max-height, 40dvh)}:where(.vds-menu-items[data-root]:not([data-placement])){max-width:480px;margin:0 auto}@media(orientation:landscape)and (pointer:coarse){:where(.vds-menu-items[data-root]:not([data-placement])){max-height:var(--media-sm-menu-landscape-max-height, min(70vh, 400px));max-height:var(--media-sm-menu-landscape-max-height, min(70dvh, 400px))}}:where(.vds-menu[data-submenu] .vds-menu-button){display:flex;align-items:center;justify-content:flex-start}:where(.vds-menu-items[data-submenu]){width:100%}:where(.vds-menu[aria-hidden=true]),:where(.vds-menu-items[data-submenu][aria-hidden=true]){display:none}:where(.vds-menu-item,.vds-radio){position:relative;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;display:flex;align-items:center;justify-content:left;width:100%;appearance:none;border:0;border-radius:var(--item-border-radius);box-sizing:border-box;min-height:var(--item-min-height);font-size:var(--font-size);outline:none}.vds-menu-item,.vds-radio{color:var(--text-color);background-color:var(--item-bg);padding:var(--item-padding)}.vds-menu-item:focus-visible,.vds-menu-item[data-focus],.vds-radio:focus-visible,.vds-radio[data-focus]{cursor:pointer;background-color:var(--item-hover-bg)}@media(hover:hover)and (pointer:fine){.vds-menu-item[role]:hover,.vds-radio:hover{cursor:pointer;background-color:var(--item-hover-bg)}}:where(.vds-menu-items[data-submenu]){align-items:flex-start;justify-content:center;flex-direction:column}:where(.vds-menu-item[aria-expanded=true]){font-weight:700;border-radius:0;border-top-left-radius:var(--item-border-radius);border-top-right-radius:var(--item-border-radius)}.vds-menu-item[aria-expanded=true]{border-bottom:var(--top-bar-divider)}:where(.vds-menu-item[aria-expanded=true]){position:sticky;top:calc(-1 * var(--root-padding));left:0;width:100%;z-index:10;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);margin-bottom:4px}.vds-menu-item[aria-expanded=true]{background-color:var(--top-bar-bg)}:where(.vds-menu-item-label){flex:1 0 0%;text-align:start}:where(.vds-menu-item .vds-icon,.vds-radio .vds-icon){--size: var(--item-icon-size);width:var(--size);height:var(--size);margin-right:var(--media-menu-item-icon-spacing, 6px)}:where(.vds-menu-open-icon,.vds-menu-close-icon){--size: var(--media-menu-arrow-icon-size, 18px);width:var(--size);height:var(--size)}:where(.vds-menu-item-hint,.vds-menu-open-icon,.vds-radio-hint){color:var(--text-hint-color);font-size:var(--media-menu-hint-font-size, 13px);font-weight:var(--media-menu-hint-font-weight, 400)}:where(.vds-menu-items .vds-menu-open-icon){margin-right:0}:where(.vds-menu-items) :where(.vds-menu-item-hint,.vds-menu-open-icon){margin-left:auto}:where(.vds-menu-items) :where(.vds-menu-item-hint+.vds-menu-open-icon),:where(.vds-menu-item-hint+media-icon .vds-menu-open-icon),:where(.vds-menu-item-hint+slot>.vds-menu-open-icon){margin-left:2px}:where(.vds-menu-item[aria-hidden=true]),:where(.vds-menu-item[aria-expanded=true] .vds-menu-open-icon){display:none!important}:where(.vds-menu-items) :where(.vds-menu-item[aria-disabled=true],.vds-menu-item[data-disabled]) :where(.vds-menu-open-icon){opacity:0}:where(.vds-menu-close-icon),:where(.vds-menu-item[aria-expanded=true]>.vds-icon){display:none!important}:where(.vds-menu-item[aria-expanded=true] .vds-menu-close-icon){display:inline!important;margin-left:calc(-1 * var(--item-padding) / 2)}:where(.vds-menu-checkbox){--checkbox-width: var(--media-menu-checkbox-width, 40px);--checkbox-height: var(--media-menu-checkbox-height, 18px);--checkbox-top: calc((var(--checkbox-height) - var(--checkbox-diameter)) / 2);--checkbox-diameter: var( --media-menu-checkbox-handle-diameter, calc(var(--checkbox-height) - 2px) );--checkbox-gap: var(--media-menu-checkbox-gap, 2.5px);position:relative;display:inline-block;width:var(--checkbox-width);height:var(--checkbox-height);border-radius:calc(var(--checkbox-height) / 2);transition:.3s all ease-in-out;box-sizing:border-box;cursor:pointer;pointer-events:auto}.vds-menu-checkbox{background-color:var(--checkbox-bg)}:where(.vds-menu-checkbox:focus-visible){outline:none;box-shadow:var(--media-focus-ring)}.vds-menu-checkbox[aria-checked=true]{background-color:var(--checkbox-active-bg)}:where(.vds-menu-checkbox):after{content:"";display:inline-block;width:var(--checkbox-diameter);height:var(--checkbox-diameter);border-radius:calc(var(--checkbox-diameter) / 2);position:absolute;top:var(--checkbox-top);transform:translate(var(--checkbox-gap));transition:.3s all ease-in-out;border:var(--checkbox-handle-border);box-sizing:border-box}.vds-menu-checkbox:after{background-color:var(--checkbox-handle-bg)}:where(.vds-menu-checkbox[aria-checked=true]):after{transform:translate(calc(var(--checkbox-width) - var(--checkbox-diameter) - var(--checkbox-gap)))}@media(prefers-reduced-motion:no-preference){:where(.vds-menu-checkbox[data-active]):after{width:calc(var(--checkbox-width) - calc(var(--checkbox-gap) * 2))}}:where(.vds-menu-checkbox[aria-checked=true][data-active]):after{transform:translate(var(--checkbox-gap))}:where(.vds-menu-items .vds-slider){--media-slider-track-bg: var(--media-menu-slider-track-bg, var(--color-gray-50));--media-slider-track-fill-bg: var(--media-menu-slider-track-fill-bg, var(--color-inverse));--media-slider-height: var(--media-menu-slider-height, 32px);--track-focus-height: var(--track-height) !important}:where(.vds-menu-items .vds-slider-thumb){opacity:1!important}:where(.vds-menu-slider-item.group){flex-direction:column}:where(.vds-menu-slider-title){margin-top:4px}:where(.vds-menu-slider-body){width:100%;display:flex;align-items:center;margin-top:6px}:where(.vds-menu-slider-item .vds-icon){margin:0;color:var(--text-hint-color)}:where(.vds-menu-slider-item[data-min] .vds-icon.down,.vds-menu-slider-item[data-max] .vds-icon.up){color:var(--text-color);animation:.6s ease-in-out vds-slider-icon;transition:all 1.2s ease}@keyframes vds-slider-icon{0%{transform:scale(1)}50%{transform:scale(1.25)}to{transform:scale(1)}}:where(.vds-menu-items .vds-slider-track-fill){transition:opacity .3s ease}:where(.vds-menu-items .vds-slider[data-active] .vds-slider-track-fill){opacity:0}:where(.vds-radio-group){box-sizing:border-box;width:100%;display:flex;flex-direction:column}.vds-radio{cursor:pointer;contain:content;padding-left:calc(var(--item-icon-size) + var(--item-padding))}.vds-radio[aria-checked=true]{padding-left:0}.vds-radio .vds-icon{display:none;color:var(--radio-icon-color)}.vds-radio[aria-checked=true] .vds-icon{display:inline-block;margin-left:6px}:where(.vds-radio-hint){margin-left:auto}.vds-color-picker{width:32px;height:32px;border:0;background-color:transparent;outline:none}.vds-color-picker::-webkit-color-swatch{border-radius:2px}.vds-color-picker::-moz-color-swatch{border-radius:2px}.vds-color-picker:focus-visible::-webkit-color-swatch{box-shadow:var(--media-focus-ring)}.vds-color-picker:focus-visible::-moz-color-swatch{box-shadow:var(--media-focus-ring)}:where(.vds-menu-section){width:100%}:where(.vds-menu-item+.vds-menu-section){margin-top:8px}:where(.vds-menu-section+.vds-menu-section){margin-top:24px}:where(.vds-menu-section:first-child){margin-top:8px}:where(.vds-menu-section:last-child){margin-bottom:8px}:where(.vds-menu-section-title),:where(.vds-menu-slider-title){width:100%;display:flex;align-items:center;justify-content:space-between;color:var(--text-secondary-color);font-size:var(--media-menu-section-header-font-size, 12px);font-weight:var(--media-menu-section-header-font-weight, 500);padding-inline:2px}:where(.vds-menu-section-body){width:100%}:where(.vds-menu-section-title+.vds-menu-section-body){margin-top:var(--media-menu-section-gap, 8px)}.vds-menu-section-body{background-color:var(--section-bg);border:var(--section-border);border-radius:var(--media-menu-section-border-radius, 2px)}:where(.vds-menu-section:not([data-open]) .vds-menu-item:not(:last-child)){border-bottom:var(--section-divider)}:where(.vds-menu-section-body .vds-menu:last-child>.vds-menu-item){border-bottom:unset}.vds-menu-section[data-open],.vds-menu-section[data-open]>.vds-menu-section-body{display:contents!important;background-color:transparent!important}.vds-menu-section[data-open]>.vds-menu-section-title,.vds-menu-section[data-open]>.vds-menu-section-body>:not([data-open]){display:none}:where(.vds-chapters-menu-items){min-width:var(--media-chapters-min-width, var(--media-menu-min-width, 220px))}.vds-chapters-menu-items{padding:var(--media-chapters-padding, 0)}:where(.vds-menu-items:has(.vds-chapters-radio-group[data-thumbnails])){min-width:var(--media-chapters-with-thumbnails-min-width, 300px)}:where(.vds-chapter-radio){border-radius:0}.vds-chapter-radio{border-bottom:var(--chapter-divider);padding:var(--item-padding)}.vds-chapter-radio[aria-checked=true]{padding-left:var(--item-padding)}:where(.vds-chapter-radio:last-child){border-bottom:0}.vds-chapter-radio[aria-checked=true]{background-color:var(--chapter-active-bg);border-left:var(--chapter-active-border-left)}:where(.vds-chapter-radio[aria-checked=true]):after{content:" ";width:var(--progress);height:var(--media-chapters-progress-height, 4px);position:absolute;bottom:0;left:0}.vds-chapter-radio[aria-checked=true]:after{border-radius:var(--media-chapters-progress-border-radius, 0);background-color:var(--chapter-progress-bg)}.vds-chapters-radio-group :where(.vds-thumbnail){margin-right:var(--media-chapters-thumbnail-gap, 12px);flex-shrink:0;min-width:var(--media-chapters-thumbnail-min-width, 100px);min-height:var(--media-chapters-thumbnail-min-height, 56px);max-width:var(--media-chapters-thumbnail-max-width, 120px);max-height:var(--media-chapters-thumbnail-max-height, 68px)}.vds-chapters-radio-group .vds-thumbnail{border:var(--media-chapters-thumbnail-border, 0)}:where(.vds-chapters-radio-group .vds-chapter-radio-label){color:var(--text-secondary-color);font-size:var(--font-size);font-weight:var(--font-weight);white-space:nowrap}:where(.vds-chapter-radio[aria-checked=true] .vds-chapter-radio-label){color:var(--text-color)}:where(.vds-chapters-radio-group .vds-chapter-radio-start-time){display:inline-block;letter-spacing:var(--media-chapters-start-time-letter-spacing, .4px);border-radius:var(--media-chapters-start-time-border-radius, 2px);font-size:var(--chapter-time-font-size);font-weight:var(--chapter-time-font-weight);margin-top:var(--chapter-time-gap)}.vds-chapters-radio-group .vds-chapter-radio-start-time{color:var(--text-secondary-color);background-color:var(--section-bg);padding:var(--media-chapters-start-time-padding, 1px 4px)}:where(.vds-chapters-radio-group .vds-chapter-radio-duration){color:var(--text-hint-color);font-size:var(--chapter-time-font-size);font-weight:var(--chapter-time-font-weight);margin-top:var(--chapter-time-gap)}.vds-chapters-radio-group .vds-chapter-radio-duration{background-color:var(--chapter-duration-bg);border-radius:var(--media-chapters-duration-border-radius, 2px)}.vds-chapters-radio-group:not([data-thumbnails]) :where(.vds-thumbnail,media-thumbnail){display:none}:where(.vds-chapter-radio-content){display:flex;align-items:flex-start;flex-direction:column}:where(.vds-chapters-radio-group:not([data-thumbnails]) .vds-chapter-radio-content){width:100%;flex-direction:row;display:flex;flex-wrap:wrap;align-items:center}:where(.vds-chapters-radio-group:not([data-thumbnails]) .vds-chapter-radio-start-time){margin-top:0;margin-left:auto}:where(.vds-chapters-radio-group:not([data-thumbnails]) .vds-chapter-radio-duration){margin-top:4px;flex-basis:100%}.vds-menu-items[data-keyboard] .vds-chapters-radio-group:focus-within{padding:var(--media-chapters-focus-padding, 4px)}:where(.vds-poster){display:block;contain:content;position:absolute;top:50%;transform:translateY(-50%);left:0;opacity:0;width:100%;height:100%;z-index:1;border:0;pointer-events:none;box-sizing:border-box;transition:opacity .2s ease-out;background-color:var(--media-poster-bg, black)}:where(.vds-poster img){object-fit:inherit;object-position:inherit;pointer-events:none;user-select:none;-webkit-user-select:none;box-sizing:border-box}.vds-poster :where(img){border:0;width:100%;height:100%;object-fit:contain}:where(.vds-poster[data-hidden]){display:none}:where(.vds-poster[data-visible]){opacity:1}.vds-poster:not(:defined),.vds-poster img:not([src]){display:none}:where(.vds-slider){--width: var(--media-slider-width, 100%);--height: var(--media-slider-height, 48px);--thumb-size: var(--media-slider-thumb-size, 15px);--thumb-focus-size: var(--media-slider-focused-thumb-size, calc(var(--thumb-size) * 1.1));--track-width: var(--media-slider-track-width, 100%);--track-height: var(--media-slider-track-height, 5px);--track-focus-width: var(--media-slider-focused-track-width, var(--track-width));--track-focus-height: var(--media-slider-focused-track-height, calc(var(--track-height) * 1.25));display:inline-flex;align-items:center;width:var(--width);height:var(--height);margin:0 calc(var(--thumb-size) / 2);position:relative;contain:layout style;outline:none;pointer-events:auto;cursor:pointer;user-select:none;touch-action:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}:where(.vds-slider[aria-hidden=true]){display:none!important}:where(.vds-slider[aria-disabled=true]){cursor:unset}:where(.vds-slider:focus){outline:none}:where(.vds-slider:not([data-chapters])[data-focus],.vds-slider:not([data-chapters]):focus-visible) :where(.vds-slider-track){box-shadow:var(--media-focus-ring)}:where(.vds-slider .vds-slider-track){z-index:0;position:absolute;width:var(--track-width);height:var(--track-height);top:50%;left:0;border-radius:var(--media-slider-track-border-radius, 2px);transform:translateY(-50%) translateZ(0);background-color:var(--media-slider-track-bg, rgb(255 255 255 / .3));contain:strict}:where(.vds-slider[data-focus],.vds-slider:focus-visible) :where(.vds-slider-track){outline-offset:var(--thumb-size)}:where(.vds-slider:not([data-chapters])[data-active] .vds-slider-track){width:var(--track-focus-width);height:var(--track-focus-height)}:where(.vds-slider .vds-slider-track-fill){z-index:2;background-color:var(--media-slider-track-fill-bg, var(--media-brand));width:var(--slider-fill, 0%);will-change:width}:where(.vds-slider .vds-slider-thumb){position:absolute;top:50%;left:var(--slider-fill);opacity:0;contain:layout size style;width:var(--thumb-size);height:var(--thumb-size);border:var(--media-slider-thumb-border, 1px solid #cacaca);border-radius:var(--media-slider-thumb-border-radius, 9999px);background-color:var(--media-slider-thumb-bg, #fff);transform:translate(-50%,-50%) translateZ(0);transition:opacity .15s ease-in;pointer-events:none;will-change:left;z-index:2}:where(.vds-slider[data-dragging],.vds-slider[data-focus],.vds-slider:focus-visible) :where(.vds-slider-thumb){box-shadow:var(--media-slider-focused-thumb-shadow, 0 0 0 4px hsla(0, 0%, 100%, .4))}:where(.vds-slider[data-active] .vds-slider-thumb){opacity:1;transition:var(--media-slider-thumb-transition, opacity .2s ease-in, box-shadow .2s ease)}:where(.vds-slider[data-dragging] .vds-slider-thumb){width:var(--thumb-focus-size);height:var(--thumb-focus-size)}:where(.vds-slider-value){display:inline-block;contain:content;font-size:14px;font-family:var(--media-font-family, sans-serif)}:where(.vds-slider-thumbnail){display:block;contain:content;box-sizing:border-box}:where(.vds-slider-video){background-color:#000;box-sizing:border-box;contain:content;display:inline-block;border:var(--media-thumbnail-border, 1px solid white)}:where(.vds-slider-video video){display:block;height:auto;width:156px}:where(.vds-slider-video[data-loading]){opacity:0}:where(.vds-slider-video[data-hidden],.vds-slider-video[data-hidden] video){display:none;width:0px}:where(.vds-slider .vds-slider-preview){display:flex;flex-direction:column;align-items:center;opacity:0;background-color:var(--media-slider-preview-bg);border-radius:var(--media-slider-preview-border-radius, 2px);pointer-events:none;transition:opacity .2s ease-out;will-change:left,opacity;contain:layout paint style}:where(.vds-slider-preview[data-visible]){opacity:1;transition:opacity .2s ease-in}.vds-slider-value{background-color:var(--media-slider-value-bg, black);border-radius:var(--media-slider-value-border-radius, 2px);border:var(--media-slider-value-border);color:var(--media-slider-value-color, white);padding:var(--media-slider-value-padding, 1px 10px)}:where(.vds-slider-video:not([data-hidden])+.vds-slider-chapter-title,.vds-slider-thumbnail:not([data-hidden])+.vds-slider-chapter-title){margin-top:var(--media-slider-chapter-title-gap, 6px)}:where(.vds-slider-video:not([data-hidden])+.vds-slider-value,.vds-slider-thumbnail:not([data-hidden])+.vds-slider-value,.vds-slider-chapter-title+.vds-slider-value){margin-top:var(--media-slider-value-gap, 2px)}:where(.vds-slider[aria-orientation=vertical]){--width: var(--media-slider-width, 48px);--height: var(--media-slider-height, 100%);--track-width: var(--media-slider-track-width, 4px);--track-height: var(--media-slider-track-height, 100%);--track-focus-width: var(--media-slider-focused-track-width, calc(var(--track-width) * 1.25));--track-focus-height: var(--media-slider-focused-track-height, var(--track-height));margin:calc(var(--thumb-size) / 2) 0}:where(.vds-slider[aria-orientation=vertical] .vds-slider-track){top:unset;bottom:0;left:50%;transform:translate(-50%) translateZ(0)}:where(.vds-slider[aria-orientation=vertical] .vds-slider-track-fill){width:var(--track-width);height:var(--slider-fill);will-change:height;transform:translate(-50%) translateZ(0)}:where(.vds-slider[aria-orientation=vertical] .vds-slider-progress){top:unset;bottom:0;width:var(--track-width);height:var(--slider-progress, 0%);will-change:height}:where(.vds-slider[aria-orientation=vertical] .vds-slider-thumb){top:unset;bottom:var(--slider-fill);left:50%;will-change:bottom;transform:translate(-50%,50%) translateZ(0)}:where(.vds-slider[aria-orientation=vertical] .vds-slider-preview){will-change:bottom,opacity}:where([data-live] .vds-time-slider .vds-slider-track-fill){background-color:var(--media-slider-track-fill-live-bg, #dc2626)}:where(.vds-time-slider .vds-slider-progress){z-index:1;left:0;width:var(--slider-progress, 0%);will-change:width;background-color:var(--media-slider-track-progress-bg, rgb(255 255 255 / .5))}:where([data-media-player]:not([data-can-play]) .vds-time-slider .vds-slider-value){display:none}:where(.vds-slider-steps){display:flex;align-items:center;justify-content:space-between;width:100%;height:100%;position:absolute;top:0;left:0}:where(.vds-slider-step){width:var(--media-slider-step-width, 2.5px);height:calc(var(--track-height) + 1px);background-color:var(--media-slider-step-color, rgb(124, 124, 124));opacity:0;transition:opacity .3s ease}:where(.vds-slider[data-active] .vds-slider-step){opacity:1}:where(.vds-time-slider .vds-slider-chapters){position:relative;display:flex;align-items:center;width:100%;height:100%;contain:layout style;border-radius:var(--media-slider-track-border-radius, 1px)}:where(.vds-slider[data-focus],.vds-slider:focus-visible) :where(.vds-slider-chapters){box-shadow:var(--media-focus-ring);height:var(--track-height)}:where(.vds-time-slider .vds-slider-chapter){margin-right:2px}:where(.vds-time-slider .vds-slider-chapter:last-child){margin-right:0}:where(.vds-time-slider .vds-slider-chapter){position:relative;display:flex;align-items:center;width:100%;height:100%;will-change:height,transform;contain:layout style;border-radius:var(--media-slider-track-border-radius, 1px)}:where(.vds-time-slider .vds-slider-chapter .vds-slider-track-fill){width:var(--chapter-fill, 0%);will-change:width}:where(.vds-time-slider .vds-slider-chapter .vds-slider-progress){width:var(--chapter-progress, 0%);will-change:width}@media(hover:hover)and (pointer:fine){:where(.vds-time-slider:hover .vds-slider-chapters){contain:strict}:where(.vds-time-slider .vds-slider-chapter:hover:not(:only-of-type)){transform:var(--media-slider-chapter-hover-transform, scaleY(2));transition:var( --media-slider-chapter-hover-transition, transform .1s cubic-bezier(.4, 0, 1, 1) )}}:where(.vds-time-slider .vds-slider-chapter-title){font-family:var(--media-font-family, sans-serif);font-size:var(--media-slider-chapter-title-font-size, 14px);color:var(--media-slider-chapter-title-color, #f5f5f5);background-color:var(--media-slider-chapter-title-bg)}:where(.vds-thumbnail){--min-width: var(--media-thumbnail-min-width, 140px);--max-width: var(--media-thumbnail-max-width, 180px);--aspect-ratio: var(--media-thumbnail-aspect-ratio, var(--thumbnail-aspect-ratio));display:block;width:var(--thumbnail-width);height:var(--thumbnail-height);background-color:var(--media-thumbnail-bg, black);contain:strict;overflow:hidden;box-sizing:border-box;min-width:var(--min-width);min-height:var(--media-thumbnail-min-height, calc(var(--min-width) / var(--aspect-ratio)));max-width:var(--max-width);max-height:var(--media-thumbnail-max-height, calc(var(--max-width) / var(--aspect-ratio)))}.vds-thumbnail{border:var(--media-thumbnail-border, 1px solid white)}:where(.vds-thumbnail img){min-width:unset!important;max-width:unset!important;will-change:width,height,transform}:where(.vds-thumbnail[data-loading] img){opacity:0}:where(.vds-thumbnail[aria-hidden=true]){display:none!important}:where(.vds-time-group){display:flex;align-items:center}.vds-time-divider{margin:0 var(--media-time-divider-gap, 2.5px);color:var(--media-time-divider-color, #e0e0e0)}:where(.vds-time){display:inline-block;contain:content;font-size:var(--media-time-font-size, 15px);font-weight:var(--media-time-font-weight, 400);font-family:var(--media-font-family, sans-serif);border-radius:var(--media-time-border-radius, 2px);letter-spacing:var(--media-time-letter-spacing, .025em)}.vds-time{outline:0;color:var(--media-time-color, var(--default-color));background-color:var(--media-time-bg);border:var(--media-time-border);padding:var(--media-time-padding, 2px)}:where(.vds-time:focus-visible){box-shadow:var(--media-focus-ring)}.light .vds-time{--default-color: rgb(10 10 10)}.dark .vds-time{--default-color: #f5f5f5}:where(.vds-tooltip,media-tooltip){display:contents}:where(.vds-tooltip-content){display:inline-block;box-sizing:border-box;font-family:var(--media-font-family, sans-serif);font-size:var(--media-tooltip-font-size, 13px);font-weight:var(--media-tooltip-font-weight, 500);opacity:0;pointer-events:none;white-space:nowrap;z-index:10;will-change:transform,opacity}.vds-tooltip-content{border-radius:var(--media-tooltip-border-radius, 2px);background-color:var(--media-tooltip-bg-color, var(--default-bg));border:var(--media-tooltip-border, var(--default-border));color:var(--media-tooltip-color, var(--default-color));padding:var(--media-tooltip-padding, 2px 8px)}.light .vds-tooltip-content{--default-color: #1a1a1a;--default-bg: white;--default-border: 1px solid rgb(0 0 0 / .2)}.dark .vds-tooltip-content{--default-color: #f5f5f5;--default-bg: black;--default-border: 1px solid rgb(255 255 255 / .1)}:where(.vds-menu .vds-menu-button[role=button][data-pressed] .vds-tooltip-content){opacity:0;display:none}:where(.vds-tooltip-content){--enter-transform: translateY(0px) scale(1);--exit-transform: translateY(12px) scale(.8)}:where(.vds-tooltip-content:not([data-visible])){animation:var(--media-tooltip-exit-animation, vds-tooltip-exit .2s ease-out)}:where(.vds-tooltip-content[data-visible]){animation:var(--media-tooltip-enter-animation, vds-tooltip-enter .2s ease-in);animation-fill-mode:forwards}:where(.vds-tooltip-content[data-placement~=bottom]){--enter-transform: translateY(0) scale(1);--exit-transform: translateY(-12px) scale(.8)}:where(.vds-tooltip-content[data-placement~=left]){--enter-transform: translateX(0) scale(1);--exit-transform: translateX(12px) scale(.8)}:where(.vds-tooltip-content[data-placement~=right]){--enter-transform: translateX(0) scale(1);--exit-transform: translateX(-12px) scale(.8)}@keyframes vds-tooltip-enter{0%{opacity:0;transform:var(--exit-transform)}to{opacity:1;transform:var(--enter-transform)}}@keyframes vds-tooltip-exit{0%{opacity:1;transform:var(--enter-transform)}to{opacity:0;transform:var(--exit-transform)}}@media(prefers-reduced-motion){:where(.vds-tooltip-content){animation:none}:where(.vds-tooltip-content[data-visible]){opacity:1}}[data-media-player]:not([data-paused]) .vds-play-tooltip-text,[data-media-player][data-paused] .vds-pause-tooltip-text,[data-media-player][data-pip] .vds-pip-enter-tooltip-text,[data-media-player]:not([data-pip]) .vds-pip-exit-tooltip-text,[data-media-player][data-fullscreen] .vds-fs-enter-tooltip-text,[data-media-player]:not([data-fullscreen]) .vds-fs-exit-tooltip-text,[data-media-player]:not([data-captions]) .vds-cc-on-tooltip-text,[data-media-player][data-captions] .vds-cc-off-tooltip-text,[data-media-player]:not([data-muted]) .vds-mute-tooltip-text,[data-media-player][data-muted] .vds-unmute-tooltip-text{display:none}[data-media-player] .vds-video-layout:not([data-match]){display:none!important}[data-media-player][data-layout=video]{background-color:var(--video-bg, black)}[data-media-player][data-layout=video]:not([data-fullscreen]){border-radius:var(--video-border-radius, 6px);border:var(--video-border, 1px solid rgb(255 255 255 / .1))}:where(.vds-video-layout){--media-brand: var(--video-brand, #f5f5f5);--media-font-family: var(--video-font-family, sans-serif);--media-controls-color: var(--video-controls-color, #f5f5f5);--media-tooltip-y-offset: 6px;--media-menu-y-offset: 6px;--media-focus-ring-color: var(--video-focus-ring-color, rgb(78 156 246));--media-focus-ring: var(--video-focus-ring, 0 0 0 3px var(--media-focus-ring-color));color:var(--video-controls-color, #f5f5f5);display:contents}:where([data-media-player][data-focus]:not([data-playing]) .vds-video-layout .vds-controls){border-radius:var(--video-border-radius, 6px);box-shadow:var(--media-focus-ring)}:where(.vds-video-layout .vds-controls[data-visible]){border-radius:var(--video-border-radius, 6px);background-image:linear-gradient(to top,rgb(0 0 0 / .6),10%,transparent,95%,rgb(0 0 0 / .3))}.vds-video-layout .vds-controls-group{align-items:center;display:flex;pointer-events:auto;z-index:0;padding:4px 6px}.vds-video-layout .vds-controls-group:first-child{z-index:50}.vds-video-layout .vds-controls-group:nth-last-child(2){padding:0 12px;z-index:11;margin-bottom:-16px}.vds-video-layout:not([data-sm]) .vds-controls-group:last-child{--media-menu-y-offset: 26px;--media-tooltip-y-offset: 26px;--media-slider-preview-offset: 26px;z-index:10}:where(.vds-video-layout .vds-button){margin-right:2.5px}:where(.vds-video-layout[data-sm] .vds-chapter-title){font-size:var(--video-sm-chapter-title-font-size, 15px)}:where([data-fullscreen] .vds-video-layout .vds-chapter-title){font-size:var(--video-fullscreen-chapter-title-font-size, 16px)}:where(.vds-video-layout:not([data-sm]) .vds-mute-button){margin-left:-2.5px;margin-right:-5px}:where(.vds-video-layout[data-sm]){--media-button-size: var(--video-sm-button-size, 36px)}:where(.vds-video-layout .vds-time-slider){--media-slider-height: 45px;flex-grow:0}:where(.vds-video-layout .vds-slider-thumbnail){--media-thumbnail-border: var(--video-slider-thumbnail-border, 1px solid #f5f5f5);border-radius:var(--video-slider-thumbnail-border-radius, 2px)}.vds-video-layout .vds-time-slider .vds-slider-value{background-color:var(--video-time-bg, unset);text-shadow:-1px -1px 0 #333333,1px -1px 0 #333333,-1px 1px 0 #333333,1px 1px 0 #333333}:where(.vds-video-layout[data-sm] .vds-time){text-shadow:unset}:where(.vds-video-layout[data-lg] .vds-volume){--gap: var(--video-volume-gap, 10px);display:contents}:where(.vds-video-layout[data-lg] .vds-volume-popup){display:contents}:where(.vds-video-layout[data-lg] .vds-volume-slider){margin:0;max-width:0;transition:all .15s ease}:where(.vds-video-layout[data-lg] .vds-volume[data-active] .vds-volume-slider),:where(.vds-video-layout[data-lg] .vds-volume:has([data-active]) .vds-volume-slider){margin-left:var(--gap);opacity:1;visibility:visible;max-width:var(--video-volume-slider-max-width, 72px)}.vds-video-layout[data-lg] .vds-volume-slider:after{content:"";position:fixed;top:0;left:calc(-1 * var(--gap));width:var(--gap);height:100%;z-index:1;pointer-events:auto}:where(.vds-video-layout[data-sm] .vds-volume){--media-slider-height: var(--video-volume-height, 96px);--media-slider-preview-offset: calc(-200% - 6px) ;--gap: var(--video-volume-gap, 10px);position:relative;display:flex;align-items:center;justify-content:center}:where(.vds-video-layout[data-sm] .vds-volume-popup){display:block;position:absolute;top:calc(100% + var(--gap));left:50%;opacity:0;transform:translate(-50%);transition:opacity .15s ease-out,visibility .15s ease-out;border-radius:var(--video-volume-border-radius, 8px);filter:var(--media-volume-filter, drop-shadow(0 1px 1px rgb(0 0 0 / .05)));visibility:hidden}.vds-video-layout[data-sm] .vds-mute-button:after{content:"";position:fixed;bottom:calc(-1 * var(--gap));right:0;width:100%;height:var(--gap);z-index:1;pointer-events:auto}.vds-video-layout .vds-volume-popup{background-color:var(--video-volume-bg, var(--media-menu-bg, var(--default-bg)));border:var(--video-volume-border, var(--default-border))}.light .vds-video-layout .vds-volume-popup,.vds-video-layout.light .vds-volume-popup{--default-bg: rgb(250 250 250);--default-border: 1px solid rgb(10 10 10 / .1)}.dark .vds-video-layout .vds-volume-popup,.vds-video-layout.dark .vds-volume-popup{--default-bg: rgb(10 10 10);--default-border: 1px solid rgb(255 255 255 / .1)}:where(.vds-video-layout[data-sm] .vds-volume[data-active] .vds-volume-popup),:where(.vds-video-layout[data-sm] .vds-volume:has([data-active]) .vds-volume-popup){transition:opacity .15s ease-in,visibility .15s ease-in;opacity:1;visibility:visible}:where(.vds-video-layout[data-sm] .vds-volume[data-active] .vds-tooltip-content){display:none!important}:where(.vds-video-layout .vds-time[data-type=current]){margin-right:2px}:where(.vds-video-layout .vds-time[data-type=current][remainder]){margin-left:2px}.vds-video-layout .vds-time{--default-color: #f5f5f5 !important}:where([data-preview] .vds-video-layout .vds-captions){opacity:0}:where(.vds-video-layout .vds-captions){z-index:10;transition:var(--video-captions-transition, bottom .3s ease-in-out)}@media(min-width:980px){:where([data-fullscreen] .vds-video-layout .vds-captions){bottom:var(--video-lg-fullscreen-captions-offset, 54px)}}:where([data-media-player][data-controls] .vds-video-layout .vds-captions){bottom:var(--video-captions-offset, 78px)}:where([data-media-player][data-controls] .vds-video-layout[data-sm] .vds-captions){bottom:var(--video-sm-captions-offset, 48px)}:where(.vds-video-layout .vds-time-slider .vds-slider-chapter-title){width:100%;text-align:center;text-shadow:-1px -1px 0 #212121,1px -1px 0 #212121,-1px 1px 0 #212121,1px 1px 0 #212121}:where(.vds-video-layout .vds-gesture){top:0;left:0;width:100%;height:100%;z-index:0}:where(.vds-video-layout .vds-gesture[action="seek:-10"]){width:var(--video-gesture-seek-width, 20%);z-index:1}:where(.vds-video-layout .vds-gesture[action="seek:10"]){left:unset;right:0;width:var(--video-gesture-seek-width, 20%);z-index:1}@media(pointer:coarse){:where(.vds-video-layout .vds-gesture[action="toggle:paused"]){display:none}}@media not (pointer:coarse){:where([data-media-player] .vds-video-layout .vds-gesture[action="toggle:controls"]){display:none}}:where(.vds-video-layout .vds-live-button){margin-left:12px}:where(.vds-video-layout:not([data-sm]) .vds-time-group){margin-left:10px}:where(.vds-video-layout[data-sm] .vds-time){font-size:var(--video-sm-time-font-size, 14px)}:where([data-fullscreen] .vds-video-layout .vds-time){font-size:var(--video-fullscreen-time-font-size, 16px)}:where(.vds-video-layout .vds-load-container){position:absolute;inset:0;width:100%;height:100%;display:none;align-items:center;justify-content:center;pointer-events:none;z-index:99}:where([data-media-player][data-load=play]:not([data-started]) .vds-video-layout[data-match] .vds-load-container){display:flex}:where(.vds-video-layout .vds-load-container .vds-play-button){--size: var(--video-load-button-size, 56px);--color: var(--video-load-button-color, rgb(0 0 0 / .8));--bg-color: var(--video-load-button-bg, var(--media-brand));--media-button-hover-transform: 0;--media-button-border: var(--video-load-button-border, var(--color));--media-button-hover-bg: var(--video-load-button-bg, var(--media-brand));width:var(--size);height:var(--size);pointer-events:auto;margin-bottom:2px;overflow:hidden}.vds-video-layout .vds-load-container .vds-play-button{border-radius:var(--video-load-button-border-radius, 100%);color:var(--color)}.vds-video-layout .vds-load-container .vds-play-button{background-color:var(--bg-color)}:where(.vds-video-layout[data-sm] .vds-load-container .vds-play-button){--size: var(--video-sm-load-button-size, 48px);--media-button-hover-transform: translateY(0%);width:var(--size);height:var(--size);transform:translateY(0)}:where(.vds-video-layout[data-sm] .vds-controls-group:nth-last-child(2)){pointer-events:none}:where(.vds-video-layout[data-sm] .vds-controls-group:last-child){z-index:2;margin-top:-2.5px;margin-bottom:-6px}:where([data-fullscreen] .vds-video-layout[data-sm] .vds-controls-group:last-child){margin-bottom:0}.vds-video-layout[data-sm] .vds-controls-group{padding:2px}:where(.vds-video-layout[data-sm]) :where(.vds-button,.vds-slider:not(.vds-time-slider),.vds-time,.vds-time-divider,.vds-chapter-title){transition:opacity .15s ease}:where([data-media-player]:not([data-started]) .vds-video-layout[data-sm]) :where(.vds-button .vds-slider,.vds-time-group){opacity:0;visibility:hidden}:where(.vds-video-layout[data-sm] .vds-time-slider){transition:transform .1s linear}@media(pointer:coarse){:where([data-preview] .vds-video-layout:not([data-no-scrub-gesture])) :where(.vds-button,.vds-slider:not(.vds-time-slider),.vds-time,.vds-chapter-title,.vds-time-divider,.vds-captions,.vds-live-button){opacity:0}:where([data-preview] .vds-video-layout:not([data-no-scrub-gesture]) .vds-time-slider){--track-height: var(--video-sm-slider-focus-track-height, 12px);transform:translateY(-6px);transition:transform .1s linear}}:where(.vds-video-layout[data-sm] .vds-controls .vds-play-button){--size: var(--video-sm-play-button-size, 45px);--media-button-hover-transform: translateY(25%);width:var(--size);height:var(--size);transform:translateY(25%);border-radius:100%;pointer-events:auto;margin-bottom:2px;overflow:hidden}.vds-video-layout[data-sm] .vds-controls .vds-play-button{background-color:var(--video-sm-play-button-bg, rgba(0 0 0 / .6))}:where([data-media-player]:not([data-started]) .vds-video-layout[data-sm] .vds-controls-group:not(:nth-child(3))){opacity:0;visibility:hidden}:where(.vds-video-layout[data-sm] .vds-buffering-indicator){--media-buffering-size: 64px;transform:translate(-2px,-4px)}:where(.vds-video-layout .vds-start-duration .vds-time){position:absolute;right:8px;bottom:8px;margin-right:8px;margin-bottom:8px;z-index:10}.vds-video-layout .vds-start-duration .vds-time{padding:var(--video-sm-start-duration-padding, 3px 6px);color:var(--video-sm-start-duration-color, var(--video-controls-color));background-color:var(--video-sm-start-duration-bg, rgba(0 0 0 / .64))}:where([data-started] .vds-video-layout .vds-start-duration .vds-time){display:none}:where([data-media-player]:not([data-can-play]) .vds-video-layout .vds-start-duration .vds-time){opacity:0}:where(.vds-video-layout[data-sm] .vds-time[data-type=current]){margin-left:8px}:where([data-fullscreen] .vds-video-layout .vds-controls-group:nth-last-child(2)){margin-bottom:-16px}@media(orientation:portrait){:where([data-fullscreen] .vds-video-layout .vds-captions){bottom:30lvh;bottom:10dvh}}@media(orientation:landscape){:where([data-fullscreen] .vds-video-layout .vds-controls-group:nth-last-child(2)){margin-bottom:-12px}}.lc-section{margin-bottom:var(--spacing-lg)}.lc-section .lc-section{margin-bottom:0}.lc-grid{display:grid;grid-template-columns:repeat(10,1fr);grid-template-rows:auto auto auto;grid-template-areas:"problem problem  solution solution uv  uv  ua       ua       cs cs" "problem problem  metrics  metrics  uv  uv  channels channels cs cs" "cost    cost     cost     cost     cost revenue  revenue  revenue revenue revenue";gap:1px;background:var(--border-light, #e5e7eb);border:1px solid var(--border-light, #e5e7eb);border-radius:8px;overflow:hidden}.lc-block.lc-block-merged{display:flex;flex-direction:column;padding:0;gap:0}.lc-block-inner{padding:var(--spacing-sm);cursor:pointer;transition:background .15s ease;display:flex;flex-direction:column;gap:4px;min-height:120px;position:relative}.lc-block-inner:first-child{border-bottom:none}.lc-block-inner:last-child{flex:1}.lc-block-inner:hover{background:var(--bg-hover, #f9fafb)}.lc-block-inner.lc-block-empty .lc-block-content{opacity:.6}.lc-block{background:var(--bg-main, #fff);padding:var(--spacing-sm);cursor:pointer;transition:background .15s ease;min-height:120px;display:flex;flex-direction:column;gap:4px;position:relative}.lc-block:hover{background:var(--bg-hover, #f9fafb)}.lc-block-expanded{background:var(--bg-hover, #f7f8fa)}.lc-block-empty>.lc-block-content{opacity:.6}.lc-block,.lc-block-inner{background:#f9fafb}.lc-block-header{display:flex;align-items:flex-start;gap:4px;flex-wrap:wrap}.lc-block-icon{font-size:14px;width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}.lc-block-title{font-size:13px;font-weight:700;color:#1a1a1a;letter-spacing:-.02em}.lc-block-title-en{display:block;font-size:10px;font-weight:500;color:var(--text-muted, #656360);letter-spacing:0}.lc-badge{font-size:9px;padding:1px 5px;border-radius:3px;font-weight:500;margin-left:auto}.lc-badge-excellent{background:#dcfce7;color:#15803d}.lc-badge-good{background:#dbeafe;color:#1d4ed8}.lc-badge-fair{background:#fef3c7;color:#d97706}.lc-badge-poor{background:#fecaca;color:#dc2626}.lc-block-content{flex:1}.lc-block-digest{font-size:13px;color:var(--text-primary, #2d2b27);line-height:1.4;margin:0;word-break:keep-all}.lc-block-digest-list{font-size:13px;color:var(--text-primary, #2d2b27);line-height:1.5;margin:0;padding-left:14px;word-break:keep-all;list-style:disc}.lc-block-digest-list li{margin-bottom:2px}.lc-content-clamp{max-height:123px;overflow:hidden;position:relative}.lc-content-clamp.lc-overflows:after{content:"…";position:absolute;bottom:0;left:0;right:0;height:24px;background:linear-gradient(#f9fafb00,#f9fafb 40%);display:flex;align-items:flex-end;justify-content:center;color:var(--text-muted, #6b7280);font-size:16px;padding-bottom:1px}.lc-block-placeholder{font-size:11px;color:var(--text-muted, #656360);margin:0;font-style:italic}.lc-block-feedback{margin-top:6px;padding-top:6px;border-top:1px solid var(--border-light, #e5e7eb)}.lc-feedback-label{font-size:10px;font-weight:600;color:var(--text-muted, #656360);display:block;margin-bottom:2px}.lc-feedback-text{font-size:12px;color:var(--text-secondary, #4a4a48);line-height:1.4;margin:0}.lc-postit{position:absolute;z-index:9999;top:100%;left:4px;margin-top:4px;background:#fff9c4;border:1px solid #f0e68c;box-shadow:2px 3px 10px #0000002e;padding:10px 14px;border-radius:2px 2px 6px 6px;max-width:340px;min-width:200px;font-size:13px;line-height:1.5;color:#3d3300;pointer-events:none}.lc-postit-title{font-weight:700;font-size:12px;margin-bottom:6px;padding-bottom:4px;border-bottom:1px dashed #e6d880}.lc-postit-list{margin:0;padding-left:16px;list-style:disc}.lc-postit-list li{margin-bottom:3px;word-break:keep-all}.lc-tab-bar{display:flex;gap:4px;margin-bottom:8px}.lc-tab{padding:5px 16px;font-size:13px;font-weight:500;border:1px solid var(--border-light, #e5e7eb);border-radius:6px;background:var(--bg-main, #fff);color:var(--text-secondary, #4a4a48);cursor:pointer;transition:all .15s ease;white-space:nowrap}.lc-tab:hover{background:var(--bg-hover, #f9fafb)}.lc-tab-active{background:var(--accent-primary, #3b82f6);color:#fff;border-color:var(--accent-primary, #3b82f6)}.lc-tab-active:hover{background:var(--accent-primary, #3b82f6);opacity:.9}.lc-info-btn{display:inline-flex;align-items:center;justify-content:center;width:15px;height:15px;border-radius:50%;border:1.5px solid var(--text-muted, #9ca3af);background:transparent;color:var(--text-muted, #9ca3af);font-size:10px;font-weight:700;cursor:pointer;margin-left:4px;vertical-align:middle;transition:all .15s ease;padding:0;line-height:1}.lc-info-btn:hover{border-color:var(--accent-primary, #3b82f6);color:var(--accent-primary, #3b82f6)}.lc-info-overlay{position:fixed;inset:0;background:#0000004d;z-index:1000;display:flex;align-items:center;justify-content:center}.lc-info-popup{background:var(--bg-main, #fff);border-radius:12px;box-shadow:0 8px 30px #0000002e;padding:24px 28px;max-width:520px;width:90vw;max-height:80vh;overflow-y:auto;position:relative}.lc-info-popup h3{font-size:16px;font-weight:700;margin:0 0 12px;color:var(--text-primary, #1a1a1a)}.lc-info-popup p{font-size:14px;line-height:1.6;color:var(--text-secondary, #4a4a48);margin:0 0 10px}.lc-info-popup ul{font-size:13px;line-height:1.6;color:var(--text-secondary, #4a4a48);margin:0 0 12px;padding-left:18px}.lc-info-popup li{margin-bottom:4px}.lc-info-popup .lc-info-note{font-size:12px;color:var(--text-muted, #656360);background:var(--bg-elevated, #f7f6f3);padding:10px 12px;border-radius:6px;margin-top:8px}.lc-info-close{position:absolute;top:12px;right:14px;background:none;border:none;font-size:20px;color:var(--text-muted, #9ca3af);cursor:pointer;padding:2px 6px;line-height:1}.lc-info-close:hover{color:var(--text-primary, #1a1a1a)}.lc-grid.lc-grid-simple{grid-template-columns:repeat(10,1fr);grid-template-rows:auto auto auto;grid-template-areas:"problem problem  solution solution uv  uv  ua       ua       cs cs" "problem problem  metrics  metrics  uv  uv  channels channels cs cs" "cost    cost     cost     cost     cost revenue  revenue  revenue revenue revenue"}@media(max-width:768px){.lc-grid.lc-grid-simple{grid-template-columns:1fr 1fr;grid-template-rows:auto;grid-template-areas:"problem  solution" "uv       uv" "ua       channels" "cs       metrics" "cost     revenue"}}.canvas-tab-header{display:flex;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}.canvas-tabs{display:flex;gap:4px;margin-left:auto}.canvas-tab{padding:5px 14px;font-size:13px;font-weight:500;border:1px solid var(--border-light, #e5e7eb);border-radius:6px;background:var(--bg-main, #fff);color:var(--text-secondary, #4a4a48);cursor:pointer;transition:all .15s ease;white-space:nowrap}.canvas-tab:hover{background:var(--bg-hover, #f9fafb)}.canvas-tab-active{background:var(--accent-primary, #3b82f6);color:#fff;border-color:var(--accent-primary, #3b82f6)}.canvas-tab-active:hover{background:var(--accent-primary, #3b82f6);opacity:.9}.canvas-detail-toggle{display:block;margin:2px 0 0 auto;padding:0;font-size:12px;color:var(--text-tertiary, #999);background:none;border:none;cursor:pointer}.canvas-detail-toggle:hover{color:var(--text-secondary, #666)}.canvas-two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:20px}.canvas-sub-title{font-size:15px;font-weight:700;color:var(--text-primary, #1a1a1a);margin:0 0 12px}@media(max-width:768px){.lc-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto;grid-template-areas:"problem  solution" "uv       uv" "ua       channels" "cs       metrics" "cost     revenue"}.canvas-two-col{grid-template-columns:1fr}.lc-tab-bar{flex-wrap:wrap}.lc-postit{max-width:260px;min-width:160px}}.wa-section{margin-bottom:var(--spacing-md, 16px)}.wa-detail-link{margin-left:auto;font-size:13px;font-weight:500;color:var(--accent-primary, #2eaadc);text-decoration:none}.wa-detail-link:hover{text-decoration:underline}.wa-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px}.wa-summary-card{display:flex;flex-direction:column;gap:6px;padding:14px;min-height:120px;background:var(--bg-elevated, #fff);border:1px solid var(--border-light, #e5e7eb);border-radius:8px;text-decoration:none;color:inherit;transition:border-color .15s,box-shadow .15s;overflow:hidden;min-width:0}.wa-summary-card:hover{border-color:var(--accent-primary, #2eaadc);box-shadow:0 2px 8px #0000000f}.wa-summary-card-empty{opacity:.5;border-style:dashed}.wa-summary-icon{font-size:28px;line-height:1}.wa-summary-content{min-width:0;width:100%}.wa-summary-label{font-size:13px;font-weight:600;color:var(--text-primary, #1f2937);margin-bottom:4px}.wa-summary-title{font-size:13px;font-weight:500;color:var(--text-muted, #6b7280);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wa-summary-desc{font-size:12px;color:var(--text-muted, #6b7280);margin-top:2px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4}@media(max-width:768px){.wa-summary-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.wa-summary-grid{grid-template-columns:repeat(2,1fr)}}.wa-section-title{font-size:16px;font-weight:700;color:var(--text-primary, #1f2937);margin:0 0 var(--spacing-md, 16px) 0;display:flex;align-items:center;gap:8px}.wa-section-icon{font-size:20px}.wa-card{background:var(--bg-elevated, #fff);border:1px solid var(--border-light, #e5e7eb);border-radius:8px;overflow:hidden;margin-bottom:var(--spacing-md, 16px)}.wa-card-header{padding:12px 16px;border-bottom:1px solid var(--border-light, #e5e7eb);display:flex;align-items:center;gap:8px;background:var(--bg-subtle, #f9fafb)}.wa-card-header-icon{display:flex;align-items:center;color:var(--text-muted, #6b7280)}.wa-card-header-title{font-size:15px;font-weight:600;color:var(--text-primary, #1f2937)}.wa-card-header-en{font-size:12px;color:var(--text-muted, #9ca3af);font-weight:400;margin-left:4px}.wa-card-body{padding:16px}.wa-persona-profile{display:flex;align-items:center;gap:12px;padding-bottom:12px;border-bottom:1px solid var(--border-light, #e5e7eb);margin-bottom:12px}.wa-persona-avatar{width:48px;height:48px;border-radius:50%;background:#e0e7ff;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.wa-persona-name{font-size:16px;font-weight:700;color:var(--text-primary, #1f2937)}.wa-persona-demo{font-size:13px;color:var(--text-muted, #6b7280);margin-top:2px}.wa-persona-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.wa-persona-block{padding:10px;background:var(--bg-subtle, #f9fafb);border-radius:6px}.wa-persona-block-title{font-size:13px;font-weight:700;color:var(--text-primary, #1f2937);text-transform:uppercase;margin-bottom:6px}.wa-persona-block ul{list-style:none;margin:0;padding:0}.wa-persona-block li{font-size:13px;color:var(--text-primary, #1f2937);padding:2px 0 2px 12px;text-indent:-12px;line-height:1.4}.wa-persona-block li:before{content:"•";color:var(--text-muted, #9ca3af);margin-right:6px}.wa-persona-idea{font-size:13px;color:var(--text-primary, #1f2937);line-height:1.5}.wa-hypothesis{margin-top:12px;padding:10px 12px;background:#f0fdfa;border-radius:6px;font-size:13px;color:#134e4a;line-height:1.5;display:flex;gap:6px}.wa-hypothesis-label{flex-shrink:0;white-space:nowrap}.wa-empathy-grid{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:auto auto auto auto;grid-template-areas:"think think think" "hear  center see" "saydo saydo saydo" "pain  pain  gain";gap:1px;background:var(--border-light, #e5e7eb);border-radius:8px;overflow:hidden}.wa-empathy-cell{padding:12px;display:flex;flex-direction:column;gap:4px;min-height:60px}.wa-empathy-cell-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;color:var(--text-primary, #1f2937)}.wa-empathy-cell-content{font-size:13px;color:var(--text-primary, #1f2937);line-height:1.5}.wa-empathy-cell-content ul{list-style:none;margin:0;padding:0}.wa-empathy-cell-content li{padding:2px 0 2px 12px;text-indent:-12px;line-height:1.4}.wa-empathy-cell-content li:before{content:"•";margin-right:6px;opacity:.5}.wa-empathy-think{grid-area:think;background:var(--bg-subtle, #f9fafb)}.wa-empathy-hear{grid-area:hear;background:var(--bg-subtle, #f9fafb)}.wa-empathy-center{grid-area:center;background:var(--bg-elevated, #fff);display:flex;align-items:center;justify-content:center;text-align:center}.wa-empathy-center-label{font-size:14px;font-weight:700;color:var(--text-primary, #1f2937)}.wa-empathy-center-sub{font-size:11px;color:var(--text-muted, #9ca3af);margin-top:2px}.wa-empathy-see{grid-area:see;background:var(--bg-subtle, #f9fafb)}.wa-empathy-saydo{grid-area:saydo;background:var(--bg-subtle, #f9fafb)}.wa-empathy-pain{grid-area:pain;background:var(--bg-subtle, #f9fafb)}.wa-empathy-gain{grid-area:gain;background:var(--bg-subtle, #f9fafb)}.wa-empathy-insight{margin-top:12px;padding:10px 12px;background:#f0fdfa;border-radius:6px;font-size:13px;color:#134e4a;line-height:1.5;display:flex;gap:6px}.wa-empathy-insight-label{flex-shrink:0;white-space:nowrap}.wa-journey-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.wa-journey-header{display:flex;gap:12px;margin-bottom:12px;flex-wrap:wrap}.wa-journey-chip{display:flex;align-items:baseline;gap:6px;font-size:13px;color:var(--text-primary, #1f2937)}.wa-journey-chip-label{font-size:11px;font-weight:700;color:var(--text-muted, #6b7280);white-space:nowrap}.wa-journey-table{width:100%;min-width:600px;border-collapse:separate;border-spacing:0;font-size:13px}.wa-journey-table th,.wa-journey-table td{border-bottom:1px solid var(--border-light, #e5e7eb);border-right:1px solid var(--border-light, #e5e7eb);padding:8px 10px;vertical-align:top;text-align:left}.wa-journey-table th:first-child,.wa-journey-table td:first-child{border-left:1px solid var(--border-light, #e5e7eb)}.wa-journey-table thead th{border-top:1px solid var(--border-light, #e5e7eb)}.wa-journey-table tbody tr:first-child td{border-top:none}.wa-journey-table th{background:var(--bg-subtle, #f9fafb);font-weight:600;color:var(--text-primary, #1f2937);white-space:nowrap;text-align:center}.wa-journey-table td{color:var(--text-primary, #374151);line-height:1.4}.wa-journey-row-label{background:var(--bg-subtle, #f9fafb);font-weight:600;color:var(--text-muted, #6b7280);white-space:nowrap;width:60px;position:sticky;left:0;z-index:1}.wa-journey-emotion-row td{padding:0;height:60px;border:none}.wa-journey-emotion-svg{width:100%;height:60px}.wa-journey-emotion-line{fill:none;stroke:#8b5cf6;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}.wa-journey-emotion-dot{fill:#8b5cf6}.wa-journey-emotion-label{fill:var(--text-muted, #6b7280);font-size:10px;text-anchor:middle}.wa-journey-hmw{color:#8b5cf6;font-style:italic}.wa-journey-pain{color:#dc2626}.wa-interview-goal{padding:12px;background:#f0fdfa;border-radius:6px;margin-bottom:12px}.wa-interview-goal-label{font-size:11px;font-weight:700;color:#134e4a;text-transform:uppercase;margin-bottom:4px}.wa-interview-goal-text{font-size:14px;color:#134e4a;line-height:1.5}.wa-hypothesis-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}.wa-hypothesis-chip{padding:10px;background:var(--bg-subtle, #f3f4f6);border-radius:6px;font-size:13px;color:var(--text-primary, #1f2937);line-height:1.4}.wa-hypothesis-chip-label{font-size:11px;font-weight:700;color:var(--text-muted, #6b7280);margin-bottom:4px}.wa-schedule-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}.wa-schedule-item{padding:8px;background:var(--bg-subtle, #f9fafb);border-radius:6px}.wa-schedule-item-label{font-size:11px;font-weight:600;color:var(--text-muted, #6b7280);margin-bottom:2px}.wa-schedule-item-value{font-size:13px;color:var(--text-primary, #1f2937)}.wa-question-timeline{display:flex;flex-direction:column;gap:0;position:relative;padding-left:20px}.wa-question-timeline:before{content:"";position:absolute;left:7px;top:8px;bottom:8px;width:2px;background:var(--border-light, #e5e7eb)}.wa-question-item{display:flex;gap:12px;align-items:flex-start;padding:8px 0;position:relative}.wa-question-item:before{content:"";position:absolute;left:-17px;top:14px;width:10px;height:10px;border-radius:50%;background:#0d9488;border:2px solid #fff;z-index:1}.wa-question-time{font-size:12px;font-weight:600;color:#0d9488;white-space:nowrap;min-width:40px}.wa-question-text{font-size:13px;color:var(--text-primary, #1f2937);line-height:1.5}@media(max-width:768px){.wa-persona-grid{grid-template-columns:1fr}.wa-empathy-grid{grid-template-columns:1fr;grid-template-areas:"think" "hear" "center" "see" "saydo" "pain" "gain"}.wa-hypothesis-row,.wa-schedule-grid{grid-template-columns:1fr}}.artifacts-scroll.worksheet-scroll-area{padding-top:0}.artifacts-scroll .page-header{padding-top:calc(var(--spacing-lg, 24px) + var(--spacing-md, 16px))}.artifacts-sticky-tabs{position:sticky;top:0;z-index:20;margin:0 calc(-1 * var(--spacing-md, 16px));padding:0;background:var(--bg-elevated, #fff);border-top:1px solid var(--border-light, #e5e7eb);border-bottom:1px solid #fff}.artifacts-sticky-tabs+.harness-dashboard{margin-top:36px}.artifacts-week-tabs{display:flex;justify-content:center;flex-wrap:wrap;gap:0;margin:0;padding:0 var(--spacing-md, 16px);border-bottom:1px solid var(--border-light, #e5e7eb);background:var(--bg-secondary, #f8f9fa)}.artifacts-week-tab{position:relative;display:flex;flex-direction:column;align-items:center;padding:10px 18px 8px;font-size:13px;font-weight:500;color:var(--text-muted, #6b7280);background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s,background .15s;margin-bottom:-1px}.artifacts-week-tab:hover{color:var(--text-primary, #1f2937);background:#00000008}.artifacts-week-tab.active{color:var(--text-primary, #1f2937);border-bottom-color:var(--accent-primary, #3b82f6);font-weight:600;background:var(--bg-elevated, #fff)}.artifacts-week-tab-num{font-size:13px;line-height:1.2}.artifacts-week-tab-title{font-size:11px;color:var(--text-muted, #9ca3af);margin-top:1px}.artifacts-week-tab.active .artifacts-week-tab-title{color:var(--text-secondary, #6b7280)}.artifacts-week-tab-dot{position:absolute;top:6px;right:8px;width:6px;height:6px;border-radius:50%;background:var(--accent-primary, #3b82f6)}@media(max-width:768px){.artifacts-week-tab{padding:8px 12px 6px}.artifacts-week-tab-num{font-size:12px}.artifacts-week-tab-title{font-size:10px}}.artifacts-tabs{display:flex;justify-content:center;gap:8px;padding:12px var(--spacing-md, 16px) 12px;margin:0;background:#fff;overflow-x:auto;-webkit-overflow-scrolling:touch}.artifacts-tab{display:flex;align-items:center;gap:6px;padding:6px 16px;font-size:13px;font-weight:500;color:var(--text-muted, #6b7280);background:var(--bg-secondary, #f3f4f6);border:1px solid var(--border-light, #e5e7eb);border-radius:20px;cursor:pointer;white-space:nowrap;transition:all .15s ease}.artifacts-tab:hover{color:var(--text-primary, #1f2937);background:var(--bg-hover, #e5e7eb)}.artifacts-tab.active{color:#fff;background:var(--accent-primary, #3b82f6);border-color:var(--accent-primary, #3b82f6)}.artifacts-tab-icon{display:flex;align-items:center}@media(max-width:768px){.artifacts-tabs{gap:6px;padding:10px var(--spacing-sm, 8px)}.artifacts-tab{padding:5px 12px;font-size:12px}}.wa-empty{text-align:center;padding:24px;color:var(--text-muted, #9ca3af);font-size:13px}.wa-simple-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:8px}.wa-simple-table th{text-align:left;padding:6px 10px;background:var(--bg-subtle, #f9fafb);color:var(--text-muted, #6b7280);font-weight:600;font-size:12px;border-bottom:1px solid var(--border-light, #e5e7eb)}.wa-simple-table td{padding:6px 10px;border-bottom:1px solid var(--border-light, #e5e7eb);line-height:1.5;vertical-align:top}.wa-pov-statement{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-top:8px}.wa-pov-block{flex:1;min-width:120px;padding:10px 14px;background:#fff;border-radius:8px;border:1px solid var(--border-light, #e5e7eb)}.wa-pov-label{font-size:11px;font-weight:600;color:var(--accent-primary, #2eaadc);text-transform:uppercase;margin-bottom:4px}.wa-pov-value{font-size:14px;line-height:1.5}.wa-pov-connector{font-size:12px;color:var(--text-muted, #9ca3af);white-space:nowrap}@media(max-width:768px){.wa-pov-statement{flex-direction:column}.wa-pov-connector{display:none}.wa-simple-table{font-size:12px}}.wa-numbered-card{padding:10px 14px;background:#fff;border-radius:8px;border-left:3px solid transparent!important;margin-bottom:10px}.wa-numbered-card-title{font-weight:600;margin-bottom:4px}.wa-numbered-card-meta{font-size:13px;color:var(--text-muted, #6b7280);line-height:1.5}.wa-matrix{display:grid;gap:1px;background:var(--border-light, #e5e7eb);border:1px solid var(--border-light, #e5e7eb);border-radius:6px;overflow:hidden;margin-top:8px}.wa-matrix-cell{padding:8px 10px;background:var(--bg-elevated, #fff);font-size:13px;line-height:1.4}.wa-matrix-header{background:var(--bg-subtle, #f9fafb);font-weight:600;font-size:12px;color:var(--text-muted, #6b7280)}.wa-round-tabs{display:flex;gap:4px;margin-bottom:12px}.wa-round-tab{padding:5px 12px;font-size:12px;font-weight:500;color:var(--text-muted, #6b7280);background:var(--bg-subtle, #f9fafb);border:1px solid var(--border-light, #e5e7eb);border-radius:16px;cursor:pointer;transition:all .15s}.wa-round-tab:hover{color:var(--text-primary)}.wa-round-tab.active{background:var(--accent-primary, #2eaadc);color:#fff;border-color:transparent}.pitch-attempt-header{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;background:none;border:none;cursor:pointer;text-align:left;font-size:14px;color:inherit}.pitch-attempt-num{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;color:#fff;font-size:12px;font-weight:700;flex-shrink:0}.pitch-grade-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px}.pitch-section-label{font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:8px}.pitch-transcript-box{padding:12px 14px;background:var(--bg-subtle, #f8f9fa);border-radius:8px;font-size:13px;line-height:1.7;white-space:pre-wrap;word-break:break-word}.pitch-judges-row{display:flex;gap:8px}.pitch-judge-card{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 4px 8px;background:var(--bg-subtle, #f8f9fa);border-radius:10px;min-width:0}.pitch-judge-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;background:var(--bg-subtle, #f0f0f0)}.pitch-judge-name{font-size:11px;font-weight:600;color:var(--text-secondary, #64748b);white-space:nowrap}.pitch-judge-score-bar-wrap{width:40%;height:5px;border-radius:3px;background:var(--border-light, #e5e7eb);overflow:hidden;margin:2px 0}.pitch-judge-score-bar{height:100%;border-radius:3px;transition:width .4s ease}.pitch-judge-score{font-size:16px;font-weight:700;line-height:1}.pitch-feedbacks{display:flex;flex-direction:column;gap:8px}.pitch-feedback-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;background:var(--bg-subtle, #f8f9fa);border-radius:8px}.pitch-feedback-avatar{width:30px;height:30px;border-radius:50%;object-fit:cover;background:var(--bg-subtle, #f0f0f0);flex-shrink:0;margin-top:1px}.pitch-feedback-body{flex:1;min-width:0}.pitch-feedback-name{font-weight:600;font-size:12px;margin-right:8px;color:var(--text-secondary, #64748b)}.pitch-feedback-text{font-size:13px;line-height:1.55;color:var(--text-primary)}@media(max-width:600px){.pitch-judges-row{gap:4px}.pitch-judge-card{padding:8px 2px 6px}.pitch-judge-avatar{width:34px;height:34px}.pitch-judge-name{font-size:10px}.pitch-judge-score{font-size:14px}}._answerArea_1gnby_2{display:flex;flex-direction:column;gap:4px}._answerTextarea_1gnby_8{width:100%;padding:4px 0;border:none;border-radius:0;font-family:var(--font-content, "Lexend", sans-serif);font-size:var(--text-base, 14px);line-height:32px;color:var(--text-primary);background:transparent;background-image:repeating-linear-gradient(to bottom,transparent 0px,transparent 31px,#CDC8BF 31px,#CDC8BF 32px);background-position:0 4px;background-clip:content-box;resize:none;min-height:128px;overflow:hidden;overflow-wrap:break-word;word-wrap:break-word;white-space:pre-wrap;box-sizing:border-box;transition:background-image var(--transition-fast)}._answerTextarea_1gnby_8:focus,._answerTextarea_1gnby_8:focus-visible{outline:none;box-shadow:none}._answerTextarea_1gnby_8::placeholder{font-family:var(--font-content, "Lexend", sans-serif);color:var(--text-placeholder);font-size:var(--text-base, 14px)}._answerTextarea_1gnby_8:disabled{color:var(--text-primary);cursor:default;opacity:1}._answerResizable_1gnby_55{resize:vertical;overflow:auto}._answerShort_1gnby_60{min-height:40px;line-height:32px}._answerCompact_1gnby_65{min-height:unset!important;height:auto!important;overflow:hidden;field-sizing:content}@media print{._answerTextarea_1gnby_8{resize:none!important;overflow:hidden!important;background-image:repeating-linear-gradient(to bottom,transparent 0px,transparent 31px,#CDC8BF 31px,#CDC8BF 32px)!important;color:var(--text-primary)!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}._answerTextarea_1gnby_8::placeholder{color:transparent!important}}._wrapper_xuagt_1{width:100%;max-width:800px;margin:0 auto}._fullscreen_xuagt_7{background:#fff;width:100vw;height:100vh;display:flex;flex-direction:column}._fullscreen_xuagt_7 ._toolbar_xuagt_15{flex-shrink:0;border-radius:0}._fullscreen_xuagt_7 ._canvasContainer_xuagt_20{flex:1;border-radius:0;display:flex;align-items:center;justify-content:center;height:auto!important}._fullscreen_xuagt_7 ._canvasContainer_xuagt_20 canvas{transform-origin:center center}._fullscreen_xuagt_7 ._resizeHandle_xuagt_34{display:none}._toolbar_xuagt_15{display:flex;align-items:center;gap:2px;padding:4px 8px;background:#f9fafb;border:1px solid #e5e7eb;border-bottom:none;border-radius:8px 8px 0 0;flex-wrap:wrap}._toolBtn_xuagt_50{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid transparent;background:transparent;border-radius:6px;cursor:pointer;color:#374151;transition:all .12s ease}._toolBtn_xuagt_50:hover{background:#e5e7eb}._toolBtn_xuagt_50:disabled{opacity:.35;cursor:default}._toolBtn_xuagt_50:disabled:hover{background:transparent}._active_xuagt_77{background:#dbeafe;border-color:#93c5fd;color:#1d4ed8}._divider_xuagt_83{width:1px;height:20px;background:#d1d5db;margin:0 4px}._toolBtnRight_xuagt_90{margin-left:auto}._canvasContainer_xuagt_20{border:1px solid #e5e7eb;border-radius:0 0 8px 8px;overflow:hidden;position:relative;background:#fff}._resizeHandle_xuagt_34{height:8px;background:#f3f4f6;cursor:ns-resize;display:flex;align-items:center;justify-content:center;border:1px solid #e5e7eb;border-top:none;border-radius:0 0 8px 8px;transition:background .12s ease}._resizeHandle_xuagt_34:hover{background:#e5e7eb}._resizeGrip_xuagt_119{width:32px;height:3px;background:#9ca3af;border-radius:2px}._colorIndicator_xuagt_127{position:absolute;bottom:2px;right:2px;width:8px;height:8px;border-radius:50%;border:1px solid rgba(0,0,0,.2)}._colorDropdown_xuagt_137{position:absolute;top:100%;left:0;z-index:30;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 12px #0000001a;padding:8px;min-width:200px}._colorLabel_xuagt_150{font-size:11px;color:#9ca3af;margin-bottom:4px}._colorGrid_xuagt_156{display:grid;grid-template-columns:repeat(8,1fr);gap:3px}._colorSwatch_xuagt_162{width:22px;height:22px;border-radius:4px;border:2px solid transparent;cursor:pointer;transition:transform 80ms ease}._colorSwatch_xuagt_162:hover{transform:scale(1.15)}._colorSwatchActive_xuagt_175{border-color:#1d4ed8;box-shadow:0 0 0 1px #fff inset}._colorDivider_xuagt_180{height:1px;background:#e5e7eb;margin:6px 0}._sliderWrapper_xuagt_187{display:flex;align-items:center;gap:6px;padding:0 4px}._sizeSlider_xuagt_194{width:80px;height:4px;appearance:none;background:#e5e7eb;border-radius:2px;outline:none}._sizeSlider_xuagt_194::-webkit-slider-thumb{appearance:none;width:14px;height:14px;border-radius:50%;background:var(--slider-color, #000);cursor:pointer;border:2px solid white;box-shadow:0 1px 3px #0003}._sliderValue_xuagt_214{font-size:11px;color:#6b7280;min-width:28px;text-align:right}._shapeDropdown_xuagt_222,._layerDropdown_xuagt_223{position:absolute;top:100%;left:0;z-index:30;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 12px #0000001a;padding:4px;min-width:160px}._dropdownItem_xuagt_236{display:flex;align-items:center;gap:8px;width:100%;padding:6px 10px;border:none;background:none;border-radius:4px;cursor:pointer;font-size:13px;color:#374151;text-align:left;transition:background 80ms ease}._dropdownItem_xuagt_236:hover{background:#f3f4f6}._dropdownItemActive_xuagt_256{background:#dbeafe;color:#1d4ed8}._dropdownItemRow_xuagt_261{display:flex;align-items:center}._sidesControl_xuagt_266{display:flex;align-items:center;gap:2px;margin-left:auto;padding-right:4px}._sidesBtn_xuagt_274{width:20px;height:20px;display:flex;align-items:center;justify-content:center;border:1px solid #d1d5db;background:#fff;border-radius:4px;cursor:pointer;color:#6b7280}._sidesBtn_xuagt_274:hover{background:#f3f4f6}._sidesValue_xuagt_291{font-size:12px;min-width:20px;text-align:center;color:#374151}._sciencePanel_xuagt_299{position:absolute;top:100%;right:0;z-index:30;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 12px #0000001a;padding:8px;width:240px}._sciencePanelHeader_xuagt_312{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:600;color:#374151;margin-bottom:8px}._scienceGrid_xuagt_322{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}._scienceItem_xuagt_328{position:relative}._scienceThumb_xuagt_332{width:100%;aspect-ratio:1;border:1px solid #e5e7eb;border-radius:6px;background:#fafafa;cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:hidden;transition:border-color 80ms ease}._scienceThumb_xuagt_332:hover{border-color:#93c5fd}._scienceThumb_xuagt_332 img{max-width:90%;max-height:90%;object-fit:contain}._scienceDelete_xuagt_356{position:absolute;top:-4px;right:-4px;width:16px;height:16px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:none;background:#ef4444;color:#fff;cursor:pointer;font-size:8px}._submitBtn_xuagt_373{display:flex;align-items:center;gap:4px;padding:4px 12px;background:#1f2937;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:13px;font-weight:500;margin-left:auto;transition:background .12s ease}._submitBtn_xuagt_373:hover{background:#374151}._toolBtn_1n8vy_1{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid transparent;background:transparent;border-radius:6px;cursor:pointer;color:#374151;transition:all .12s ease}._toolBtn_1n8vy_1:hover{background:#e5e7eb}._toolBtn_1n8vy_1:disabled{opacity:.35;cursor:default}._toolBtn_1n8vy_1:disabled:hover{background:transparent}._colorIndicator_1n8vy_28{position:absolute;bottom:2px;right:2px;width:8px;height:8px;border-radius:50%;border:1px solid rgba(0,0,0,.2)}._colorDropdown_1n8vy_38{position:absolute;top:100%;left:0;z-index:30;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 12px #0000001a;padding:8px;min-width:200px}._colorLabel_1n8vy_51{font-size:11px;color:#9ca3af;margin-bottom:4px}._colorGrid_1n8vy_57{display:grid;grid-template-columns:repeat(8,1fr);gap:3px}._colorSwatch_1n8vy_63{width:22px;height:22px;border-radius:4px;border:2px solid transparent;cursor:pointer;transition:transform 80ms ease}._colorSwatch_1n8vy_63:hover{transform:scale(1.15)}._colorSwatchActive_1n8vy_76{border-color:#1d4ed8;box-shadow:0 0 0 1px #fff inset}._colorDivider_1n8vy_81{height:1px;background:#e5e7eb;margin:6px 0}._toolBtn_18wzk_1{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid transparent;background:transparent;border-radius:6px;cursor:pointer;color:#374151;transition:all .12s ease}._toolBtn_18wzk_1:hover{background:#e5e7eb}._toolBtn_18wzk_1:disabled{opacity:.35;cursor:default}._toolBtn_18wzk_1:disabled:hover{background:transparent}._active_18wzk_28{background:#dbeafe;border-color:#93c5fd;color:#1d4ed8}._shapeDropdown_18wzk_34{position:absolute;top:100%;left:0;z-index:30;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 12px #0000001a;padding:4px;min-width:160px}._dropdownItem_18wzk_47{display:flex;align-items:center;gap:8px;width:100%;padding:6px 10px;border:none;background:none;border-radius:4px;cursor:pointer;font-size:13px;color:#374151;text-align:left;transition:background 80ms ease}._dropdownItem_18wzk_47:hover{background:#f3f4f6}._dropdownItemActive_18wzk_67{background:#dbeafe;color:#1d4ed8}._dropdownItemRow_18wzk_72{display:flex;align-items:center}._sidesControl_18wzk_77{display:flex;align-items:center;gap:2px;margin-left:auto;padding-right:4px}._sidesBtn_18wzk_85{width:20px;height:20px;display:flex;align-items:center;justify-content:center;border:1px solid #d1d5db;background:#fff;border-radius:4px;cursor:pointer;color:#6b7280}._sidesBtn_18wzk_85:hover{background:#f3f4f6}._sidesValue_18wzk_102{font-size:12px;min-width:20px;text-align:center;color:#374151}._toolBtn_r19ux_1{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid transparent;background:transparent;border-radius:6px;cursor:pointer;color:#374151;transition:all .12s ease}._toolBtn_r19ux_1:hover{background:#e5e7eb}._toolBtn_r19ux_1:disabled{opacity:.35;cursor:default}._toolBtn_r19ux_1:disabled:hover{background:transparent}._layerDropdown_r19ux_28{position:absolute;top:100%;left:0;z-index:30;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 12px #0000001a;padding:4px;min-width:160px}._dropdownItem_r19ux_41{display:flex;align-items:center;gap:8px;width:100%;padding:6px 10px;border:none;background:none;border-radius:4px;cursor:pointer;font-size:13px;color:#374151;text-align:left;transition:background 80ms ease}._dropdownItem_r19ux_41:hover{background:#f3f4f6}._container_16zrv_1{border:1px solid #e0e0e0;border-radius:6px;overflow:hidden;position:relative}._printBox_16zrv_9{display:none}@media print{._printBox_16zrv_9{display:block;width:100%;height:5in;border:1.5px solid #444;border-radius:4px;background:#fff;page-break-inside:avoid;break-inside:avoid}._screenOnly_16zrv_23{display:none!important}._container_16zrv_1{border:none}}._canvasWrapper_16zrv_27{display:flex;justify-content:center;background:#fafafa;padding:8px}._canvasWrapper_16zrv_27 canvas{border:1px solid #e0e0e0;border-radius:4px}._previewOverlay_16zrv_39{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#ffffffb3;color:#999;font-size:13px;pointer-events:none}._container_zsxi4_3{padding:8px 0}._empty_zsxi4_7{padding:16px;color:#999;text-align:center;font-size:13px}._recordBtn_zsxi4_16{display:flex;align-items:center;gap:8px;padding:12px 16px;width:100%;border:1px solid #ccc;border-radius:6px;background:#fff;cursor:pointer;font-size:13px;color:#333}._recordBtn_zsxi4_16:hover{border-color:#009688;color:#009688}._recordingContainer_zsxi4_37{padding:12px;border:1px solid #80CBC4;border-radius:8px;background:#e0f2f1;display:flex;flex-direction:column;gap:10px}._recordingHeader_zsxi4_47{display:flex;align-items:center;gap:10px}._pulse_zsxi4_53{width:10px;height:10px;border-radius:50%;background:#009688;animation:_pulse_zsxi4_53 1s ease-in-out infinite;flex-shrink:0}@keyframes _pulse_zsxi4_53{0%,to{opacity:1}50%{opacity:.3}}._timer_zsxi4_67{font-size:14px;font-weight:600;color:#00796b;font-variant-numeric:tabular-nums;min-width:36px}._liveTranscript_zsxi4_75{font-size:13px;color:#555;line-height:1.5;min-height:20px;margin:0}._interim_zsxi4_83{color:#999;font-style:italic}._fallbackHint_zsxi4_88{font-size:12px;color:#999;font-style:italic;margin:0}._stopBtn_zsxi4_95{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border:none;border-radius:6px;background:#009688;color:#fff;cursor:pointer;font-size:13px;font-weight:500;align-self:center}._stopBtn_zsxi4_95:hover{background:#00796b}._waveform_zsxi4_117{display:flex;align-items:center;gap:2px;height:24px;flex:1}._bar_zsxi4_125{width:3px;background:#009688;border-radius:1px;transition:height .08s ease-out}._playerRow_zsxi4_134{display:flex;align-items:center;gap:8px}._player_zsxi4_134{flex:1;height:36px}._rerecordBtn_zsxi4_145{padding:6px;border:1px solid #ccc;border-radius:4px;background:#fff;cursor:pointer;display:flex;align-items:center;color:#555}._rerecordBtn_zsxi4_145:hover{border-color:#009688;color:#009688}._transcript_zsxi4_161{margin:8px 0 0;padding:8px 12px;font-size:13px;color:#333;line-height:1.5;background:#f5f5f5;border-radius:6px}._transcribing_zsxi4_171{display:flex;align-items:center;gap:6px;margin-top:8px;font-size:12px;color:#999}._spinner_zsxi4_180{animation:_spin_zsxi4_180 1s linear infinite}@keyframes _spin_zsxi4_180{0%{transform:rotate(0)}to{transform:rotate(360deg)}}._container_1gywk_1{padding:8px 0}._empty_1gywk_5{padding:16px;color:#999;text-align:center;font-size:13px}._error_1gywk_12{padding:8px 12px;margin-bottom:8px;background:#fff5f5;border:1px solid #EF5350;border-radius:4px;color:#d32f2f;font-size:12px}._imageWrapper_1gywk_22{position:relative;display:inline-block}._image_1gywk_22{max-width:100%;border-radius:6px}._removeBtn_1gywk_32{position:absolute;top:4px;right:4px;background:#00000080;color:#fff;border:none;border-radius:50%;width:24px;height:24px;cursor:pointer;display:flex;align-items:center;justify-content:center}._removeBtn_1gywk_32:hover{background:#000000b3}._uploadBtn_1gywk_52{display:flex;align-items:center;gap:8px;justify-content:center;padding:24px;width:100%;border:2px dashed #ccc;border-radius:6px;background:#fff;cursor:pointer;color:#666;font-size:13px}._uploadBtn_1gywk_52:hover{border-color:#009688;color:#009688}._hiddenInput_1gywk_72{display:none}._container_1nwcj_1{display:flex;flex-direction:column;gap:0;overflow:hidden;background:#fff}._recordingBar_1nwcj_9{display:flex;flex-direction:column;gap:8px;padding:12px 16px;background:#e0f2f1;border-top:1px solid #80CBC4}._recordingTop_1nwcj_18{display:flex;align-items:center;gap:12px}._recordingIndicator_1nwcj_24{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:#00796b}._pulse_1nwcj_33{width:10px;height:10px;border-radius:50%;background:#009688;animation:_pulse_1nwcj_33 1s ease-in-out infinite;flex-shrink:0}@keyframes _pulse_1nwcj_33{0%,to{opacity:1}50%{opacity:.3}}._timer_1nwcj_47{font-variant-numeric:tabular-nums}._waveform_1nwcj_51{display:flex;align-items:center;gap:2px;height:24px;flex:1}._bar_1nwcj_59{width:3px;background:#009688;border-radius:1px;transition:height .08s ease-out;min-height:2px}._liveTranscript_1nwcj_67{font-size:13px;color:#555;line-height:1.5;min-height:20px;margin:0;max-height:120px;overflow-y:auto}._interim_1nwcj_77{color:#999;font-style:italic}._stopButton_1nwcj_82{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;background:#009688;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;align-self:center}._stopButton_1nwcj_82:hover{background:#00796b}._stopIcon_1nwcj_102{width:12px;height:12px;background:#fff;border-radius:2px}._startButton_1nwcj_109{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;background:#f5f5f5;color:#374151;border:2px dashed #d1d5db;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;margin:8px}._startButton_1nwcj_109:hover{background:#e5e7eb;border-color:#9ca3af}._playerWrapper_1nwcj_131{position:relative}._overlayButton_1nwcj_136{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#00000059;color:#fff;border:none;border-radius:50%;font-size:16px;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:opacity .3s,background .2s;z-index:2}._overlayButton_1nwcj_136:hover{background:#0000008c}._overlayPlaying_1nwcj_162{opacity:.5}._overlayPlaying_1nwcj_162:hover{opacity:1}._transcriptOverlay_1nwcj_171{position:absolute;bottom:0;left:0;right:0;padding:8px 12px 8px 68px;background:#00000026;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);font-size:13px;color:#333;line-height:1.5;z-index:1}._currentWord_1nwcj_185{font-weight:700;color:#009688}._error_1nwcj_190{padding:12px 16px;background:#fef2f2;color:#dc2626;font-size:13px;border-radius:6px;margin:8px}._area_2pug7_1{padding:0;margin-top:8px}._placeholder_2pug7_7{min-height:128px;padding:4px 0;border:none;border-radius:0;font-family:var(--font-handwriting, "Patrick Hand", cursive);font-size:18px;line-height:32px;color:var(--text-placeholder, #94A3B8);background:transparent;background-image:repeating-linear-gradient(to bottom,transparent 0px,transparent 31px,#CDC8BF 31px,#CDC8BF 32px);background-position:0 4px;background-clip:content-box;text-align:left}.teacher-sidebar{display:flex;flex-direction:column;gap:0;padding:var(--spacing-sm) 0;width:260px;min-width:260px;border-right:1px solid var(--border-default);background:var(--bg-sidebar);height:100%;overflow:hidden}.sidebar-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:10px 20px;border:none;border-left:3px solid transparent;border-radius:0;background:none;font-family:inherit;font-size:var(--font-size-base);font-weight:500;color:var(--text-secondary);cursor:pointer;text-align:left;width:100%;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.sidebar-item:hover{background:var(--bg-sidebar-hover);color:var(--text-primary)}.sidebar-item--active{background:var(--accent-teal-light);color:var(--accent-teal-dark);font-weight:var(--font-weight-semibold);border-left-color:var(--accent-teal)}.submissions-container{padding:var(--spacing-md)}.submissions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.submissions-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin:0}.submissions-table{width:100%;border-collapse:collapse}.submissions-table th{padding:var(--spacing-sm);text-align:left;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text-secondary);border-bottom:2px solid var(--border-default);cursor:pointer;-webkit-user-select:none;user-select:none}.submissions-table th:hover{color:var(--text-primary)}.submissions-table td{padding:var(--spacing-sm);font-size:var(--font-size-sm);border-bottom:1px solid var(--border-default)}.submissions-row{cursor:pointer}.submissions-row:hover{background:var(--bg-hover)}.submissions-empty{text-align:center;padding:var(--spacing-2xl);color:var(--text-muted)}.split-pane{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg);height:100%;overflow:hidden}.split-pane__left,.split-pane__right{overflow-y:auto;padding:var(--spacing-md)}.split-pane__left{border-right:1px solid var(--border-default)}@media(max-width:1024px){.split-pane{grid-template-columns:1fr}.split-pane__left{border-right:none;border-bottom:1px solid var(--border-default)}}.student-answer-block{background:var(--bg-sidebar);border-radius:var(--radius-md);padding:var(--spacing-sm);font-size:var(--font-size-sm);line-height:var(--line-height-relaxed);color:var(--text-primary);margin-top:var(--spacing-xs);white-space:pre-wrap}.eval-results{display:flex;flex-direction:column;gap:var(--spacing-md)}.eval-section{display:flex;flex-direction:column;gap:var(--spacing-sm)}.eval-section-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.teacher-notes{display:flex;flex-direction:column;gap:var(--spacing-sm);padding-top:var(--spacing-md);border-top:1px solid var(--border-default)}.teacher-notes-textarea{width:100%;min-height:100px;padding:var(--spacing-sm);border:1px solid var(--border-input);border-radius:var(--radius-md);font-family:inherit;font-size:var(--font-size-sm);resize:vertical}.teacher-notes-actions{display:flex;gap:var(--spacing-sm);align-items:center}.phase2-placeholder{opacity:.5;font-size:var(--font-size-xs);color:var(--text-muted);font-style:italic}.teacher-layout{display:flex;height:100%;overflow:hidden}.teacher-content{flex:1;display:flex;flex-direction:column;overflow-y:auto}.eval-inline{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-paper);box-shadow:var(--shadow-sm)}.eval-inline-header{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.eval-inline-level-wrap{display:flex;align-items:center;gap:var(--spacing-sm)}.eval-inline-level-select{padding:6px 12px;border-radius:var(--radius-md);font-family:var(--font-heading);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text);border:1px solid var(--border);background:var(--card);cursor:pointer;min-height:32px}.eval-inline-cer{display:flex;flex-direction:row;gap:var(--spacing-sm)}.eval-inline-cer-item{display:inline-flex;align-items:center;padding:3px var(--spacing-sm);border-radius:var(--radius-full);background:var(--bg-warm);border:1px solid var(--border);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--text-secondary)}.eval-inline-toggle{display:flex;align-items:center;gap:4px;background:none;border:none;padding:0;font-family:var(--font-heading);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text-muted);text-decoration:none;cursor:pointer;text-align:left}.eval-inline-toggle:hover{color:var(--text-primary)}.eval-inline-rationale{font-size:var(--font-size-sm);line-height:var(--line-height-relaxed);color:var(--text-secondary);background:var(--bg-warm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);margin-top:var(--spacing-xs)}.eval-inline-rationale .rationale-tag{font-weight:var(--font-weight-bold, 700)}.eval-inline-rationale .rationale-tag--strength{color:var(--accent-teal, #2B9E8F)}.eval-inline-rationale .rationale-tag--weakness{color:var(--accent-orange, #F59E0B)}.eval-inline-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.eval-inline-label{font-family:var(--font-heading);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text-muted)}.eval-inline-text{font-size:var(--font-size-sm);line-height:var(--line-height-relaxed);color:var(--text-primary);margin:0}.eval-inline-textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-default, #e0e0e0);border-radius:var(--radius-md);font-family:inherit;font-size:var(--font-size-sm);line-height:var(--line-height-relaxed);color:var(--text-primary);background:var(--bg-warm);resize:none;box-sizing:border-box;outline:none}.eval-inline-textarea:focus{border-color:var(--border-default, #d0d0d0);box-shadow:0 0 0 1px var(--border-default, #e0e0e0)}.eval-digilog{display:flex;flex-direction:column;gap:0}.eval-digilog-feedback{margin-top:-1px}.eval-digilog-feedback-text{font-family:Patrick Hand,cursive;font-size:19px;line-height:32px;color:var(--feedback-pen-color, #b45309);background-image:repeating-linear-gradient(transparent,transparent 31px,var(--line-rule) 31px,var(--line-rule) 32px);padding:0 4px;margin:0}.eval-digilog-feedback-input{font-family:Patrick Hand,cursive;font-size:19px;line-height:32px;color:var(--feedback-pen-color, #b45309);background-image:repeating-linear-gradient(transparent,transparent 31px,var(--line-rule) 31px,var(--line-rule) 32px);background-color:transparent;padding:0 4px;margin:0;border:none;outline:none;width:100%;resize:none;box-sizing:border-box}.eval-digilog-feedback-input:focus{outline:none;box-shadow:none}.eval-digilog-feedback-input::placeholder{color:var(--text-muted);font-family:Patrick Hand,cursive}.eval-digilog-strip-wrapper{height:0;overflow:visible;position:relative;z-index:2}.eval-inline-summary{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:6px 0;font-family:var(--font-body, "Nunito", sans-serif);font-size:var(--text-sm, 13px);color:var(--text-secondary, #78716c)}.eval-inline-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.eval-inline-level{border:none;background:none;font-family:inherit;font-size:inherit;font-weight:600;color:var(--text-primary, #1c1917);cursor:pointer;padding:0}.eval-inline-cer{color:var(--text-muted, #a8a29e);font-size:12px;letter-spacing:.5px}.eval-inline-rationale-btn{border:none;background:none;font-family:inherit;font-size:inherit;color:var(--text-secondary, #78716c);cursor:pointer;padding:2px 4px;border-radius:4px}.eval-inline-rationale-btn:hover{background:var(--bg-hover, #f5f5f4);color:var(--text-primary, #1c1917)}.eval-inline-popover{position:absolute;right:0;top:32px;width:360px;z-index:10}.eval-inline-popover-arrow{position:absolute;top:-6px;right:24px;width:12px;height:12px;background:var(--bg-paper, #fff);border:1px solid var(--border-card, #e5e5e5);border-right:none;border-bottom:none;transform:rotate(45deg)}.eval-inline-popover-body{background:var(--bg-paper, #fff);border:1px solid var(--border-card, #e5e5e5);border-radius:var(--radius-sm, 8px);padding:12px 16px;font-family:var(--font-body, "Nunito", sans-serif);font-size:var(--text-sm, 13px);line-height:1.6;color:var(--text-primary, #1c1917);box-shadow:0 4px 16px #0000001a}.eval-digilog-strip{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--bg-paper);border-radius:10px;border:1px solid var(--border-card);margin-top:12px}.eval-digilog-strip--open{border-radius:10px 10px 0 0}.eval-digilog-level{display:flex;align-items:center;gap:5px}.eval-digilog-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.eval-digilog-level-select{font-family:Nunito,sans-serif;font-size:12px;font-weight:700;color:var(--text-primary);background:var(--bg-warm);border:1px solid var(--border-card);border-radius:6px;padding:3px 20px 3px 8px;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='10' viewBox='0 0 12 12' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3 5l3 3 3-3' fill='none' stroke='%2378716c' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center}.eval-digilog-level-select:focus{outline:none;border-color:var(--text-secondary, #78716c)}.eval-digilog-sep{width:1px;height:18px;background:var(--border-card);flex-shrink:0}.eval-digilog-cer{display:flex;gap:8px;align-items:center}.eval-digilog-cer-item{display:flex;align-items:center;gap:3px;font-size:10px;font-weight:700;color:var(--text-muted);letter-spacing:.3px}.eval-digilog-cer-bar{width:28px;height:4px;background:var(--border-card);border-radius:2px;overflow:hidden}.eval-digilog-cer-fill{height:100%;border-radius:2px;background:var(--text-muted)}.eval-digilog-rationale-btn{font-family:Nunito,sans-serif;font-size:11px;color:var(--text-muted);cursor:pointer;border:none;background:none;padding:2px 6px;border-radius:4px;margin-left:auto;white-space:nowrap;transition:all .15s}.eval-digilog-rationale-btn:hover{background:var(--bg-warm);color:var(--text-secondary)}.eval-digilog-rationale{font-size:12px;color:var(--text-secondary);line-height:1.6;padding:8px 12px;background:var(--bg-paper);border:1px solid var(--border-card);border-top:none;border-radius:0 0 10px 10px;font-family:Nunito,sans-serif}.eval-digilog-tag{font-weight:800;color:var(--text-primary)}.student-list-panel{display:flex;flex-direction:column;width:240px;min-width:240px;border-right:1px solid var(--border-default);overflow-y:auto;background:var(--bg-paper)}.student-list-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--border-default);color:var(--text-secondary)}.student-list-items{display:flex;flex-direction:column;gap:2px;padding:var(--spacing-xs)}.student-list-item{display:flex;flex-direction:column;gap:2px;width:100%;padding:var(--spacing-sm) var(--spacing-md);border:none;border-radius:var(--radius-md);background:none;font-family:inherit;cursor:pointer;text-align:left}.student-list-item:hover{background:var(--bg-hover)}.student-list-item--active{background:var(--accent-teal-light)}.student-list-row{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.student-list-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text-primary)}.student-list-level{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--accent-teal)}.student-list-cer{font-size:var(--font-size-xs);color:var(--text-secondary)}.student-list-status{font-size:var(--font-size-sm);color:var(--text-muted)}.student-list-panel--right{border-right:none;border-left:1px solid var(--border-default)}.teacher-assignments-layout{display:flex;flex:1;overflow:hidden}.teacher-empty-state{display:flex;flex:1;align-items:center;justify-content:center;color:var(--text-muted);font-family:var(--font-body);font-size:var(--font-size-base)}.teacher-approve-bar{display:flex;justify-content:flex-end;padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--border-default);background:var(--bg-paper)}.teacher-approve-btn{padding:var(--spacing-sm) var(--spacing-md);background:var(--accent-teal);color:#fff;border:none;border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:opacity var(--transition-fast)}.teacher-approve-btn:hover{opacity:.9}.rubric-editor{border:1px solid var(--border-default);border-radius:var(--radius-md);overflow:hidden;font-size:var(--font-size-xs);margin-top:var(--spacing-md)}.rubric-editor-bar{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-sidebar);border-bottom:1px solid var(--border-default)}.rubric-editor-title{font-weight:var(--font-weight-bold);font-size:var(--font-size-xs);color:var(--text-primary)}.rubric-editor-toggle{background:none;border:none;cursor:pointer;font-size:10px;color:var(--text-secondary);padding:var(--spacing-xs)}.rubric-editor-block{border-bottom:1px solid var(--border-default)}.rubric-editor-block:last-child{border-bottom:none}.rubric-editor-block-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-paper)}.rubric-editor-block-title{display:flex;align-items:center;gap:var(--spacing-xs);background:none;border:none;cursor:pointer;font-family:inherit;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--text-primary);padding:var(--spacing-xs) 0}.rubric-editor-chevron{font-size:10px;color:var(--text-secondary);width:12px}.rubric-editor-block-actions{display:flex;gap:var(--spacing-xs)}.rubric-editor-btn-edit,.rubric-editor-btn-save,.rubric-editor-btn-cancel{padding:2px var(--spacing-sm);border:1px solid var(--border-default);border-radius:var(--radius-sm);background:none;font-family:inherit;font-size:var(--font-size-xs);cursor:pointer;color:var(--text-secondary)}.rubric-editor-btn-edit:hover{background:var(--bg-sidebar-hover);color:var(--text-primary)}.rubric-editor-btn-save{background:var(--btn-primary-bg, #44403C);color:#fff;border-color:var(--btn-primary-bg, #44403C)}.rubric-editor-btn-save:hover{opacity:.9}.rubric-editor-btn-cancel:hover{background:var(--bg-sidebar-hover)}.rubric-editor-block-content{padding:var(--spacing-sm) var(--spacing-md)}.rubric-editor-view{display:flex;flex-direction:column;gap:var(--spacing-xs)}.rubric-editor-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-top:var(--spacing-xs)}.rubric-editor-text{margin:0;line-height:var(--line-height-relaxed);color:var(--text-primary)}.rubric-editor-table{width:100%;border-collapse:collapse;font-size:var(--font-size-xs)}.rubric-editor-table th{text-align:left;padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--text-secondary);border-bottom:1px solid var(--border-default)}.rubric-editor-table td{padding:var(--spacing-xs) var(--spacing-sm);border-bottom:1px solid var(--border-default);vertical-align:top;line-height:var(--line-height-relaxed)}.rubric-editor-table tr:last-child td{border-bottom:none}.rubric-editor-th-level{width:70px;white-space:nowrap}.rubric-editor-th-perf{width:30%}.rubric-editor-dim-label{font-weight:var(--font-weight-semibold);width:90px;white-space:nowrap;color:var(--text-primary)}.rubric-editor-dim-desc{color:var(--text-secondary);font-style:italic}.rubric-editor-level-num{font-weight:var(--font-weight-semibold);color:var(--text-primary);white-space:nowrap}.rubric-editor-level-perf,.rubric-editor-level-criteria{color:var(--text-secondary);font-style:italic}.rubric-editor-edit-form{display:flex;flex-direction:column;gap:var(--spacing-xs)}.rubric-editor-textarea{width:100%;padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--border-input);border-radius:var(--radius-sm);font-family:inherit;font-size:var(--font-size-sm);line-height:var(--line-height-relaxed);resize:vertical;box-sizing:border-box}.rubric-editor-cell-textarea{width:100%;padding:var(--spacing-xs);border:1px solid var(--border-input);border-radius:var(--radius-sm);font-family:inherit;font-size:var(--font-size-xs);line-height:var(--line-height-relaxed);resize:vertical;box-sizing:border-box}.rubric-editor-dim-edit-row{display:flex;flex-direction:column;gap:2px}.rubric-editor-inline-text{cursor:text;display:inline-block;min-width:60px;padding:1px 2px;border-radius:2px;border:1px solid transparent;color:var(--text-secondary);font-style:italic;outline:none}.rubric-editor-inline-text:hover{background:var(--bg-sidebar-hover, rgba(0, 0, 0, .04))}.rubric-editor-inline-text:focus{border-color:var(--btn-primary-bg, #44403C);background:#fff}.rubric-editor-inline-text:empty:before{content:attr(data-placeholder);color:var(--text-muted, #bbb);font-style:italic;pointer-events:none}.rubric-editor-empty{color:var(--text-muted, #bbb)}.teacher-submissions-layout{display:flex;flex:1;overflow:hidden}.submissions-main{padding:var(--spacing-md)}.submissions-worksheet-header{margin-bottom:var(--spacing-md)}.submissions-worksheet-header h2{margin:0;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold)}.submissions-question-block{margin-bottom:var(--spacing-lg)}.submissions-question-prompt{font-size:var(--font-size-sm);line-height:var(--line-height-relaxed);margin-bottom:var(--spacing-sm)}.submissions-student-answer{background:var(--bg-sidebar);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);font-style:italic;color:var(--text-primary);margin-bottom:var(--spacing-sm);line-height:var(--line-height-relaxed)}.submissions-no-answer{color:var(--text-muted);font-size:var(--font-size-sm);font-style:italic}.submissions-send-section{display:flex;justify-content:flex-end;padding-top:var(--spacing-md);border-top:1px solid var(--border-default);margin-top:var(--spacing-lg)}.student-list-empty{padding:var(--spacing-md);color:var(--text-muted);font-size:var(--font-size-sm);text-align:center}.student-list-meta{display:flex;align-items:center;gap:var(--spacing-xs, 4px);font-size:var(--font-size-xs);color:var(--text-secondary)}.support-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.support-dot--level-0{background:var(--level-0)}.support-dot--level-1{background:var(--level-1)}.support-dot--level-2{background:var(--level-2)}.support-dot--level-3{background:var(--level-3)}.support-dot--level-4{background:var(--level-4)}.support-label{white-space:nowrap}.eval-inline-support-level{display:flex;align-items:center;gap:var(--spacing-xs, 4px)}.student-list-name-row{display:flex;align-items:center;gap:var(--spacing-sm)}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot--not-submitted{background:var(--text-muted, #C4C4C4)}.status-dot--submitted{background:var(--accent-orange, #F59E0B)}.status-dot--sent{background:var(--accent-teal, #2B9E8F)}.status-badge{font-size:.625rem;font-weight:600;padding:1px 6px;border-radius:9999px;white-space:nowrap;text-transform:uppercase;letter-spacing:.04em}.status-badge--not_submitted{color:#9ca3af;background:#f3f4f6}.status-badge--submitted{color:#92400e;background:#fef3c7}.status-badge--sent{color:#065f46;background:#d1fae5}.eval-inline-level-select{padding:4px 8px;border:1px solid var(--border-default, #e0e0e0);border-radius:4px;font-size:.875rem;background:#fff;cursor:pointer}.eval-block{display:flex;flex-direction:column;border:1px solid var(--border-default, #e0e0e0);border-radius:var(--radius-md, 8px);background:var(--bg-paper, #fff);overflow:hidden}.eval-block-section{padding:var(--spacing-sm, 8px) var(--spacing-md, 16px)}.eval-block-section+.eval-block-section{border-top:1px solid var(--border-default, #e0e0e0)}.eval-block-level-section{background:var(--bg-sidebar, #f8f7f5)}.eval-block-level-row{display:flex;justify-content:space-between;align-items:center}.eval-block-label{display:block;font-size:var(--font-size-xs, .75rem);font-weight:var(--font-weight-semibold, 600);color:var(--text-secondary, #6b7280);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-xs, 4px)}.eval-block-rationale-section{background:var(--bg-sidebar, #f8f7f5)}.eval-block-rationale{font-size:var(--font-size-sm, .875rem);line-height:var(--line-height-relaxed, 1.6);color:var(--text-primary, #1f2937);margin:0}.rationale-tag{display:inline;font-weight:var(--font-weight-bold, 700)}.rationale-tag--strength{color:var(--accent-teal, #2B9E8F)}.rationale-tag--weakness{color:var(--accent-orange, #F59E0B)}.sidebar-lesson-selector{padding:var(--spacing-xs) 0 var(--spacing-sm);flex:1;overflow-y:auto;min-height:0;border-top:1px solid var(--border-default);margin-top:var(--spacing-xs)}.sidebar-nav-bottom{display:flex;flex-direction:column;gap:2px;border-top:1px solid var(--border-default);padding-top:var(--spacing-sm);margin-top:auto;flex-shrink:0}.lesson-tree{display:flex;flex-direction:column;gap:2px}.lesson-tree-group-header{display:flex;align-items:center;gap:var(--spacing-xs);width:100%;padding:var(--spacing-xs) var(--spacing-sm);border:none;border-radius:var(--radius-sm);background:none;font-family:inherit;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--text-secondary);cursor:pointer;text-align:left;text-transform:uppercase;letter-spacing:.03em}.lesson-tree-group-header:hover{background:var(--bg-sidebar-hover);color:var(--text-primary)}.lesson-tree-group-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lesson-tree-group-count{font-size:.625rem;color:var(--text-muted);background:var(--bg-elevated);padding:0 5px;border-radius:9999px;line-height:1.4}.lesson-tree-items{display:flex;flex-direction:column;gap:1px;padding-left:var(--spacing-sm)}.lesson-tree-item{width:100%;padding:var(--spacing-xs) var(--spacing-sm);border:none;border-radius:var(--radius-sm);background:none;font-family:inherit;font-size:var(--font-size-xs);color:var(--text-primary);line-height:1.3;cursor:pointer;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:background var(--transition-fast)}.lesson-tree-item:hover{background:var(--bg-sidebar-hover)}.lesson-tree-item--active{background:#18453b1a;font-weight:var(--font-weight-semibold);color:#18453b}.lesson-selector-error{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs);color:var(--color-error)}.lesson-selector-loading{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs);color:var(--text-muted)}.teacher-lesson-view{padding:var(--spacing-lg) var(--spacing-xl);max-width:800px;margin:0 auto}.lesson-detail-panel{display:flex;flex-direction:column;gap:var(--spacing-md);font-family:var(--font-body)}.lesson-detail-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin:0;color:var(--text-primary)}.lesson-breadcrumb{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--text-muted);margin-bottom:var(--spacing-xs)}.lesson-breadcrumb-sep{color:var(--text-muted)}.lesson-breadcrumb-current{color:var(--text-secondary);font-weight:var(--font-weight-semibold)}.lesson-detail-set{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0 0 var(--spacing-sm)}.lesson-detail-panel h3{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);margin:0 0 var(--spacing-xs);color:var(--text-primary)}.lesson-detail-panel p{font-size:var(--font-size-base);line-height:var(--line-height-relaxed);margin:0;color:var(--text-primary)}.lesson-detail-panel ul{margin:0;padding-left:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-xs)}.lesson-detail-panel li{font-size:var(--font-size-base);line-height:var(--line-height-relaxed);color:var(--text-primary)}.lesson-error{color:var(--color-error);padding:var(--spacing-md)}.sidebar-student-list{flex:1;overflow:hidden;border-top:1px solid var(--border-default);margin-top:var(--spacing-xs)}.class-tabs{display:flex;gap:0;border-bottom:1px solid var(--border-card, #e5e5e5);padding:0 16px}.class-tabs__btn{padding:8px 16px;border:none;background:none;font-family:var(--font-body, "Nunito", sans-serif);font-size:var(--text-sm, 13px);font-weight:600;color:var(--text-secondary, #78716c);cursor:pointer;border-bottom:2px solid transparent}.class-tabs__btn--active{color:var(--text-primary, #1c1917);border-bottom-color:var(--btn-primary-bg, #44403C)}.class-tabs__btn:hover:not(.class-tabs__btn--active){color:var(--text-primary, #1c1917)}.teacher-review-content{display:flex;flex-direction:column;height:100%;position:relative}.review-worksheet-area{flex:1;overflow-y:auto;padding-left:56px;position:relative}.review-student-header{display:flex;gap:32px;padding:12px 0 16px;border-bottom:1px dashed var(--line-dashed, #ccc);margin-bottom:8px}.review-student-header__name,.review-student-header__date{font-family:var(--font-body, "Nunito", sans-serif);font-size:var(--text-lg, 22px);font-weight:600;color:var(--text-primary)}.review-student-header__name strong,.review-student-header__date strong{font-family:var(--font-handwriting, "Patrick Hand", cursive);font-weight:400;color:var(--text-secondary);margin-left:8px;border-bottom:1.5px solid var(--line-rule, #999);padding-bottom:2px}.annotation-content-area{position:relative;max-width:816px;margin:0 auto}.annotation-content-area .ProseMirror{font-family:var(--font-content, "Lexend", sans-serif);font-size:var(--text-base);line-height:1.7;outline:none}.annotation-content-area[style*=background-image] .ProseMirror{background:transparent}.annotation-canvas-overlay{position:absolute;top:0;left:0;z-index:5;pointer-events:none}.review-anno-toolbar{position:absolute;left:-20px;top:50%;transform:translateY(-50%);width:48px;background:#2c2c2e;border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;padding:8px 0;gap:2px;box-shadow:0 4px 20px #00000059;z-index:10}.review-anno-tool{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;color:#ffffff8c;border:none;background:transparent;transition:all .15s}.review-anno-tool:hover{background:#ffffff1a;color:#fff}.review-anno-tool.active{background:#fff3;color:#fff}.review-anno-tool--sm{width:30px;height:30px;color:#fff6}.review-anno-tool--sm:hover{color:#ffffffb3}.review-anno-sep{width:24px;height:1px;background:#ffffff1a;margin:3px 0}.review-anno-colors{display:flex;flex-direction:column;align-items:center;gap:4px;padding:4px 0}.review-anno-color{width:18px;height:18px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:all .15s}.review-anno-color:hover{transform:scale(1.15)}.review-anno-color.active{border-color:#fff;box-shadow:0 0 0 2px #ffffff40}.review-approve-inline{display:flex;align-items:center;justify-content:center;padding:24px;margin-top:16px}.review-action-bar__nav{width:28px;height:28px;border:1px solid var(--border, #e7e5e4);border-radius:var(--radius-sm, 8px);background:var(--card, white);color:var(--text-muted, #a8a29e);cursor:pointer;display:flex;align-items:center;justify-content:center}.review-action-bar__nav:hover{background:var(--bg-hover, #f5f5f4)}.review-action-bar__count{font-size:var(--text-sm, 13px);color:var(--text-secondary, #78716c)}@media print{.teacher-sidebar,.review-anno-toolbar,.review-approve-inline,.eval-digilog-strip,.eval-digilog-rationale,.activity-tabs,.anno-float,.ws-zoom,.page-nav-arrow{display:none!important}nav,aside,header[role=banner],.skip-nav,[class*=topbar],[class*=Topbar],[class*=sidebar],[class*=Sidebar],[class*=panel-container],[class*=PanelContainer]{display:none!important}.app-grid{display:block!important}.main,.main-scroll{overflow:visible!important;height:auto!important;padding:0!important;margin:0!important}.review-worksheet-area{padding-left:0!important;overflow:visible!important;height:auto!important;position:static!important}.teacher-review-content{height:auto!important;overflow:visible!important;position:static!important}.annotation-overlay-wrapper{display:none!important}body,.teacher-review-content,.review-worksheet-area{background:#fff!important}*{overflow:visible!important;box-shadow:none!important}}.paper-grading__img{width:100%;display:block}.paper-grading__feedback{font-family:var(--font-handwriting, "Patrick Hand", cursive);font-size:1em;color:var(--color-error, #EF5350);line-height:1.3;margin:.15em 0 .3em}.paper-grading__eval{display:flex;align-items:center;gap:.45em;font-family:var(--font-body, "Nunito", sans-serif);font-size:.8em;color:var(--text-secondary, #78716c)}.paper-grading__dot{width:.5em;height:.5em;border-radius:50%;flex-shrink:0}.paper-grading__level{font-weight:600;color:var(--text-primary, #1c1917)}.paper-grading__cer{color:var(--text-muted, #a8a29e);font-size:.75em}.sparky-avatar{display:inline-block;border-radius:var(--radius-full);flex-shrink:0;object-fit:cover}.sparky-avatar--sm{width:24px;height:24px}.sparky-avatar--md{width:36px;height:36px}.sparky-avatar--lg{width:48px;height:48px}.mode-selector{display:flex;gap:0;border-bottom:1px solid var(--border-default)}.mode-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 12px;border:none;background:none;font-family:var(--font-body);font-size:13px;font-weight:600;color:var(--text-placeholder);cursor:pointer;border-bottom:2px solid transparent;transition:color var(--transition-fast),border-color var(--transition-fast);min-height:42px}.mode-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.mode-tab--active{color:var(--text-primary);border-bottom-color:var(--btn-primary-bg)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:var(--radius-sm);font-family:var(--font-body);font-weight:var(--weight-semibold);cursor:pointer;transition:background var(--transition-fast);line-height:1;-webkit-user-select:none;user-select:none}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-sm{padding:6px 12px;font-size:var(--text-sm);min-height:30px}.btn-md{padding:8px 16px;font-size:var(--text-base);min-height:36px}.btn-lg{padding:10px 20px;font-size:var(--text-md);min-height:42px}.btn-primary{background:var(--btn-primary-bg);color:var(--btn-primary-text)}.btn-primary:hover:not(:disabled){background:var(--btn-primary-hover)}.btn-secondary{background:var(--bg-card, #fff);color:var(--text-secondary, #57534E);border:1px solid var(--border-card, #E7E5E4)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover)}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text)}.btn-danger{background:var(--alert-critical);color:#fff}.btn-danger:hover:not(:disabled){opacity:.9}.btn-spinner{display:inline-block;width:16px;height:16px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:spin .6s linear infinite}.input-wrapper{display:flex;flex-direction:column;gap:4px}.input-label{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-secondary, #57534E)}.input-field{width:100%;padding:10px 12px;border:1px solid var(--border-card, #E7E5E4);border-radius:var(--radius-sm);font-family:inherit;font-size:var(--text-base);color:var(--text, #1C1917);background:transparent;outline:none;transition:border-color .15s}.input-field:focus{border-color:var(--btn-primary-bg, #44403C)}.input-field::placeholder{color:var(--text-placeholder)}.input-field.input-error{border-color:var(--alert-critical)}.input-error-text{font-size:var(--text-sm);color:var(--alert-critical)}.input-count{font-size:var(--text-xs);color:var(--text-muted);text-align:right}textarea.input-field{resize:vertical;min-height:80px}.modal-backdrop{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#0006;z-index:100}.modal-content{background:var(--bg-main);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);max-width:480px;width:90%;max-height:80vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);border-bottom:1px solid var(--border-default)}.modal-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.modal-close{background:none;border:none;font-size:var(--font-size-xl);cursor:pointer;color:var(--text-muted);padding:var(--spacing-xs);line-height:1}.modal-body{padding:var(--spacing-md)}.progress-wrapper{display:flex;flex-direction:column;gap:var(--spacing-xs)}.progress-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-primary)}.progress-bar{height:6px;width:100%;background:var(--border-default);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-normal)}.progress-primary .progress-fill{background:var(--text-muted)}.progress-success .progress-fill{background:var(--color-success)}.progress-warning .progress-fill{background:var(--color-warning)}.progress-error .progress-fill{background:var(--color-error)}.progress-info .progress-fill{background:var(--color-info)}.badge{display:inline-flex;align-items:center;padding:2px 8px;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:var(--radius-md);line-height:1.5;background:var(--bg-elevated);color:var(--text-muted)}.badge-submitted{background:var(--color-info-light);color:var(--color-info)}.badge-evaluated{background:var(--color-success-light);color:var(--color-success)}.badge-pending{background:var(--bg-elevated);color:var(--text-muted)}.badge-in-progress{background:var(--color-warning-light);color:var(--color-warning)}.card{background:var(--bg-main);border:1px solid var(--border-default);border-radius:var(--radius-md)}.card-padding-sm{padding:var(--spacing-sm)}.card-padding-md{padding:var(--spacing-md)}.card-padding-lg{padding:var(--spacing-lg)}.tooltip-wrapper{position:relative;display:inline-flex}.tooltip-content{position:absolute;left:50%;transform:translate(-50%);padding:4px 8px;background:var(--text-primary);color:#fff;font-size:var(--font-size-xs);border-radius:var(--radius-sm);white-space:nowrap;z-index:50;pointer-events:none}.tooltip-top{bottom:calc(100% + 6px)}.tooltip-bottom{top:calc(100% + 6px)}.toast{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);font-size:var(--font-size-sm);animation:slideIn .2s ease}.toast-success{background:var(--color-success-light);color:var(--color-success)}.toast-error{background:var(--color-error-light);color:var(--color-error)}.toast-info{background:var(--color-info-light);color:var(--color-info)}.toast-warning{background:var(--color-warning-light);color:var(--color-warning)}.toast-message{flex:1}.toast-close{background:none;border:none;font-size:var(--font-size-lg);cursor:pointer;color:inherit;opacity:.7;line-height:1}@keyframes slideIn{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}.turn-counter{display:flex;align-items:center;gap:12px;padding:6px 16px;font-size:11px;color:var(--text-placeholder)}.turn-counter-text{white-space:nowrap;min-width:80px}.thinking-steps{margin-bottom:4px}.thinking-steps-toggle{display:flex;align-items:center;gap:4px;background:none;border:none;padding:2px 0;font-size:11px;color:var(--text-placeholder);cursor:pointer;font-family:inherit}.thinking-steps-toggle:hover{color:var(--text-muted)}.thinking-steps-chevron{transition:transform var(--transition-fast)}.thinking-steps-chevron--open{transform:rotate(90deg)}.thinking-steps-content{padding:8px 0 0 12px;margin:0;border-left:2px solid var(--border-default);list-style:none;counter-reset:step}.thinking-step-item{font-size:12px;color:var(--text-muted);margin-bottom:4px;padding-left:8px;counter-increment:step}.thinking-step-item:before{content:counter(step) ". ";font-weight:var(--font-weight-semibold);color:var(--text-placeholder)}.chat-message{display:flex;align-items:flex-start;gap:10px;max-width:100%}.chat-message--student{flex-direction:row-reverse}.chat-message--ai{flex-direction:row}.chat-avatar{flex-shrink:0;padding-top:2px}.student-avatar{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-md);background:var(--btn-primary-bg);color:#fff;font-family:var(--font-body);font-size:11px;font-weight:600}.chat-bubble-wrapper{display:flex;flex-direction:column;max-width:85%}.chat-bubble{padding:10px 14px;border-radius:var(--radius-md);word-wrap:break-word;font-family:var(--font-body);font-size:15px;line-height:1.7}.chat-bubble--student{background:var(--bg-warm, #f5f5f4);color:var(--text-primary);border-bottom-right-radius:var(--radius-sm)}.chat-bubble--ai{background:transparent;color:var(--text-secondary);padding:4px 0 0;border-radius:0}.chat-text{margin:0;line-height:1.7}.chat-markdown p{margin:0 0 10px}.chat-markdown p:last-child{margin-bottom:0}.chat-markdown strong{font-weight:var(--font-weight-semibold)}.chat-markdown ul,.chat-markdown ol{margin:4px 0;padding-left:20px}.chat-markdown a{color:var(--color-primary, #18453B);text-decoration:underline;text-underline-offset:2px}.chat-markdown a:hover{opacity:.8}.chat-level-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.level-badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:var(--radius-full, 999px);font-family:var(--font-body);font-size:11px;font-weight:600;letter-spacing:.02em}.level-badge--level-0{background:var(--accent-coral-light, #ffe4e4);color:var(--accent-coral-dark, #dc2626)}.level-badge--level-1{background:#ffedd5;color:#ea580c}.level-badge--level-2{background:#fef3c7;color:#d97706}.level-badge--level-3{background:#e3f0ff;color:#3b82f6}.level-badge--level-4{background:var(--bg-warm, #f5f5f4);color:var(--text-primary, #1c1917)}.level-up-indicator{display:inline-flex;align-items:center;gap:3px;font-family:var(--font-body);font-size:11px;font-weight:600;color:var(--text-primary, #1c1917);animation:level-up-pop .4s ease-out}@keyframes level-up-pop{0%{opacity:0;transform:translateY(4px) scale(.9)}60%{transform:translateY(-1px) scale(1.05)}to{opacity:1;transform:translateY(0) scale(1)}}.review-context-card{display:flex;flex-direction:column;gap:12px;padding:0}.review-context-field{display:flex;flex-direction:column;gap:2px}.review-context-label{font-family:var(--font-body);font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.review-context-value{font-family:var(--font-body);font-size:14px;color:var(--text-primary)}.review-context-qid{font-weight:600}.review-context-prompt{font-family:var(--font-body);font-size:14px;line-height:1.7;color:var(--text-primary);margin:2px 0 0}.review-context-response{font-family:var(--font-handwriting, var(--font-body));font-size:15px;line-height:1.7;color:var(--text-primary);margin:0;padding:4px 0;border-bottom:1px dashed var(--line-dashed, #e5e0d8);white-space:pre-wrap}.review-context-row{display:flex;align-items:center;gap:10px}.review-context-cer{font-family:var(--font-body);font-size:12px;font-weight:600;color:var(--text-secondary);letter-spacing:.03em}.review-context-confidence{font-family:var(--font-body);font-size:12px;font-weight:600;color:var(--text-muted)}.review-context-rationale{font-family:var(--font-body);font-size:13px;line-height:1.6;color:var(--text-secondary);margin:0;padding:6px 10px;background:var(--bg-desk, #f8f6f1);border-radius:var(--radius-sm);border-left:2px solid var(--text-muted, #a8a29e)}.review-action{display:inline-flex;align-items:center;gap:6px;margin-top:8px;padding:6px 14px;border-radius:var(--radius-full, 999px);font-family:var(--font-body);font-size:13px;font-weight:600;cursor:pointer;border:none;transition:background .15s,transform .1s}.review-action:active{transform:scale(.97)}.review-action--keep{background:var(--bg-warm, #f5f5f4);color:var(--text-primary, #1c1917)}.review-action--keep:hover{background:#c8ede7}.review-action-group{display:flex;align-items:center;gap:8px;margin-top:8px;flex-wrap:wrap}.review-action-change{display:inline-flex;align-items:center;gap:4px}.review-action-select{font-family:var(--font-body);font-size:12px;font-weight:500;padding:5px 8px;border:1px solid var(--line-default, #d6d3d1);border-radius:var(--radius-md, 6px);background:var(--bg-card, #fff);color:var(--text-primary);cursor:pointer;outline:none}.review-action-select:focus{border-color:var(--color-primary, #18453B);box-shadow:0 0 0 2px #18453b1f}.review-action--apply{background:#ffedd5;color:#ea580c}.review-action--apply:hover{background:#fde0c4}.review-action--done{background:var(--bg-warm, #f5f5f4);color:var(--text-primary, #1c1917);cursor:default;padding:6px 14px;animation:level-up-pop .3s ease-out}.follow-up-questions{display:flex;flex-direction:column;gap:6px;margin-top:8px}.follow-up-btn{background:var(--surface-secondary, #f5f3ef);border:1px solid var(--border-light, #e5e2dc);border-radius:8px;padding:8px 12px;font-size:15px;color:var(--text-primary, #333);cursor:pointer;text-align:left;transition:background .15s,border-color .15s}.follow-up-btn:hover{background:var(--surface-hover, #ece9e3);border-color:var(--primary, #18453B)}.citation-link{color:var(--color-primary, #18453B);font-size:.75rem;vertical-align:super;text-decoration:none;cursor:pointer}.citation-link:hover{text-decoration:underline}.sources-section{border-top:1px solid var(--border-light, #e5e2dc);margin-top:8px;padding-top:6px;font-size:13px;color:var(--text-secondary)}.sources-toggle{cursor:pointer;font-weight:500;-webkit-user-select:none;user-select:none;font-family:var(--font-body)}.sources-list{margin-top:4px;padding-left:0;list-style:none}.sources-list li{margin-bottom:4px}.sources-list a{color:var(--color-primary, #18453B);text-decoration:underline;text-underline-offset:2px}.sources-list a:hover{opacity:.8}.chat-input{display:flex;align-items:flex-end;gap:8px;padding:12px 16px;border-top:1px solid var(--border-default);background:var(--bg-paper)}.chat-input-field{flex:1;min-height:var(--touch-min);max-height:200px;padding:10px 16px;border:1.5px solid var(--border-default);border-radius:22px;font-family:var(--font-body);font-size:14px;line-height:1.5;resize:none;color:var(--text-primary);background:var(--bg-main);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);overflow-y:hidden;box-sizing:border-box}.chat-input-field:focus{outline:none;border-color:var(--btn-primary-bg);box-shadow:0 0 0 3px #44403c1f}.chat-input-field::placeholder{color:var(--text-placeholder)}.chat-input-field:disabled{background:var(--bg-hover);color:var(--text-placeholder);cursor:not-allowed}.chat-send-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;border-radius:50%;background:var(--btn-primary-bg);color:#fff;cursor:pointer;flex-shrink:0;transition:background var(--transition-fast),transform .1s ease;box-shadow:0 2px 4px #44403c4d}.chat-send-btn:hover:not(:disabled){background:var(--btn-primary-hover);transform:scale(1.05)}.chat-send-btn:active:not(:disabled){transform:scale(.95)}.chat-send-btn:disabled{opacity:.3;cursor:not-allowed}.sparky-msg{display:flex;flex-direction:column;gap:12px}.sparky-msg-greeting{display:flex;align-items:flex-start;gap:10px}.sparky-msg-greeting-text{font-family:var(--font-body);font-size:14px;color:var(--text-primary, var(--text));line-height:1.6;padding-top:2px}.sparky-msg-greeting-text strong{font-weight:600;color:var(--text, #212121)}.sparky-msg-body{display:flex;flex-direction:column;align-items:center;gap:10px;padding:0 8px}.sparky-info-card{display:flex;flex-direction:column;gap:0;width:100%;background:var(--bg-surface, var(--bg-warm, #F5F3EE));border-radius:var(--radius-md, 12px);padding:4px 0;overflow:hidden}.sparky-info-row{display:flex;align-items:baseline;gap:8px;padding:5px 12px}.sparky-info-row:hover{background:#00000005}.sparky-info-label{font-family:var(--font-body);font-size:11px;font-weight:600;color:var(--text-muted, #64748B);text-transform:uppercase;letter-spacing:.04em;min-width:64px;flex-shrink:0}.sparky-info-value{font-family:var(--font-body);font-size:13px;color:var(--text-secondary, #4A4A48);line-height:1.4;word-break:break-word}.sparky-info-input{flex:1;min-width:0;font-family:var(--font-body);font-size:13px;color:var(--text, #212121);background:transparent;background-image:repeating-linear-gradient(to bottom,transparent 0px,transparent 23px,var(--border, rgba(0, 0, 0, .08)) 23px,var(--border, rgba(0, 0, 0, .08)) 24px);background-position:0 2px;background-clip:content-box;border:none;border-radius:0;outline:none;padding:2px 0;line-height:24px;transition:background-image .15s}.sparky-info-input:focus{background-image:repeating-linear-gradient(to bottom,transparent 0px,transparent 23px,var(--btn-primary-bg, #44403C) 23px,var(--btn-primary-bg, #44403C) 24px)}.sparky-info-input::placeholder{color:var(--text-placeholder, #94A3B8);font-style:italic}.sparky-info-select{cursor:pointer;-webkit-appearance:none;appearance:none;padding-right:16px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%2364748B'/%3E%3C/svg%3E"),repeating-linear-gradient(to bottom,transparent 0px,transparent 23px,var(--border, rgba(0, 0, 0, .08)) 23px,var(--border, rgba(0, 0, 0, .08)) 24px);background-repeat:no-repeat,repeat;background-position:right 2px center,0 2px;background-clip:border-box,content-box}.sparky-info-textarea{resize:none;overflow:hidden;min-height:24px}.sparky-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:6px;width:100%}.sparky-action-chip{display:inline-block;text-align:left;padding:6px 12px;background:var(--bg-surface, #f8f8f6);border:1px solid var(--border-default, rgba(0, 0, 0, .08));border-radius:18px;font-family:var(--font-body);font-size:12px;font-weight:500;color:var(--text-secondary, #4A4A48);cursor:pointer;transition:background .15s,color .15s,border-color .15s;line-height:1.3}.sparky-action-chip:hover{background:#00968814;color:var(--text-primary, #1c1917);border-color:#0096884d}.sparky-action-chip--primary{background:var(--bg-warm, #f5f5f4);color:var(--text-primary, #1c1917);border-color:#00968833}.sparky-action-chip--primary:hover{background:#00968826}.loading-indicator{display:flex;align-items:flex-start;gap:var(--spacing-4);padding:var(--spacing-3) 0}.loading-body{display:flex;align-items:center;gap:6px;margin-left:var(--spacing-2);padding:var(--spacing-2) 0}.loading-dots{display:flex;gap:4px}.loading-dot{width:8px;height:8px;border-radius:50%;background:var(--color-text-tertiary);animation:dot-bounce 1.4s ease-in-out infinite}.loading-dot:nth-child(2){animation-delay:.2s}.loading-dot:nth-child(3){animation-delay:.4s}@keyframes dot-bounce{0%,80%,to{transform:translateY(0);opacity:.4}40%{transform:translateY(-6px);opacity:1}}.loading-message{font-size:var(--text-sm, 13px);color:var(--text-secondary, #78716c);font-style:italic}@media(prefers-reduced-motion:reduce){.loading-dot{animation:none;opacity:.6}}.sparky-panel{height:100%;display:flex;flex-direction:column;background:var(--bg-paper);min-height:0}.sparky-panel-header{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border-bottom:1px solid var(--border-default);min-height:50px;box-sizing:border-box}.sparky-title{display:flex;align-items:center;gap:8px}.sparky-name{font-family:var(--font-heading);font-size:16px;font-weight:600;color:var(--text-primary)}.sparky-panel-controls{display:flex;align-items:center;gap:2px}.sparky-toggle,.sparky-close{display:flex;align-items:center;justify-content:center;padding:6px;border:none;border-radius:var(--radius-md);background:transparent;color:var(--text-muted);cursor:pointer;transition:background var(--transition-fast);min-width:32px;min-height:32px}.sparky-toggle:hover,.sparky-close:hover{background:var(--bg-hover);color:var(--text-primary)}.sparky-messages{flex:1;min-height:0;overflow-y:auto;padding:24px 18px;display:flex;flex-direction:column;gap:24px}.sparky-messages::-webkit-scrollbar{width:5px}.sparky-messages::-webkit-scrollbar-track{background:transparent}.sparky-messages::-webkit-scrollbar-thumb{background:#0000001f;border-radius:10px}.sparky-progress-bar{display:flex;align-items:center;gap:4px;padding:6px 12px;color:var(--text-muted);font-size:.75rem;border-bottom:1px solid var(--border-light, var(--border-default))}.sparky-dot-completed{width:6px;height:6px;border-radius:50%;background:var(--primary);flex-shrink:0}.sparky-dot-pending{width:6px;height:6px;border-radius:50%;background:var(--border-default);flex-shrink:0}.sparky-progress-text{margin-left:4px;font-family:var(--font-body)}.sparky-lesson-context{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#18453b0f;border-bottom:1px solid var(--border-default);font-size:13px;color:var(--text-secondary)}.sparky-lesson-context--empty{background:transparent;color:var(--text-muted);font-style:italic}.sparky-lesson-id{font-family:var(--font-body);font-weight:600;color:#18453b;background:#18453b1a;padding:2px 8px;border-radius:10px;font-size:11px;flex-shrink:0}.sparky-lesson-title{font-family:var(--font-body);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sparky-error{padding:10px 14px;font-family:var(--font-body);font-size:13px;color:var(--accent-coral-dark);background:var(--accent-coral-light);border:1px solid var(--accent-coral);border-radius:var(--radius-md);line-height:1.5}._wrapper_81lyl_1{border:none;border-radius:0;margin:0;padding:24px 0;border-bottom:1px dashed #C5C0B8;background:transparent;position:relative;outline:none}._wrapper_81lyl_1:last-child{border-bottom:none}._wrapper_81lyl_1._selected_81lyl_16{background:#00968808;outline:none!important;box-shadow:none!important}._feedbackBlock_81lyl_30{margin-top:4px}._feedbackLevel_81lyl_34{display:flex;align-items:center;justify-content:flex-end;gap:5px;font-family:var(--font-body, "Nunito", sans-serif);font-size:var(--text-sm, 13px);font-weight:600;color:var(--text-secondary, #78716c);margin:0 0 2px}._feedbackDot_81lyl_46{width:7px;height:7px;border-radius:50%;flex-shrink:0}._feedbackText_81lyl_53{font-family:var(--font-body, "Pretendard", sans-serif);font-size:14px;line-height:1.6;color:var(--feedback-pen-color, #b45309);background-image:repeating-linear-gradient(transparent,transparent 31px,var(--line-rule, #e8e4df) 31px,var(--line-rule, #e8e4df) 32px);padding:0 4px;margin:0}._prompt_81lyl_65{padding:0;margin:0;font-family:var(--font-content, "Lexend", sans-serif);font-size:var(--text-base);line-height:1.7;color:var(--text, #212121)}._promptRow_81lyl_74{display:flex;align-items:baseline;gap:6px;margin:0;font-family:var(--font-content, "Lexend", sans-serif);font-size:var(--text-base);line-height:1.7;color:var(--text, #212121)}._promptLabel_81lyl_85{flex-shrink:0}._promptEditable_81lyl_89{flex:1;outline:none;border:1px solid transparent;border-radius:2px;padding:0 2px;min-width:80px}._promptEditable_81lyl_89:focus{border-color:var(--btn-primary-bg, #44403C)}._promptEditable_81lyl_89:empty:before{content:attr(data-placeholder);color:var(--text-muted, #bbb);font-style:italic;pointer-events:none}._responseTypeSelect_81lyl_109{flex-shrink:0;padding:2px 6px;border:1px solid var(--border, rgba(0, 0, 0, .1));border-radius:var(--radius-sm, 8px);background:var(--bg-warm, #F5F3EE);font-family:var(--font-body, "Nunito", sans-serif);font-size:var(--text-sm, 13px);color:var(--text-secondary, #78716c);cursor:pointer;outline:none}._responseTypeSelect_81lyl_109:focus{border-color:var(--btn-primary-bg, #44403C)}._sparkyActions_81lyl_126{display:flex;justify-content:flex-end;padding:6px 12px 8px}._sparkyCheckBtn_81lyl_132{display:inline-flex;align-items:center;gap:6px;padding:0;background:none;border:none;font-family:var(--font-body);font-size:var(--text-base, 16px);font-weight:500;color:var(--text-primary, #1c1917);text-decoration:underline;text-underline-offset:3px;cursor:pointer}._sparkyCheckBtn_81lyl_132:hover{color:var(--text-secondary, #57534e)}._rubricLoading_81lyl_152{display:flex;align-items:center;justify-content:center;gap:8px;padding:24px 16px;margin:8px 12px;background:#f5f5f5;border-radius:6px;color:#666;font-size:12px}._spinner_81lyl_165{animation:_spin_81lyl_165 1s linear infinite}@keyframes _spin_81lyl_165{0%{transform:rotate(0)}to{transform:rotate(360deg)}}._rubricSection_81lyl_175{margin:4px 12px 8px}._rubricToggle_81lyl_179{display:flex;align-items:center;gap:4px;width:100%;padding:6px 8px;background:var(--bg-warm, #F5F3EE);border:1px solid var(--border, rgba(0, 0, 0, .06));border-radius:6px;font-size:12px;font-weight:600;color:var(--text-secondary, #666);cursor:pointer;transition:background .15s}._rubricToggle_81lyl_179:hover{background:var(--bg-hover, #F0EDEA)}._rubricToggleIcon_81lyl_199{font-size:10px;width:12px}.highlight-flash{animation:_highlight-flash_81lyl_205 6s ease-out}@keyframes _highlight-flash_81lyl_205{0%{background:#ffc8004d}to{background:transparent}}.collab-highlight{background:#ffc80066;border-radius:2px;padding:0 1px;animation:_collab-highlight-fade_81lyl_1 6s ease-out forwards}@keyframes _collab-highlight-fade_81lyl_1{0%,70%{background:#ffc80066}to{background:transparent}}@media print{._sparkyActions_81lyl_126,._rubricSection_81lyl_175,._rubricLoading_81lyl_152,._responseTypeSelect_81lyl_109{display:none!important}}._wrapper_2jbby_1{position:relative;margin:12px 0;border:1.5px dashed var(--brand, #009688);border-radius:6px;padding:8px;background:#00968805}._selected_2jbby_10{outline:2px solid var(--brand, #009688)}._canvasContainer_2jbby_14{border-radius:4px;overflow:hidden;border:1px solid var(--border-light, #EEEEEE);background:#fafafa}._wrapper_1pdmh_1{margin:8px 0;border-radius:8px;overflow:hidden}._selected_1pdmh_7{outline:2px solid var(--brand, #009688);border-radius:8px}._player_1pdmh_12{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--brand-light, #E0F2F1);border-radius:8px}._icon_1pdmh_21{color:var(--brand, #009688);flex-shrink:0}._audio_1pdmh_26{flex:1;height:32px}._duration_1pdmh_31{font-size:11px;color:var(--text-muted, #9E9E9E);font-family:var(--font-body, "Nunito", sans-serif)}._recorder_1pdmh_37{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--bg-warm, #F5F5F5);border:1.5px dashed var(--border, #E0E0E0);border-radius:8px;cursor:pointer}._recorderText_1pdmh_48{font-size:12px;color:var(--text-muted, #9E9E9E)}._wrapper_1b74c_1{margin:12px 0;border-radius:8px}._container_1b74c_10{display:flex;flex-direction:column;overflow:hidden;background:#fff}._actionBar_1b74c_18{display:flex;gap:8px;padding:10px 12px;background:#fafafa}._insertBtn_1b74c_25,._recordBtn_1b74c_26{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid #d1d5db;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;background:#fff;color:#374151}._insertBtn_1b74c_25:hover,._recordBtn_1b74c_26:hover{background:#f3f4f6;border-color:#9ca3af}._recordBtn_1b74c_26{border-color:#009688;color:#00796b}._recordBtn_1b74c_26:hover{background:#e0f2f1}._recordingBar_1b74c_56{display:flex;flex-direction:column;gap:8px;padding:12px 16px;background:#e0f2f1}._recordingTop_1b74c_64{display:flex;align-items:center;gap:12px}._recordingIndicator_1b74c_70{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:#00796b}._pulse_1b74c_79{width:10px;height:10px;border-radius:50%;background:#ef5350;animation:_pulse_1b74c_79 1s ease-in-out infinite;flex-shrink:0}@keyframes _pulse_1b74c_79{0%,to{opacity:1}50%{opacity:.3}}._timer_1b74c_93{font-variant-numeric:tabular-nums}._waveform_1b74c_97{display:flex;align-items:center;gap:2px;height:24px;flex:1}._bar_1b74c_105{width:3px;background:#009688;border-radius:1px;transition:height .08s ease-out;min-height:2px}._stopButton_1b74c_113{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;background:#009688;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;align-self:center}._stopButton_1b74c_113:hover{background:#00796b}._stopIcon_1b74c_133{width:12px;height:12px;background:#fff;border-radius:2px}._resultBar_1b74c_141{display:flex;justify-content:flex-end;padding:6px 10px;background:#fafafa}._resetBtn_1b74c_148{display:flex;align-items:center;gap:4px;padding:4px 10px;background:transparent;border:1px solid #d1d5db;border-radius:4px;font-size:12px;color:#6b7280;cursor:pointer}._resetBtn_1b74c_148:hover{background:#f3f4f6}._placeholder_1b74c_166{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#00968808;border:1.5px dashed #80CBC4;border-radius:8px;cursor:pointer;color:#009688;font-size:13px}._placeholder_1b74c_166:hover{background:#0096880f}._error_1b74c_184{padding:8px 12px;background:#fef2f2;color:#dc2626;font-size:13px}._root_252d1_1{padding:20px;max-width:900px;margin:0 auto}._grid_252d1_7{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}._card_252d1_14{position:relative;border:1px solid var(--border, rgba(0,0,0,.06));border-radius:var(--radius-sm, 8px);overflow:hidden;background:var(--card, #fff);box-shadow:var(--shadow-sm);cursor:grab}._card_252d1_14:active{cursor:grabbing}._dragHandle_252d1_26{position:absolute;top:4px;left:4px;color:#fff;opacity:0;background:#0000004d;border-radius:4px;padding:2px;cursor:grab;transition:opacity .15s;z-index:1}._card_252d1_14:hover ._dragHandle_252d1_26{opacity:1}._deleteBtn_252d1_42{position:absolute;top:4px;right:4px;background:#0006;color:#fff;border:none;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .15s;z-index:1}._card_252d1_14:hover ._deleteBtn_252d1_42{opacity:1}._deleteBtn_252d1_42:hover{background:#ef4444}._cardImg_252d1_64{width:100%;aspect-ratio:4 / 3;object-fit:cover;display:block}._captionInput_252d1_71{width:100%;border:none;border-top:1px solid var(--border, rgba(0,0,0,.06));padding:6px 8px;font-size:var(--text-sm, 13px);font-family:var(--font-ui);color:var(--text, #212121);background:transparent;outline:none}._captionInput_252d1_71:focus{border-color:var(--btn-primary-bg)}._captionInput_252d1_71::placeholder{color:var(--text-muted, #64748B)}._cardNumber_252d1_91{text-align:center;font-size:var(--text-xs, 11px);color:var(--text-muted, #64748B);padding:2px 0 6px}._actions_252d1_98{display:flex;gap:8px;align-items:center}._addBtn_252d1_104{display:flex;align-items:center;gap:4px;background:var(--btn-primary-bg);color:var(--btn-primary-text);border:none;border-radius:var(--radius-sm, 8px);padding:8px 16px;font-size:var(--text-sm, 13px);font-weight:600;cursor:pointer;transition:background .15s}._addBtn_252d1_104:hover{background:var(--btn-primary-hover)}._addBtn_252d1_104:disabled{opacity:.5;cursor:default}._uploadingText_252d1_122{font-size:var(--text-sm, 13px);color:var(--text-muted, #64748B)}._toolbar_118ia_6{display:flex;align-items:center;justify-content:center;gap:4px;padding:0;background:transparent;flex-wrap:wrap;flex-shrink:1;min-width:0;overflow:visible}._group_118ia_20{display:flex;align-items:center;gap:2px}._separator_118ia_26{width:1px;height:24px;background:var(--border);margin:0 4px;flex-shrink:0}._button_118ia_34{position:relative;display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:none;border-radius:4px;cursor:pointer;color:var(--text-secondary);transition:background var(--transition-fast, .12s ease);flex-shrink:0}._button_118ia_34:hover:not(:disabled){background:#f3f4f6}._button_118ia_34:disabled{opacity:.35;cursor:not-allowed}._button_118ia_34._active_118ia_60{background:#dbeafe;color:#2563eb}._saveExitBtn_118ia_65{display:flex;align-items:center;gap:5px;height:32px;padding:0 12px;background:#f3f4f6;border:1px solid var(--border, #e0e0e0);border-radius:6px;cursor:pointer;color:var(--text-secondary, #666);font-size:13px;font-weight:500;white-space:nowrap;transition:background .15s,color .15s;flex-shrink:0}._saveExitBtn_118ia_65:hover:not(:disabled){background:var(--btn-primary-bg);color:#fff;border-color:var(--btn-primary-bg)}._saveExitBtn_118ia_65:disabled{opacity:.35;cursor:not-allowed}._tealGroup_118ia_95{display:flex;align-items:center;gap:2px;background:#009688;border-radius:6px;padding:2px 4px}._tealButton_118ia_104{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:none;border-radius:4px;cursor:pointer;color:#fff;transition:background var(--transition-fast, .12s ease);flex-shrink:0}._tealButton_118ia_104:hover:not(:disabled){background:#fff3}._tealButton_118ia_104:disabled{opacity:.45;cursor:not-allowed}._dropdownWrapper_118ia_131{position:relative}._dropdown_118ia_131{position:absolute;top:100%;left:0;margin-top:4px;background:#fff;border:1px solid var(--border, #E5E7EB);border-radius:6px;box-shadow:0 4px 12px #0000001a;padding:4px;z-index:20;min-width:140px}._dropdownItem_118ia_149{display:block;width:100%;padding:6px 12px;border:none;background:transparent;border-radius:4px;font-size:13px;text-align:left;cursor:pointer;color:var(--text, #212121)}._dropdownItem_118ia_149:hover{background:#f3f4f6}._colorSection_118ia_168{padding:8px 10px 4px}._colorLabel_118ia_172{display:block;font-size:10px;font-weight:600;color:var(--text-muted, #94A3B8);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}._colorDivider_118ia_182{height:1px;background:var(--border-light, #EEEEEE);margin:2px 10px}._colorGrid_118ia_188{display:flex;gap:4px;flex-wrap:wrap}._colorSwatch_118ia_194{width:22px;height:22px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0;background:none;transition:transform .12s ease}._colorSwatch_118ia_194:hover{border-color:var(--text-secondary, #6B7280);transform:scale(1.15)}._colorSwatchActive_118ia_210{border-color:var(--btn-primary-bg);box-shadow:0 0 0 1px var(--btn-primary-bg)}._colorSwatchReset_118ia_215{border:1px dashed var(--border, #E5E1DB);font-size:12px;line-height:1;color:var(--text-muted, #94A3B8);display:flex;align-items:center;justify-content:center}._colorSwatchBg_118ia_225{border:1px solid var(--border, #E5E1DB);border-radius:4px}._colorDot_118ia_230{position:absolute;bottom:2px;left:50%;transform:translate(-50%);width:6px;height:6px;border-radius:50%}._linkInput_118ia_242{display:block;width:100%;padding:6px 8px;border:1px solid var(--border, #E5E7EB);border-radius:4px;font-size:13px;outline:none;box-sizing:border-box}._linkInput_118ia_242:focus{border-color:var(--btn-primary-bg)}._linkActions_118ia_257{display:flex;gap:4px;margin-top:6px}._linkApply_118ia_263,._linkRemove_118ia_264{flex:1;padding:4px 8px;border:none;border-radius:4px;font-size:12px;cursor:pointer}._linkApply_118ia_263{background:var(--btn-primary-bg);color:#fff}._linkApply_118ia_263:hover{opacity:.9}._linkRemove_118ia_264{background:#f3f4f6;color:var(--text, #212121)}._linkRemove_118ia_264:hover{background:#e5e7eb}._navigator_1vwhz_1{display:flex;flex-direction:column;gap:4px;padding:58px 0 0}._toggleButton_1vwhz_9{display:flex;align-items:center;justify-content:center;width:44px;height:44px;margin:4px auto;border:none;background:transparent;border-radius:var(--radius-sm, 8px);color:var(--text-secondary, #6B7280);cursor:pointer;transition:all .15s}._toggleButton_1vwhz_9:hover{color:var(--text, #212121);background:var(--bg-hover, rgba(0, 0, 0, .04))}._pageList_1vwhz_29{display:flex;flex-direction:column;gap:4px;align-items:stretch;padding:0 8px}._pageThumb_1vwhz_37{background:#fff;border-radius:3px;padding:2px;aspect-ratio:210 / 297;width:100%;cursor:pointer;border:2px solid transparent;box-shadow:0 1px 2px #00000014;transition:border-color .15s}._pageThumb_1vwhz_37:hover{border-color:var(--border, #E5E7EB)}._active_1vwhz_54{border-color:var(--btn-primary-bg)}._thumbContent_1vwhz_58{height:100%;overflow:hidden;position:relative}._thumbScale_1vwhz_65{width:816px;transform-origin:top left;transform:scale(.22);font-family:var(--font-content, "Lexend", sans-serif);font-size:13.33px;line-height:1.45;color:var(--text, #212121);pointer-events:none;-webkit-user-select:none;user-select:none;padding:96px 100px 110px;box-sizing:border-box}._thumbScale_1vwhz_65 img{max-width:100%;height:auto}._thumbScale_1vwhz_65 h1{font-size:28px;font-weight:700;margin:.5em 0 .2em}._thumbScale_1vwhz_65 h2{font-size:22px;font-weight:700;margin:.4em 0 .2em}._thumbScale_1vwhz_65 h3{font-size:18px;font-weight:600;margin:.3em 0 .2em}._thumbScale_1vwhz_65 p{margin-bottom:.3em}._thumbScale_1vwhz_65 table{border-collapse:collapse;width:100%}._thumbScale_1vwhz_65 th,._thumbScale_1vwhz_65 td{border:1px solid #D1D5DB;padding:4px 8px;font-size:12px}._thumbScale_1vwhz_65 th{background:#f3f4f6;font-weight:600}._pageNumber_1vwhz_92{text-align:center;font-size:9px;color:var(--text-muted, #9CA3AF);margin:2px 0 6px}._addPage_1vwhz_99{border:1.5px dashed var(--border, #D1D5DB);border-radius:3px;aspect-ratio:210 / 297;width:100%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted, #9CA3AF);font-size:16px;transition:border-color .15s,color .15s}._addPage_1vwhz_99:hover{border-color:var(--btn-primary-bg);color:var(--btn-primary-bg)}._root_1g4k3_3{display:flex;flex-direction:column;gap:16px;padding:12px 16px;overflow-y:auto;max-height:calc(100vh - 180px)}._empty_1g4k3_12{color:var(--text-muted, #a8a29e);font-size:var(--text-sm, 13px);font-family:var(--font-body, "Nunito", sans-serif);text-align:center;padding:32px 0}._dayGroup_1g4k3_20{display:flex;flex-direction:column;gap:2px}._dayLabel_1g4k3_26{font-size:var(--text-xs, 11px);font-family:var(--font-body, "Nunito", sans-serif);color:var(--text-muted, #a8a29e);text-transform:uppercase;letter-spacing:.05em;padding:4px 0;margin-bottom:2px}._editItem_1g4k3_36{display:flex;align-items:flex-start;gap:8px;padding:6px 8px;border-radius:6px;cursor:default;transition:background .15s}._editItem_1g4k3_36[data-clickable=true]{cursor:pointer}._editItem_1g4k3_36[data-clickable=true]:hover{background:var(--bg-hover, #f5f5f4)}._avatar_1g4k3_54{flex-shrink:0;width:28px;height:28px;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:var(--text-xs, 11px);font-weight:700;font-family:var(--font-body, "Nunito", sans-serif);color:#fff;background:var(--btn-primary-bg, #44403C)}._avatar_1g4k3_54 img{width:100%;height:100%;object-fit:cover}._body_1g4k3_76{flex:1;min-width:0}._actionLine_1g4k3_81{font-size:var(--text-sm, 13px);font-family:var(--font-body, "Nunito", sans-serif);color:var(--text-primary, #1c1917);line-height:1.4}._userName_1g4k3_88{font-weight:700}._actionLabel_1g4k3_92{color:var(--text-secondary, #78716c)}._summary_1g4k3_96{font-size:var(--text-xs, 11px);font-family:var(--font-body, "Nunito", sans-serif);color:var(--text-muted, #a8a29e);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}._time_1g4k3_106{flex-shrink:0;font-size:var(--text-xs, 11px);font-family:var(--font-body, "Nunito", sans-serif);color:var(--text-muted, #a8a29e);padding-top:2px}._overlay_bste9_1{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100}._modal_bste9_11{background:#fff;border-radius:12px;padding:28px 32px;width:380px;max-width:90vw;box-shadow:0 8px 32px #0000002e}._title_bste9_20{font-size:17px;font-weight:700;color:var(--text, #212121);margin-bottom:8px}._body_bste9_27{font-size:14px;color:var(--text-secondary, #6B7280);margin-bottom:24px;line-height:1.5}._actions_bste9_34{display:flex;gap:8px;justify-content:flex-end}._discardBtn_bste9_40{padding:8px 14px;border:1px solid var(--border, #E5E7EB);border-radius:6px;background:#fff;color:#ef5350;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}._discardBtn_bste9_40:hover{background:#fff5f5;border-color:#ef5350}._discardBtn_bste9_40:disabled{opacity:.5;cursor:not-allowed}._cancelBtn_bste9_62{padding:8px 14px;border:1px solid var(--border, #E5E7EB);border-radius:6px;background:#fff;color:var(--text-secondary, #6B7280);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}._cancelBtn_bste9_62:hover{background:var(--bg-warm, #F5F5F5)}._cancelBtn_bste9_62:disabled{opacity:.5;cursor:not-allowed}._saveBtn_bste9_83{padding:8px 16px;border:none;border-radius:6px;background:#009688;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}._saveBtn_bste9_83:hover{background:#00796b}._saveBtn_bste9_83:disabled{opacity:.5;cursor:not-allowed}._loading_1cyf8_3,._loadError_1cyf8_4{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-muted, #9E9E9E);font-size:14px}._loadError_1cyf8_4{color:#ef5350}._saveError_1cyf8_17{position:fixed;top:56px;left:50%;transform:translate(-50%);z-index:100;display:flex;align-items:center;gap:8px;padding:8px 16px;background:#fff3e0;border:1px solid #FF9800;border-radius:6px;color:#e65100;font-size:13px}._saveError_1cyf8_17 button{background:none;border:none;cursor:pointer;font-size:16px;color:#e65100;padding:0 4px}._editor_1cyf8_43{display:flex;flex-direction:column;height:100%}._editor_1cyf8_43[data-mode=answer],._editor_1cyf8_43[data-mode=feedback],._editor_1cyf8_43[data-mode=view]{display:block;height:auto}._unifiedBar_1cyf8_57{display:flex;align-items:center;justify-content:center;gap:8px;padding:4px 0;flex-shrink:0;min-height:42px;border-bottom:1px solid var(--border-light, #EEEEEE);margin-bottom:var(--space-md, 16px);position:sticky;top:calc(-1 * var(--space-lg, 24px));margin-top:calc(-1 * var(--space-lg, 24px));padding-top:calc(var(--space-lg, 24px) + 4px);background:var(--bg, #FAFAFA);z-index:5}._a4Page_1cyf8_77{flex:1;width:100%;max-width:816px;margin:0 auto;background:var(--bg, #FAFAF8);border:1px solid var(--border-light, #EEEEEE);border-radius:4px;padding:53px 62px 67px;min-height:1056px;font-family:var(--font-content, "Lexend", sans-serif)}._editor_1cyf8_43[data-mode=answer] ._a4Page_1cyf8_77,._editor_1cyf8_43[data-mode=feedback] ._a4Page_1cyf8_77,._editor_1cyf8_43[data-mode=view] ._a4Page_1cyf8_77{max-width:800px;min-height:auto;border:none;border-radius:0;padding:24px;margin:0 auto;background:transparent}._readingContent_1cyf8_105{outline:none;min-height:400px;transform:scale(1.15);transform-origin:top left;width:87%}._readingContent_1cyf8_105 hr[data-page-break]{border:none;border-top:2px dashed var(--border, #D1D5DB);margin:32px 0;page-break-after:always}._readingContent_1cyf8_105 img{max-width:100%;height:auto;cursor:pointer}._readingContent_1cyf8_105 p{margin-right:0!important}._readingContent_1cyf8_105 table{width:100%!important}._a4Page_1cyf8_77 .tiptap,._a4Page_1cyf8_77 .ProseMirror{outline:none;min-height:400px;font-family:var(--font-content, "Lexend", sans-serif);font-size:13.33px;line-height:1.4;color:var(--text, #212121)}._a4Page_1cyf8_77 .ProseMirror p{margin-bottom:.5em}._a4Page_1cyf8_77 .ProseMirror h1{font-family:var(--font-heading);font-size:21.33px;font-weight:700;margin:1em 0 .4em;line-height:1.3}._a4Page_1cyf8_77 .ProseMirror h2{font-family:var(--font-heading);font-size:17.33px;font-weight:700;margin:.8em 0 .3em;line-height:1.3}._a4Page_1cyf8_77 .ProseMirror h3{font-family:var(--font-heading);font-size:14.67px;font-weight:600;margin:.7em 0 .3em;line-height:1.4}._a4Page_1cyf8_77 .ProseMirror h4{font-family:var(--font-heading);font-size:13.33px;font-weight:600;margin:.6em 0 .2em;line-height:1.4}._a4Page_1cyf8_77 .ProseMirror img{max-width:70%;height:auto}._a4Page_1cyf8_77 .ProseMirror ul,._a4Page_1cyf8_77 .ProseMirror ol{padding-left:24px;margin-bottom:.5em}._a4Page_1cyf8_77 .ProseMirror li{margin-bottom:.2em}._a4Page_1cyf8_77 .ProseMirror ul{list-style:disc}._a4Page_1cyf8_77 .ProseMirror ol{list-style:decimal}._a4Page_1cyf8_77 .ProseMirror blockquote{border-left:3px solid var(--border, #E5E7EB);padding-left:16px;color:var(--text-secondary, #6B7280);margin:.5em 0}._a4Page_1cyf8_77 .ProseMirror code{background:#f3f4f6;padding:2px 4px;border-radius:3px;font-size:13px}._a4Page_1cyf8_77 .ProseMirror pre{background:#f3f4f6;color:var(--text, #212121);padding:16px;border-radius:6px;border:1px solid var(--border-light, #EEEEEE);overflow-x:auto;font-size:13px;margin:.5em 0}._a4Page_1cyf8_77 .ProseMirror img{max-width:100%;height:auto;border-radius:var(--radius-md);cursor:pointer}._a4Page_1cyf8_77 .ProseMirror img.ProseMirror-selectednode{outline:2px solid var(--btn-primary-bg);outline-offset:2px}._a4Page_1cyf8_77 .ProseMirror div:has(>div>img[data-align=left]){display:flex;justify-content:flex-start}._a4Page_1cyf8_77 .ProseMirror div:has(>div>img[data-align=center]){display:flex;justify-content:center}._a4Page_1cyf8_77 .ProseMirror div:has(>div>img[data-align=right]){display:flex;justify-content:flex-end}._a4Page_1cyf8_77 .ProseMirror div:has(>div>img[data-float=left]){float:left;margin:0 16px 8px 0}._a4Page_1cyf8_77 .ProseMirror div:has(>div>img[data-float=right]){float:right;margin:0 0 8px 16px}._a4Page_1cyf8_77 .ProseMirror [data-resize-handle]{width:10px;height:10px;background:var(--btn-primary-bg);border:2px solid white;border-radius:50%;z-index:10}._imageMenuAnchored_1cyf8_269{position:absolute;top:-40px;left:50%;transform:translate(-50%);z-index:20;display:flex;align-items:center;gap:2px;padding:4px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000026;border:1px solid var(--border-light, #EEEEEE);white-space:nowrap;pointer-events:auto}._imageBubbleBtn_1cyf8_287{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;border-radius:4px;cursor:pointer;font-size:14px;color:var(--text-secondary, #4A4A48);transition:background .12s ease}._imageBubbleBtn_1cyf8_287:hover{background:#f3f4f6}._imageBubbleBtnActive_1cyf8_306{background:#f5f5f4;color:var(--btn-primary-bg)}._imageBubbleDivider_1cyf8_311{width:1px;height:18px;background:var(--border-light, #EEEEEE);margin:0 2px}._tableContextMenu_1cyf8_319{position:fixed;z-index:50;min-width:200px;background:#fff;border-radius:8px;box-shadow:0 4px 16px #0000001f;border:1px solid var(--border-light, #EEEEEE);padding:4px 0}._tableContextItem_1cyf8_330{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:transparent;font-size:13px;color:var(--text, #212121);cursor:pointer;font-family:var(--font-body, "Nunito", sans-serif)}._tableContextItem_1cyf8_330:hover{background:#f3f4f6}._tableContextDivider_1cyf8_348{height:1px;background:var(--border-light, #EEEEEE);margin:4px 0}._a4Page_1cyf8_77 .ProseMirror hr{border:none;border-top:1px solid var(--border, #E5E7EB);margin:1em 0}._a4Page_1cyf8_77 .ProseMirror div[data-page-break]{margin:0 -48px;height:8px;background:var(--bg, #FAFAFA);border-top:1px solid #D9D9D9;border-bottom:1px solid #D9D9D9;-webkit-user-select:none;user-select:none;cursor:default}._printHeader_1cyf8_372{display:none}@media print{._printHeader_1cyf8_372{display:flex;align-items:flex-end;gap:24px;padding-bottom:10px;margin-bottom:18px;border-bottom:1.5px solid #333;font-family:var(--font-content, "Lexend", sans-serif);font-size:12px;color:#1a1a1a}._printHeaderTitle_1cyf8_388{flex:1;font-family:var(--font-display, "Fredoka One", sans-serif);font-size:18px}._printHeaderField_1cyf8_393{display:flex;align-items:flex-end;gap:8px;white-space:nowrap}._printHeaderField_1cyf8_393>span:first-child{font-weight:600}._printHeaderLine_1cyf8_402{display:inline-block;width:160px;border-bottom:1.5px solid #333;height:0}}@media print{._editor_1cyf8_43{display:block}._unifiedBar_1cyf8_57{display:none}._a4Page_1cyf8_77{padding:0;border:none;background:#fff}._a4Page_1cyf8_77 .ProseMirror{padding:0;border:none;box-shadow:none}._a4Page_1cyf8_77 .ProseMirror div[data-page-break]{height:0;margin:0;padding:0;border:none;background:none;page-break-after:always;break-after:page}._a4Page_1cyf8_77 .ProseMirror div[data-page-break]:after{display:none}}._a4Page_1cyf8_77 .ProseMirror a{color:var(--btn-primary-bg);text-decoration:underline}._a4Page_1cyf8_77 .ProseMirror .tableWrapper{overflow-x:auto;margin:.5em 0}._a4Page_1cyf8_77 .ProseMirror table{border-collapse:collapse;width:100%;table-layout:fixed}._a4Page_1cyf8_77 .ProseMirror th,._a4Page_1cyf8_77 .ProseMirror td{border:1.5px solid #D1D5DB;padding:10px 14px;text-align:left;vertical-align:top;min-width:80px;position:relative}._a4Page_1cyf8_77 .ProseMirror th{background:#f3f4f6;font-weight:600}._a4Page_1cyf8_77 .ProseMirror td>p,._a4Page_1cyf8_77 .ProseMirror th>p{margin:0}._a4Page_1cyf8_77 .ProseMirror .selectedCell{background:#44403c14}._a4Page_1cyf8_77 .ProseMirror p._is-editor-empty_1cyf8_484:first-child:before{content:attr(data-placeholder);float:left;color:var(--text-placeholder, #94A3B8);pointer-events:none;height:0}._panelTabs_1cyf8_493{display:flex;gap:0;border-bottom:1px solid var(--border-light, #f3f4f6);padding:0 12px;flex-shrink:0}._panelTab_1cyf8_493{flex:1;padding:8px 0;border:none;background:transparent;font-family:var(--font-body, "Nunito", sans-serif);font-size:var(--text-sm, 13px);font-weight:600;color:var(--text-muted, #a8a29e);cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s;text-align:center}._panelTab_1cyf8_493:hover{color:var(--text-secondary, #78716c)}._panelTabActive_1cyf8_520{color:var(--text-primary, #1c1917);border-bottom-color:var(--btn-primary-bg, #44403C)}._photoTopBar_1cyf8_526{display:flex;align-items:center;gap:12px;padding:12px 20px;border-bottom:1px solid var(--border, rgba(0,0,0,.06))}._photoTitle_1cyf8_534{flex:1;font-size:var(--text-lg, 22px);font-family:var(--font-heading);font-weight:600;color:var(--text, #212121);border:none;background:transparent;outline:none;padding:0}._photoTitle_1cyf8_534::placeholder{color:var(--text-muted, #64748B)}._saveExitBtn_1cyf8_551{display:flex;align-items:center;gap:5px;height:32px;padding:0 12px;background:#f3f4f6;border:1px solid var(--border, #e0e0e0);border-radius:6px;cursor:pointer;color:var(--text-secondary, #666);font-size:13px;font-weight:500;white-space:nowrap;transition:background .15s,color .15s}._saveExitBtn_1cyf8_551:hover{background:var(--btn-primary-bg);color:#fff;border-color:var(--btn-primary-bg)}.artifacts-page{max-width:800px;margin:0 auto;padding:24px}.artifacts-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.artifacts-title{font-size:1.5rem;font-weight:700;margin:0}.artifacts-print-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:#1a1a1a;color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer}.artifacts-print-btn:hover{background:#333}.artifacts-filters{display:flex;gap:8px;margin-bottom:20px}.artifacts-filter-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border:1px solid #e2e8f0;border-radius:20px;background:#fff;font-size:.8rem;font-weight:500;color:#718096;cursor:pointer;transition:all .12s}.artifacts-filter-btn:hover{border-color:#a0aec0;color:#4a5568}.artifacts-filter-btn.active{background:#1a202c;color:#fff;border-color:#1a202c}.artifacts-list{display:flex;flex-direction:column;gap:8px}.artifact-card{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border:1px solid #e2e8f0;border-radius:10px;background:#fff;cursor:pointer;transition:background .12s;text-align:left}.artifact-card:hover{background:#f7fafc}.artifact-card-left{display:flex;align-items:center;gap:10px;min-width:0}.artifact-card-icon{flex-shrink:0;color:#a0aec0}.artifact-card-title{font-size:.95rem;font-weight:600;color:#1a202c}.artifact-card-meta{display:flex;align-items:center;gap:12px;flex-shrink:0}.artifact-level{font-size:.8rem;font-weight:700}.artifact-date{font-size:.8rem;color:#a0aec0}.artifacts-empty,.artifacts-loading,.artifacts-error{padding:60px 0;text-align:center;color:#a0aec0;font-size:.95rem}.artifacts-detail-toolbar{display:flex;justify-content:space-between;align-items:center;padding:8px 16px;border-bottom:1px solid #e2e8f0}.artifact-back-btn{display:inline-flex;align-items:center;gap:4px;background:none;border:none;color:#4a5568;font-size:.85rem;cursor:pointer}.artifact-back-btn:hover{color:#1a202c}.artifacts-print-header,.artifacts-print-toc{display:none}@media print{.artifacts-print-header{display:block!important;margin-bottom:12px}.artifacts-print-title{font-size:18pt;font-weight:700;margin:0 0 4px}.artifacts-print-meta{font-size:11pt;color:#666;margin:0 0 8px}.artifacts-print-toc{display:block!important;page-break-after:always}.print-header{display:none!important}}:root{--bg-main: #ffffff;--bg-sidebar: #F2F2F1;--bg-sidebar-hover: #E8E8E6;--bg-elevated: #f7f6f3;--text-primary: #2d2b27;--text-muted: #656360;--text-placeholder: #8a8985;--accent-primary: #8b5cf6;--accent-primary-hover: #7c3aed;--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: #4a4a48;--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{height:auto;max-height:40px;width:auto;max-width:160px;object-fit:contain}.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)}.header-icon-btn{position:relative;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:8px;background:transparent;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s}.header-icon-btn:hover{background:var(--bg-sidebar-hover);color:var(--text-primary)}.header-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;line-height:16px;text-align:center}.course-selector{padding:0;border:none;font-size:13px;background:none}.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))}body[data-role=professor] .app-layout.simulator-mode .right-panel,body[data-role=instructor] .app-layout.simulator-mode .right-panel,body[data-role=admin] .app-layout.simulator-mode .right-panel{display:flex;visibility:hidden;pointer-events:none}#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);height:100vh;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,.nav-item .badge{margin-left:auto;background:var(--text-muted);color:#fff;font-size:11px;min-width:20px;height:20px;border-radius:10px;font-weight:500;display:inline-flex;align-items:center;justify-content:center;padding:0 6px;line-height:1;box-sizing:border-box}.badge-warning{background:var(--level-orange)}.nav-new-dot{margin-left:auto;width:8px;height:8px;border-radius:50%;background:#ef4444;flex-shrink:0}.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:var(--spacing-sm) var(--spacing-md);background:var(--bg-white);min-width:0}.view{display:none}.view.active{display:block}.view>.page-header{padding-left:max(var(--spacing-lg),calc((100% - 1200px)/2));padding-right:max(var(--spacing-lg),calc((100% - 1200px)/2))}.view-content{padding:0 var(--spacing-lg) 60px}.view-inner{max-width:1200px;margin:0 auto}.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:center;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;z-index:0}.modal-content{position:relative;z-index:1;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)}.student-detail-modal{max-width:860px;max-height:85vh}.student-detail-loading,.student-detail-error{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px 0;color:var(--text-muted);font-size:14px}.student-detail-avatar{width:36px;height:36px;border-radius:50%;background:var(--accent-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;flex-shrink:0}.student-detail-section{margin-bottom:20px}.student-detail-section-title{font-size:14px;font-weight:600;color:var(--text-primary);margin:0 0 12px;display:flex;align-items:center;gap:8px}.section-count{font-size:11px;font-weight:500;color:var(--text-muted);background:var(--bg-elevated);padding:2px 8px;border-radius:10px}.student-detail-empty{font-size:13px;color:var(--text-muted);padding:16px;text-align:center;background:var(--bg-elevated);border-radius:var(--radius-sm)}.sd-scroll-content{display:flex;flex-direction:column;gap:4px}.sd-summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:20px}.sd-summary-card{background:var(--bg-elevated);border-radius:var(--radius-md);padding:14px 10px;text-align:center}.sd-summary-value{font-size:20px;font-weight:700;color:var(--text-primary)}.sd-summary-label{font-size:11px;color:var(--text-muted);margin-top:4px}.sd-summary-sub{font-size:10px;color:var(--text-muted);margin-top:2px}.sd-table{width:100%;border-collapse:collapse;font-size:13px}.sd-table th{text-align:left;font-weight:600;color:var(--text-muted);font-size:11px;text-transform:uppercase;letter-spacing:.5px;padding:8px 10px;border-bottom:1px solid var(--border-light)}.sd-table td{padding:8px 10px;border-bottom:1px solid var(--border-light);color:var(--text-primary)}.sd-table tr:last-child td{border-bottom:none}.sd-progress-bar{width:60px;height:6px;background:var(--bg-elevated);border-radius:3px;overflow:hidden}.sd-progress-fill{height:100%;border-radius:3px;transition:width .3s ease}.sd-status{font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px}.sd-status.submitted{background:#e6f5f0;color:#0f7b6c}.sd-status.draft{background:#f7f6f3;color:#9b9a97}.sd-section-tabs{display:flex;gap:0;border-bottom:1px solid var(--border-light);margin-bottom:12px}.sd-section-tab{background:none;border:none;padding:8px 14px;font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.sd-section-tab:hover{color:var(--text-primary)}.sd-section-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.sd-xp-list{display:flex;flex-direction:column}.sd-xp-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border-light)}.sd-xp-item:last-child{border-bottom:none}.sd-xp-info{display:flex;flex-direction:column;gap:2px}.sd-xp-reason{font-size:13px;color:var(--text-primary)}.sd-xp-meta{font-size:11px;color:var(--text-muted)}.sd-chat-summary{font-size:12px;color:var(--text-muted);padding:8px 0;border-bottom:1px solid var(--border-light);margin-bottom:4px}.sd-week-table-wrap{overflow-x:auto}.sd-week-table th,.sd-week-table td{text-align:center;vertical-align:middle}.sd-col-week{width:50px;white-space:nowrap}.sd-col-video{min-width:90px}.sd-col-ws{min-width:70px}.sd-col-eval,.sd-col-xp{min-width:56px}.sd-cell-stack{display:flex;flex-direction:column;align-items:center;gap:3px}.sd-cell-row{display:flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap}.sd-cell-sub{font-size:11px;color:var(--text-muted)}.sd-cell-empty{color:#d3d1cb;font-size:12px}.sd-cell-none{color:#c4c3bf;font-size:11px}.sd-row-empty td{background:var(--bg-elevated);opacity:.55}.sd-eval-badge{display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px;white-space:nowrap}.sd-xp-amount{font-size:13px;font-weight:700}.sd-xp-amount.positive,.sd-xp-amount.negative{color:var(--text-muted)}.sd-week-table .sd-xp-amount{color:var(--text-muted);font-size:11px;font-weight:400}.sd-week-table .sd-xp-amount.positive,.sd-week-table .sd-xp-amount.negative{color:var(--text-muted)}.step-eval-grid{display:flex;flex-wrap:wrap;gap:8px}.step-eval-item{display:flex;align-items:center;gap:6px;padding:6px 10px;background:var(--bg-elevated);border-radius:var(--radius-sm);font-size:13px}.step-eval-step{font-weight:600;color:var(--text-primary)}.step-eval-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px}.misconception-list{display:flex;flex-direction:column;gap:8px}.misconception-item{padding:12px;background:var(--bg-elevated);border-radius:var(--radius-sm);border-left:3px solid #e03e3e}.misconception-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.misconception-step{font-size:12px;font-weight:600;color:var(--text-primary)}.misconception-date{font-size:11px;color:var(--text-muted)}.misconception-content{font-size:13px;color:var(--text-secondary);line-height:1.5}.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;display:flex;align-items:baseline;gap:4px}.kpi-meta{display:flex;align-items:center;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.kpi-unit{font-size:14px;font-weight:500;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}.info-popover-wrapper{position:relative;display:inline-flex;align-items:center;margin-left:4px}.info-popover-btn{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:2px;display:inline-flex;align-items:center;opacity:.4;transition:opacity .15s}.info-popover-btn:hover{opacity:1}.info-popover-content{position:absolute;top:calc(100% + 8px);left:0;width:280px;padding:12px 14px;background:var(--bg-white, #fff);border:1px solid var(--border-light);border-radius:8px;box-shadow:0 8px 24px #0000001f;font-size:12px;line-height:1.6;color:var(--text-primary);z-index:100;white-space:pre-line}.section-title .info-popover-wrapper{vertical-align:middle}.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)}.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)}.custom-select-wrap{position:relative;display:inline-block}.custom-select{appearance:none;-webkit-appearance:none;padding:7px 34px 7px 14px;font-size:13px;font-weight:500;color:#374151;background:#fff;border:1px solid #e5e7eb;border-radius:10px;cursor:pointer;min-width:150px;outline:none;transition:border-color .15s,box-shadow .15s}.custom-select:hover{border-color:#c7c9ce}.custom-select:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px #6366f11a}.custom-select-icon{position:absolute;right:11px;top:50%;transform:translateY(-50%);pointer-events:none;color:#9ca3af;transition:color .15s}.custom-select-wrap:hover .custom-select-icon{color:#6b7280}.custom-select option{font-size:13px;font-weight:500;color:#374151;background:#fff;padding:8px 12px}.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}#assignments-view>.page-header{padding-left:max(var(--spacing-lg),calc((100% - 800px)/2));padding-right:max(var(--spacing-lg),calc((100% - 800px)/2))}#assignments-view .week-timeline-15{max-width:800px;margin-left:auto;margin-right:auto}.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:none}.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:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.week-timeline-15 .timeline-node.active .node-label{color:var(--accent-primary);font-weight:600}.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;max-width:800px;margin:16px auto 0;padding:14px 20px;background:linear-gradient(135deg,#f9f9f9,#f3f4f6);border:1px solid var(--border-light);border-radius:10px;position:sticky;top:0;z-index:10}.viewer-header-left{display:flex;flex-direction:column;gap:4px}.viewer-student-name{font-size:16px;font-weight:600;color:var(--text-primary)}.viewer-members{font-size:13px;color:var(--text-muted)}.viewer-header-right{display:flex;flex-direction:column;align-items:flex-end;gap:3px}.viewer-submit-status{font-size:13px;font-weight:600;color:var(--text-primary)}.viewer-submit-date{font-size:12px;color:var(--text-muted)}.worksheet-viewer{min-height:400px}.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);box-shadow:inset 1px 0 0 var(--border-light),inset -1px 0 0 var(--border-light)}#right-panel-roster .student-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}#right-panel-roster .student-status-dot.submitted{background:#0d9488}#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)}#right-panel-roster .student-status-area{display:flex;align-items:center;gap:4px;flex-shrink:0}#right-panel-roster .student-status-badge{font-size:11px;font-weight:500;padding:2px 6px;border-radius:4px;white-space:nowrap}#right-panel-roster .student-status-badge.not-submitted{background:var(--bg-elevated);color:var(--text-muted)}#right-panel-roster .student-status-badge.submitted{background:#f0fdfa;color:#0d9488}#right-panel-roster .student-status-badge.delivered{background:#e3f2fd;color:var(--accent-primary)}#right-panel-roster .student-member-count{font-size:11px;color:var(--text-muted)}.btn-deliver-team{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:1px solid var(--accent-primary);border-radius:4px;background:#fff;color:var(--accent-primary);cursor:pointer;transition:all .15s ease;flex-shrink:0;margin-left:2px}.btn-deliver-team:hover{background:var(--accent-primary);color:#fff}.btn-deliver-team:disabled{opacity:.5;cursor:not-allowed}.deliver-spinner{width:10px;height:10px;border:2px solid var(--border-light);border-top-color:var(--accent-primary);border-radius:50%;animation:deliver-spin .6s linear infinite}@keyframes deliver-spin{to{transform:rotate(360deg)}}.submission-summary-compact .summary-item.delivered .summary-value{color:#3b82f6}@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(--text-primary)}.submission-summary-compact .summary-item.not-submitted .summary-value{color:#e54d2e}.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}.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-timeline{margin-bottom:20px}.team-timeline .timeline-week{min-width:60px}.team-timeline .timeline-connector{margin-top:-44px}.team-tl-bar{width:36px;height:4px;background:var(--border-light, #e0e0e0);border-radius:2px;overflow:hidden;margin-top:4px}.team-tl-bar-fill{height:100%;background:var(--accent-primary, #8b5cf6);border-radius:2px;transition:width .3s}.team-tl-rate{font-size:10px;font-weight:600;color:var(--text-muted, #656360);margin-top:2px}.team-timeline .timeline-week.selected .team-tl-rate{color:var(--accent-primary, #8b5cf6)}.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,.team-stat-card.stat-blue .stat-value,.team-stat-card.stat-orange .stat-value,.team-stat-card.stat-xp .stat-value{color:var(--text-primary)}.team-list-container{display:flex;flex-direction:column;gap:14px}.team-gallery{display:grid;grid-template-columns:1fr;gap:16px}.team-gallery-card{display:flex;align-items:stretch;gap:16px;background:var(--bg-main);border:1px solid var(--border-light);border-radius:10px;padding:16px;transition:box-shadow .2s}.team-gallery-card:hover{box-shadow:0 2px 12px #00000012}.tg-info{flex:1;min-width:0}.tg-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.tg-name{font-size:15px;font-weight:600;color:var(--text-primary)}.tg-meta{display:flex;gap:14px;font-size:13px;color:var(--text-muted);margin-bottom:8px}.tg-donut{position:relative;flex-shrink:0;width:56px;display:flex;align-items:center;justify-content:center}.tg-donut-svg{width:56px;height:56px}.tg-donut-label{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--text-primary)}.tg-toolbar{display:flex;align-items:center;gap:24px;margin-bottom:14px}.tg-search{width:220px;flex-shrink:0;margin-right:120px}.tg-filter-tabs{display:flex;align-items:center;gap:6px}.tg-filter-tab{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;font-size:13px;font-weight:500;color:var(--text-muted);background:var(--bg-sidebar);border:1px solid var(--border-light);border-radius:20px;cursor:pointer;transition:all .15s}.tg-filter-tab:hover{color:var(--text-primary);border-color:var(--text-muted)}.tg-filter-tab.active{color:var(--accent-primary);background:var(--bg-main);border-color:var(--accent-primary);font-weight:600}.tg-filter-count{font-size:11px;font-weight:600;color:var(--text-muted);background:var(--border-light);border-radius:10px;padding:1px 6px;min-width:18px;text-align:center}.tg-filter-tab.active .tg-filter-count{color:var(--accent-primary);background:#6366f11a}.tg-filter-refresh{margin-left:auto}.tg-members{display:flex;flex-direction:column;gap:4px;padding-top:10px}.tg-member-row{display:flex;align-items:baseline;gap:8px}.tg-member-name{font-size:13px;color:var(--text-primary);font-weight:500}.tg-member-info{font-size:13px;color:var(--text-secondary)}.tg-member-stats{font-size:12px;color:var(--text-muted);margin-left:4px;white-space:nowrap}.tg-no-members{font-size:12px;color:var(--text-muted)}.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-icon-lucide{color:var(--accent-primary);flex-shrink:0}.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}.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(--text-muted)}.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:var(--border-light);background:var(--bg-main)}.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(--text-muted)}.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 150px 60px 48px;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:hover{border-color:var(--accent-primary);box-shadow:0 2px 8px #0000000d}.week-schedule-item.locked{background:var(--bg-sidebar);opacity:.8}.toggle-switch{position:relative;width:44px;height:24px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background:#d1d5db;border-radius:24px;transition:.25s}.toggle-slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.25s}.toggle-switch input:checked+.toggle-slider{background:#8b5cf6}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.week-number{font-size:14px;font-weight:600;color:#374151}.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:#eff6ff;color:#3b82f6}.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(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}.page-wrapper{flex-direction:column}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}.delivery-settings-body,.form-row{flex-direction:column}.form-row .form-group{width:100%}.week-schedule-item{flex-wrap:wrap;gap:8px}}.modal-content.notify-modal{max-width:480px;padding:0}.modal-content.notify-modal .modal-header{padding:18px 20px 8px}.notify-body{padding:16px 20px 20px}.notify-field{margin-bottom:12px}.notify-label{display:block;font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:6px}.notify-input{width:100%;padding:8px 12px;border:1px solid var(--border-light);border-radius:6px;font-size:13px;outline:none;box-sizing:border-box}.notify-input:focus{border-color:var(--accent-primary)}.notify-textarea{width:100%;padding:8px 12px;border:1px solid var(--border-light);border-radius:6px;font-size:13px;font-family:inherit;resize:vertical;outline:none;box-sizing:border-box;min-height:80px}.notify-textarea:focus{border-color:var(--accent-primary)}.notify-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.notify-btn{padding:8px 20px;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer}.notify-btn.cancel{background:var(--bg-elevated);color:var(--text-muted)}.notify-btn.cancel:hover{background:var(--bg-sidebar-hover)}.notify-btn.send{background:var(--accent-primary);color:#fff}.notify-btn.send:hover{background:var(--accent-primary-hover)}.notify-btn.send:disabled{opacity:.5;cursor:not-allowed}.messages-layout{display:grid;grid-template-columns:320px 1fr;gap:0;border:1px solid var(--border-color);border-radius:var(--radius-lg, 12px);overflow:hidden;min-height:500px;background:var(--bg-primary)}.messages-inbox-list{border-right:1px solid var(--border-color);overflow-y:auto;max-height:600px}.messages-empty{padding:40px 20px;text-align:center;color:var(--text-muted);font-size:13px}.inbox-item{padding:14px 16px;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background .15s}.inbox-item:hover{background:var(--bg-sidebar-hover)}.inbox-item.active{background:var(--bg-sidebar-hover);border-left:3px solid var(--accent-primary);padding-left:13px}.inbox-item.unread{background:#f8faff}.inbox-item.unread .inbox-student-name{font-weight:700}.inbox-student-name{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.inbox-thread-title{font-size:12px;color:var(--text-secondary);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inbox-preview{font-size:12px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inbox-time{font-size:11px;color:var(--text-muted);margin-top:4px}.messages-thread-panel{display:flex;flex-direction:column;overflow:hidden}.thread-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:13px}.thread-header{padding:16px 20px;border-bottom:1px solid var(--border-color)}.thread-title{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.thread-student{font-size:12px;color:var(--text-muted)}.thread-messages-scroll{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:8px}.thread-reply-compose{padding:12px 20px 16px;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:8px}@media(max-width:768px){.messages-layout{grid-template-columns:1fr;min-height:auto}.messages-inbox-list{border-right:none;border-bottom:1px solid var(--border-color);max-height:300px}}
