@import"https://fonts.googleapis.com/css2?family=Noto+Sans+Gujarati:wght@400;500;600;700&family=Inter:wght@400;500;600;700&display=swap";:root{--color-primary: #4A4DC9;--color-primary-hover: #3d40a8;--color-primary-pressed: #32358a;--color-highlight: #FF7212;--color-highlight-hover: #FC9145;--color-highlight-bg: #FFF3E4;--color-accent-purple: #533086;--color-accent-purple-light: #C1C1EA;--color-text: #4E4E4E;--color-text-muted: #6B6B6B;--color-border: #CACACA;--color-border-light: #EBEBEB;--color-bg: #F5F5F5;--color-bg-card: #ffffff;--color-disabled: #CACACA;--color-disabled-bg: #EBEBEB;--gradient-primary: linear-gradient(135deg, #4A4DC9 0%, #533086 100%);--gradient-primary-soft: linear-gradient(135deg, rgba(74, 77, 201, .12) 0%, rgba(83, 48, 134, .08) 100%);--gradient-hero: linear-gradient(160deg, #f8f7ff 0%, #f0eeff 40%, #fff8f2 100%);--gradient-accent: linear-gradient(135deg, #FF7212 0%, #FC9145 100%);--gradient-card: linear-gradient(180deg, #ffffff 0%, #fdfcff 100%);--gradient-header: linear-gradient(90deg, #ffffff 0%, #fafaff 50%, #fffbf7 100%);--shadow-glow-primary: 0 8px 32px rgba(74, 77, 201, .2);--shadow-glow-highlight: 0 8px 32px rgba(255, 114, 18, .2);--transition-smooth: .3s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .4s cubic-bezier(.34, 1.56, .64, 1);font-family:Poppins,system-ui,sans-serif;line-height:1.5;font-weight:400;color:var(--color-text);background-color:var(--color-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes progressFill{0%{width:0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes pulse-soft{0%,to{opacity:1;box-shadow:0 0 #4a4dc940}50%{opacity:.95;box-shadow:0 0 0 8px #4a4dc900}}@keyframes gradient-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.btn-contained{padding:12px 24px;min-height:40px;background:var(--gradient-primary);color:#fff;border:none;border-radius:8px;font-family:inherit;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .3s}.btn-contained:hover:not(:disabled){box-shadow:var(--shadow-glow-primary);transform:translateY(-1px)}.btn-contained:active:not(:disabled){transform:scale(.98)}.btn-contained:disabled{background:var(--color-disabled);cursor:not-allowed;opacity:.8}.btn-highlight{background:var(--gradient-accent);color:#fff}.btn-highlight:hover:not(:disabled){box-shadow:var(--shadow-glow-highlight)}.btn-outlined{background:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}.btn-outlined:hover:not(:disabled){background:var(--color-accent-purple-light);color:var(--color-accent-purple)}button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gradient-hero);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:-40%;right:-20%;width:70%;height:80%;background:radial-gradient(ellipse at center,rgba(74,77,201,.2) 0%,rgba(83,48,134,.12) 40%,transparent 70%);border-radius:50%;pointer-events:none;animation:float 8s ease-in-out infinite}.login-page:after{content:"";position:absolute;bottom:-30%;left:-15%;width:55%;height:65%;background:radial-gradient(ellipse at center,rgba(255,114,18,.15) 0%,rgba(252,145,69,.08) 40%,transparent 70%);border-radius:50%;pointer-events:none;animation:float 10s ease-in-out infinite reverse}.login-card{position:relative;z-index:1;width:100%;max-width:440px;padding:3rem 2.5rem;background:var(--gradient-card);border-radius:20px;border:1px solid var(--color-border-light);box-shadow:0 4px 24px #4a4dc914,0 12px 48px #0000000f;animation:scaleIn .5s var(--transition-smooth) both;transition:box-shadow .4s,transform .3s}.login-card:hover{box-shadow:var(--shadow-glow-primary);transform:translateY(-2px)}.login-title{margin:0 0 .25rem;font-size:1.875rem;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-align:center;letter-spacing:-.02em;animation:fadeInUp .5s var(--transition-smooth) .1s both}.login-subtitle{margin:0 0 2rem;color:var(--color-text-muted);text-align:center;font-size:.9375rem;font-weight:500;animation:fadeInUp .5s var(--transition-smooth) .15s both}.login-form{display:flex;flex-direction:column;gap:1.375rem;animation:fadeInUp .5s var(--transition-smooth) .2s both}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:600;color:var(--color-text)}.form-group input{padding:14px 16px;border:2px solid var(--color-border-light);border-radius:10px;background:var(--color-bg-card);color:var(--color-text);font-family:"Poppins",inherit;font-size:1rem;transition:border-color .3s,box-shadow .3s,transform .2s}.form-group input::placeholder{color:var(--color-border)}.form-group input:hover{border-color:var(--color-accent-purple-light)}.form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px #4a4dc933;transform:translateY(-1px)}.password-input-wrapper{position:relative;display:flex;align-items:center;width:100%}.password-input-wrapper input{width:100%;padding-right:48px}.password-toggle{position:absolute;right:12px;background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);transition:color .2s}.password-toggle:hover{color:var(--color-primary)}.password-toggle:disabled{cursor:not-allowed;opacity:.5}.login-error{margin:0;font-size:.875rem;font-weight:500;color:var(--color-highlight);animation:fadeIn .3s ease}.login-button{margin-top:.5rem;padding:14px 24px;min-height:48px;background:var(--gradient-primary);background-size:200% 200%;color:#fff;border:none;border-radius:10px;font-family:"Poppins",inherit;font-size:1rem;font-weight:600;cursor:pointer;transition:box-shadow .3s,transform .2s}.login-button:hover{box-shadow:var(--shadow-glow-primary);transform:translateY(-2px)}.login-button:active{transform:scale(.98)}.logout-confirm-backdrop{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:9999;animation:logoutConfirmFadeIn .2s ease}@keyframes logoutConfirmFadeIn{0%{opacity:0}to{opacity:1}}.logout-confirm-box{background:var(--color-bg-card, #fff);border-radius:12px;padding:1.5rem 1.75rem;max-width:360px;width:calc(100% - 2rem);box-shadow:0 12px 40px #00000026;border:1px solid var(--color-border-light, rgba(0, 0, 0, .08));animation:logoutConfirmSlideIn .25s ease}@keyframes logoutConfirmSlideIn{0%{opacity:0;transform:scale(.96) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}.logout-confirm-title{margin:0 0 .5rem;font-size:1.25rem;font-weight:700;color:var(--color-text, #1a1a1a)}.logout-confirm-desc{margin:0 0 1.5rem;font-size:.9375rem;color:var(--color-text-muted, #555);line-height:1.45}.logout-confirm-actions{display:flex;gap:.75rem;justify-content:flex-end}.logout-confirm-btn{padding:8px 18px;min-height:38px;border-radius:8px;font-family:"Poppins",inherit;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .2s,color .2s,transform .15s,box-shadow .2s}.logout-confirm-btn--cancel{background:transparent;color:var(--color-text-muted, #555);border:2px solid var(--color-border-light, #ddd)}.logout-confirm-btn--cancel:hover{background:#0000000a;border-color:var(--color-text-muted, #888);color:var(--color-text, #1a1a1a)}.logout-confirm-btn--confirm{background:var(--gradient-primary, linear-gradient(135deg, #4a4dc9, #6b4fa3));color:#fff;border:none}.logout-confirm-btn--confirm:hover{opacity:.95;transform:translateY(-1px);box-shadow:0 4px 12px #4a4dc959}.notification-bell-wrapper{position:relative;display:inline-flex;align-items:center}.notification-bell-btn{position:relative;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:#e2e8f0;cursor:pointer;padding:6px 8px;transition:background .2s,border-color .2s}.notification-bell-btn:hover{background:#ffffff2e;border-color:#ffffff40}.notification-badge{position:absolute;top:-4px;right:-4px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;line-height:18px;text-align:center;border-radius:9px;padding:0 4px;pointer-events:none}.notification-panel{position:absolute;top:calc(100% + 8px);right:0;width:360px;max-height:420px;background:#1e293b;border:1px solid rgba(255,255,255,.1);border-radius:12px;box-shadow:0 8px 32px #00000059;z-index:1000;overflow:hidden;display:flex;flex-direction:column}.notification-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 12px;border-bottom:1px solid rgba(255,255,255,.08)}.notification-panel-header h3{margin:0;font-size:15px;font-weight:600;color:#f1f5f9}.notification-mark-all-btn{background:none;border:none;color:#818cf8;font-size:12px;font-weight:500;cursor:pointer;padding:2px 6px;border-radius:4px;transition:background .2s}.notification-mark-all-btn:hover{background:#818cf81f}.notification-panel-list{overflow-y:auto;flex:1;max-height:360px}.notification-item{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;cursor:pointer;border-bottom:1px solid rgba(255,255,255,.05);transition:background .15s}.notification-item:hover{background:#ffffff0a}.notification-item.unread{background:#4a4dc914}.notification-item.unread:hover{background:#4a4dc924}.notification-item-dot{width:8px;height:8px;min-width:8px;border-radius:50%;margin-top:5px;background:transparent}.notification-item.unread .notification-item-dot{background:#818cf8}.notification-item-content{flex:1;min-width:0}.notification-item-title{font-size:13px;font-weight:600;color:#e2e8f0;line-height:1.3}.notification-item-body{font-size:12px;color:#94a3b8;line-height:1.4;margin-top:2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notification-item-time{font-size:11px;color:#64748b;margin-top:4px}.notification-empty{text-align:center;padding:32px 16px;color:#64748b;font-size:13px}@media(max-width:480px){.notification-panel{width:300px;right:-40px}}.home-page{min-height:100vh;background:var(--gradient-hero);animation:fadeIn .4s ease}.home-header{display:flex;align-items:center;justify-content:space-between;padding:.875rem 2rem 1rem;background:var(--gradient-header);border-bottom:1px solid var(--color-border-light);box-shadow:0 2px 12px #4a4dc90f;animation:slideInLeft .4s var(--transition-smooth) both}.header-left{display:flex;align-items:center;gap:.75rem}.logo-link{text-decoration:none;color:inherit;transition:transform .2s}.logo-link:hover{transform:scale(1.02)}.logo-link:hover h1{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.home-header h1{margin:0;font-size:1.375rem;font-weight:700;color:var(--color-primary);letter-spacing:-.02em;transition:color .2s}.header-badge{font-size:.75rem;font-weight:600;color:var(--color-text-muted);background:var(--gradient-primary-soft);padding:.25rem .625rem;border-radius:6px;text-transform:uppercase;letter-spacing:.04em;border:1px solid rgba(74,77,201,.15)}.header-right{display:flex;align-items:center;gap:1rem}.user-pill{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem .375rem .375rem;background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:999px;text-decoration:none;color:var(--color-text);font-size:.875rem;font-weight:600;transition:border-color .3s,box-shadow .3s,transform .2s}.user-pill:hover{border-color:var(--color-primary);box-shadow:0 4px 16px #4a4dc926;transform:translateY(-1px)}.user-pill-avatar{width:28px;height:28px;border-radius:50%;background:var(--gradient-primary);color:#fff;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .3s}.user-pill:hover .user-pill-avatar{transform:scale(1.08)}.user-pill-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text)}.how-to-use-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;min-height:36px;background:#eef2ff;color:#4a4dc9;border:1.5px solid #c7d2fe;border-radius:8px;font-family:inherit;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .2s,box-shadow .2s,transform .15s}.how-to-use-btn:hover{background:#e0e7ff;box-shadow:0 2px 8px #4a4dc92e;transform:translateY(-1px)}.logout-btn{padding:8px 16px;min-height:36px;background:transparent;color:var(--color-primary);border:2px solid var(--color-primary);border-radius:8px;font-family:"Poppins",inherit;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .3s,color .3s,transform .2s,box-shadow .2s}.logout-btn:hover{background:var(--gradient-primary-soft);color:var(--color-accent-purple);border-color:var(--color-primary);transform:translateY(-1px);box-shadow:0 4px 12px #4a4dc933}.home-main{max-width:960px;margin:0 auto;padding:2rem 2rem 3rem}.home-hero{margin-bottom:1.75rem;animation:fadeInUp .5s var(--transition-smooth) .1s both}.home-main h2{margin:0 0 .5rem;font-size:1.5rem;font-weight:700;color:var(--color-text);letter-spacing:-.02em}.welcome-text{margin:0 0 1.25rem;font-size:.9375rem;color:var(--color-text-muted)}.welcome-text strong{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:600}.progress-strip{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1rem;padding:1rem 1.25rem;background:var(--gradient-card);border-radius:12px;border:1px solid var(--color-border-light);box-shadow:0 4px 16px #4a4dc90f;transition:box-shadow .3s}.progress-strip:hover{box-shadow:0 6px 20px #4a4dc91a}.progress-label{font-size:.8125rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.progress-bar-wrap{flex:1;min-width:120px;height:10px;background:var(--color-border-light);border-radius:999px;overflow:hidden}.progress-bar{height:100%;background:var(--gradient-primary);border-radius:999px;transition:width .5s var(--transition-bounce)}.progress-count{font-size:.875rem;font-weight:600;color:var(--color-primary)}.dropdowns-wrapper{background:var(--gradient-card);border-radius:16px;border:1px solid var(--color-border-light);padding:2rem;margin-bottom:1.5rem;box-shadow:0 4px 20px #4a4dc914;animation:fadeInUp .5s var(--transition-smooth) .2s both;transition:box-shadow .3s,transform .2s}.dropdowns-wrapper:hover{box-shadow:0 8px 28px #4a4dc91f}.dropdowns-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem}.dropdown-group{display:flex;flex-direction:column;gap:.5rem;transition:transform .3s,opacity .3s;animation:fadeInUp .4s var(--transition-smooth) both}.dropdown-group:nth-child(1){animation-delay:.25s}.dropdown-group:nth-child(2){animation-delay:.3s}.dropdown-group:nth-child(3){animation-delay:.35s}.dropdown-group:nth-child(4){animation-delay:.4s}.dropdown-group:nth-child(5){animation-delay:.45s}.dropdown-group:nth-child(6){animation-delay:.5s}.dropdown-group:hover{transform:translateY(-2px)}.dropdown-group--selected select{border-color:var(--color-primary);background:var(--gradient-primary-soft);box-shadow:0 0 0 1px #4a4dc933}.dropdown-group label{font-size:.875rem;font-weight:600;color:var(--color-text)}.dropdown-group select{padding:12px 16px;border:2px solid var(--color-border-light);border-radius:10px;background:var(--color-bg-card);color:var(--color-text);font-family:"Poppins",inherit;font-size:.9375rem;cursor:pointer;transition:border-color .3s,box-shadow .3s,background .3s,transform .2s}.dropdown-group select:hover{border-color:var(--color-accent-purple-light)}.dropdown-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px #4a4dc933;transform:translateY(-1px)}.dropdown-group select option{background:var(--color-bg-card);color:var(--color-text)}.validate-actions{display:flex;align-items:center;gap:1rem;animation:fadeInUp .5s var(--transition-smooth) .35s both}.validate-btn{padding:14px 28px;min-height:48px;background:var(--color-disabled);color:var(--color-text-muted);border:none;border-radius:10px;font-family:"Poppins",inherit;font-size:.9375rem;font-weight:600;cursor:not-allowed;transition:all .4s var(--transition-smooth)}.validate-btn--active,.validate-btn:not(:disabled):hover{background:var(--gradient-primary);color:#fff;cursor:pointer;box-shadow:var(--shadow-glow-primary);transform:translateY(-2px)}.validate-btn--active{animation:pulse-soft 2.5s ease-in-out infinite}.validate-btn--active:hover{box-shadow:0 12px 40px #4a4dc959;transform:translateY(-3px)}.validate-btn:disabled{opacity:1}.validate-btn:active:not(:disabled){transform:scale(.98)}.chapters-accordion-wrapper{animation:fadeInUp .5s var(--transition-smooth) .2s both}.chapters-accordion{background:var(--gradient-card);border-radius:16px;border:1px solid var(--color-border-light);box-shadow:0 4px 20px #4a4dc914;overflow:hidden;transition:box-shadow .3s}.chapters-accordion:hover{box-shadow:0 8px 28px #4a4dc91f}.chapters-accordion-header{width:100%;padding:1.25rem 1.5rem;background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:background .2s;text-align:left}.chapters-accordion-header:hover:not(:disabled){background:#4a4dc90a}.chapters-accordion-header:disabled{cursor:not-allowed;opacity:.6}.chapters-header-content{display:flex;align-items:center;gap:.75rem;flex:1}.chapters-header-icon{display:flex;align-items:center;justify-content:center;color:var(--color-primary);transition:transform .3s,color .2s}.chapters-accordion-header:hover:not(:disabled) .chapters-header-icon{color:var(--color-accent-purple)}.chapters-header-title{font-size:1.125rem;font-weight:700;color:var(--color-text);letter-spacing:-.01em}.chapters-count-badge{background:var(--gradient-primary);color:#fff;font-size:.75rem;font-weight:700;padding:.25rem .625rem;border-radius:12px;min-width:24px;text-align:center}.chapters-loading{font-size:.875rem;color:var(--color-text-muted);font-weight:500}.chapters-content{border-top:1px solid var(--color-border-light);background:var(--color-bg-card);animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:1000px}}.chapters-loading-state{padding:2rem;display:flex;align-items:center;justify-content:center;gap:.75rem;color:var(--color-text-muted);font-size:.9375rem}.chapters-spinner{width:16px;height:16px;border:2px solid var(--color-border-light);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.chapters-empty-state{padding:2rem;text-align:center;color:var(--color-text-muted);font-size:.9375rem}.chapters-list{padding:1rem;display:flex;flex-direction:column;gap:.75rem}.chapter-item{background:var(--gradient-card);border:1px solid var(--color-border-light);border-radius:12px;padding:1rem 1.25rem;transition:all .2s}.chapter-item:hover{border-color:var(--color-primary);box-shadow:0 4px 12px #4a4dc91a;transform:translateY(-1px)}.chapter-item-content{display:flex;align-items:center;justify-content:space-between;gap:1rem}.chapter-name-row{display:flex;align-items:center;gap:.625rem;flex:1;min-width:0}.chapter-name{font-size:.9375rem;font-weight:600;color:var(--color-text)}.chapter-standard-badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:99px;font-size:.75rem;font-weight:600;background:#dbeafe;color:#1d4ed8;white-space:nowrap;letter-spacing:.02em;flex-shrink:0}.chapter-subject-badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:99px;font-size:.75rem;font-weight:600;background:#ede9fe;color:#7c3aed;white-space:nowrap;letter-spacing:.02em;flex-shrink:0}.chapter-actions{display:flex;align-items:center;gap:.75rem}.chapter-status-dropdown{padding:8px 32px 8px 12px;min-height:40px;border:2px solid;border-radius:8px;font-family:"Poppins",inherit;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;background:var(--color-bg-card);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.chapter-status-dropdown:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.chapter-status-dropdown:disabled{opacity:.6;cursor:not-allowed}.chapter-status-dropdown:focus{outline:none;box-shadow:0 0 0 3px #0000001a}.chapter-status-tag{display:inline-flex;align-items:center;padding:8px 16px;min-height:40px;border:2px solid;border-radius:8px;font-family:"Poppins",inherit;font-size:.875rem;font-weight:600;white-space:nowrap;-webkit-user-select:none;user-select:none}.chapter-validate-btn{padding:10px 20px;min-height:40px;background:var(--gradient-primary);color:#fff;border:none;border-radius:8px;font-family:"Poppins",inherit;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s;white-space:nowrap}.chapter-validate-btn:hover:not(:disabled){box-shadow:var(--shadow-glow-primary);transform:translateY(-2px)}.chapter-validate-btn:active:not(:disabled){transform:scale(.98)}.chapter-validate-btn:disabled{opacity:.6;cursor:not-allowed}.toast{position:fixed;top:20px;right:20px;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:280px;max-width:400px;z-index:10000;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-content{display:flex;align-items:center;gap:10px;flex:1}.toast-icon{color:#16a34a;flex-shrink:0}.toast-message{font-size:.875rem;color:#1e293b;line-height:1.4}.toast-close{background:none;border:none;cursor:pointer;color:#64748b;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s;flex-shrink:0}.toast-close:hover{background-color:#f1f5f9;color:#1e293b}.toast-close:focus{outline:2px solid var(--color-primary, #3b82f6);outline-offset:2px}.dlp-backdrop{position:fixed;inset:0;background:#f0eff5;z-index:1200;animation:lp-modal-fade-in .25s ease-out}.dlp-modal{background:#f0eff5;width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden}.dlp-accent-line{height:3px;background:linear-gradient(90deg,#4a4dc9,#7c3aed 30%,#ff7212 70%,#f59e0b);flex-shrink:0}.dlp-header{display:flex;flex-direction:column;padding:0;background:var(--color-bg-card, #fff);flex-shrink:0;box-shadow:0 1px 8px #4a4dc90f}.dlp-header-top{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem .5rem}.dlp-header-left{display:flex;align-items:center;gap:.75rem;min-width:0}.dlp-header-icon{width:36px;height:36px;border-radius:10px;background:var(--gradient-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.6875rem;font-weight:800;letter-spacing:.5px;flex-shrink:0;box-shadow:0 2px 8px #4a4dc940}.dlp-title{margin:0;font-size:1.0625rem;font-weight:700;color:var(--color-text, #1e1e2e);letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.dlp-header-meta{display:flex;align-items:center;gap:.125rem;margin-top:1px}.dlp-header-crumb{font-size:.6875rem;color:var(--color-text-muted, #6b6b6b);white-space:nowrap}.dlp-header-crumb+.dlp-header-crumb:before{content:"·";margin:0 .4rem;color:var(--color-border, #cacaca);font-weight:700}.dlp-header-crumb--muted{color:var(--color-disabled, #b0b0b0);font-style:italic}.dlp-close-btn{width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:transparent;color:var(--color-text-muted, #6b6b6b);border:none;border-radius:8px;cursor:pointer;transition:all var(--transition-smooth);flex-shrink:0}.dlp-close-btn:hover{background:#fef2f2;color:#dc2626}.dlp-header-bottom{padding:0 1.5rem .75rem}.dlp-stats-row{display:flex;gap:.5rem}.dlp-stat-card{display:flex;align-items:center;gap:.375rem;padding:.3rem .75rem;border-radius:8px;border:1px solid}.dlp-stat-num{font-size:.9375rem;font-weight:800;font-family:Poppins,sans-serif;line-height:1}.dlp-stat-label{font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;opacity:.8}.dlp-stat-card--purple{background:#f3f0ff;border-color:#ddd6fe}.dlp-stat-card--purple .dlp-stat-num,.dlp-stat-card--purple .dlp-stat-label{color:#7c3aed}.dlp-stat-card--blue{background:#eff6ff;border-color:#bfdbfe}.dlp-stat-card--blue .dlp-stat-num,.dlp-stat-card--blue .dlp-stat-label{color:#2563eb}.dlp-stat-card--indigo{background:#e8e8f7;border-color:#c1c1ea}.dlp-stat-card--indigo .dlp-stat-num,.dlp-stat-card--indigo .dlp-stat-label{color:#4a4dc9}.dlp-stat-card--green{background:#ecfdf5;border-color:#a7f3d0}.dlp-stat-card--green .dlp-stat-num,.dlp-stat-card--green .dlp-stat-label{color:#059669}.dlp-stat-card--orange{background:#fff7ed;border-color:#fed7aa}.dlp-stat-card--orange .dlp-stat-num,.dlp-stat-card--orange .dlp-stat-label{color:#ea580c}.dlp-toolbar{display:flex;align-items:center;gap:.5rem;padding:.5rem 1.5rem;background:var(--color-bg-card, #fff);border-bottom:1px solid var(--color-border-light, #ebebeb);flex-shrink:0;box-shadow:0 2px 6px #00000008}.dlp-toolbar-divider{width:1px;height:24px;background:var(--color-border-light, #ebebeb);flex-shrink:0}.dlp-toolbar-sep{width:1px;height:18px;background:var(--color-border-light, #ebebeb);flex-shrink:0}.dlp-toolbar-right{display:flex;align-items:center;gap:.5rem;margin-left:auto}.dlp-search-wrap{display:flex;align-items:center;gap:.35rem;background:var(--color-bg, #f5f5f5);border:1px solid transparent;border-radius:8px;padding:.35rem .6rem;transition:all var(--transition-smooth)}.dlp-search-wrap:focus-within{border-color:var(--color-primary, #4a4dc9);background:var(--color-bg-card, #fff);box-shadow:0 0 0 3px #4a4dc914}.dlp-search-input{border:none;outline:none;background:transparent;font-size:.75rem;color:var(--color-text, #4e4e4e);width:120px;font-family:inherit}.dlp-search-input::placeholder{color:#b0b0b0}.dlp-filter-x{background:none;border:none;cursor:pointer;font-size:.875rem;color:var(--color-text-muted, #6b6b6b);padding:0;line-height:1}.dlp-filters{display:flex;gap:.25rem;flex-wrap:wrap;align-items:center}.dlp-filter-btn{padding:.25rem .5rem;border-radius:6px;font-size:.6875rem;font-weight:500;border:1px solid var(--color-border-light, #ebebeb);background:var(--color-bg, #f5f5f5);color:var(--color-text-muted, #6b6b6b);cursor:pointer;transition:all .15s ease}.dlp-filter-btn:hover:not(.dlp-filter-btn--active){border-color:var(--color-border, #cacaca);background:var(--color-bg-card, #fff)}.dlp-filter-btn--active{font-weight:600;box-shadow:0 1px 4px #00000014}.dlp-filter-clear{padding:.2rem .5rem;border-radius:99px;background:#fef2f2;color:#dc2626;font-size:.6875rem;font-weight:600;border:none;cursor:pointer}.dlp-bloom-filters{display:flex;gap:.25rem;align-items:center}.dlp-bloom-filters-label{font-size:.5625rem;font-weight:700;color:var(--color-text-muted, #9ca3af);margin-right:.2rem;text-transform:uppercase;letter-spacing:.5px}.dlp-bloom-dot{width:14px;height:14px;border-radius:50%;padding:0;cursor:pointer;border:2px solid transparent;transition:all .15s ease}.dlp-bloom-dot:hover{transform:scale(1.2)}.dlp-bloom-dot--active{border-color:var(--color-text, #333);transform:scale(1.25);box-shadow:0 0 0 2px #0000000f}.dlp-view-tabs{display:flex;gap:2px;background:var(--color-bg, #f0eff5);border-radius:10px;padding:3px}.dlp-view-tab{padding:.375rem .875rem;border-radius:8px;font-size:.6875rem;font-weight:500;background:transparent;color:var(--color-text-muted, #6b6b6b);border:none;cursor:pointer;transition:all .2s ease;white-space:nowrap;position:relative}.dlp-view-tab:hover:not(.dlp-view-tab--active){color:var(--color-text, #4e4e4e);background:#fff9}.dlp-view-tab--active{background:var(--gradient-primary);color:#fff;font-weight:600;box-shadow:0 2px 8px #4a4dc94d}.dlp-body{flex:1;overflow-y:auto;padding:1.25rem 1.5rem;min-height:0;background:#f0eff5}.dlp-module{border-radius:14px;border:1px solid var(--color-border-light, #e0dfe6);background:var(--color-bg-card, #fff);margin-bottom:.875rem;overflow:hidden;transition:border-color var(--transition-smooth),box-shadow var(--transition-smooth);box-shadow:0 1px 3px #0000000a}.dlp-module--open{border-color:var(--color-accent-purple-light, #c1c1ea);box-shadow:0 4px 20px #4a4dc91a}.dlp-module-header{padding:.875rem 1.125rem;cursor:pointer;display:flex;align-items:center;gap:.75rem;transition:background var(--transition-smooth)}.dlp-module--open .dlp-module-header{background:var(--gradient-primary-soft)}.dlp-module-num{width:36px;height:36px;border-radius:10px;background:var(--color-border-light, #ebebeb);display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:700;color:var(--color-text-muted, #6b6b6b);flex-shrink:0;font-family:Poppins,sans-serif;transition:all var(--transition-smooth)}.dlp-module--open .dlp-module-num{background:var(--gradient-primary);color:#fff}.dlp-module-info{flex:1;min-width:0}.dlp-module-name{margin:0;font-size:.9375rem;font-weight:700;color:var(--color-text, #4e4e4e);letter-spacing:-.01em}.dlp-module-meta{font-size:.75rem;color:var(--color-text-muted, #6b6b6b);display:flex;gap:.5rem;flex-wrap:wrap;margin-top:2px}.dlp-module-meta-media{color:var(--color-highlight, #ff7212)}.dlp-chevron{font-size:1rem;color:var(--color-text-muted, #6b6b6b);transition:transform var(--transition-smooth);flex-shrink:0}.dlp-chevron--open{transform:rotate(180deg)}.dlp-module-body{padding:.75rem 1.125rem 1rem;border-top:1px solid var(--color-border-light, #ebebeb);animation:dlp-slide-in .25s ease-out}@keyframes dlp-slide-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dlp-segment{margin-bottom:1rem}.dlp-segment-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.625rem;padding-bottom:.375rem;border-bottom:1px solid var(--color-border-light, #ebebeb)}.dlp-segment-id{font-size:.6875rem;color:var(--color-primary, #4a4dc9);background:var(--gradient-primary-soft);padding:.15rem .4rem;border-radius:5px;font-family:Poppins,sans-serif;font-weight:600}.dlp-segment-name{font-size:.8125rem;font-weight:600;color:var(--color-accent-purple, #533086)}.dlp-topics-list{display:flex;flex-direction:column;gap:.5rem;padding-left:.625rem;border-left:2px solid var(--color-border-light, #ebebeb)}.dlp-topic{border-radius:10px;border:1px solid var(--color-border-light, #ebebeb);background:var(--color-bg-card, #fff);overflow:hidden;transition:border-color var(--transition-smooth),box-shadow var(--transition-smooth)}.dlp-topic--open{box-shadow:0 2px 12px #0000000f}.dlp-topic-header{padding:.625rem .875rem;cursor:pointer;display:flex;align-items:center;gap:.5rem}.dlp-topic-type-badge{width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.6875rem;font-weight:700;flex-shrink:0}.dlp-topic-info{flex:1;min-width:0}.dlp-topic-name-row{display:flex;align-items:center;gap:.375rem;flex-wrap:wrap}.dlp-topic-id{font-size:.625rem;color:var(--color-text-muted, #6b6b6b);font-family:Poppins,sans-serif}.dlp-topic-name{font-size:.8125rem;font-weight:600;color:var(--color-text, #4e4e4e)}.dlp-topic-tags{display:flex;gap:.25rem;margin-top:.25rem;flex-wrap:wrap;align-items:center}.dlp-tag{padding:.125rem .5rem;border-radius:99px;font-size:.625rem;font-weight:600}.dlp-diff-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dlp-topic-body{padding:0 .875rem .875rem;border-top:1px solid var(--color-border-light, #ebebeb);animation:dlp-slide-in .2s ease-out}.dlp-topic-summary{font-size:.8125rem;color:var(--color-text, #4e4e4e);line-height:1.6;margin:.625rem 0 .875rem}.dlp-textblock{margin-bottom:1rem}.dlp-textblock-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem;flex-wrap:wrap;gap:.375rem}.dlp-textblock-label{font-size:.625rem;font-weight:700;color:var(--color-text-muted, #6b6b6b);text-transform:uppercase;letter-spacing:.4px}.dlp-textblock-tabs{display:flex;gap:2px;background:var(--color-border-light, #ebebeb);border-radius:7px;padding:2px}.dlp-textblock-tab{padding:.25rem .625rem;border-radius:5px;font-size:.6875rem;font-weight:500;background:transparent;color:var(--color-text-muted, #6b6b6b);border:none;cursor:pointer;transition:all var(--transition-smooth)}.dlp-textblock-tab--active{background:var(--color-bg-card, #fff);font-weight:600;box-shadow:0 1px 3px #0000000f}.dlp-textblock-tab--modified.dlp-textblock-tab--active{color:#059669}.dlp-textblock-tab--original.dlp-textblock-tab--active{color:var(--color-highlight, #ff7212)}.dlp-textblock-content{position:relative;padding:.875rem 1rem 1.25rem;border-radius:10px;border:1.5px solid;line-height:1.75}.dlp-textblock-content--modified{border-color:#86efac;background:#f0fdf4}.dlp-textblock-content--original{border-color:#fde68a;background:#fffbeb}.dlp-textblock-wc{position:absolute;top:8px;right:10px;font-size:.625rem;font-weight:600;padding:.125rem .5rem;border-radius:99px}.dlp-textblock-wc--modified{color:#059669;background:#dcfce7}.dlp-textblock-wc--original{color:var(--color-highlight, #ff7212);background:#fef3c7}.dlp-textblock-text{font-size:.8125rem;padding-right:4rem}.dlp-textblock-text--modified{color:#14532d}.dlp-textblock-text--original{color:#78350f}.dlp-textblock-text p{margin:0}.dlp-textblock-text p+p{margin-top:.625rem}.dlp-textblock-toggle{display:block;margin:.5rem auto 0;font-size:.6875rem;font-weight:600;background:transparent;border:none;cursor:pointer;text-decoration:underline}.dlp-textblock-toggle--modified{color:#059669}.dlp-textblock-toggle--original{color:var(--color-highlight, #ff7212)}.dlp-textblock-badge{position:absolute;bottom:-1px;left:1rem;transform:translateY(50%);font-size:.5625rem;padding:.125rem .625rem;border-radius:99px;font-weight:600;border:1px solid}.dlp-textblock-badge--modified{background:#f0fdf4;color:#059669;border-color:#86efac}.dlp-textblock-badge--original{background:#fffbeb;color:var(--color-highlight, #ff7212);border-color:#fde68a}.dlp-section-label{font-size:.625rem;font-weight:700;color:var(--color-text-muted, #6b6b6b);text-transform:uppercase;letter-spacing:.4px;margin-bottom:.375rem}.dlp-terms{display:flex;gap:.3rem;flex-wrap:wrap;margin-bottom:.75rem}.dlp-term{padding:.2rem .625rem;border-radius:6px;font-size:.6875rem;background:var(--gradient-primary-soft);color:var(--color-primary, #4a4dc9);border:1px solid var(--color-accent-purple-light, #c1c1ea)}.dlp-concepts{margin-bottom:.75rem}.dlp-concept-item{font-size:.8125rem;color:var(--color-text, #4e4e4e);padding-left:1rem;position:relative;line-height:1.5;margin-bottom:.125rem}.dlp-concept-dot{position:absolute;left:0;font-size:.5625rem;top:.25em}.dlp-objectives{margin-bottom:.75rem}.dlp-objective-item{display:flex;gap:.5rem;align-items:center;padding:.5rem .75rem;background:var(--color-bg, #f5f5f5);border-radius:8px;border:1px solid var(--color-border-light, #ebebeb);margin-bottom:.3rem}.dlp-bloom-badge{padding:.125rem .4rem;border-radius:99px;font-size:.5625rem;font-weight:700;text-transform:uppercase;flex-shrink:0}.dlp-objective-text{flex:1}.dlp-objective-id{font-size:.5625rem;color:var(--color-text-muted, #6b6b6b);font-family:Poppins,sans-serif;margin-right:.25rem}.dlp-objective-content{font-size:.75rem;color:var(--color-text, #4e4e4e)}.dlp-recall{margin-bottom:.75rem}.dlp-recall-item{background:var(--color-bg, #f5f5f5);border:1px solid var(--color-border-light, #ebebeb);border-radius:8px;padding:.5rem .75rem;cursor:pointer;margin-bottom:.25rem;transition:background var(--transition-smooth)}.dlp-recall-item:hover{background:var(--gradient-primary-soft)}.dlp-recall-header{display:flex;align-items:center;gap:.375rem}.dlp-recall-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dlp-recall-prompt{font-size:.75rem;font-weight:500;color:var(--color-text, #4e4e4e);flex:1}.dlp-recall-answer{margin-top:.375rem;padding-top:.375rem;border-top:1px dashed var(--color-border, #cacaca);font-size:.75rem;color:#059669;font-weight:500;animation:dlp-slide-in .2s ease-out}.dlp-media-section{margin-bottom:1rem}.dlp-media-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem;flex-wrap:wrap;gap:.375rem}.dlp-media-filters{display:flex;gap:.2rem}.dlp-media-filter-btn{padding:.2rem .5rem;border-radius:99px;font-size:.625rem;font-weight:500;border:1px solid var(--color-border-light, #ebebeb);background:var(--color-bg-card, #fff);color:var(--color-text-muted, #6b6b6b);cursor:pointer;transition:all var(--transition-smooth)}.dlp-media-filter-btn--active{font-weight:600}.dlp-media-list{display:flex;flex-direction:column;gap:.5rem}.dlp-media-card{border-radius:10px;border:1px solid var(--color-border-light, #ebebeb);background:var(--color-bg-card, #fff);overflow:hidden;transition:box-shadow var(--transition-smooth)}.dlp-media-card:hover{box-shadow:0 2px 8px #0000000f}.dlp-media-card-header{padding:.5rem .75rem;display:flex;align-items:center;gap:.5rem;border-bottom:1px solid var(--color-border-light, #ebebeb)}.dlp-media-icon{font-size:1rem}.dlp-media-card-title{font-size:.75rem;font-weight:700}.dlp-media-card-meta{font-size:.625rem;margin-top:1px}.dlp-media-card-body{padding:.625rem .75rem}.dlp-media-desc{font-size:.75rem;color:var(--color-text, #4e4e4e);line-height:1.5}.dlp-media-image{max-width:100%;border-radius:8px;border:1px solid var(--color-border-light, #ebebeb);margin-top:.5rem}.dlp-media-2d-tool-wrap{margin-top:.5rem;border-radius:8px;overflow:hidden;border:1px solid var(--color-border-light, #ebebeb)}.dlp-media-2d-tool-above{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:linear-gradient(135deg,#fdf2f8,#fce7f3);border-bottom:1px solid var(--color-border-light, #ebebeb)}.dlp-media-2d-tool-above-label{font-size:.75rem;font-weight:600;color:#be185d;text-transform:uppercase;letter-spacing:.03em}.dlp-media-2d-tool-above-title{font-size:.8125rem;color:var(--color-text, #1a1a1a);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.dlp-media-2d-tool-above--clickable{width:100%;cursor:pointer;border:none;font:inherit;text-align:left;transition:background .15s ease}.dlp-media-2d-tool-above--clickable[aria-expanded=false]{border-radius:8px;border:1px solid var(--color-border-light, #ebebeb)}.dlp-media-2d-tool-above--clickable[aria-expanded=true]{border-radius:8px 8px 0 0;border-bottom:none}.dlp-media-2d-tool-above--clickable:hover{background:linear-gradient(135deg,#fce7f3,#fbcfe8)}.dlp-media-2d-tool-above-icon{flex-shrink:0;color:#be185d;display:flex;align-items:center}.dlp-media-2d-tool-preview-header{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.75rem;font-weight:600;color:#4f46e5;background:linear-gradient(to right,#eef2ff,#f5f3ff);border-bottom:1px solid var(--color-border-light, #ebebeb)}.dlp-media-2d-tool-iframe-wrap{width:100%;aspect-ratio:4 / 3;max-height:360px;overflow:hidden;background:#fdf2f8}.dlp-media-2d-tool-iframe{width:100%;height:100%;min-height:280px;border:0;display:block}.dlp-media-2d-tool-preview-hint{font-size:.7rem;color:var(--color-text-muted, #6b7280);padding:.35rem .75rem;background:#f9fafb;border-top:1px solid var(--color-border-light, #ebebeb)}.dlp-media-prompt-btn{font-size:.625rem;font-weight:600;color:var(--color-text-muted, #6b6b6b);background:var(--color-bg, #f5f5f5);padding:.25rem .5rem;border-radius:6px;border:1px solid var(--color-border, #cacaca);cursor:pointer;margin-top:.5rem;transition:background var(--transition-smooth)}.dlp-media-prompt-btn:hover{background:var(--color-border-light, #ebebeb)}.dlp-media-prompt-content{margin-top:.375rem;padding:.5rem .75rem;background:#1e1b2e;border-radius:8px;overflow:auto;max-height:160px}.dlp-media-prompt-text{font-size:.6875rem;color:#c4b5fd;line-height:1.5;margin:0;white-space:pre-wrap;word-break:break-word;font-family:Poppins,monospace}.dlp-media-view-json{margin-top:.75rem;border-top:1px solid var(--color-border-light);padding-top:.5rem}.dlp-media-view-json-btn{margin-bottom:.375rem}.dlp-media-json-sections{display:flex;flex-direction:column;gap:1rem}.dlp-media-json-block{display:flex;flex-direction:column;gap:.375rem}.dlp-media-json-block-label{font-size:.75rem;font-weight:600;color:var(--color-primary);text-transform:uppercase;letter-spacing:.02em}.dlp-media-json-wrap{background:#1e1b2e;border-radius:8px;overflow:auto;max-height:280px;border:1px solid rgba(148,163,184,.2)}.dlp-media-json-pre{font-size:.6875rem;color:#93c5fd;line-height:1.45;margin:0;padding:.75rem;white-space:pre-wrap;word-break:break-word;font-family:ui-monospace,Cascadia Code,Source Code Pro,Menlo,monospace}.dlp-gallery-stats{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.dlp-gallery-stat-card{cursor:pointer;padding:.625rem 1rem;border-radius:10px;border:1.5px solid;min-width:90px;transition:all var(--transition-smooth)}.dlp-gallery-stat-icon{font-size:1.125rem;margin-bottom:.125rem}.dlp-gallery-stat-count{font-size:1.25rem;font-weight:700;font-family:Poppins,sans-serif}.dlp-gallery-stat-label{font-size:.625rem;font-weight:600;text-transform:uppercase}.dlp-gallery-module-heading{font-size:.8125rem;font-weight:700;color:var(--color-text, #4e4e4e);margin-bottom:.625rem;padding-bottom:.375rem;border-bottom:2px solid var(--color-border-light, #ebebeb);display:flex;align-items:center;gap:.5rem}.dlp-gallery-module-badge{background:var(--gradient-primary);color:#fff;padding:.125rem .5rem;border-radius:6px;font-size:.6875rem;font-weight:700}.dlp-gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem;margin-bottom:1.5rem}.dlp-priority-legend{display:flex;align-items:center;justify-content:flex-start;gap:2.5rem;padding:.875rem 1.25rem;background:var(--color-bg-card, #fff);border:1px solid var(--color-border-light, #ebebeb);border-radius:12px;margin-bottom:1.25rem;box-shadow:0 1px 3px #00000005}.dlp-priority-group{display:flex;align-items:center;gap:1.5rem}.dlp-priority-label{font-size:.6875rem;font-weight:800;color:var(--color-text, #4e4e4e);letter-spacing:.6px;text-transform:uppercase}.dlp-priority-item{display:flex;align-items:center;gap:.5rem}.dlp-priority-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.dlp-priority-dot--primary{background:#dc2626;box-shadow:0 0 0 3px #dc26261a}.dlp-priority-dot--secondary{background:#d97706;box-shadow:0 0 0 3px #d977061a}.dlp-priority-dot--tertiary{background:#94a3b8;box-shadow:0 0 0 3px #94a3b81a}.dlp-priority-text{font-size:.75rem;font-weight:600;color:var(--color-text, #4e4e4e)}.dlp-priority-hint{font-size:.75rem;color:var(--color-text-muted, #9ca3af);font-weight:400}.dlp-cell-dot{position:absolute;width:10px;height:10px;border-radius:50%;top:-3px;right:-6px;border:1px solid #fff}.dlp-cell-dot--p1{background:#dc2626}.dlp-cell-dot--p2{background:#d97706}.dlp-cell-dot--p3{background:#94a3b8}.dlp-map-table-wrap{overflow-x:auto;border-radius:12px;border:1px solid var(--color-border-light, #ebebeb);background:var(--color-bg-card, #fff)}.dlp-map-table{width:100%;border-collapse:collapse;font-size:.75rem}.dlp-map-table th{padding:.625rem .5rem;font-weight:700;font-size:.625rem;text-transform:uppercase;letter-spacing:.3px;border-bottom:2px solid var(--color-border, #cacaca)}.dlp-map-table td{padding:.5rem;border-bottom:1px solid var(--color-border-light, #ebebeb);transition:background var(--transition-smooth)}.dlp-map-row--module{background:var(--gradient-primary-soft)}.dlp-map-row--segment{background:var(--color-bg, #f5f5f5)}.dlp-map-row--topic{cursor:pointer}.dlp-map-row--topic:hover{background:#fffbeb}.dlp-map-row--total{background:var(--gradient-primary)}.dlp-map-row--total td{color:#fff;font-weight:700;border-bottom:none}.dlp-bloom-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:2px;border-radius:12px;overflow:hidden;border:1px solid var(--color-border-light, #ebebeb)}.dlp-bloom-col-header{padding:.625rem .375rem;text-align:center;font-size:.625rem;font-weight:700;text-transform:uppercase}.dlp-bloom-col{background:var(--color-bg-card, #fff);padding:.25rem;min-height:60px}.dlp-bloom-card{padding:.2rem .3rem;border-radius:5px;margin-bottom:2px;border-left:3px solid}.dlp-bloom-card-id{font-size:.4375rem;color:var(--color-text-muted, #6b6b6b);font-family:Poppins,sans-serif}.dlp-bloom-card-text{font-size:.5625rem;color:var(--color-text, #4e4e4e);line-height:1.3}.dlp-bloom-count{margin-top:.25rem;font-size:.6875rem;font-weight:700;text-align:center;font-family:Poppins,sans-serif}.dlp-modal--loading{display:flex;align-items:center;justify-content:center}.dlp-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;color:var(--color-text-muted, #6b6b6b);font-size:.875rem}.dlp-loading-spinner{width:36px;height:36px;border:3px solid var(--color-border-light, #ebebeb);border-top-color:var(--color-primary, #4a4dc9);border-radius:50%;animation:dlp-spin .7s linear infinite}@keyframes dlp-spin{to{transform:rotate(360deg)}}.dlp-module-summary{font-size:.8125rem;color:var(--color-text, #4e4e4e);line-height:1.6;margin:0 0 1rem;padding:.625rem .875rem;background:var(--gradient-primary-soft);border-radius:8px;border-left:3px solid var(--color-primary, #4a4dc9)}.dlp-segment-summary{font-size:.75rem;color:var(--color-text-muted, #6b6b6b);line-height:1.55;margin:0 0 .5rem;padding:.375rem .625rem;background:var(--color-bg, #f5f5f5);border-radius:6px}.dlp-media-placeholder{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1.25rem 1rem;border-radius:8px;margin-top:.5rem;font-size:.75rem;font-weight:500;border:1.5px dashed;text-transform:capitalize}.dlp-media-placeholder--simulation{background:#fffbeb;border-color:#fcd34d;color:#b45309}.dlp-media-placeholder--3d_model{background:#f0fdfa;border-color:#5eead4;color:#0f766e}.dlp-media-placeholder-icon{font-size:1.5rem}.dlp-media-instructions{font-size:.6875rem;color:var(--color-primary, #4a4dc9);background:var(--gradient-primary-soft);padding:.375rem .625rem;border-radius:6px;margin-top:.5rem;line-height:1.45}.dlp-media-instructions-label{font-weight:700}.dlp-media-teaching-notes{font-size:.6875rem;color:#92400e;background:#fef3c7;padding:.375rem .625rem;border-radius:6px;margin-top:.375rem;line-height:1.45}.dlp-media-tn-label{font-weight:700}.dlp-media-subtype{text-transform:capitalize}.dlp-recall-diff{padding:.075rem .4rem;border-radius:99px;font-size:.5625rem;font-weight:600;color:#fff;text-transform:capitalize;flex-shrink:0}.dlp-tag--exchanges{background:var(--color-bg, #f5f5f5);color:var(--color-text-muted, #6b6b6b);border:1px solid var(--color-border-light, #ebebeb)}.dlp-tag--dep{background:#fef3c7;color:#92400e;border:1px solid #fde68a;font-size:.5625rem}.dlp-footer{padding:.5rem 1.5rem;border-top:1px solid var(--color-border-light, #ebebeb);text-align:center;font-size:.625rem;color:var(--color-text-muted, #9ca3af);flex-shrink:0;background:var(--color-bg-card, #fff);letter-spacing:.2px}.dlp-footer-planid{display:inline-block;background:var(--gradient-primary-soft);color:var(--color-primary, #4a4dc9);padding:.1rem .5rem;border-radius:4px;font-weight:600;font-size:.5625rem;font-family:SF Mono,Fira Code,monospace;margin-right:.5rem}.dlp-footer-version{display:inline-block;margin-right:.5rem;font-size:.5625rem;color:var(--color-text-muted, #9ca3af)}.dlp-imp-list{margin:.5rem 0 .75rem}.dlp-imp-list .dlp-section-label{display:block;margin-bottom:.25rem}.dlp-imp-items{margin:0;padding-left:1.25rem;font-size:.75rem;color:var(--color-text, #4e4e4e);line-height:1.5}.dlp-imp-items li{margin-bottom:.2rem}.dlp-imp-list--segment,.dlp-imp-list--topic{margin-left:.25rem}.dlp-media-meta-row{display:flex;flex-wrap:wrap;align-items:center;gap:.375rem;margin-top:.5rem}.dlp-media-badge{font-size:.625rem;font-weight:600;padding:.15rem .5rem;border-radius:6px}.dlp-media-badge--category{background:#ecfdf5;color:#047857;border:1px solid #a7f3d0}.dlp-media-details{font-size:.6875rem;margin-top:.25rem}.dlp-media-details-summary{cursor:pointer;color:var(--color-primary, #4a4dc9);font-weight:600}.dlp-media-negative-prompt{margin:.25rem 0 0;padding:.5rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;font-size:.625rem;color:#475569;white-space:pre-wrap;word-break:break-word;max-height:120px;overflow-y:auto}.dlp-media-parts{margin-top:.5rem}.dlp-media-parts-label{font-size:.625rem;font-weight:700;color:var(--color-primary, #4a4dc9);text-transform:uppercase;letter-spacing:.04em;display:block;margin-bottom:.25rem}.dlp-media-parts-list{display:flex;flex-wrap:wrap;gap:.25rem}.dlp-media-part-tag{font-size:.6875rem;padding:.2rem .5rem;border-radius:6px;background:#f5f3ff;border:1px solid #ddd6fe;color:#5b21b6}.dlp-dep-container{position:relative;min-height:200px}.dlp-dep-svg{position:absolute;left:0;top:0;width:100%;height:100%;pointer-events:none;overflow:visible}.dlp-dep-list{display:flex;flex-direction:column;gap:.4rem;padding:.5rem 0 .5rem 2rem}.dlp-dep-row{display:flex;align-items:center;gap:.6rem}.dlp-dep-id-label{display:flex;align-items:center;gap:.3rem;flex-shrink:0;min-width:90px}.dlp-dep-id-text{font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.65rem;font-weight:600;color:var(--color-text-muted, #6b7280)}.dlp-dep-card{flex:1;display:flex;flex-direction:column;gap:.1rem;padding:.45rem .75rem;border-left:4px solid #6b7280;border-radius:6px;background:#fff;box-shadow:0 1px 3px #0000000f;transition:box-shadow .2s,transform .15s}.dlp-dep-card:hover{box-shadow:0 3px 10px #0000001a;transform:translate(2px)}.dlp-dep-card-name{font-size:.75rem;font-weight:600;color:var(--color-text, #1f2937)}.dlp-dep-card-meta{display:flex;align-items:center;gap:.4rem}.dlp-dep-card-type{font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.dlp-dep-card-cat{font-size:.6rem;font-weight:500;padding:.05rem .3rem;border-radius:3px;background:#0000000a}.dlp-dep-card-deps{font-size:.65rem;color:var(--color-primary, #4a4dc9);font-weight:500;margin-top:.1rem}.dlp-tool-preview-compiling{color:#6b7280;background:#f9fafb}.lp-root{flex:1;min-height:0;display:flex;flex-direction:column}.learning-plan-view{padding:0;min-height:0;flex:1;display:flex;flex-direction:column;overflow:hidden}.learning-plan-view--loading,.learning-plan-view--error{align-items:center;justify-content:center;color:var(--color-text-muted);font-size:.9375rem}.learning-plan-view--error{color:var(--color-highlight)}.learning-plan-view--not-available{display:flex;align-items:center;justify-content:center;min-height:400px;padding:2rem}.lp-not-available-content{text-align:center;max-width:400px}.lp-not-available-icon{margin-bottom:1.5rem}.lp-not-available-icon svg{width:80px;height:80px}.lp-not-available-title{font-size:1.25rem;font-weight:600;color:#1f2937;margin:0 0 1rem}.lp-not-available-text{font-size:.9375rem;color:#6b7280;line-height:1.6;margin:0 0 1rem}.lp-not-available-hint{font-size:.875rem;color:#7c3aed;font-weight:500;margin:0}.lp-hero{background:var(--gradient-primary);color:#fff;padding:.65rem 1rem;border-radius:8px;margin-bottom:.5rem;display:flex;align-items:center;gap:1rem;animation:lp-hero-in .35s ease-out}@keyframes lp-hero-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.lp-chapter-title{margin:0;font-size:.8125rem;font-weight:600;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.lp-hero-meta{display:flex;align-items:center;gap:.35rem;margin-left:auto;flex-shrink:0}.lp-content{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding-right:0}.lp-module{background:var(--gradient-card);border:1px solid var(--color-border-light);border-radius:14px;padding:1.25rem 1.5rem;margin-bottom:1.25rem;box-shadow:0 2px 12px #4a4dc90f;transition:box-shadow .3s ease,transform .3s ease,border-color .3s ease;animation:lp-module-in .4s ease-out backwards}.lp-module:nth-child(1){animation-delay:.05s}.lp-module:nth-child(2){animation-delay:.1s}.lp-module:nth-child(3){animation-delay:.15s}.lp-module:nth-child(4){animation-delay:.2s}.lp-module:nth-child(5){animation-delay:.25s}.lp-module:nth-child(n+6){animation-delay:.3s}.lp-module:hover{box-shadow:0 8px 28px #4a4dc924;transform:translateY(-3px);border-color:#4a4dc933}@keyframes lp-module-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.lp-module-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid var(--color-border-light)}.lp-module-badge{flex-shrink:0;background:var(--gradient-primary);color:#fff;font-size:.75rem;font-weight:700;padding:.35rem .6rem;border-radius:8px;transition:transform .25s ease,box-shadow .25s ease}.lp-module:hover .lp-module-badge{transform:scale(1.08);box-shadow:0 2px 12px #4a4dc966}.lp-module-title{margin:0;font-size:1rem;font-weight:700;color:var(--color-text);letter-spacing:-.01em}.lp-segment{margin-bottom:1.25rem}.lp-segment:last-child{margin-bottom:0}.lp-segment-title{margin:0 0 .75rem;font-size:.9375rem;font-weight:600;color:var(--color-accent-purple);display:flex;align-items:baseline;gap:.5rem;transition:color .25s ease,letter-spacing .25s ease}.lp-segment:hover .lp-segment-title{color:var(--color-primary);letter-spacing:.02em}.lp-segment-id{flex-shrink:0;font-size:.75rem;color:var(--color-primary);background:var(--gradient-primary-soft);padding:.2rem .45rem;border-radius:6px}.lp-segment--dragging{opacity:.5;box-shadow:0 8px 24px #0000001f}.lp-segment--drop-target{border:2px dashed var(--color-primary);border-radius:8px;background:#7c3aed0a}.lp-segment-drag-handle{flex-shrink:0;padding:.15rem;cursor:grab;color:var(--color-text-muted);border-radius:4px;display:flex;align-items:center;justify-content:center}.lp-segment-drag-handle:hover{color:var(--color-primary);background:#7c3aed1a}.lp-segment-drag-handle:active{cursor:grabbing}.lp-topic{position:relative;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem 1.5rem 1.25rem 2.75rem;margin-bottom:1.25rem;box-shadow:0 1px 3px #0000000a}.lp-topic:last-child{margin-bottom:0}.lp-topic-drag-handle{position:absolute;left:.5rem;top:1rem;padding:.25rem;cursor:grab;color:var(--color-text-muted);border-radius:4px;display:flex;align-items:center;justify-content:center}.lp-topic-drag-handle:hover{color:var(--color-primary);background:#7c3aed1a}.lp-topic-drag-handle:active{cursor:grabbing}.lp-topic--dragging{opacity:.6;box-shadow:0 8px 24px #00000026}.lp-topic--drop-target{border-color:var(--color-primary);background:#7c3aed0f;box-shadow:0 0 0 2px #7c3aed33}.lp-topic--has-images{cursor:pointer}.lp-topic--has-images:hover{border-color:#4a4dc933}.lp-topic--focused{border-color:var(--color-primary);box-shadow:0 0 0 2px #4a4dc940;background:linear-gradient(135deg,rgba(74,77,201,.08) 0%,var(--color-bg) 100%);animation:lp-topic-focused-pulse 2s ease-in-out infinite}@keyframes lp-topic-focused-pulse{0%,to{box-shadow:0 0 0 2px #4a4dc940}50%{box-shadow:0 0 0 3px #4a4dc959}}.lp-topic-title{margin:0 0 .85rem;font-size:.9375rem;font-weight:600;color:#1e293b;display:flex;align-items:baseline;gap:.5rem;letter-spacing:-.01em;min-width:0}.lp-topic-title .lp-inline-edit{flex:1 1 0%;min-width:0}.lp-topic-id{flex-shrink:0;font-size:.6875rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.04em;padding:.2rem .5rem;background:#f1f5f9;border-radius:6px}.lp-block{margin-bottom:1rem;min-width:0}.lp-block:last-child{margin-bottom:0}.lp-block-label{display:block;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#5b21b6;margin-bottom:.5rem;transition:color .25s ease,letter-spacing .25s ease;position:relative;padding-bottom:.25rem}.lp-block-label:after{content:"";position:absolute;left:0;bottom:0;width:1.5rem;height:2px;background:linear-gradient(90deg,var(--color-primary),transparent);border-radius:1px;opacity:.6}.lp-block:hover .lp-block-label{letter-spacing:.1em;color:#6d28d9}.lp-bullet-list{margin:0;padding-left:1.25rem;font-size:.8125rem;color:var(--color-text-muted);line-height:1.6}.lp-bullet-list li{margin-bottom:.25rem}.lp-objective-list{margin:0;padding-left:1.25rem;font-size:.8125rem;color:var(--color-text-muted);line-height:1.6}.lp-objective-item{position:relative;margin-bottom:.75rem;padding:.75rem .75rem .75rem 2.5rem;border-radius:10px;border:1px solid #e2e8f0;background:#fefefe;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease}.lp-objective-item:last-child{margin-bottom:0}.lp-objective-item:hover{border-color:#cbd5e1;box-shadow:0 2px 8px #0000000a}.lp-objective-item--dragging{opacity:.6;box-shadow:0 8px 24px #0000001f}.lp-objective-item--drop-target{border-color:var(--color-primary);background:linear-gradient(135deg,#7c3aed0f,#8b5cf60a);box-shadow:0 0 0 2px #7c3aed2e}.lp-objective-drag-handle{position:absolute;left:.4rem;top:.65rem;padding:.3rem;cursor:grab;color:#94a3b8;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:color .2s ease,background .2s ease}.lp-objective-drag-handle:hover{color:var(--color-primary);background:#7c3aed14}.lp-objective-drag-handle:hover{color:var(--color-primary)}.lp-objective-drag-handle:active{cursor:grabbing}.lp-objective-text{display:block;margin-bottom:.5rem}.lp-image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;margin-top:.75rem}.lp-add-image-card{min-height:140px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;background:var(--color-bg);border:2px dashed var(--color-border-light);border-radius:10px;color:var(--color-text-muted);cursor:pointer;transition:border-color .2s,color .2s,background .2s}.lp-add-image-card:hover{border-color:var(--color-primary);color:var(--color-primary);background:#7c3aed0d}.lp-add-image-label{font-size:.8125rem;font-weight:600}.lp-image-placeholder{aspect-ratio:4 / 3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.35rem;background:var(--color-bg);color:var(--color-text-muted);font-size:.75rem}.lp-image-placeholder svg{opacity:.6}.lp-figure{position:relative;margin:0;background:var(--color-bg-card);border-radius:10px;overflow:visible;border:1px solid var(--color-border-light);box-shadow:0 2px 8px #0000000f;transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s ease,border-color .2s ease,background .2s ease}.lp-figure .lp-image-wrap{overflow:hidden;border-radius:10px 10px 0 0}.lp-image-checkbox{position:absolute;top:.35rem;left:.35rem;z-index:2;display:flex;align-items:center;justify-content:center}.lp-image-checkbox input{width:14px;height:14px;margin:0;cursor:pointer}.lp-figure-drag-handle{position:absolute;top:.35rem;right:.35rem;z-index:2;padding:.25rem;cursor:grab;color:var(--color-text-muted);background:#ffffffe6;border-radius:6px;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 4px #00000026}.lp-figure-drag-handle:hover{color:var(--color-primary);background:#fff}.lp-figure-drag-handle:active{cursor:grabbing}.lp-figure--dragging{opacity:.65;box-shadow:0 8px 24px #0003}.lp-figure--drop-target{border-color:var(--color-primary);background:#7c3aed14;box-shadow:0 0 0 2px #7c3aed40}.lp-figure:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 12px 24px #4a4dc92e}.lp-figure .lp-image{transition:transform .5s ease}.lp-figure:hover .lp-image{transform:scale(1.06)}.lp-image{width:100%;height:auto;display:block;aspect-ratio:4 / 3;object-fit:cover}.lp-figcaption{padding:.5rem .75rem;font-size:.75rem;font-weight:600;color:var(--color-text);background:var(--gradient-primary-soft)}.lp-image-desc{margin:0;padding:.5rem .75rem;font-size:.7rem;color:var(--color-text-muted);line-height:1.4;border-top:1px solid var(--color-border-light)}.lp-image-wrap,.lp-carousel-image-wrap{position:relative;overflow:hidden;display:block}.lp-image-wrap--mark-mode{cursor:crosshair}.lp-image-wrap .lp-image,.lp-carousel-image-wrap .lp-carousel-image{display:block;width:100%;height:auto;vertical-align:top}.lp-markup-overlay{position:absolute;border:2px solid rgba(220,38,38,.9);background:#dc262633;pointer-events:none;display:flex;align-items:flex-end;padding:2px;box-sizing:border-box}.lp-markup-note{font-size:.6rem;line-height:1.2;color:#fff;background:#000000bf;padding:2px 4px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lp-markup-overlay--drawn{border:none;background:transparent;padding:0;flex-direction:column;align-items:stretch;justify-content:flex-end;overflow:hidden}.lp-markup-drawn-img{position:absolute;left:0;top:0;width:100%;height:100%;object-fit:cover;object-position:center;pointer-events:none}.lp-markup-overlay--drawn .lp-markup-note{position:relative;z-index:1;margin-top:auto}.lp-image-actions,.lp-carousel-image-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.35rem;padding:.4rem .5rem;border-top:1px solid var(--color-border-light);background:var(--color-bg);width:100%;margin:0 auto}.lp-img-btn{display:inline-flex;align-items:center;gap:.25rem;padding:.3rem .5rem;font-size:.7rem;font-weight:600;color:var(--color-text-muted);background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:6px;cursor:pointer;transition:color .2s,background .2s,border-color .2s}.lp-img-btn:hover{color:var(--color-text);border-color:var(--color-primary)}.lp-img-btn--like.lp-img-btn--active{color:#0d9488;background:#0d94881f;border-color:#0d9488}.lp-img-btn--dislike.lp-img-btn--active{color:#dc2626;background:#dc26261a;border-color:#dc2626}.lp-img-btn--mark.lp-img-btn--active{color:var(--color-primary);background:var(--gradient-primary-soft);border-color:var(--color-primary)}.lp-img-btn--delete{color:var(--color-text-muted)}.lp-img-btn--delete:hover{color:#dc2626;background:#dc26261a;border-color:#dc26264d}.lp-image-dislike-form{padding:.5rem .75rem;border-top:1px solid var(--color-border-light);background:var(--color-bg)}.lp-image-dislike-form--carousel{margin-top:.25rem;width:100%;max-width:100%;text-align:left}.lp-image-dislike-label{display:block;font-size:.7rem;font-weight:600;color:var(--color-text);margin-top:.35rem;margin-bottom:.2rem}.lp-image-dislike-label:first-child{margin-top:0}.lp-image-dislike-input{width:100%;padding:.4rem .5rem;font-size:.75rem;font-family:inherit;line-height:1.4;color:var(--color-text);background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:6px;resize:vertical;box-sizing:border-box}.lp-video-evidence-row{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem;margin-top:.4rem}.lp-video-evidence-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;padding:.25rem .6rem;font-size:.7rem;font-weight:600;color:var(--color-primary);background:var(--gradient-primary-soft);border-radius:999px;cursor:pointer}.lp-video-evidence-btn input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}.lp-video-evidence-count{font-size:.7rem;color:var(--color-text-muted)}.lp-media-section{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--color-border-light)}.lp-media-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.lp-media-drag-handle{padding:.3rem;cursor:grab;color:#94a3b8;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:color .2s ease,background .2s ease}.lp-media-drag-handle:hover{color:var(--color-primary);background:#7c3aed14}.lp-media-drag-handle:active{cursor:grabbing}.lp-media-checkbox{display:flex;align-items:center;justify-content:center}.lp-media-checkbox input{width:14px;height:14px;margin:0;cursor:pointer}.lp-media-label{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#5b21b6;flex:1}.lp-media-empty{grid-column:1 / -1;min-height:140px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;background:var(--color-bg);border:2px dashed var(--color-border-light);border-radius:10px;color:var(--color-text-muted);padding:2rem;text-align:center}.lp-media-empty p{margin:0;font-size:.8125rem;font-weight:600}.lp-media-empty-hint{font-size:.75rem;opacity:.7}.lp-media-content{aspect-ratio:4 / 3;display:flex;align-items:center;justify-content:center;background:var(--color-bg)}.lp-media-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--color-bg);color:var(--color-text-muted);font-size:.75rem;font-weight:600;border:1px dashed var(--color-border-light);border-radius:8px}.lp-media-2d-tool-button{width:100%;display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:linear-gradient(135deg,#fdf2f8,#fce7f3);border:1px solid var(--color-border-light);border-radius:8px;cursor:pointer;font:inherit;text-align:left;transition:background .15s ease}.lp-media-2d-tool-button:hover{background:linear-gradient(135deg,#fce7f3,#fbcfe8)}.lp-media-2d-tool-label{font-size:.75rem;font-weight:600;color:#be185d;text-transform:uppercase;letter-spacing:.03em}.lp-media-2d-tool-title{font-size:.8125rem;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.lp-media-instructions{padding:.5rem .75rem;background:var(--color-bg);border-top:1px solid var(--color-border-light);font-size:.75rem;line-height:1.5;color:var(--color-text)}.lp-media-instructions-label{font-weight:600;color:#7c3aed;margin-right:.25rem}.lp-media-teaching-notes{padding:.5rem .75rem;background:#fffbeb;border-top:1px solid #fde68a;font-size:.75rem;line-height:1.5;color:var(--color-text)}.lp-media-tn-label{font-weight:600;color:#92400e;margin-right:.25rem}.dlp-tool-preview-backdrop{position:fixed;inset:0;background:#0000008c;z-index:1300;display:flex;align-items:center;justify-content:center;padding:1.5rem;animation:lp-modal-fade-in .2s ease-out}.dlp-tool-preview-modal{background:var(--color-bg-card, #fff);border-radius:16px;box-shadow:0 24px 48px #00000040;width:90vw;max-width:90vw;height:90vh;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.dlp-tool-preview-modal-header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:linear-gradient(to right,#eef2ff,#f5f3ff);border-bottom:1px solid var(--color-border-light, #ebebeb);flex-shrink:0}.dlp-tool-preview-modal-title{font-size:.875rem;font-weight:600;color:#4f46e5}.dlp-tool-preview-modal-subtitle{font-size:.8125rem;color:var(--color-text, #1a1a1a);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.dlp-tool-preview-modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:8px;color:var(--color-text-muted, #6b6b6b);cursor:pointer;flex-shrink:0;transition:background .15s,color .15s}.dlp-tool-preview-modal-close:hover{background:#fef2f2;color:#dc2626}.dlp-tool-preview-modal-body{flex:1;min-height:360px;overflow:hidden;background:#fdf2f8}.dlp-tool-preview-iframe{width:100%;height:100%;min-height:400px;border:0;display:block}.dlp-tool-preview-compile-error,.dlp-tool-preview-compiling{padding:1rem 1.25rem;font-size:.875rem}.dlp-tool-preview-compile-error{color:#b91c1c;background:#fef2f2;border-radius:8px;white-space:pre-wrap}.dlp-tool-preview-compiling{color:#6b7280;text-align:center}.lp-image-dislike-input:focus{outline:none;border-color:var(--color-primary)}.lp-img-save-btn{display:inline-flex;align-items:center;gap:.25rem;margin-top:.5rem;padding:.35rem .65rem;font-size:.75rem;font-weight:600;color:#fff;background:var(--gradient-primary);border:none;border-radius:6px;cursor:pointer;transition:opacity .2s,transform .2s}.lp-img-save-btn:hover{opacity:.95;transform:scale(1.02)}.lp-carousel-slide{display:flex;flex-direction:column;align-items:center;gap:.25rem;min-width:0}.lp-carousel-image-wrap{width:100%;min-height:0;position:relative;border-radius:10px;overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--color-bg)}.lp-carousel-image-wrap .lp-carousel-image{max-width:100%;max-height:60vh;width:auto;height:auto;object-fit:contain;display:block;margin:0 auto;align-self:center}.lp-table-wrap{overflow-x:auto;margin-top:.5rem}.lp-table{width:100%;max-width:320px;border-collapse:collapse;font-size:.8125rem;border-radius:12px;overflow:hidden;border:1px solid #e2e8f0;box-shadow:0 2px 12px #0000000d;transition:box-shadow .25s ease,border-color .25s ease}.lp-table-wrap:hover .lp-table{box-shadow:0 4px 16px #4a4dc91f;border-color:#cbd5e1}.lp-table tbody tr{transition:background .2s ease}.lp-table tbody tr:hover{background:linear-gradient(135deg,#7c3aed0f,#8b5cf60a)}.lp-table thead{color:#fff}.lp-table th{padding:.65rem 1rem;text-align:center;font-weight:600;font-size:.6875rem;text-transform:uppercase;letter-spacing:.06em}.lp-table th:first-child{background:linear-gradient(135deg,#4a4dc9,#4338ca)}.lp-table th:last-child{background:linear-gradient(135deg,#5b21b6,#533086)}.lp-table td{padding:.75rem 1rem;text-align:center;border-bottom:1px solid #e2e8f0;color:#1e293b;font-weight:500;font-size:.9375rem}.lp-table tbody tr:last-child td{border-bottom:none}.lp-table tbody tr:nth-child(2n) td{background:linear-gradient(135deg,#7c3aed08,#8b5cf605)}.lp-chunks{display:flex;flex-direction:column;gap:.75rem;overflow:visible}.lp-chunk{padding:.75rem 1rem;background:var(--color-bg-card);border-radius:8px;border-left:4px solid var(--color-primary);position:relative;overflow:hidden;z-index:0}.lp-chunk:after{content:"";position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);pointer-events:none}.lp-chunk--original{border-left-color:var(--color-border);background:var(--color-bg)}.lp-chunk-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.35rem}.lp-chunk-header .lp-block-label{margin-bottom:0}.lp-chunk-header-actions{display:flex;align-items:center;gap:4px;opacity:0;transition:opacity .15s}.lp-chunk--original:hover .lp-chunk-header-actions{opacity:1}.lp-chunk-action-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;padding:0;color:#6d28d9;background:transparent;border:1px solid transparent;border-radius:6px;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.lp-chunk-action-btn:hover{background:#6d28d914;border-color:#6d28d9}.lp-chunk-action-btn--copied{color:#10b981;border-color:#10b981}@keyframes lp-popup-in{0%{opacity:0;transform:translate(-50%,calc(-100% - 4px)) scale(.92)}to{opacity:1;transform:translate(-50%,calc(-100% - 10px)) scale(1)}}.lp-selection-popup{position:fixed;transform:translate(-50%,calc(-100% - 10px));z-index:9999;pointer-events:auto;animation:lp-popup-in .12s ease-out both}.lp-selection-popup:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#1e1b4b}.lp-selection-popup-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;font-size:.75rem;font-weight:600;color:#fff;background:#1e1b4b;border:none;border-radius:7px;cursor:pointer;white-space:nowrap;box-shadow:0 6px 20px #0000004d;transition:background .15s;letter-spacing:.01em}.lp-selection-popup-btn:hover{background:#4c1d95}.lp-chunk--original:after{background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent)}.lp-chunk-text{margin:0;font-size:.8125rem;line-height:1.6;color:var(--color-text-muted)}.lp-chunk-text strong{color:var(--color-text);font-weight:600}.lp-topic-actions{display:flex;align-items:center;gap:.5rem;margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--color-border-light)}.lp-action-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .75rem;font-size:.8125rem;font-weight:600;color:var(--color-text-muted);background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:8px;cursor:pointer;transition:color .2s,background .2s,border-color .2s,box-shadow .2s,transform .2s}.lp-action-btn:hover{color:var(--color-text);background:var(--color-bg);border-color:var(--color-primary);box-shadow:0 2px 8px #4a4dc91f;transform:scale(1.05)}.lp-action-btn:active{transform:scale(.98)}.lp-action-btn--like.lp-action-btn--active{color:#0d9488;background:#0d94881f;border-color:#0d9488}.lp-action-btn--dislike.lp-action-btn--active{color:#dc2626;background:#dc26261a;border-color:#dc2626}.lp-dislike-reason-wrap{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--color-border-light)}.lp-dislike-reason-label{display:block;font-size:.8125rem;font-weight:600;color:var(--color-text);margin-bottom:.4rem}.lp-dislike-reason-input{width:100%;min-height:72px;padding:.6rem .75rem;font-size:.8125rem;font-family:inherit;line-height:1.5;color:var(--color-text);background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:8px;resize:vertical;transition:border-color .2s,box-shadow .2s}.lp-dislike-reason-input::placeholder{color:var(--color-text-muted)}.lp-dislike-reason-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #4a4dc933}.lp-save-btn{display:inline-flex;align-items:center;gap:.4rem;margin-top:.6rem;padding:.5rem 1rem;font-size:.8125rem;font-weight:600;color:#fff;background:var(--gradient-primary);border:none;border-radius:8px;cursor:pointer;transition:opacity .2s,transform .2s,box-shadow .2s}.lp-save-btn:hover{opacity:.95;transform:translateY(-2px) scale(1.02);box-shadow:0 6px 16px #4a4dc966}.lp-save-btn:active{transform:translateY(0) scale(.98)}.lp-image-modal-backdrop{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1.5rem;animation:lp-modal-fade-in .2s ease-out}@keyframes lp-modal-fade-in{0%{opacity:0}to{opacity:1}}.lp-image-modal{position:relative;background:var(--color-bg-card);border-radius:16px;box-shadow:0 24px 48px #0003;max-width:90vw;max-height:90vh;width:100%;overflow:hidden;display:flex;flex-direction:column;animation:lp-modal-scale-in .25s ease-out}@keyframes lp-modal-scale-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.lp-image-modal-close{position:absolute;top:.75rem;right:.75rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#0003;color:#fff;border:none;border-radius:50%;cursor:pointer;z-index:2;transition:background .2s}.lp-image-modal-close:hover{background:#0006}.lp-image-modal-title{margin:0;padding:1rem 3rem .5rem 1.25rem;font-size:1rem;font-weight:700;color:var(--color-text);display:flex;align-items:baseline;gap:.5rem}.lp-image-modal-topic-id{flex-shrink:0;font-size:.75rem;font-weight:600;color:var(--color-primary);background:var(--gradient-primary-soft);padding:.25rem .5rem;border-radius:6px}.lp-carousel{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem 1rem;min-height:0}.lp-carousel-btn{flex-shrink:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);color:#fff;border:none;border-radius:50%;cursor:pointer;transition:transform .2s,box-shadow .2s}.lp-carousel-btn:hover{transform:scale(1.08);box-shadow:0 4px 16px #4a4dc966}.lp-carousel-slide{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;text-align:center}.lp-carousel-image{max-width:100%;max-height:60vh;width:auto;height:auto;object-fit:contain;border-radius:10px;background:var(--color-bg);margin:0 auto;display:block;align-self:center}.lp-carousel-caption{margin:0;font-size:.875rem;font-weight:600;color:var(--color-text-muted);text-align:center}.lp-carousel-dots{display:flex;align-items:center;justify-content:center;gap:.35rem;padding:.75rem 1rem 1rem}.lp-carousel-dot{width:8px;height:8px;border-radius:50%;border:none;background:var(--color-border);cursor:pointer;padding:0;transition:background .2s,transform .2s}.lp-carousel-dot:hover,.lp-carousel-dot--active{background:var(--color-primary);transform:scale(1.2)}.lp-image-modal-empty{margin:0;padding:2rem 1.5rem;font-size:.9375rem;color:var(--color-text-muted);text-align:center}.lp-markarea-embedded{padding:.5rem 0}.lp-markarea-embedded .lp-markarea-main{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:1rem;align-items:start}.lp-markarea-embedded .lp-markarea-image-wrap{position:relative;border-radius:12px;overflow:hidden;border:1px solid var(--color-border-light);background:var(--color-bg);box-shadow:0 6px 16px #0000000f}.lp-markarea-embedded .lp-markarea-image{display:block;height:100%;max-height:none;background:#fff}.lp-markarea-embedded .lp-markarea-canvas{cursor:crosshair}.lp-markarea-embedded .lp-markarea-sidebar{border-radius:12px;border:1px solid var(--color-border-light);background:#fff;padding:.85rem;box-shadow:0 6px 16px #0000000d}.lp-markarea-embedded .lp-markarea-title{margin:0 0 .35rem;font-size:.95rem;font-weight:700;color:var(--color-text);letter-spacing:-.01em}.lp-markarea-embedded .lp-markarea-subtitle{margin:0 0 .75rem;font-size:.8rem;color:var(--color-text-muted);line-height:1.4}.lp-markarea-embedded .lp-markarea-textarea{width:100%;border:1px solid var(--color-border-light);border-radius:10px;padding:.6rem .7rem;font-size:.875rem;line-height:1.45;resize:vertical;min-height:92px;background:var(--color-bg);box-sizing:border-box}.lp-markarea-embedded .lp-markarea-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #4a4dc92e}.lp-markarea-embedded .lp-markarea-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.75rem}.lp-markarea-embedded .lp-confirm-btn{border-radius:10px;padding:.5rem .9rem;font-size:.875rem;font-weight:700}@media(max-width:900px){.lp-markarea-embedded .lp-markarea-main{grid-template-columns:1fr}.lp-markarea-embedded .lp-markarea-image{max-height:46vh}}.lp-markarea-modal-backdrop{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1001;padding:1.5rem;animation:lp-modal-fade-in .2s ease-out}.lp-markarea-modal{background:var(--color-bg-card);border-radius:16px;box-shadow:0 24px 48px #00000040;max-width:90vw;max-height:90vh;width:100%;overflow:hidden;display:flex;flex-direction:column;animation:lp-modal-scale-in .25s ease-out}.lp-markarea-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:var(--gradient-primary);color:#fff;flex-shrink:0}.lp-markarea-modal-title{margin:0;font-size:1rem;font-weight:700;letter-spacing:-.02em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:calc(100% - 48px)}.lp-markarea-modal-close{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fff3;color:#fff;border:none;border-radius:50%;cursor:pointer;transition:background .2s;flex-shrink:0}.lp-markarea-modal-close:hover{background:#ffffff59}.lp-markarea-modal-body{padding:1rem 1.25rem;overflow-y:auto;flex:1;min-height:0}.lp-markarea-image-container{position:relative;display:flex;align-items:center;justify-content:center;max-width:100%;margin:0 auto .75rem;border-radius:10px;overflow:hidden;border:1px solid var(--color-border-light);background:var(--color-bg)}.lp-markarea-image{display:block;max-width:100%;max-height:55vh;width:auto;height:auto;vertical-align:top;margin:0 auto}.lp-markarea-canvas{position:absolute;left:0;top:0;cursor:crosshair;pointer-events:auto}.lp-markarea-hint{margin:0 0 .5rem;font-size:.75rem;color:var(--color-text-muted)}.lp-markarea-label{display:block;font-size:.8125rem;font-weight:600;color:var(--color-text);margin-bottom:.35rem}.lp-markarea-suggestion{width:100%;padding:.5rem .65rem;font-size:.875rem;font-family:inherit;line-height:1.5;color:var(--color-text);background:var(--color-bg);border:1px solid var(--color-border-light);border-radius:8px;resize:vertical;margin-bottom:.75rem;box-sizing:border-box}.lp-markarea-suggestion:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #4a4dc933}.lp-markarea-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.lp-markarea-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;border-radius:8px;cursor:pointer;transition:opacity .2s,transform .2s}.lp-markarea-btn--secondary{background:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border-light)}.lp-markarea-btn--secondary:hover{border-color:var(--color-primary);color:var(--color-text)}.lp-markarea-btn--primary{background:var(--gradient-primary);color:#fff;border:none}.lp-markarea-btn--primary:hover{opacity:.95;transform:translateY(-1px)}.lp-markarea-btn--primary:disabled,.lp-markarea-btn--primary[disabled]{background:linear-gradient(to right,#d1d5db,#9ca3af);cursor:not-allowed;opacity:.8;transform:none}.lp-editable{cursor:text;border-radius:4px;padding:2px 4px;margin:-2px -4px}.lp-editable:hover{background:#7c3aed14}.lp-original-text-area,.lp-original-text-area *,.lp-chunk--original .lp-chunk-text,.lp-chunk--original .lp-chunk-text *{cursor:text;-webkit-user-select:text;user-select:text}.lp-sentence-unmatched{background:#ef444426;color:#dc2626;border-radius:3px;padding:1px 3px;border-bottom:2px solid #dc2626}.lp-inline-edit{margin:.5rem 0;padding:.75rem;background:var(--color-bg);border:1px solid var(--color-primary);border-radius:8px;box-shadow:0 4px 12px #7c3aed26;width:100%;min-width:0;max-width:100%;box-sizing:border-box}.lp-inline-edit-input,.lp-inline-edit-textarea{display:block;width:100%;min-width:0;max-width:100%;padding:.5rem .75rem;font-size:.9375rem;line-height:1.5;color:var(--color-text);background:#fff;border:1px solid var(--color-border-light);border-radius:6px;margin-bottom:.75rem;font-family:inherit;box-sizing:border-box}.lp-inline-edit-input:focus,.lp-inline-edit-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #7c3aed33}.lp-inline-edit-textarea{min-height:100px;resize:vertical}.lp-inline-edit-actions{display:flex;gap:.5rem;flex-wrap:wrap}.lp-inline-edit-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .75rem;font-size:.8125rem;font-weight:600;border-radius:6px;cursor:pointer;border:none;transition:background .2s,color .2s}.lp-inline-edit-btn--save{background:var(--gradient-primary);color:#fff}.lp-inline-edit-btn--save:hover{opacity:.95}.lp-inline-edit-btn--cancel{background:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border-light)}.lp-inline-edit-btn--cancel:hover{border-color:var(--color-primary);color:var(--color-text)}.lp-toolbar{display:flex;align-items:center;gap:.5rem;padding:.4rem .5rem;margin-bottom:.75rem;background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:8px}.lp-search-wrap{display:flex;align-items:center;gap:.3rem;background:var(--color-bg);border-radius:6px;padding:.3rem .5rem;width:180px;flex-shrink:0}.lp-search-actions{display:inline-flex;align-items:center;gap:.35rem}.lp-toolbar-btn--compact{height:30px;padding:0 .55rem;font-size:.6875rem;border-radius:6px;white-space:nowrap}.lp-search-wrap svg{color:var(--color-disabled);flex-shrink:0}.lp-search-highlight{background:#fff176!important;color:#1a1a1a!important;border-radius:3px;padding:1px 2px;font-weight:600;outline:1px solid rgba(234,179,8,.5)}.lp-search-input{border:none;background:transparent;color:var(--color-text);font-size:.75rem;font-family:inherit;outline:none;width:100%}.lp-search-input::placeholder{color:var(--color-disabled)}.lp-search-clear{display:flex;align-items:center;justify-content:center;background:var(--color-border-light);border:none;border-radius:50%;width:14px;height:14px;cursor:pointer;color:var(--color-text-muted);flex-shrink:0}.lp-search-clear:hover{background:var(--color-border)}.lp-toolbar-actions{display:flex;align-items:center;gap:.25rem;margin-left:auto}.lp-toolbar-btn{display:inline-flex;align-items:center;justify-content:center;gap:.25rem;width:30px;height:30px;font-size:.6875rem;font-weight:600;color:var(--color-text-muted);background:var(--color-bg);border:none;border-radius:6px;cursor:pointer;transition:color .15s,background .15s}.lp-toolbar-btn:hover:not(:disabled){color:var(--color-primary);background:var(--gradient-primary-soft)}.lp-toolbar-btn:disabled{opacity:.3;cursor:not-allowed}.lp-toolbar-btn--primary{width:auto;padding:0 .6rem;color:var(--color-primary);background:var(--gradient-primary-soft)}.lp-toolbar-btn--primary:hover:not(:disabled){background:#4a4dc926}.lp-merge-bar{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--gradient-primary-soft);border:1px solid rgba(124,58,237,.2);border-radius:8px;margin-bottom:.75rem;font-size:.8125rem;font-weight:600;color:var(--color-primary)}.lp-merge-bar-btn{display:inline-flex;align-items:center;gap:.25rem;padding:.3rem .6rem;font-size:.75rem;font-weight:600;border-radius:6px;cursor:pointer;transition:opacity .2s,transform .2s;border:none}.lp-merge-bar-btn--merge{background:var(--gradient-primary);color:#fff}.lp-merge-bar-btn--merge:hover{opacity:.9;transform:scale(1.03)}.lp-merge-bar-btn--cancel{background:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border-light)}.lp-merge-bar-btn--cancel:hover{border-color:var(--color-primary)}.lp-collapse-btn{display:flex;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;color:var(--color-text-muted);padding:.15rem;border-radius:4px;transition:color .2s,background .2s;flex-shrink:0}.lp-collapse-btn:hover{color:var(--color-primary);background:#7c3aed14}.lp-collapse-btn--small{padding:.1rem}.lp-delete-btn{display:flex;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;color:var(--color-text-muted);padding:.2rem;border-radius:4px;margin-left:auto;opacity:0;transition:color .2s,background .2s,opacity .2s;flex-shrink:0}.lp-module-header:hover .lp-delete-btn,.lp-segment-title:hover .lp-delete-btn{opacity:1}.lp-delete-btn:hover{color:#dc2626;background:#dc262614}.lp-delete-btn--small{padding:.15rem}.lp-add-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem .85rem;font-size:.8125rem;font-weight:600;color:#5b21b6;background:linear-gradient(135deg,#7c3aed0f,#8b5cf60a);border:1.5px dashed rgba(124,58,237,.35);border-radius:8px;cursor:pointer;margin-top:.5rem;transition:background .2s,border-color .2s,transform .2s,box-shadow .2s}.lp-add-btn:hover{background:linear-gradient(135deg,#7c3aed1f,#8b5cf614);border-color:var(--color-primary);transform:translateY(-1px);box-shadow:0 4px 12px #7c3aed26}.lp-merge-checkbox{position:absolute;right:.5rem;top:.5rem;z-index:2;cursor:pointer;display:flex;align-items:center}.lp-merge-checkbox input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--color-primary)}.lp-topic--merge-selected{border-color:var(--color-primary);background:#7c3aed0a}.lp-topic-extra-actions{display:flex;align-items:center;gap:.35rem;margin-left:auto}.lp-action-btn--split{color:var(--color-text-muted)}.lp-action-btn--split:hover{color:var(--color-primary);border-color:var(--color-primary)}.lp-action-btn--merge{color:var(--color-text-muted)}.lp-action-btn--merge:hover{color:var(--color-primary);border-color:var(--color-primary)}.lp-action-btn--merge.lp-action-btn--active{color:var(--color-primary);border-color:var(--color-primary);background:var(--gradient-primary-soft)}.lp-action-btn--delete{color:var(--color-text-muted)}.lp-action-btn--delete:hover{color:#dc2626;border-color:#dc2626;background:#dc26260f}.lp-confirm-backdrop{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1100;animation:lp-modal-fade-in .15s ease-out}.lp-confirm-dialog{background:var(--color-bg-card);border-radius:12px;padding:1.5rem;max-width:400px;width:90%;box-shadow:0 16px 40px #0003;animation:lp-modal-scale-in .2s ease-out}.lp-confirm-message{margin:0 0 1.25rem;font-size:.9375rem;line-height:1.5;color:var(--color-text)}.lp-confirm-actions{display:flex;justify-content:flex-end;gap:.5rem}.lp-confirm-btn{padding:.45rem 1rem;font-size:.8125rem;font-weight:600;border-radius:6px;cursor:pointer;transition:opacity .2s,transform .2s;border:none}.lp-confirm-btn--cancel{background:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border-light)}.lp-confirm-btn--cancel:hover{border-color:var(--color-primary);color:var(--color-text)}.lp-confirm-btn--confirm{background:#dc2626;color:#fff}.lp-confirm-btn--confirm:hover{opacity:.9;transform:scale(1.02)}.lp-image-details-modal{background:var(--color-bg-card);border-radius:12px;padding:1.25rem 1.5rem;max-width:440px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 16px 40px #0003;animation:lp-modal-scale-in .2s ease-out}.lp-image-details-title{margin:0 0 .25rem;font-size:1.125rem;font-weight:600;color:var(--color-text)}.lp-image-details-desc{margin:0 0 1rem;font-size:.8125rem;color:var(--color-text-muted)}.lp-image-details-label{display:block;font-size:.75rem;font-weight:600;color:var(--color-text);margin-bottom:.35rem}.lp-image-details-input,.lp-image-details-textarea{width:100%;padding:.5rem .75rem;font-size:.875rem;font-family:inherit;color:var(--color-text);background:var(--color-bg);border:1px solid var(--color-border-light);border-radius:6px;margin-bottom:1rem;box-sizing:border-box}.lp-image-details-input:focus,.lp-image-details-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #7c3aed33}.lp-image-details-textarea{resize:vertical;min-height:60px}.lp-image-details-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem}.lp-image-details-actions .lp-confirm-btn--confirm{background:var(--gradient-primary);color:#fff}.lp-image-placeholder-hint{display:block;font-size:.7rem;color:var(--color-text-muted);margin-top:.25rem}.lp-figure--video{grid-column:1 / -1}.lp-figure--video:hover{transform:none!important;box-shadow:0 4px 14px #4a4dc91f!important}.lp-figure--video:hover .lp-image{transform:none!important}.lp-video-wrap{overflow:hidden!important;border-radius:10px 10px 0 0;line-height:0}.lp-video-embed-wrap{position:relative;width:100%;aspect-ratio:16 / 9;background:#000;border-radius:0;overflow:hidden}.lp-video-embed{position:absolute;inset:0;width:100%;height:100%;border:none;display:block}.lp-video-direct{width:100%;display:block;background:#000;border-radius:0;max-height:360px;object-fit:contain}.lp-video-placeholder{aspect-ratio:16 / 9!important;flex-direction:column;gap:10px;background:linear-gradient(135deg,#1a1a2e,#2d1b69);color:#ffffffbf;cursor:default;border-radius:0}.lp-video-play-icon{width:52px;height:52px;border-radius:50%;background:#ffffff26;border:2px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;color:#fff}.lp-stat-chip{padding:.15rem .5rem;font-size:.625rem;font-weight:500;color:#ffffffd9;background:#ffffff26;border-radius:4px;white-space:nowrap}.lp-json-editor-backdrop{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1050;padding:.5rem;animation:lp-modal-fade-in .15s ease-out}.lp-json-editor-modal{background:var(--color-bg-card);border-radius:16px;box-shadow:0 24px 48px #00000040;max-width:98vw;width:98vw;max-height:98vh;height:98vh;display:flex;flex-direction:column;overflow:hidden;animation:lp-modal-scale-in .2s ease-out}.lp-json-editor-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:var(--gradient-primary);color:#fff;flex-shrink:0}.lp-json-editor-title{margin:0;font-size:1rem;font-weight:700;display:flex;align-items:center;gap:.5rem}.lp-json-editor-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#fff3;color:#fff;border:none;border-radius:50%;cursor:pointer;transition:background .2s;flex-shrink:0}.lp-json-editor-close:hover{background:#ffffff59}.lp-json-editor-body{flex:1;min-height:0;padding:1rem 1.25rem;display:flex;flex-direction:column;overflow:hidden}.lp-json-editor-textarea{flex:1;min-height:0;max-height:none;width:100%;padding:.75rem 1rem;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.8125rem;line-height:1.55;color:var(--color-text);background:#1e1e2e;color:#cdd6f4;border:1px solid var(--color-border-light);border-radius:10px;resize:none;tab-size:2;white-space:pre;overflow:auto;box-sizing:border-box}.lp-json-editor-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #7c3aed33}.lp-split-textarea{width:100%;min-height:200px;max-height:60vh;padding:.75rem 1rem;font-size:.875rem;line-height:1.5;font-family:inherit;color:var(--color-text);background:var(--color-bg);border:1px solid var(--color-border-light);border-radius:10px;resize:vertical;box-sizing:border-box;white-space:pre-wrap;word-wrap:break-word}.lp-json-editor-error{margin-top:.5rem;padding:.4rem .75rem;font-size:.8125rem;color:#dc2626;background:#dc262614;border:1px solid rgba(220,38,38,.2);border-radius:6px;font-weight:500}.lp-json-editor-footer{display:flex;align-items:center;justify-content:flex-end;gap:.5rem;padding:.75rem 1.25rem;border-top:1px solid var(--color-border-light);flex-shrink:0}.lp-json-editor-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem 1rem;font-size:.8125rem;font-weight:600;border-radius:8px;cursor:pointer;transition:opacity .2s,transform .2s;border:none}.lp-json-editor-btn--cancel{background:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border-light)}.lp-json-editor-btn--cancel:hover{border-color:var(--color-primary);color:var(--color-text)}.lp-json-editor-btn--apply{background:var(--gradient-primary);color:#fff}.lp-json-editor-btn--apply:hover{opacity:.92;transform:scale(1.02)}.lp-merge-options{display:flex;flex-direction:column;gap:.75rem;overflow-y:auto;max-height:400px;padding-right:4px}.lp-merge-option{padding:.75rem;background:var(--color-bg);border:1px solid var(--color-border-light);border-radius:8px;cursor:pointer;transition:all .2s}.lp-merge-option:hover{border-color:var(--color-primary);background:var(--gradient-primary-soft)}.lp-merge-option--selected{border-color:var(--color-primary);background:var(--gradient-primary-soft);box-shadow:0 0 0 2px #7c3aed33}.lp-merge-option-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.35rem}.lp-merge-option-label{font-size:.625rem;font-weight:700;text-transform:uppercase;color:var(--color-primary);background:#fff;padding:.15rem .35rem;border-radius:4px}.lp-merge-option-name{font-size:.8125rem;font-weight:600;color:var(--color-text)}.lp-merge-option-snippet{margin:0;font-size:.75rem;color:var(--color-text-muted);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4}.lp-save-section{display:flex;justify-content:center;padding:1.5rem 0 2rem}.lp-save-plan-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 2.5rem;font-size:.9375rem;font-weight:700;font-family:inherit;color:#fff;background:var(--gradient-primary);border:none;border-radius:10px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 14px #4a4dc94d}.lp-save-plan-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4a4dc966}.lp-save-plan-btn:active{transform:translateY(0) scale(.98);box-shadow:0 2px 8px #4a4dc94d}.lp-topic-meta-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1rem;padding:1rem 1.25rem;background:linear-gradient(135deg,#fafbff,#f5f6fb);border:1px solid rgba(124,58,237,.12);border-radius:12px;box-shadow:0 1px 3px #0000000a;transition:box-shadow .2s ease,border-color .2s ease}@media(max-width:640px){.lp-topic-meta-row{grid-template-columns:repeat(2,1fr)}}.lp-meta-field{display:flex;flex-direction:column;gap:.35rem;min-width:0}.lp-meta-label{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#64748b;transition:color .2s ease}.lp-meta-field:focus-within .lp-meta-label{color:var(--color-primary)}.lp-meta-select{padding:.5rem 1.75rem .5rem .75rem;font-size:.8125rem;font-family:inherit;color:var(--color-text);background:#fff;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;outline:none;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M3 4.5L6 7.5L9 4.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .6rem center}.lp-meta-select:hover{border-color:#cbd5e1;background-color:#fefefe}.lp-meta-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #7c3aed26}.lp-meta-number{width:100%;max-width:80px;padding:.5rem .75rem;font-size:.8125rem;font-family:inherit;color:var(--color-text);background:#fff;border:1px solid #e2e8f0;border-radius:8px;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.lp-meta-number:hover{border-color:#cbd5e1}.lp-meta-number:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #7c3aed26}.lp-meta-select--difficulty[data-difficulty=easy]{border-color:#22c55e80;color:#15803d;background:linear-gradient(135deg,#22c55e0f,#22c55e05)}.lp-meta-select--difficulty[data-difficulty=medium]{border-color:#f59e0b80;color:#b45309;background:linear-gradient(135deg,#f59e0b0f,#f59e0b05)}.lp-meta-select--difficulty[data-difficulty=hard]{border-color:#ef444480;color:#b91c1c;background:linear-gradient(135deg,#ef44440f,#ef444405)}.lp-block.lp-summary{padding:.75rem 0;border-bottom:1px solid rgba(0,0,0,.04)}.lp-summary-text{margin:0;font-size:.875rem;line-height:1.65;color:#475569}.lp-placeholder{font-style:italic;color:#94a3b8;opacity:.9}.lp-block.lp-terms{padding:.5rem 0}.lp-terms-list{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.lp-term-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .75rem;font-size:.8125rem;font-weight:600;color:#5b21b6;background:linear-gradient(135deg,#7c3aed14,#8b5cf60f);border:1px solid rgba(124,58,237,.2);border-radius:999px;white-space:nowrap;transition:background .2s ease,border-color .2s ease,box-shadow .2s ease}.lp-term-chip:hover{background:linear-gradient(135deg,#7c3aed1f,#8b5cf614);border-color:#7c3aed59;box-shadow:0 2px 8px #7c3aed1f}.lp-term-remove{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:1rem;line-height:1;padding:0 .15rem;border-radius:4px;transition:color .15s,background .15s}.lp-term-remove:hover{color:#dc2626;background:#dc262614}.lp-term-add-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;font-size:1rem;font-weight:700;color:var(--color-primary);background:linear-gradient(135deg,#7c3aed14,#8b5cf60f);border:1.5px dashed rgba(124,58,237,.4);border-radius:50%;cursor:pointer;transition:background .2s,border-color .2s,transform .2s,box-shadow .2s}.lp-term-add-btn:hover{background:#7c3aed24;border-color:var(--color-primary);transform:scale(1.08);box-shadow:0 2px 10px #7c3aed33}.lp-term-add-input{padding:.35rem .65rem;font-size:.8125rem;font-family:inherit;border:1px solid var(--color-primary);border-radius:8px;outline:none;width:140px;transition:box-shadow .2s ease}.lp-term-add-input:focus{box-shadow:0 0 0 3px #7c3aed33}.lp-important-points-add{padding-left:1.25rem;margin-top:.35rem}.lp-important-points-add .lp-term-add-input{width:100%;min-width:0;max-width:100%;box-sizing:border-box}.lp-objective-meta{display:flex;align-items:center;gap:.5rem;margin-top:.4rem;flex-wrap:wrap}.lp-obj-collapse-btn{display:flex;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;color:#94a3b8;padding:.3rem;border-radius:6px;transition:color .18s,background .18s;flex-shrink:0}.lp-obj-collapse-btn:hover{color:var(--color-primary);background:#4a4dc912}.lp-media-count{font-size:.7rem;font-weight:600;color:var(--color-primary, #4A4DC9);background:#4a4dc917;padding:1px 6px;border-radius:10px;margin-left:5px}.lp-media-chevron{margin-left:auto;display:flex;align-items:center;color:#94a3b8;transition:color .18s}.lp-media-header:hover .lp-media-chevron{color:var(--color-primary)}.lp-meta-select--bloom{font-size:.75rem;padding:.4rem .65rem;min-width:7rem;background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#475569;transition:border-color .2s ease,box-shadow .2s ease}.lp-meta-select--bloom:hover{border-color:#cbd5e1}.lp-meta-select--bloom:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px #7c3aed26}.lp-objective-delete-btn{display:flex;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;color:#94a3b8;padding:.35rem;border-radius:6px;opacity:.7;transition:color .2s,opacity .2s,background .2s}.lp-objective-item:hover .lp-objective-delete-btn{opacity:1}.lp-objective-delete-btn:hover{color:#dc2626;background:#dc262614}.lp-add-btn--objective{margin-top:.5rem;padding:.5rem .85rem;font-size:.8125rem;border-radius:8px;border-style:dashed;border-width:1.5px}.lp-block.lp-content-priority{padding:1rem 1.25rem;background:linear-gradient(135deg,#fafbff,#f8fafc);border:1px solid #e2e8f0;border-radius:12px;margin-bottom:1rem}.lp-content-priority .lp-block-label{margin-bottom:.65rem}.lp-priority-row{display:flex;flex-wrap:wrap;gap:1.25rem;align-items:center}.lp-priority-field{display:flex;align-items:center;gap:.5rem}.lp-priority-label{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#64748b;min-width:28px}.lp-priority-field .lp-meta-select{min-width:8.5rem;padding:.5rem .85rem;font-size:.8125rem;border-radius:8px;border:1px solid #e2e8f0;transition:border-color .2s ease,box-shadow .2s ease}.lp-priority-field .lp-meta-select:hover{border-color:#cbd5e1}.lp-priority-field .lp-meta-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px #7c3aed26}.lp-recall-list{display:flex;flex-direction:column;gap:.5rem}.lp-recall-item{display:flex;align-items:flex-start;gap:.5rem;padding:.65rem .85rem;background:linear-gradient(135deg,#fafbff,#f8fafc);border:1px solid #e2e8f0;border-radius:10px;transition:border-color .2s ease,box-shadow .2s ease}.lp-recall-item:hover{border-color:#cbd5e1;box-shadow:0 2px 8px #0000000a}.lp-recall-item--dragging{opacity:.6;box-shadow:0 4px 12px #0000001a}.lp-recall-item--drop-target{border-color:var(--color-primary);background:#7c3aed0f;box-shadow:0 0 0 2px #7c3aed33}.lp-recall-drag-handle{flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:.25rem;color:#94a3b8;cursor:grab;border-radius:4px;transition:color .2s,background .2s}.lp-recall-drag-handle:hover{color:var(--color-primary);background:#7c3aed14}.lp-recall-drag-handle:active{cursor:grabbing}.lp-recall-item-body{flex:1;min-width:0}.lp-recall-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem;flex-wrap:wrap}.lp-add-btn--recall{margin-top:.5rem}.lp-recall-q-label{font-size:.6875rem;font-weight:700;color:var(--color-primary)}.lp-bloom-badge{display:inline-block;padding:.1rem .4rem;font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;border-radius:4px;color:#fff;background:#6b7280}.lp-bloom-badge--remember{background:#6366f1}.lp-bloom-badge--understand{background:#8b5cf6}.lp-bloom-badge--apply{background:#0ea5e9}.lp-bloom-badge--analyze{background:#f59e0b}.lp-bloom-badge--evaluate{background:#ef4444}.lp-bloom-badge--create{background:#22c55e}.lp-recall-prompt{margin:0;font-size:.8125rem;line-height:1.5;color:var(--color-text);font-weight:500}.lp-recall-answer{margin:.3rem 0 0;font-size:.75rem;line-height:1.5;color:var(--color-text-muted);padding-left:.5rem;border-left:2px solid var(--color-border-light)}.lp-chunk--original{cursor:pointer;border:1px solid transparent;border-radius:8px}.pdf-unavailable{display:flex;align-items:center;justify-content:center;min-height:280px;padding:2rem 1.5rem}.pdf-unavailable-card{max-width:400px;width:100%;padding:2rem 1.75rem;background:linear-gradient(145deg,var(--color-bg-card, #fff) 0%,rgba(255,255,255,.97) 100%);border-radius:16px;border:1px solid var(--color-border-light, rgba(74, 77, 201, .12));box-shadow:0 8px 32px #4a4dc914,0 2px 8px #0000000a;text-align:center;animation:pdfUnavailableFadeIn .4s ease}@keyframes pdfUnavailableFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.pdf-unavailable-icon-wrap{position:relative;display:inline-flex;margin-bottom:1.25rem}.pdf-unavailable-icon{width:64px;height:64px;color:var(--color-text-muted, #6b7280);opacity:.85}.pdf-unavailable-icon-badge{position:absolute;right:-4px;bottom:-4px;width:28px;height:28px;color:var(--color-primary, #4a4dc9);background:var(--color-bg-card, #fff);border-radius:50%;padding:4px;box-shadow:0 2px 8px #4a4dc933}.pdf-unavailable-title{margin:0 0 .75rem;font-size:1.25rem;font-weight:700;color:var(--color-text, #1a1a1a);letter-spacing:-.02em}.pdf-unavailable-desc{margin:0 0 1rem;font-size:.9375rem;line-height:1.55;color:var(--color-text-muted, #555)}.pdf-unavailable-hint{margin:0;font-size:.8125rem;color:var(--color-primary);font-weight:500;opacity:.9}.pdf-compare-viewer{width:100%;overflow:visible;padding:.5rem 0}.pdf-compare-viewer--loading,.pdf-compare-viewer--error{display:flex;align-items:center;justify-content:center;min-height:280px;color:var(--color-text-muted);font-size:.9375rem}.pdf-loading-content{display:flex;flex-direction:column;align-items:center;gap:1.25rem;padding:2rem;animation:pdfLoadingFadeIn .4s ease}@keyframes pdfLoadingFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.pdf-loading-icon{width:64px;height:80px;color:var(--color-primary);animation:pdfLoadingIconPulse 1.5s ease-in-out infinite}@keyframes pdfLoadingIconPulse{0%,to{opacity:.7;transform:scale(.98)}50%{opacity:1;transform:scale(1.02)}}.pdf-loading-icon .pdf-loading-line{animation:pdfLoadingShimmer 1.2s ease-in-out infinite}.pdf-loading-line-1{animation-delay:0s}.pdf-loading-line-2{animation-delay:.15s}.pdf-loading-line-3{animation-delay:.3s}@keyframes pdfLoadingShimmer{0%,to{opacity:.35}50%{opacity:.7}}.pdf-loading-dots{display:flex;gap:6px}.pdf-loading-dot{width:8px;height:8px;border-radius:50%;background:var(--color-primary);animation:pdfLoadingDotBounce 1.2s ease-in-out infinite both}.pdf-loading-dot:nth-child(1){animation-delay:0s}.pdf-loading-dot:nth-child(2){animation-delay:.15s}.pdf-loading-dot:nth-child(3){animation-delay:.3s}@keyframes pdfLoadingDotBounce{0%,80%,to{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}.pdf-loading-text{margin:0;font-size:.9rem;color:var(--color-text-muted);font-weight:500}.pdf-compare-viewer--error{color:var(--color-highlight)}.pdf-zoom-toolbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:4px;justify-content:center;padding:6px 10px;background:#fffffff5;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-bottom:1px solid var(--color-border, #e5e7eb);margin-bottom:8px}.pdf-zoom-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--color-border, #e5e7eb);border-radius:6px;background:var(--color-surface, #fff);color:var(--color-text, #111);font-size:1.1rem;font-weight:700;line-height:1;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease;-webkit-user-select:none;user-select:none}.pdf-zoom-btn:hover:not(:disabled){background:var(--color-primary-light, #eff6ff);border-color:var(--color-primary, #3b82f6);color:var(--color-primary, #3b82f6)}.pdf-zoom-btn:disabled{opacity:.35;cursor:not-allowed}.pdf-zoom-level{min-width:52px;height:28px;padding:0 8px;border:1px solid var(--color-border, #e5e7eb);border-radius:6px;background:var(--color-surface, #fff);color:var(--color-text, #111);font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease;-webkit-user-select:none;user-select:none}.pdf-zoom-level:hover{background:var(--color-primary-light, #eff6ff);border-color:var(--color-primary, #3b82f6);color:var(--color-primary, #3b82f6)}.pdf-compare-page{position:relative;margin-bottom:1rem;display:block}.pdf-compare-page:last-child{margin-bottom:0}.pdf-compare-page-inner{position:relative;max-width:100%;margin:0 auto;overflow:visible;display:block}.pdf-compare-canvas{display:block;width:100%;height:auto;box-shadow:0 2px 8px #0000001a}.pdf-compare-overlay{position:absolute;left:0;top:0;width:100%;height:100%;pointer-events:none}.pdf-hl{position:absolute;pointer-events:auto;cursor:pointer;transition:filter .12s ease}.pdf-hl:hover{filter:brightness(.9) saturate(1.3)}.pdf-hl--first{border-top-left-radius:4px;border-top-right-radius:4px}.pdf-hl--last{border-bottom-left-radius:4px;border-bottom-right-radius:4px}.pdf-hl-label{position:absolute;transform:translate(-100%) translate(-8px);font-size:.6rem;font-weight:700;font-family:system-ui,-apple-system,sans-serif;padding:2px 7px;border-radius:4px;border:1px solid;white-space:nowrap;pointer-events:auto;cursor:pointer;z-index:2;line-height:1.4;letter-spacing:.2px;box-shadow:0 1px 3px #0000001a;transition:box-shadow .15s ease,transform .15s ease}.pdf-hl-label:hover{box-shadow:0 2px 8px #0000002e;transform:translate(-100%) translate(-8px) scale(1.08)}.pdf-hl-label:focus-visible{outline:2px solid currentColor;outline-offset:2px}.pdf-compare-highlight{position:absolute;background:#dc262640;border-bottom:2px solid rgba(220,38,38,.85);pointer-events:none;border-radius:0 0 2px 2px;box-shadow:0 1px #dc262633}.content-validate-page{height:100vh;min-height:100vh;overflow:hidden;display:flex;flex-direction:column;background:var(--gradient-hero);animation:fadeIn .4s ease}.content-validate-header{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1.5rem;background:var(--gradient-header);border-bottom:1px solid var(--color-border-light);box-shadow:0 2px 12px #4a4dc90f;animation:slideInLeft .4s var(--transition-smooth) both}.content-validate-header-title{flex-shrink:0}.content-validate-header .header-nav-wrap{display:flex;align-items:center;gap:1rem;flex:1;min-width:0;margin:0 .5rem}.content-validate-header .header-nav-wrap .breadcrumb{flex:1;min-width:0;padding:0;margin:0;background:none;border:none;box-shadow:none}.content-validate-header .header-nav-wrap .breadcrumb-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.content-validate-header .breadcrumb-list{gap:.25rem}.content-validate-header .breadcrumb-pill{padding:.35rem .65rem;font-size:.8125rem}.content-validate-header .complete-btn,.content-validate-header .how-to-use-btn{padding:.4rem .75rem;font-size:.8125rem}.content-validate-header h1,.content-validate-header .content-validate-header-title{margin:0;font-size:1.375rem;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.content-validate-header .header-right{display:flex;align-items:center;gap:1rem}.content-validate-header .user-pill{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem .375rem .375rem;background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:999px;text-decoration:none;color:var(--color-text);font-size:.875rem;font-weight:600;transition:border-color .3s,box-shadow .3s,transform .2s}.content-validate-header .user-pill:hover{border-color:var(--color-primary);box-shadow:0 4px 16px #4a4dc926;transform:translateY(-1px)}.content-validate-header .user-pill-avatar{width:28px;height:28px;border-radius:50%;background:var(--gradient-primary);color:#fff;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .3s}.content-validate-header .user-pill:hover .user-pill-avatar{transform:scale(1.08)}.content-validate-header .user-pill-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text)}.content-validate-header .back-btn{padding:8px 16px;min-height:36px;background:transparent;color:var(--color-primary);border:2px solid var(--color-primary);border-radius:8px;font-family:"Poppins",inherit;font-size:.875rem;font-weight:600;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;transition:background .3s,color .3s,transform .2s,box-shadow .2s}.content-validate-header .back-btn:hover{background:var(--gradient-primary-soft);color:var(--color-accent-purple);border-color:var(--color-primary);transform:translateY(-1px);box-shadow:0 4px 12px #4a4dc933}.content-validate-header .logout-btn{padding:8px 16px;min-height:36px;background:transparent;color:var(--color-primary);border:2px solid var(--color-primary);border-radius:8px;font-family:"Poppins",inherit;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .3s,color .3s,transform .2s,box-shadow .2s}.content-validate-header .logout-btn:hover{background:var(--gradient-primary-soft);color:var(--color-accent-purple);border-color:var(--color-primary);transform:translateY(-1px);box-shadow:0 4px 12px #4a4dc933}.content-validate-header .statistic-btn{display:inline-flex;align-items:center;gap:.4rem;padding:8px 16px;min-height:36px;background:var(--gradient-primary);color:#fff;border:none;border-radius:8px;font-family:"Poppins",inherit;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .2s,transform .2s,box-shadow .2s}.content-validate-header .statistic-btn:hover{opacity:.95;transform:translateY(-1px);box-shadow:0 4px 16px #4a4dc959}.content-validate-header .statistic-btn--hidden{opacity:0;pointer-events:auto;cursor:default}.content-validate-header .statistic-btn--hidden:hover{opacity:0;transform:none;box-shadow:none}.content-validate-main{flex:1;min-height:0;width:100%;padding:1rem;overflow:hidden;display:flex;flex-direction:column}.breadcrumb-bar{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem;animation:fadeInUp .5s var(--transition-smooth) .1s both;transition:box-shadow .3s}.breadcrumb-bar .breadcrumb{flex:1;min-width:0;padding:0;margin:0;background:none;border:none;border-radius:0;box-shadow:none;animation:none}.breadcrumb-bar .breadcrumb:hover{box-shadow:none}.breadcrumb-actions{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.complete-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;color:#fff;background:#10b981;border:1px solid #10b981;border-radius:10px;cursor:pointer;font-family:inherit;transition:background .2s,border-color .2s,transform .15s,box-shadow .2s}.complete-btn:hover:not(:disabled){background:#059669;border-color:#059669;box-shadow:0 4px 12px #10b9814d;transform:translateY(-1px)}.complete-btn:active:not(:disabled){transform:scale(.98)}.complete-btn:disabled{opacity:.6;cursor:not-allowed}.how-to-use-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;color:var(--color-primary);background:var(--gradient-primary-soft);border:1px solid rgba(74,77,201,.3);border-radius:10px;cursor:pointer;font-family:inherit;flex-shrink:0;transition:background .2s,border-color .2s,transform .15s}.how-to-use-btn:hover{background:#4a4dc92e;border-color:var(--color-primary);transform:translateY(-1px)}.validate-questions-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;color:#fff;background:var(--gradient-primary, linear-gradient(135deg, #4a4dc9, #6c6fe0));border:none;border-radius:10px;cursor:pointer;font-family:inherit;flex-shrink:0;transition:opacity .2s,transform .15s}.validate-questions-btn:hover{opacity:.88;transform:translateY(-1px)}.content-validate-header .validate-questions-btn{padding:.4rem .75rem;font-size:.8125rem}.breadcrumb{flex-shrink:0;padding:1rem 1.25rem;margin-bottom:1.5rem;background:var(--gradient-card);border-radius:14px;border:1px solid var(--color-border-light);box-shadow:0 4px 16px #4a4dc90f;animation:fadeInUp .5s var(--transition-smooth) .1s both;transition:box-shadow .3s}.breadcrumb:hover{box-shadow:0 6px 20px #4a4dc91a}.content-validate-sections{flex:1;min-height:0;overflow:hidden}.breadcrumb-list{margin:0;padding:0;list-style:none;display:flex;flex-wrap:wrap;align-items:center;gap:.5rem 0;row-gap:.5rem}.breadcrumb-item{display:inline-flex;align-items:center;gap:.375rem}.breadcrumb-sep{color:var(--color-text-muted);font-size:.75rem;font-weight:500;-webkit-user-select:none;user-select:none;margin:0 .125rem;opacity:.8}.breadcrumb-pill{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem .8rem;border-radius:8px;font-size:.8125rem;background:var(--color-bg);border:1px solid var(--color-border-light);color:var(--color-text);max-width:240px}.breadcrumb-pill-value{font-weight:600;color:var(--color-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.breadcrumb-pill-label{color:var(--color-text-muted);font-size:.75rem;font-weight:500;flex-shrink:0;text-transform:capitalize}.breadcrumb-pill--link{background:var(--gradient-primary-soft);border-color:#4a4dc940;color:var(--color-primary);font-weight:600;cursor:pointer;font-family:inherit;transition:background .2s,border-color .2s,transform .15s}.breadcrumb-pill--link:hover{background:#4a4dc92e;border-color:var(--color-primary);transform:translateY(-1px)}.breadcrumb-pill--current{background:linear-gradient(135deg,#4a4dc91f,#764ba214);border-color:#4a4dc966;box-shadow:0 2px 8px #4a4dc91f;border-left-width:3px;border-left-color:var(--color-primary);padding-left:calc(.8rem - 2px)}.breadcrumb-pill--current .breadcrumb-pill-value{color:var(--color-accent-purple);font-weight:700}.content-validate-sections{flex:1;min-height:0;overflow:hidden;display:grid;grid-template-columns:repeat(3,1fr);gap:0;animation:fadeInUp .5s var(--transition-smooth) .2s both}.content-validate-sections--resizable{grid-template-columns:33.33% 8px 33.33% 8px 33.33%;transition:grid-template-columns .4s cubic-bezier(.4,0,.2,1)}.content-validate-sections--resizable.is-resizing{transition:none!important}.cv-resizer--hidden{opacity:0;pointer-events:none;width:0!important;min-width:0!important}.cv-resizer{width:8px;min-width:8px;background:var(--color-border-light);border:1px solid white;cursor:col-resize;transition:background .2s;flex-shrink:0;position:relative;-webkit-user-select:none;user-select:none}.cv-resizer:after{content:"";position:absolute;inset:0 -4px}.cv-resizer:hover,.cv-resizer--active{background:var(--color-primary)}@media(max-width:1024px){.content-validate-sections--resizable{grid-template-columns:1fr!important}.content-validate-sections{display:block!important;min-height:80vh!important;gap:1rem!important;overflow:auto!important}.cv-section{margin-bottom:1rem!important;height:90%!important}.cv-section--hidden{display:none!important}.cv-resizer{display:none}}.cv-section{background:var(--gradient-card);border-radius:16px;border:1px solid var(--color-border-light);box-shadow:0 4px 20px #4a4dc914;overflow:hidden;transition:box-shadow .3s,transform .2s;display:flex;flex-direction:column;min-height:0;align-items:stretch}.cv-section:hover{box-shadow:0 8px 28px #4a4dc91f}.cv-section-title{margin:0;padding:.25rem 1.5rem;font-size:1.125rem;font-weight:700;color:var(--color-text);letter-spacing:-.02em;background:var(--gradient-primary-soft);border-bottom:1px solid var(--color-border-light)}.cv-section--pdf .cv-section-title{border-left:4px solid var(--color-primary)}.cv-section--learning-plan .cv-section-title{border-left:4px solid var(--color-accent-purple);display:flex;align-items:center;justify-content:space-between;position:relative;padding-right:11rem}.cv-lp-heading-text{flex:1;min-width:0}.cv-lp-header-actions{position:absolute;right:1rem;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:.5rem;z-index:10}.cv-section--visible{opacity:1;visibility:visible;transform:translate(0);transition:opacity .4s ease,transform .4s cubic-bezier(.34,1.56,.64,1)}.cv-section--hidden{opacity:0;visibility:hidden;transform:translate(20px);pointer-events:none;transition:opacity .3s ease,transform .3s ease}.cv-section--teacher .cv-section-title{border-left:4px solid var(--color-highlight)}.feedback-toggle-btn{width:32px;height:32px;border-radius:50%;background:var(--color-bg-card);border:1px solid var(--color-border-light);color:var(--color-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.25rem;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 2px 8px #0000000d}.image-verify-toggle-btn{position:relative;height:32px;min-width:32px;padding:0 .65rem 0 .5rem;border-radius:999px;background:var(--color-bg-card);border:1px solid var(--color-border-light);color:var(--color-primary);display:inline-flex;align-items:center;justify-content:center;gap:.4rem;cursor:pointer;font-size:.8125rem;font-weight:600;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 2px 8px #0000000d;white-space:nowrap}.image-verify-toggle-label{line-height:1;letter-spacing:-.01em}.image-verify-toggle-btn:hover,.feedback-toggle-btn:hover{background:var(--color-primary);color:#fff;box-shadow:0 4px 12px #4a4dc940;transform:scale(1.03)}.feedback-toggle-btn.active,.image-verify-toggle-btn.active{background:var(--color-accent-purple);color:#fff;border-color:transparent}.image-verify-badge{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:#e53e3e;color:#fff;font-size:11px;font-weight:700;line-height:18px;text-align:center;pointer-events:none;box-shadow:0 1px 4px #0000002e;animation:image-badge-pop .3s ease}@keyframes image-badge-pop{0%{transform:scale(0)}60%{transform:scale(1.2)}to{transform:scale(1)}}.cv-section-body{flex:1;min-height:0;padding:1.5rem;color:var(--color-text-muted);font-size:.9375rem;line-height:1.6;overflow-y:auto}.cv-learning-plan-wrap{overflow:hidden;display:flex;flex-direction:column;padding:0}.cv-section-body::-webkit-scrollbar{width:10px}.cv-section-body::-webkit-scrollbar-track{background:var(--color-border-light);border-radius:3px}.cv-section-body::-webkit-scrollbar-thumb{background:var(--color-primary);border-radius:3px}.cv-section-body p{margin:0 0 .75rem}.cv-section-body p:last-child{margin-bottom:0}.cv-placeholder-hint{font-size:.875rem;color:var(--color-border)}.cv-pdf-viewer-wrap{padding:0;flex:1;min-height:0;display:flex;flex-direction:column;overflow-x:auto}.cv-pdf-iframe{width:100%;flex:1;min-height:0;border:none;border-radius:0 0 16px 16px;background:var(--color-bg)}.cv-learning-plan-wrap{padding:1rem;flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column}.cv-pdf-placeholder,.cv-learning-placeholder,.cv-teacher-placeholder{display:flex;flex-direction:column;justify-content:center;min-height:200px}.cv-label-only{font-weight:600;color:var(--color-text)}.cv-teacher-placeholder .cv-label-only{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stats-modal-backdrop{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1.5rem;animation:stats-modal-fade-in .2s ease-out}@keyframes stats-modal-fade-in{0%{opacity:0}to{opacity:1}}.stats-modal{background:var(--color-bg-card);border-radius:16px;box-shadow:0 24px 48px #0003;max-width:420px;width:100%;overflow:hidden;animation:stats-modal-scale-in .25s ease-out}@keyframes stats-modal-scale-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.stats-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;background:var(--gradient-primary);color:#fff}.stats-modal-title{margin:0;font-size:1.125rem;font-weight:700;letter-spacing:-.02em}.stats-modal-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#fff3;color:#fff;border:none;border-radius:50%;cursor:pointer;transition:background .2s}.stats-modal-close:hover{background:#ffffff59}.stats-modal-body{padding:1.25rem 1.5rem;overflow-y:auto;max-height:70vh}.stats-row{display:flex;align-items:center;justify-content:space-between;padding:.65rem 0;border-bottom:1px solid var(--color-border-light);font-size:.9375rem}.stats-row:last-child{border-bottom:none}.stats-row--highlight{margin-top:.5rem;background:var(--gradient-primary-soft);border-radius:8px;padding:.75rem}.stats-label{color:var(--color-text-muted);font-weight:500}.stats-value{font-weight:700;color:var(--color-primary)}.stats-row--highlight .stats-value{color:var(--color-accent-purple)}.how-to-use-modal{max-width:560px;max-height:85vh;display:flex;flex-direction:column}.how-to-use-modal .stats-modal-body{overflow-y:auto}.how-to-use-body{padding:1.25rem 1.5rem 1.5rem}.how-to-use-section{margin-bottom:1.25rem}.how-to-use-section:last-child{margin-bottom:0}.how-to-use-h3{margin:0 0 .5rem;font-size:.9375rem;font-weight:700;color:var(--color-primary)}.how-to-use-section p{margin:0 0 .5rem;font-size:.875rem;line-height:1.55;color:var(--color-text)}.how-to-use-section p:last-child{margin-bottom:0}.how-to-use-list{margin:.5rem 0 0 1.25rem;padding:0;font-size:.875rem;line-height:1.6;color:var(--color-text)}.how-to-use-list li{margin-bottom:.35rem}.how-to-use-list li:last-child{margin-bottom:0}.inactivity-overlay{position:fixed;inset:0;background:#000c;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:99999;pointer-events:auto;transition:opacity .3s ease}.stats-row--clickable{cursor:pointer;transition:background-color .2s}.stats-row--clickable:hover{background-color:var(--gradient-primary-soft);border-radius:8px}.inactivity-details-modal{max-width:800px;max-height:85vh;display:flex;flex-direction:column}.inactivity-table-container{overflow-x:auto;overflow-y:auto;max-height:60vh;margin:-1.25rem -1.5rem;padding:1.25rem 1.5rem}.inactivity-table{width:100%;border-collapse:collapse;font-size:.875rem}.inactivity-table thead{position:sticky;top:0;background:var(--color-bg-card);z-index:10}.inactivity-table th{padding:.75rem 1rem;text-align:left;font-weight:700;color:var(--color-primary);border-bottom:2px solid var(--color-border-light);background:var(--gradient-primary-soft)}.inactivity-table td{padding:.75rem 1rem;border-bottom:1px solid var(--color-border-light);color:var(--color-text)}.inactivity-table tbody tr:hover{background-color:var(--gradient-primary-soft)}.inactivity-table tbody tr:last-child td{border-bottom:none}.inactivity-table td:first-child{font-weight:600;color:var(--color-primary);text-align:center;width:50px}.inactivity-table td:nth-child(2),.inactivity-table td:nth-child(3){font-family:Courier New,monospace;font-size:.8125rem}.inactivity-table td:last-child{font-weight:600;color:var(--color-accent-purple)}.cv-img-verify-panel{margin-bottom:1.25rem;padding:1rem 1.25rem;border-radius:12px;border:1px solid var(--color-border-light, #e2e8f0);background:#fff;box-shadow:0 2px 8px #0000000a}.cv-img-verify-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.cv-img-verify-title{display:flex;align-items:center;gap:.5rem}.cv-img-verify-title h3{margin:0;font-size:1rem;font-weight:700;color:var(--color-text, #1e293b)}.cv-img-verify-title-icon{width:36px;height:36px;border-radius:8px;background:var(--gradient-primary-soft, #f1f5f9);color:var(--color-accent-purple, #6366f1);display:flex;align-items:center;justify-content:center}.cv-img-verify-close{border:none;background:transparent;color:var(--color-text-muted, #64748b);cursor:pointer;padding:.25rem;border-radius:8px;display:flex;align-items:center;justify-content:center}.cv-img-verify-close:hover{background:var(--gradient-primary-soft, #f1f5f9);color:var(--color-primary)}.cv-img-verify-muted{margin:0;font-size:.875rem;color:var(--color-text-muted, #64748b);line-height:1.5}.cv-img-verify-error{margin:0 0 .75rem;font-size:.8125rem;color:#b91c1c}.cv-img-verify-hint{margin:0 0 .75rem;font-size:.8125rem;color:var(--color-text-muted, #64748b)}.cv-img-verify-card{margin-top:.25rem}.cv-img-verify-images{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1rem}@media(max-width:520px){.cv-img-verify-images{grid-template-columns:1fr}}.cv-img-verify-fig{margin:0}.cv-img-verify-fig figcaption{font-size:.75rem;font-weight:600;color:var(--color-primary);margin-bottom:.35rem}.cv-img-verify-thumb-wrap{position:relative;width:100%;padding:0;border:1px solid var(--color-border-light, #e2e8f0);border-radius:10px;overflow:hidden;background:#f8fafc;cursor:pointer;display:block;min-height:120px}.cv-img-verify-thumb-wrap:disabled{cursor:default;opacity:.7}.cv-img-verify-thumb{width:100%;height:auto;max-height:180px;object-fit:contain;display:block;vertical-align:middle}.cv-img-verify-placeholder{display:flex;align-items:center;justify-content:center;min-height:120px;font-size:.8125rem;color:var(--color-text-muted)}.cv-img-verify-expand{position:absolute;bottom:6px;right:6px;width:28px;height:28px;border-radius:6px;background:#0000008c;color:#fff;display:flex;align-items:center;justify-content:center;pointer-events:none}.cv-img-verify-actions{display:flex;flex-wrap:wrap;gap:.5rem}.cv-img-verify-btn{padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:600;border:none;cursor:pointer;transition:background .2s,transform .15s}.cv-img-verify-btn:disabled{opacity:.6;cursor:not-allowed}.cv-img-verify-btn--approve{background:#16a34a;color:#fff}.cv-img-verify-btn--approve:hover:not(:disabled){background:#15803d}.cv-img-verify-btn--reject{background:#dc2626;color:#fff}.cv-img-verify-btn--reject:hover:not(:disabled){background:#b91c1c}.cv-img-verify-btn--ghost{background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border-light)}.cv-img-verify-btn--ghost:hover:not(:disabled){background:var(--gradient-primary-soft, #f1f5f9)}.cv-img-verify-reject{margin-top:.5rem}.cv-img-verify-label{display:block;font-size:.8125rem;font-weight:600;color:var(--color-text, #334155);margin-bottom:.35rem}.cv-img-verify-textarea{width:100%;box-sizing:border-box;border:1px solid var(--color-border-light, #e2e8f0);border-radius:8px;padding:.5rem .65rem;font-size:.875rem;font-family:inherit;resize:vertical;min-height:88px;margin-bottom:.75rem}.cv-img-verify-textarea:focus{outline:2px solid var(--color-accent-purple, #818cf8);outline-offset:1px}.cv-img-verify-queue{margin:.75rem 0 0;font-size:.75rem;color:var(--color-text-muted)}.cv-img-verify-lightbox{position:fixed;inset:0;z-index:100000;box-sizing:border-box;background:#0f172aeb;display:flex;flex-direction:column;align-items:stretch;justify-content:center;padding:max(1rem,env(safe-area-inset-top,0px)) max(1rem,env(safe-area-inset-right,0px)) max(1rem,env(safe-area-inset-bottom,0px)) max(1rem,env(safe-area-inset-left,0px));cursor:pointer}.cv-img-verify-lightbox-close{position:fixed;top:max(1rem,env(safe-area-inset-top,0px));right:max(1rem,env(safe-area-inset-right,0px));z-index:100001;width:48px;height:48px;border-radius:50%;border:none;background:#fff3;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.cv-img-verify-lightbox-close:hover{background:#ffffff52}.cv-img-verify-lightbox-frame{flex:1 1 auto;min-height:0;min-width:0;width:100%;display:flex;align-items:center;justify-content:center;cursor:default}.cv-img-verify-lightbox-img{display:block;max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;border-radius:6px;box-shadow:0 12px 48px #00000073}.profile-page{min-height:100vh;background:var(--gradient-hero);animation:fadeIn .4s ease}.profile-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem 1.25rem;background:var(--gradient-header);border-bottom:1px solid var(--color-border-light);box-shadow:0 2px 12px #4a4dc90f;animation:slideInLeft .4s var(--transition-smooth) both}.profile-header h1{margin:0;font-size:1.5rem;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.header-actions{display:flex;align-items:center;gap:.75rem}.profile-header .back-btn{padding:8px 16px;min-height:36px;background:transparent;color:var(--color-primary);border:2px solid var(--color-primary);border-radius:8px;font-family:"Poppins",inherit;font-size:.875rem;font-weight:600;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;transition:background .3s,color .3s,transform .2s,box-shadow .2s}.profile-header .back-btn:hover{background:var(--gradient-primary-soft);color:var(--color-accent-purple);border-color:var(--color-primary);transform:translateY(-1px);box-shadow:0 4px 12px #4a4dc933}.profile-header .logout-btn{padding:8px 16px;min-height:36px;background:transparent;color:var(--color-primary);border:2px solid var(--color-primary);border-radius:8px;font-family:"Poppins",inherit;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .3s,color .3s,transform .2s,box-shadow .2s}.profile-header .logout-btn:hover{background:var(--gradient-primary-soft);color:var(--color-accent-purple);border-color:var(--color-primary);transform:translateY(-1px);box-shadow:0 4px 12px #4a4dc933}.profile-main{max-width:520px;margin:0 auto;padding:3rem 2rem}.profile-card{background:var(--gradient-card);border-radius:20px;border:1px solid var(--color-border-light);padding:2.5rem;text-align:center;box-shadow:0 4px 24px #4a4dc914,0 12px 48px #0000000f;animation:scaleIn .5s var(--transition-smooth) both;transition:box-shadow .3s,transform .2s}.profile-card:hover{box-shadow:var(--shadow-glow-primary);transform:translateY(-4px)}.profile-avatar{width:88px;height:88px;margin:0 auto 1.25rem;border-radius:50%;background:var(--gradient-primary);color:#fff;font-size:1.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;letter-spacing:-.02em;animation:fadeInUp .5s var(--transition-smooth) .15s both;box-shadow:0 8px 24px #4a4dc959;transition:transform .3s,box-shadow .3s}.profile-card:hover .profile-avatar{transform:scale(1.05);box-shadow:0 12px 32px #4a4dc966}.profile-name{margin:0 0 .25rem;font-size:1.5rem;font-weight:700;color:var(--color-text);letter-spacing:-.02em;animation:fadeInUp .5s var(--transition-smooth) .2s both}.profile-role{margin:0 0 1.75rem;font-size:.9375rem;font-weight:500;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:fadeInUp .5s var(--transition-smooth) .25s both}.profile-details{margin:0 0 1.75rem;text-align:left;padding:1.25rem 1.5rem;background:var(--gradient-primary-soft);border-radius:12px;border:1px solid rgba(74,77,201,.12);animation:fadeInUp .5s var(--transition-smooth) .3s both}.profile-detail-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--color-border-light);gap:1rem}.profile-detail-row:last-child{border-bottom:none}.profile-detail-row dt{margin:0;font-size:.875rem;font-weight:600;color:var(--color-text-muted)}.profile-detail-row dd{margin:0;font-size:.9375rem;font-weight:500;color:var(--color-text)}.profile-logout-btn{padding:12px 24px;min-height:44px;background:transparent;color:var(--color-primary);border:2px solid var(--color-primary);border-radius:10px;font-family:"Poppins",inherit;font-size:.9375rem;font-weight:600;cursor:pointer;transition:background .3s,color .3s,transform .2s,box-shadow .2s;animation:fadeInUp .5s var(--transition-smooth) .35s both}.profile-logout-btn:hover{background:var(--gradient-primary-soft);color:var(--color-accent-purple);transform:translateY(-2px);box-shadow:0 6px 20px #4a4dc933}.admin-shell{display:flex;height:100vh;background:var(--color-bg, #F5F5F5);font-family:Poppins,system-ui,sans-serif;overflow:hidden;color:var(--color-text, #4E4E4E)}.admin-sidebar{width:236px;min-width:236px;background:#fff;border-right:1px solid var(--color-border-light, #EBEBEB);display:flex;flex-direction:column;box-shadow:2px 0 12px #4a4dc90d;z-index:20}.sidebar-brand{padding:20px 20px 16px;border-bottom:1px solid var(--color-border-light, #EBEBEB)}.sidebar-brand-title{font-size:1.1rem;font-weight:700;background:var(--gradient-primary, linear-gradient(135deg, #4A4DC9 0%, #533086 100%));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.01em}.sidebar-brand-sub{font-size:.7rem;font-weight:600;color:#fff;background:var(--gradient-primary, linear-gradient(135deg, #4A4DC9 0%, #533086 100%));padding:2px 8px;border-radius:4px;display:inline-block;margin-top:4px;text-transform:uppercase;letter-spacing:.05em}.sidebar-nav{flex:1;padding:12px 0;overflow-y:auto}.sidebar-section-label{font-size:.65rem;font-weight:700;color:var(--color-text-muted, #6B6B6B);text-transform:uppercase;letter-spacing:.08em;padding:10px 20px 4px;margin-top:6px}.sidebar-link{display:flex;align-items:center;gap:10px;padding:9px 20px;color:var(--color-text-muted, #6B6B6B);cursor:pointer;font-size:.8125rem;font-weight:500;border:none;background:none;width:100%;text-align:left;transition:background .18s,color .18s;text-decoration:none;border-left:3px solid transparent;border-right:none;position:relative}.sidebar-link:hover{background:var(--gradient-primary-soft, rgba(74,77,201,.06));color:var(--color-primary, #4A4DC9);border-left-color:#4a4dc94d}.sidebar-link.active{background:linear-gradient(90deg,#4a4dc91a,#5330860d);color:var(--color-primary, #4A4DC9);border-left-color:var(--color-primary, #4A4DC9);font-weight:600}.sidebar-link svg{width:15px;height:15px;flex-shrink:0;opacity:.7}.sidebar-link.active svg,.sidebar-link:hover svg{opacity:1}.sidebar-help-btn{display:flex;align-items:center;gap:8px;width:calc(100% - 32px);margin:0 16px 8px;padding:9px 14px;background:#eef2ff;color:#4a4dc9;border:1.5px solid #c7d2fe;border-radius:8px;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s,box-shadow .15s}.sidebar-help-btn:hover{background:#e0e7ff;box-shadow:0 2px 8px #4a4dc926}.sidebar-footer{padding:12px 16px 14px;border-top:1px solid var(--color-border-light, #EBEBEB);display:flex;align-items:center;gap:10px;background:var(--color-bg, #F5F5F5);border-radius:0}.sidebar-user-avatar{width:34px;height:34px;border-radius:50%;background:var(--gradient-primary, linear-gradient(135deg, #4A4DC9 0%, #533086 100%));display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0;box-shadow:0 2px 8px #4a4dc94d}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:.8125rem;font-weight:600;color:var(--color-text, #4E4E4E);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:.6875rem;color:var(--color-primary, #4A4DC9);font-weight:500}.sidebar-logout-btn{background:none;border:none;cursor:pointer;color:var(--color-text-muted, #6B6B6B);display:flex;align-items:center;padding:5px;border-radius:6px;transition:color .15s,background .15s}.sidebar-logout-btn:hover{color:#ef4444;background:#fef2f2}.admin-main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--color-bg, #F5F5F5)}.admin-topbar{height:56px;min-height:56px;background:var(--gradient-header, #fff);border-bottom:1px solid var(--color-border-light, #EBEBEB);display:flex;align-items:center;padding:0 28px;gap:12px;box-shadow:0 1px 8px #4a4dc90f}.admin-topbar-breadcrumb{font-size:.8125rem;color:var(--color-text-muted, #6B6B6B);display:flex;align-items:center;gap:6px;font-weight:500}.admin-topbar-breadcrumb span{color:var(--color-text, #4E4E4E)}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:14px}.topbar-date{font-size:.75rem;color:var(--color-text-muted, #6B6B6B);font-weight:500;background:var(--gradient-primary-soft, rgba(74,77,201,.07));padding:4px 10px;border-radius:6px;border:1px solid rgba(74,77,201,.12)}.admin-content{flex:1;overflow-y:auto;padding:28px}.dash-header{margin-bottom:24px;animation:fadeInUp .4s var(--transition-smooth, .3s ease) both}.dash-title{font-size:1.5rem;font-weight:700;color:var(--color-text, #4E4E4E);margin:0 0 4px;letter-spacing:-.02em}.dash-title span{background:var(--gradient-primary, linear-gradient(135deg,#4A4DC9,#533086));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dash-subtitle{font-size:.875rem;color:var(--color-text-muted, #6B6B6B);margin:0;font-weight:400}.dash-charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-bottom:24px;animation:fadeInUp .45s var(--transition-smooth, ease) .05s both}@media(max-width:900px){.dash-charts-grid{grid-template-columns:1fr}}.dash-chart-card{background:#fff;border:1px solid var(--color-border-light, #EBEBEB);border-radius:14px;overflow:hidden;box-shadow:0 2px 10px #4a4dc90a;transition:transform .2s,box-shadow .2s}.dash-chart-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4a4dc914}.dash-chart-card-header{padding:12px 16px;border-bottom:1px solid var(--color-border-light, #EBEBEB);background:linear-gradient(90deg,#fafaff,#fffbf7);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px}.dash-chart-title{font-size:.9375rem;font-weight:700;color:var(--color-text, #4E4E4E);margin:0;letter-spacing:-.01em}.dash-chart-controls{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.chart-select{background:var(--color-bg, #F5F5F5);border:1.5px solid var(--color-border, #CACACA);border-radius:8px;color:var(--color-text, #4E4E4E);font-family:Poppins,sans-serif;font-size:.75rem;padding:6px 10px;outline:none;cursor:pointer;transition:border-color .2s}.chart-select:focus{border-color:var(--color-primary, #4A4DC9)}.dash-chart-body{padding:12px 16px 16px;min-height:340px;display:flex;align-items:center;justify-content:center}.dash-chart-tooltip{background:#fff;border:1px solid var(--color-border-light, #EBEBEB);border-radius:10px;box-shadow:0 8px 24px #0000001f;padding:12px 14px;font-family:Poppins,sans-serif;font-size:.8125rem;min-width:180px}.dash-chart-tooltip-title{font-weight:700;color:var(--color-text, #4E4E4E);margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--color-border-light, #EBEBEB);word-break:break-word}.dash-chart-tooltip-row{display:flex;justify-content:space-between;gap:16px;color:var(--color-text-muted, #6B6B6B);font-weight:500}.dash-chart-tooltip-row span:last-child{color:var(--color-primary, #4A4DC9);font-weight:700}.chart-empty{margin:0;font-size:.8125rem;color:var(--color-text-muted, #6B6B6B);font-style:italic}.dash-chart-hint{margin:0 0 8px;font-size:.75rem;color:var(--color-text-muted, #6B6B6B)}.dash-session-details{padding:12px 16px 16px;border-top:1px solid var(--color-border-light, #EBEBEB);background:#fafaff}.dash-session-details-title{font-size:.875rem;font-weight:600;color:var(--color-text, #4E4E4E);margin:0 0 10px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.dash-session-details-clear{font-size:.75rem;font-weight:500;color:var(--color-primary, #4A4DC9);background:none;border:none;cursor:pointer;padding:2px 6px;border-radius:4px}.dash-session-details-clear:hover{background:#4a4dc91a;text-decoration:underline}.dash-session-details-table-wrap{overflow-x:auto;max-height:220px;overflow-y:auto}.dash-session-details-table{width:100%;border-collapse:collapse;font-size:.8125rem}.dash-session-details-table th,.dash-session-details-table td{padding:6px 10px;text-align:left;border-bottom:1px solid var(--color-border-light, #EBEBEB)}.dash-session-details-table th{font-weight:600;color:var(--color-text-muted, #6B6B6B);background:#4a4dc90f;position:sticky;top:0}.dash-session-details-table tbody tr:hover{background:#4a4dc90a}.educator-summary-section{margin-bottom:22px}.educator-summary-section .dash-section-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px}.educator-summary-select-wrap{display:flex;align-items:center;gap:10px}.educator-summary-label{font-size:.8125rem;font-weight:600;color:var(--color-text-muted, #6B6B6B);white-space:nowrap}.educator-summary-select{min-width:220px;padding:8px 12px;border:1.5px solid var(--color-border, #CACACA);border-radius:8px;background:#fff;color:var(--color-text, #4E4E4E);font-family:Poppins,sans-serif;font-size:.875rem;font-weight:500;outline:none;cursor:pointer;transition:border-color .2s}.educator-summary-select:focus{border-color:var(--color-primary, #4A4DC9)}.educator-summary-body{padding:16px 22px 20px}.educator-summary-placeholder{margin:0;font-size:.875rem;color:var(--color-text-muted, #6B6B6B);font-style:italic;padding:20px 0;text-align:center}.educator-summary-card{background:linear-gradient(135deg,#4a4dc90a,#53308608);border:1px solid var(--color-border-light, #EBEBEB);border-radius:12px;padding:18px 22px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:20px}.educator-summary-name{display:flex;align-items:center;gap:12px;font-size:1rem;font-weight:700;color:var(--color-text, #4E4E4E)}.educator-summary-name .edu-avatar{width:40px;height:40px;font-size:13px}.educator-summary-stats{display:flex;flex-wrap:wrap;gap:24px 32px}.educator-summary-stat{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.educator-summary-stat-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted, #6B6B6B)}.educator-summary-stat-value{font-size:1.25rem;font-weight:700;color:var(--color-text, #4E4E4E)}.educator-summary-stat-value.green{color:#10b981}.educator-summary-stat-value.blue{color:#4a4dc9}.educator-summary-stat-value.red{color:#ef4444}.educator-summary-stat-value.gray{color:#64748b}.sessions-by-date-subtitle{font-size:.8125rem;font-weight:600;color:var(--color-primary, #4A4DC9);margin-right:auto;padding-left:8px}.sessions-by-date-desc{padding-top:0;padding-bottom:4px}.sessions-by-date-caption{margin:0;font-size:.75rem;color:var(--color-text-muted, #6B6B6B);line-height:1.4}.kpi-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-bottom:24px;animation:fadeInUp .45s var(--transition-smooth, ease) .05s both}@media(max-width:1400px){.kpi-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:900px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}.kpi-card{background:#fff;border:1px solid var(--color-border-light, #EBEBEB);border-radius:14px;padding:18px 20px;display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden;box-shadow:0 2px 10px #4a4dc90d;transition:transform .2s,box-shadow .2s}.kpi-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4a4dc91a}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;border-radius:14px 14px 0 0}.kpi-card.blue:before{background:linear-gradient(90deg,#4a4dc9,#6366f1)}.kpi-card.green:before{background:linear-gradient(90deg,#10b981,#34d399)}.kpi-card.purple:before{background:linear-gradient(90deg,#533086,#8b5cf6)}.kpi-card.orange:before{background:var(--gradient-accent, linear-gradient(90deg,#FF7212,#FC9145))}.kpi-card.teal:before{background:linear-gradient(90deg,#006d77,#00a896)}.kpi-card.red:before{background:linear-gradient(90deg,#ef4444,#f87171)}.kpi-icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;margin-bottom:2px}.kpi-icon.blue{background:#4a4dc91a;color:#4a4dc9}.kpi-icon.green{background:#10b9811a;color:#10b981}.kpi-icon.purple{background:#5330861a;color:#533086}.kpi-icon.orange{background:#ff72121a;color:#ff7212}.kpi-icon.teal{background:#006d771a;color:#006d77}.kpi-icon.red{background:#ef44441a;color:#ef4444}.kpi-label{font-size:.675rem;color:var(--color-text-muted, #6B6B6B);font-weight:700;text-transform:uppercase;letter-spacing:.07em}.kpi-value{font-size:1.75rem;font-weight:700;color:var(--color-text, #4E4E4E);letter-spacing:-.02em;line-height:1}.kpi-change{font-size:.7rem;color:#10b981;display:flex;align-items:center;gap:3px;font-weight:600}.kpi-change.down{color:#ef4444}.dash-section{background:#fff;border:1px solid var(--color-border-light, #EBEBEB);border-radius:14px;margin-bottom:22px;overflow:hidden;box-shadow:0 2px 10px #4a4dc90a;animation:fadeInUp .5s var(--transition-smooth, ease) .1s both}.dash-section-header{padding:16px 22px;border-bottom:1px solid var(--color-border-light, #EBEBEB);display:flex;align-items:center;justify-content:space-between;gap:12px;background:linear-gradient(90deg,#fafaff,#fffbf7)}.dash-section-title{font-size:.9375rem;font-weight:700;color:var(--color-text, #4E4E4E);margin:0;letter-spacing:-.01em}.dash-section-body{padding:20px 22px}.table-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.table-search{position:relative;flex:1;min-width:200px;max-width:280px}.table-search input{width:100%;background:var(--color-bg, #F5F5F5);border:1.5px solid var(--color-border, #CACACA);border-radius:8px;color:var(--color-text, #4E4E4E);font-family:"Poppins",inherit;font-size:.8125rem;padding:7px 12px 7px 32px;outline:none;transition:border-color .2s,box-shadow .2s}.table-search input::placeholder{color:var(--color-border, #CACACA)}.table-search input:focus{border-color:var(--color-primary, #4A4DC9);box-shadow:0 0 0 3px #4a4dc91f}.table-search svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:14px;height:14px;color:#cacaca;pointer-events:none}.table-filter-select{background:var(--color-bg, #F5F5F5);border:1.5px solid var(--color-border, #CACACA);border-radius:8px;color:var(--color-text, #4E4E4E);font-family:"Poppins",inherit;font-size:.8125rem;padding:7px 10px;outline:none;cursor:pointer;transition:border-color .2s}.table-filter-select:focus{border-color:var(--color-primary, #4A4DC9)}.table-filter-select--active{background:var(--color-primary, #4A4DC9)!important;color:#fff!important;border-color:var(--color-primary, #4A4DC9)!important;font-weight:600;box-shadow:0 2px 8px #4a4dc940}.table-badge{background:linear-gradient(135deg,#4a4dc91a,#53308612);color:var(--color-primary, #4A4DC9);font-size:.75rem;font-weight:700;padding:3px 10px;border-radius:20px;margin-left:auto;border:1px solid rgba(74,77,201,.15)}.data-table-wrap{overflow-x:auto;margin-top:12px;border-radius:10px;border:1px solid var(--color-border-light, #EBEBEB)}.data-table{width:100%;border-collapse:collapse;font-size:.8125rem}.data-table th{padding:10px 14px;text-align:left;font-size:.675rem;font-weight:700;color:var(--color-text-muted, #6B6B6B);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--color-border-light, #EBEBEB);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none;background:var(--color-bg, #F5F5F5)}.data-table th:hover{color:var(--color-primary, #4A4DC9)}.data-table th .th-inner{display:flex;align-items:center;gap:4px}.sort-icon{display:inline-flex;flex-direction:column;gap:1px;opacity:.35}.sort-icon.active{opacity:1;color:var(--color-primary, #4A4DC9)}.sort-icon svg{width:8px;height:8px}.data-table td{padding:12px 14px;border-bottom:1px solid var(--color-border-light, #EBEBEB);color:var(--color-text-muted, #6B6B6B);white-space:nowrap;background:#fff}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--gradient-primary-soft, rgba(74,77,201,.03))}.edu-name-cell{display:flex;align-items:center;gap:10px}.edu-avatar{width:32px;height:32px;border-radius:50%;background:var(--gradient-primary, linear-gradient(135deg,#4A4DC9,#533086));display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0;box-shadow:0 2px 6px #4a4dc940}.edu-name{font-weight:600;color:var(--color-text, #4E4E4E);font-size:.8125rem}.edu-school{font-size:.7rem;color:var(--color-text-muted, #6B6B6B);font-weight:400;margin-top:1px}.progress-bar-cell{display:flex;align-items:center;gap:8px;min-width:100px}.mini-progress{flex:1;height:5px;background:var(--color-border-light, #EBEBEB);border-radius:3px;overflow:hidden}.mini-progress-fill{height:100%;border-radius:3px;background:var(--gradient-primary, linear-gradient(90deg,#4A4DC9,#6366f1))}.mini-progress-fill.green{background:linear-gradient(90deg,#10b981,#34d399)}.mini-progress-fill.orange{background:var(--gradient-accent, linear-gradient(90deg,#FF7212,#FC9145))}.score-badge{display:inline-flex;align-items:center;justify-content:center;width:36px;height:22px;border-radius:5px;font-size:.75rem;font-weight:700}.score-badge.high{background:#10b9811a;color:#059669}.score-badge.mid{background:#ff72121a;color:#ff7212}.score-badge.low{background:#ef44441a;color:#ef4444}.status-dot{display:inline-flex;align-items:center;gap:5px;font-size:.75rem;color:var(--color-text-muted, #6B6B6B);font-weight:500}.status-dot:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--color-border, #CACACA)}.status-dot.active:before{background:#10b981}.status-dot.recent:before{background:#ff7212}.action-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;background:linear-gradient(135deg,#4a4dc914,#5330860d);color:var(--color-primary, #4A4DC9);border:1.5px solid rgba(74,77,201,.2);border-radius:7px;font-size:.75rem;font-weight:600;cursor:pointer;transition:background .18s,box-shadow .18s,transform .15s;text-decoration:none;font-family:"Poppins",inherit}.action-btn:hover{background:var(--gradient-primary, linear-gradient(135deg,#4A4DC9,#533086));color:#fff;border-color:transparent;box-shadow:var(--shadow-glow-primary, 0 4px 16px rgba(74,77,201,.25));transform:translateY(-1px)}.action-btns-wrap{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.chapter-hover-cell{position:relative;display:inline-block;cursor:default}.chapter-count-pill{display:inline-flex;align-items:center;justify-content:center;min-width:28px;padding:4px 8px;border-radius:999px;background:#4a4dc91f;color:var(--color-primary, #4A4DC9);font-size:.8125rem;font-weight:600}.chapter-hover-cell:hover .chapter-count-pill{background:#4a4dc933}.chapter-hover-modal-portal{animation:chapterHoverFadeIn .15s ease}@keyframes chapterHoverFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.chapter-hover-modal{width:100%;height:100%;min-height:160px;display:flex;flex-direction:column;padding:14px 0;background:#fff;border:1px solid var(--color-border-light, #EBEBEB);border-radius:12px;box-shadow:0 16px 48px #0000002e;overflow:hidden;pointer-events:auto}.chapter-hover-title{padding:0 18px 10px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted, #6B6B6B);border-bottom:1px solid var(--color-border-light, #EBEBEB);margin-bottom:10px;flex-shrink:0}.chapter-hover-list{list-style:none;margin:0;padding:0 12px 8px;flex:1;min-height:80px;max-height:340px;overflow-y:auto;font-size:.875rem;color:var(--color-text, #4E4E4E)}.chapter-hover-list li{padding:6px 8px;border-radius:6px;margin-bottom:2px}.chapter-hover-list li:hover{background:#4a4dc90f}.chapter-hover-empty{color:var(--color-text-muted, #6B6B6B);font-style:italic}.analytics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:24px;animation:fadeInUp .55s var(--transition-smooth, ease) .15s both}@media(max-width:1280px){.analytics-grid{grid-template-columns:1fr 1fr}}@media(max-width:900px){.analytics-grid{grid-template-columns:1fr}}.analytics-card{background:#fff;border:1px solid var(--color-border-light, #EBEBEB);border-radius:14px;overflow:hidden;box-shadow:0 2px 10px #4a4dc90a;transition:transform .2s,box-shadow .2s}.analytics-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4a4dc914}.analytics-card-header{padding:14px 18px 12px;border-bottom:1px solid var(--color-border-light, #EBEBEB);display:flex;align-items:center;gap:10px;background:linear-gradient(90deg,#fafaff,#fffbf7)}.analytics-card-icon{width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.analytics-card-icon.blue{background:#4a4dc91a;color:#4a4dc9}.analytics-card-icon.purple{background:#5330861a;color:#533086}.analytics-card-icon.teal{background:#006d771a;color:#006d77}.analytics-card-title{font-size:.875rem;font-weight:700;color:var(--color-text, #4E4E4E);letter-spacing:-.01em}.analytics-card-body{padding:16px 18px}.metric-list{display:flex;flex-direction:column;gap:11px}.metric-row{display:flex;align-items:center;gap:10px}.metric-label{font-size:.75rem;color:var(--color-text-muted, #6B6B6B);flex:1;min-width:0;font-weight:500}.metric-bar-wrap{flex:2;height:6px;background:var(--color-border-light, #EBEBEB);border-radius:3px;overflow:hidden}.metric-bar-fill{height:100%;border-radius:3px;background:var(--gradient-primary, linear-gradient(90deg,#4A4DC9,#6366f1));animation:progressFill .8s ease both}.metric-bar-fill.purple{background:linear-gradient(90deg,#533086,#8b5cf6)}.metric-bar-fill.teal{background:linear-gradient(90deg,#006d77,#00a896)}.metric-bar-fill.green{background:linear-gradient(90deg,#10b981,#34d399)}.metric-bar-fill.orange{background:var(--gradient-accent, linear-gradient(90deg,#FF7212,#FC9145))}.metric-bar-fill.red{background:linear-gradient(90deg,#ef4444,#f87171)}.metric-value{font-size:.75rem;font-weight:700;color:var(--color-text, #4E4E4E);min-width:44px;text-align:right}.trend-chart{display:flex;align-items:flex-end;gap:3px;height:44px;margin-top:8px}.trend-bar{flex:1;border-radius:3px 3px 0 0;background:#4a4dc933;transition:background .15s;min-width:8px;cursor:pointer}.trend-bar:hover{background:#4a4dc973}.trend-bar.highlight{background:var(--gradient-primary, linear-gradient(180deg,#4A4DC9,#533086))}.trend-labels{display:flex;justify-content:space-between;margin-top:5px;font-size:.65rem;color:var(--color-text-muted, #6B6B6B);font-weight:500}.session-analytics-block{margin-bottom:14px}.session-analytics-block:last-child{margin-bottom:0}.session-analytics-label{font-size:.7rem;color:var(--color-text-muted, #6B6B6B);font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.session-completion-dual{margin:14px 0}.session-completion-dual .dual-stat-item{padding:14px 12px}.session-completion-dual .dual-stat-value{font-size:1.5rem}.completion-box .dual-stat-value{color:#10b981}.dropoff-box .dual-stat-value{color:#ff7212}.dual-stat{display:flex;gap:12px}.dual-stat-item{flex:1;background:var(--color-bg, #F5F5F5);border:1px solid var(--color-border-light, #EBEBEB);border-radius:10px;padding:12px;text-align:center}.dual-stat-value{font-size:1.375rem;font-weight:700;color:var(--color-text, #4E4E4E);line-height:1;margin-bottom:3px}.dual-stat-value.green{color:#10b981}.dual-stat-value.orange{color:#ff7212}.dual-stat-label{font-size:.7rem;color:var(--color-text-muted, #6B6B6B);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.hourly-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:3px;margin-top:4px}.hourly-cell{height:26px;border-radius:4px;background:#ebebeb;cursor:default;transition:opacity .15s}.hourly-cell:hover{opacity:.75}.hourly-labels{display:grid;grid-template-columns:repeat(12,1fr);gap:3px;margin-top:3px;font-size:.6rem;color:var(--color-text-muted, #6B6B6B);text-align:center;font-weight:500}.stats-pill{display:inline-flex;align-items:center;justify-content:center;min-width:38px;padding:2px 8px;border-radius:5px;font-size:.75rem;font-weight:700;font-family:Poppins,sans-serif}.stats-pill.blue{background:#4a4dc917;color:#4a4dc9}.stats-pill.indigo{background:#6366f117;color:#4f46e5}.stats-pill.purple{background:#53308617;color:#533086}.stats-pill.teal{background:#006d7717;color:#006d77}.stats-pill.orange{background:#ff721217;color:#ff7212}.stats-pill.red{background:#ef444417;color:#ef4444}.stats-pill.gray{background:#64748b17;color:#64748b}.stats-pill.green{background:#10b98117;color:#059669}.table-pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 0 0;font-size:.75rem;color:var(--color-text-muted, #6B6B6B);font-weight:500}.pagination-btns{display:flex;gap:6px}.page-btn{width:28px;height:28px;border-radius:7px;border:1.5px solid var(--color-border-light, #EBEBEB);background:#fff;color:var(--color-text-muted, #6B6B6B);font-size:.75rem;font-family:"Poppins",inherit;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.page-btn:hover:not(:disabled){border-color:var(--color-primary, #4A4DC9);color:var(--color-primary, #4A4DC9)}.page-btn.active{background:var(--gradient-primary, linear-gradient(135deg,#4A4DC9,#533086));color:#fff;border-color:transparent;box-shadow:0 2px 8px #4a4dc94d}.page-btn:disabled{opacity:.35;cursor:not-allowed}.add-educator-btn{background:var(--gradient-primary, linear-gradient(135deg, #4A4DC9, #533086));color:#fff;border:none;border-radius:8px;font-family:Poppins,sans-serif;font-size:.8125rem;font-weight:600;padding:8px 16px;cursor:pointer;white-space:nowrap;box-shadow:0 2px 8px #4a4dc940;transition:transform .2s,box-shadow .2s}.add-educator-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #4a4dc959}.add-educator-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.add-educator-modal{background:#fff;border-radius:14px;box-shadow:0 20px 60px #0003;max-width:520px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .25s ease}.add-educator-modal-wide{max-width:560px}.edit-educator-modal-tall{max-height:90vh;overflow-y:auto}.edit-educator-current-section{margin:0 22px 16px;padding:14px 16px;background:#4a4dc90f;border:1px solid rgba(74,77,201,.15);border-radius:10px}.edit-educator-current-title{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-primary, #4A4DC9);margin-bottom:10px}.edit-educator-current-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px 20px}.edit-educator-current-item{display:flex;flex-direction:column;gap:2px}.edit-educator-current-item.edit-educator-current-subjects{grid-column:1 / -1}.edit-educator-current-label{font-size:.6875rem;font-weight:600;color:var(--color-text-muted, #6B6B6B);text-transform:uppercase;letter-spacing:.04em}.edit-educator-current-value{font-size:.875rem;font-weight:500;color:var(--color-text, #4E4E4E)}.edit-educator-form-section{border-top:1px solid var(--color-border-light, #EBEBEB);padding-top:16px}.add-educator-error{margin:12px 22px 0;padding:10px 12px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;font-size:.8125rem;color:#b91c1c}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.add-educator-title{margin:0;padding:20px 22px 12px;font-size:1.125rem;font-weight:700;color:var(--color-text, #4E4E4E);border-bottom:1px solid var(--color-border-light, #EBEBEB)}.add-educator-form{padding:16px 22px;display:flex;flex-direction:column;gap:14px}.add-educator-row-label{display:block;font-size:.75rem;font-weight:600;color:var(--color-text-muted, #6B6B6B);margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}.add-educator-row label.add-educator-row-label{cursor:default}.add-educator-row input[type=text],.add-educator-row input[type=email],.add-educator-row input[type=tel],.add-educator-row input[type=password],.add-educator-row select,.add-educator-select{width:100%;padding:9px 12px;border:1.5px solid var(--color-border, #CACACA);border-radius:8px;font-family:Poppins,sans-serif;font-size:.875rem;color:var(--color-text, #4E4E4E);outline:none;transition:border-color .2s}.add-educator-row input[type=text]:focus,.add-educator-row input[type=email]:focus,.add-educator-row input[type=tel]:focus,.add-educator-row input[type=password]:focus,.add-educator-row select:focus,.add-educator-select:focus{border-color:var(--color-primary, #4A4DC9)}.add-educator-subject-row{display:flex;gap:10px;align-items:center}.add-educator-subject-row .add-educator-select{flex:1;min-width:0}.add-educator-remove-row{flex-shrink:0;width:36px;height:36px;padding:0;border:1.5px solid var(--color-border, #CACACA);border-radius:8px;background:#fff;color:var(--color-text-muted, #6B6B6B);font-size:1.25rem;line-height:1;cursor:pointer}.add-educator-remove-row:hover:not(:disabled){border-color:var(--color-primary, #4A4DC9);color:var(--color-primary, #4A4DC9)}.add-educator-remove-row:disabled{opacity:.5;cursor:not-allowed}.add-educator-add-subject{align-self:flex-start;padding:8px 14px;border:1.5px dashed var(--color-border, #CACACA);border-radius:8px;background:#fafafa;font-size:.8125rem;font-weight:500;color:var(--color-text-muted, #6B6B6B);cursor:pointer}.add-educator-add-subject:hover{border-color:var(--color-primary, #4A4DC9);color:var(--color-primary, #4A4DC9)}.add-educator-classes{display:grid;grid-template-columns:repeat(4,1fr);gap:10px 12px}.add-educator-loading,.add-educator-hint{grid-column:1 / -1;font-size:.8125rem;color:var(--color-text-muted, #6B6B6B);font-style:italic}.add-educator-subjects{margin-top:4px}.add-educator-subjects .add-educator-checkbox-label span{white-space:nowrap}.add-educator-checkbox-label{display:flex;align-items:center;gap:8px;font-size:.8125rem;font-weight:500;color:var(--color-text, #4E4E4E);text-transform:none;letter-spacing:0;cursor:pointer;margin:0}.add-educator-checkbox-label input[type=checkbox]{width:auto;margin:0;accent-color:var(--color-primary, #4A4DC9);flex-shrink:0}.add-educator-radio-group{display:flex;flex-wrap:wrap;gap:16px 24px;align-items:center}.add-educator-radio-label{display:inline-flex;align-items:center;gap:8px;font-size:.875rem;font-weight:500;color:var(--color-text, #4E4E4E);cursor:pointer;margin:0;text-transform:none;letter-spacing:0}.add-educator-radio-label input[type=radio]{width:18px;height:18px;margin:0;accent-color:var(--color-primary, #4A4DC9);flex-shrink:0;cursor:pointer}.add-educator-actions{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px 20px;border-top:1px solid var(--color-border-light, #EBEBEB)}.add-educator-cancel,.add-educator-save{padding:9px 20px;border-radius:8px;font-family:Poppins,sans-serif;font-size:.875rem;font-weight:600;cursor:pointer;transition:border-color .2s,background .2s}.add-educator-cancel{background:#fff;border:1.5px solid var(--color-border, #CACACA);color:var(--color-text-muted, #6B6B6B)}.add-educator-cancel:hover{border-color:var(--color-primary, #4A4DC9);color:var(--color-primary, #4A4DC9)}.add-educator-save{background:var(--gradient-primary, linear-gradient(135deg, #4A4DC9, #533086));color:#fff;border:none;box-shadow:0 2px 8px #4a4dc940}.add-educator-save:hover:not(:disabled){box-shadow:0 4px 12px #4a4dc959}.add-educator-save:disabled{opacity:.7;cursor:not-allowed}.edit-assign-meta{padding:12px 22px 0;display:grid;gap:4px;font-size:.875rem;color:var(--color-text, #4E4E4E)}.edit-assign-meta strong{font-weight:700}.edit-assign-empty{font-size:.875rem;color:var(--color-text-muted, #6B6B6B);font-style:italic}.edit-assign-chips{display:flex;flex-wrap:wrap;gap:8px}.edit-assign-chip{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;border:1px solid rgba(74,77,201,.22);background:#4a4dc90f;color:var(--color-primary, #4A4DC9);font-family:Poppins,sans-serif;font-size:.8125rem;font-weight:600;cursor:pointer}.edit-assign-chip span{font-size:1rem;line-height:1;opacity:.8}.edit-assign-chip:hover{background:#4a4dc91a;border-color:#4a4dc959}.edit-assign-list{display:grid;grid-template-columns:repeat(2,1fr);gap:10px 14px;padding:6px 0 2px}@media(max-width:720px){.edit-assign-list{grid-template-columns:1fr}}.add-educator-actions.edit-assign-actions{justify-content:space-between;align-items:center}.edit-assign-actions-right{display:inline-flex;gap:10px}.edit-assign-danger{padding:9px 14px;border-radius:8px;font-family:Poppins,sans-serif;font-size:.875rem;font-weight:700;cursor:pointer;border:1.5px solid #fecaca;background:#fff;color:#b91c1c;transition:background .2s,border-color .2s}.edit-assign-danger:hover:not(:disabled){background:#fef2f2;border-color:#fca5a5}.edit-assign-danger:disabled{opacity:.6;cursor:not-allowed}.chapter-hover-cell{position:relative;display:inline-block}.chapter-hover-modal{display:none;position:absolute;z-index:100;top:calc(100% + 8px);left:50%;transform:translate(-50%);background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 8px 24px #0000001f;padding:10px 12px;min-width:200px;white-space:nowrap}.chapter-hover-cell:hover .chapter-hover-modal{display:block}.chapter-hover-title{font-size:.75rem;font-weight:700;color:#4a4dc9;margin-bottom:6px;padding-bottom:4px;border-bottom:1px solid #e2e8f0}.chapter-hover-list{list-style:none;margin:0;padding:0}.chapter-hover-list li{font-size:.75rem;color:#4e4e4e;padding:2px 0}.analytics-section-header{flex-wrap:wrap;gap:8px}.analytics-all-badge{display:inline-block;background:linear-gradient(135deg,#4a4dc91f,#53308614);color:var(--color-primary, #4A4DC9);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:4px 10px;border-radius:6px;border:1px solid rgba(74,77,201,.2)}.analytics-loading{color:var(--color-text-muted, #6B6B6B);font-size:.875rem;padding:1rem 0;font-family:Poppins,sans-serif}.an-page-header{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:12px}.an-filter-bar{display:flex;align-items:center;gap:10px;flex-shrink:0;padding:6px 10px 0 15px}.an-mode-toggle{display:inline-flex;align-items:center;background:linear-gradient(135deg,#4a4dc914,#0f9d9d0f);border-radius:999px;padding:2px;gap:2px;border:1px solid rgba(74,77,201,.18)}.an-mode-pill{border:none;background:transparent;padding:4px 10px;font-size:.7rem;font-weight:600;font-family:Poppins,sans-serif;color:var(--color-text-muted, #6B6B6B);border-radius:999px;cursor:pointer;transition:background .15s,color .15s}.an-mode-pill.is-active{background:#fff;color:#4a4dc9;box-shadow:0 1px 4px #0f172a29}.an-filter-bar .table-filter-select{min-width:150px;border-radius:999px;border-color:#e2e8ff;font-size:.7rem;padding-inline:12px;background-color:#fff;color:#4e4e4e}.an-filter-bar .table-filter-select:focus{outline:none;border-color:#4a4dc9;box-shadow:0 0 0 1px #4a4dc940}.an-reload-btn{border:1px solid rgba(148,163,184,.45);background:#fff;border-radius:999px;padding:4px 12px;font-size:.7rem;font-weight:600;font-family:Poppins,sans-serif;color:#4a4dc9;cursor:pointer;display:inline-flex;align-items:center;gap:4px;transition:background .15s,box-shadow .15s,transform .05s}.an-reload-btn:hover{background:#4a4dc90f;box-shadow:0 1px 3px #0f172a29}.an-reload-btn:active{transform:translateY(1px);box-shadow:0 0 #0000}.an-date-filters .an-date-field input[type=date]{background-color:#fff;border-radius:999px;border-color:#e2e8ff;padding-inline:10px}.an-date-filters .an-date-field input[type=date]:focus{outline:none;border-color:#4a4dc9;box-shadow:0 0 0 1px #4a4dc933}.an-date-filters{display:flex;align-items:center;gap:8px}.an-date-field{display:flex;justify-content:center;align-items:center;gap:15px;font-size:.68rem;color:var(--color-text-muted, #6B6B6B)}.an-date-field input[type=date]{padding:4px 8px;border-radius:6px;border:1px solid var(--color-border-light, #EBEBEB);font-size:.72rem}.an-loading-text{font-size:.75rem;color:var(--color-text-muted, #6B6B6B);font-style:italic}.an-session-details-btn{padding:6px 10px;border-radius:6px;border:1px solid #4A4DC9;background:#4a4dc9;color:#fff;font-size:.72rem;font-weight:600;cursor:pointer;font-family:Poppins,sans-serif}.an-session-details-btn:hover{background:#3b3fc0}.an-kpi-row{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:20px}.an-kpi-card{background:#fff;border:1px solid var(--color-border-light, #EBEBEB);border-radius:14px;padding:18px 16px 16px;display:flex;flex-direction:column;align-items:flex-start;gap:0;position:relative;overflow:hidden;transition:box-shadow .18s}.an-kpi-card:hover{box-shadow:0 4px 16px #4a4dc917}.an-kpi-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px}.an-kpi-blue:after{background:#4a4dc9}.an-kpi-green:after{background:#10b981}.an-kpi-indigo:after{background:#6366f1}.an-kpi-teal:after{background:#0f9d9d}.an-kpi-purple:after{background:#7c3aed}.an-kpi-icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;margin-bottom:10px}.an-kpi-blue .an-kpi-icon{background:#4a4dc91a;color:#4a4dc9}.an-kpi-green .an-kpi-icon{background:#10b9811a;color:#10b981}.an-kpi-indigo .an-kpi-icon{background:#6366f11a;color:#6366f1}.an-kpi-teal .an-kpi-icon{background:#0f9d9d1a;color:#0f9d9d}.an-kpi-purple .an-kpi-icon{background:#7c3aed1a;color:#7c3aed}.an-kpi-val{font-size:1.85rem;font-weight:800;line-height:1;color:#1e1e2d;font-family:Poppins,sans-serif;margin-bottom:4px}.an-kpi-lbl{font-size:.71rem;color:var(--color-text-muted, #6B6B6B);font-weight:500;line-height:1.3}.an-charts-row{display:grid;grid-template-columns:240px 1fr 240px;gap:14px;margin-bottom:20px;align-items:start}.an-chart-card{background:#fff;border:1px solid var(--color-border-light, #EBEBEB);border-radius:14px;padding:14px 16px 16px;display:flex;flex-direction:column;overflow:hidden;min-width:0}.an-chart-header{margin-bottom:10px}.an-chart-title{display:block;font-size:.85rem;font-weight:700;color:#1e1e2d;font-family:Poppins,sans-serif}.an-chart-sub{display:block;font-size:.7rem;color:var(--color-text-muted, #6B6B6B);margin-top:2px}.an-donut-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:18px}.an-donut-chart-area{display:flex;justify-content:center}.an-donut{width:110px;height:110px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative}.an-donut-hole{width:78px;height:78px;background:#fff;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;position:relative;z-index:1}.an-donut-val{font-size:1.1rem;font-weight:800;color:#1e1e2d;font-family:Poppins,sans-serif;line-height:1}.an-donut-sub{font-size:.62rem;color:var(--color-text-muted, #6B6B6B);font-weight:500}.an-donut-legend{width:100%;display:flex;flex-direction:column;gap:10px}.an-legend-item{display:flex;align-items:center;gap:10px}.an-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.an-legend-text{flex:1;display:flex;flex-direction:column;gap:1px}.an-legend-name{font-size:.72rem;font-weight:600;color:#4e4e4e}.an-legend-val{font-size:.68rem;color:var(--color-text-muted, #6B6B6B)}.an-legend-pct{font-size:.82rem;font-weight:800;font-family:Poppins,sans-serif}.an-hbar-chart{display:flex;flex-direction:column;gap:11px;padding:4px 0 2px}.an-hbar-row{display:flex;align-items:center;gap:10px}.an-hbar-lbl{width:76px;font-size:.71rem;font-weight:600;color:#4e4e4e;flex-shrink:0;white-space:nowrap}.an-hbar-track{flex:1;height:8px;background:#f0f1f8;border-radius:99px;overflow:hidden}.an-hbar-fill{height:100%;border-radius:99px;transition:width .5s cubic-bezier(.4,0,.2,1);min-width:3px}.an-hbar-val{width:26px;text-align:right;font-size:.78rem;font-weight:800;font-family:Poppins,sans-serif;flex-shrink:0}.an-gauges-row{display:flex;gap:8px;margin:8px 0 4px}.an-gauge{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;gap:4px}.an-gauge-label{font-size:.62rem;color:var(--color-text-muted, #6B6B6B);font-weight:600;text-transform:uppercase;letter-spacing:.04em;text-align:center;margin:0;word-break:break-word;width:100%}.an-gauge-detail{margin-top:auto;padding-top:14px;border-top:1px solid var(--color-border-light, #EBEBEB);display:flex;flex-direction:column;gap:7px}.an-gauge-detail-row{display:flex;align-items:center;gap:8px;font-size:.7rem;color:var(--color-text-muted, #6B6B6B)}.an-gauge-detail-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}@media(max-width:1200px){.an-kpi-row{grid-template-columns:repeat(3,1fr)}.an-charts-row{grid-template-columns:1fr 1fr}.an-chart-card:last-child{grid-column:1 / -1}}@media(max-width:800px){.an-kpi-row{grid-template-columns:repeat(2,1fr)}.an-charts-row{grid-template-columns:1fr}}.ac-body{padding:14px!important}.ac-kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--color-border-light, #EBEBEB);border-radius:10px;overflow:hidden}.ac-kpi-tile{background:#fff;padding:18px 12px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:5px;transition:background .15s}.ac-kpi-tile:hover{background:#f9f9fb}.ac-kpi-val{font-size:1.55rem;font-weight:800;font-family:Poppins,sans-serif;line-height:1}.ac-kpi-lbl{font-size:.67rem;color:var(--color-text-muted, #6B6B6B);font-weight:500;line-height:1.3}.ac-blue .ac-kpi-val{color:#4a4dc9}.ac-indigo .ac-kpi-val{color:#6366f1}.ac-green .ac-kpi-val{color:#10b981}.ac-orange .ac-kpi-val{color:#ff7212}.ac-purple .ac-kpi-val{color:#7c3aed}.ac-teal .ac-kpi-val{color:#0f9d9d}.ac-satisfaction{margin-top:14px;padding-top:12px;border-top:1px solid var(--color-border-light, #EBEBEB)}.ac-satisfaction-label{display:flex;justify-content:space-between;align-items:center;font-size:.67rem;color:var(--color-text-muted, #6B6B6B);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:7px}.ac-satisfaction-pct{font-size:.78rem;font-weight:800;color:#10b981;font-family:Poppins,sans-serif}.ac-satisfaction-bar{height:7px;background:#f0f0f0;border-radius:99px;overflow:hidden}.ac-satisfaction-fill{height:100%;background:linear-gradient(90deg,#10b981,#34d399);border-radius:99px;transition:width .4s ease}.ss-layout{display:flex;flex-direction:column;gap:20px}.an-chapter-time-card{background:#fff;border:1px solid rgba(226,232,255,.9);border-radius:14px;padding:16px 18px 14px;box-shadow:0 8px 22px #0f172a0a;position:relative;overflow:hidden}.an-chapter-time-header{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:10px}.an-chapter-time-title{font-size:.85rem;font-weight:700;color:#1e1e2d}.an-chapter-time-sub,.an-chapter-time-meta{font-size:.7rem;color:var(--color-text-muted, #6B6B6B)}.an-chapter-time-card:before{content:"";position:absolute;inset-inline-end:-40px;inset-block-start:-40px;width:120px;height:120px;background:radial-gradient(circle at center,rgba(74,77,201,.16),transparent 60%);opacity:.8;pointer-events:none}.an-chapter-table-wrapper{overflow-x:auto}.an-chapter-table{width:100%;border-collapse:collapse;font-size:.72rem}.an-chapter-table th,.an-chapter-table td{padding:8px 10px;border-bottom:1px solid #F2F2F5;text-align:left;white-space:nowrap}.an-chapter-table th{font-weight:600;color:#4e4e4e;background:#f9f9fb}.an-chapter-row{cursor:pointer;transition:background .12s}.an-chapter-row:hover{background:#fafbff}.an-chapter-row--expanded{background:#f3f4ff}.an-chapter-row-toggle{display:inline-flex;align-items:center;gap:4px}.an-chapter-row-chevron{font-size:.75rem}.an-chapter-details-row td{background:#fbfbff;padding-top:4px;padding-bottom:10px}.an-topic-table-wrapper{overflow-x:auto}.an-topic-table{width:100%;border-collapse:collapse;font-size:.7rem}.an-topic-table th,.an-topic-table td{padding:6px 8px;border-bottom:1px solid #E5E7F5;text-align:left;white-space:nowrap}.an-topic-table th{font-weight:600;color:#4e4e4e;background:#eef0ff}.an-session-details-card{background:#fff;border:1px solid var(--color-border-light, #EBEBEB);border-radius:12px;padding:14px 16px 12px}.an-session-details-header{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:10px}.an-session-details-title{font-size:.85rem;font-weight:700;color:#1e1e2d}.an-session-details-sub{font-size:.7rem;color:var(--color-text-muted, #6B6B6B)}.an-session-details-meta{font-size:.7rem;color:var(--color-text-muted, #6B6B6B);display:flex;align-items:center;gap:6px}.an-session-table-wrapper{overflow-x:auto}.an-session-table{width:100%;border-collapse:collapse;font-size:.72rem}.an-session-table th,.an-session-table td{padding:8px 10px;border-bottom:1px solid #F2F2F5;text-align:left;white-space:nowrap}.an-session-table th{font-weight:600;color:#4e4e4e;background:#f9f9fb}.an-card-toggle-btn{border:none;background:#f1f4ffe6;border-radius:999px;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;font-size:.8rem;cursor:pointer;color:#4a4dc9;transition:background .15s,transform .05s}.an-card-toggle-btn:hover{background:#4a4dc924}.an-card-toggle-btn:active{transform:translateY(1px)}.an-session-empty{text-align:center;color:var(--color-text-muted, #6B6B6B)}.ss-hero-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.ss-hero-card{background:#fff;border:1px solid var(--color-border-light, #EBEBEB);border-radius:12px;padding:18px 16px 16px;display:flex;flex-direction:column;align-items:flex-start;gap:0;position:relative;overflow:hidden}.ss-hero-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px}.ss-hero-blue:after{background:#4a4dc9}.ss-hero-indigo:after{background:#6366f1}.ss-hero-teal:after{background:#0f9d9d}.ss-hero-purple:after{background:#7c3aed}.ss-hero-icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;margin-bottom:10px}.ss-hero-blue .ss-hero-icon{background:#4a4dc91a;color:#4a4dc9}.ss-hero-indigo .ss-hero-icon{background:#6366f11a;color:#6366f1}.ss-hero-teal .ss-hero-icon{background:#0f9d9d1a;color:#0f9d9d}.ss-hero-purple .ss-hero-icon{background:#7c3aed1a;color:#7c3aed}.ss-hero-val{font-size:1.9rem;font-weight:800;line-height:1;color:#1e1e2d;font-family:Poppins,sans-serif;margin-bottom:4px}.ss-hero-lbl{font-size:.72rem;color:var(--color-text-muted, #6B6B6B);font-weight:500;line-height:1.3}.ss-groups-row{display:grid;grid-template-columns:1fr 2fr 1fr;gap:14px;align-items:start}.ss-group{background:#fff;border:1px solid var(--color-border-light, #EBEBEB);border-radius:12px;overflow:hidden}.ss-group-title{padding:10px 14px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-muted, #6B6B6B);background:#f9f9fb;border-bottom:1px solid var(--color-border-light, #EBEBEB);display:flex;align-items:center;gap:6px}.ss-group-title--alert{color:#c2410c;background:#fff8f5;border-bottom-color:#fed7aa}.ss-stat-list{padding:4px 0}.ss-stat-list--2col{display:grid;grid-template-columns:1fr 1fr;padding:0}.ss-stat-list--2col .ss-stat-row{border-bottom:1px solid var(--color-border-light, #F0F0F0);border-right:none}.ss-stat-list--2col .ss-stat-row:nth-child(odd){border-right:1px solid var(--color-border-light, #F0F0F0)}.ss-stat-row{display:flex;align-items:center;gap:9px;padding:10px 16px;border-bottom:1px solid #F5F5F8;transition:background .12s}.ss-stat-row:last-child{border-bottom:none}.ss-stat-row:hover{background:#fafbff}.ss-stat-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.ss-stat-lbl{flex:1;font-size:.72rem;font-weight:500;color:#4e4e4e;line-height:1.3}.ss-stat-val{font-size:.85rem;font-weight:800;font-family:Poppins,sans-serif;min-width:28px;text-align:right;flex-shrink:0}.ss-tile:hover{background:#f9f9fb}.ss-tile-val{font-size:1.3rem;font-weight:800;color:var(--color-primary, #4A4DC9);font-family:Poppins,sans-serif;line-height:1}.ss-tile-lbl{font-size:.66rem;color:var(--color-text-muted, #6B6B6B);font-weight:500;line-height:1.35}.ss-tile--alert .ss-tile-val{color:#ea580c}.ss-time-row{display:grid;grid-template-columns:1fr auto;gap:14px;align-items:stretch}.ss-time-panel-card{background:#fff;border:1px solid var(--color-border-light, #EBEBEB);border-radius:12px;padding:16px 20px}.ss-time-panel-header{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-muted, #6B6B6B);margin-bottom:14px}.ss-time-panels{display:flex;align-items:center;gap:16px}.ss-time-panel-item{display:flex;flex-direction:column;align-items:center;gap:3px;min-width:72px}.ss-time-panel-val{font-size:1.15rem;font-weight:800;font-family:Poppins,sans-serif;line-height:1;color:#1e1e2d}.ss-pdf .ss-time-panel-val{color:#4a4dc9}.ss-lp .ss-time-panel-val{color:#0f9d9d}.ss-time-panel-lbl{font-size:.68rem;color:var(--color-text-muted, #6B6B6B);font-weight:500}.ss-time-split-bar{flex:1;height:10px;border-radius:99px;overflow:hidden;background:#f0f0f0;display:flex;min-width:0}.ss-time-split-pdf{background:#4a4dc9;height:100%;transition:width .4s ease}.ss-time-split-lp{background:#0f9d9d;height:100%;transition:width .4s ease}.ss-total-time-card{background:linear-gradient(135deg,#4a4dc912,#5330860d);border:1px solid rgba(74,77,201,.15);border-radius:12px;padding:16px 24px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-width:160px;text-align:center}.ss-total-time-lbl{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-muted, #6B6B6B)}.ss-total-time-val{font-size:1.6rem;font-weight:800;font-family:Poppins,sans-serif;color:var(--color-primary, #4A4DC9);line-height:1}.ca-page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px}.ca-page-title{font-size:1.5rem;font-weight:700;color:#1e1e2d;margin:0 0 4px;letter-spacing:-.02em;font-family:Poppins,sans-serif}.ca-page-sub{font-size:.875rem;color:#6b6b6b;margin:0;font-family:Poppins,sans-serif}.ca-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}.ca-stat-card{background:#fff;border:1px solid #EBEBEB;border-radius:14px;padding:16px 18px 18px;display:flex;align-items:center;gap:14px;position:relative;overflow:hidden;transition:box-shadow .18s,transform .18s;box-shadow:0 2px 8px #4a4dc90a}.ca-stat-card:hover{box-shadow:0 6px 20px #4a4dc91a;transform:translateY(-1px)}.ca-stat-icon{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ca-stat-body{display:flex;flex-direction:column;gap:2px;flex:1}.ca-stat-val{font-size:1.9rem;font-weight:800;line-height:1;font-family:Poppins,sans-serif}.ca-stat-lbl{font-size:.71rem;color:#6b6b6b;font-weight:500}.ca-stat-stripe{position:absolute;bottom:0;left:0;right:0;height:3px}.assign-layout{display:grid;grid-template-columns:370px 1fr;gap:22px;align-items:start}@media(max-width:1100px){.assign-layout{grid-template-columns:1fr}.ca-stats-row{grid-template-columns:repeat(2,1fr)}}@media(max-width:680px){.ca-stats-row{grid-template-columns:1fr 1fr}.ca-form-row{grid-template-columns:1fr}}.assign-form-card{background:#fff;border:1px solid #EBEBEB;border-radius:14px;overflow:hidden;position:sticky;top:16px;box-shadow:0 2px 14px #4a4dc912}.assign-form-header{padding:14px 18px;border-bottom:1px solid #EBEBEB;display:flex;align-items:center;gap:10px;background:linear-gradient(90deg,#fafaff,#fffbf7)}.assign-form-header-icon{width:30px;height:30px;border-radius:7px;background:linear-gradient(135deg,#4a4dc91a,#53308612);color:var(--color-primary, #4A4DC9);display:flex;align-items:center;justify-content:center;flex-shrink:0}.assign-form-title{font-size:.875rem;font-weight:700;color:#1e1e2d}.ca-header-badge{background:#4a4dc91a;color:#4a4dc9;font-size:.68rem;font-weight:700;padding:3px 10px;border-radius:20px;white-space:nowrap;border:1px solid rgba(74,77,201,.15)}.assign-form-body{padding:16px 18px 20px;display:flex;flex-direction:column;gap:11px;max-height:calc(100vh - 250px);overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(74,77,201,.15) transparent}.assign-form-body::-webkit-scrollbar{width:4px}.assign-form-body::-webkit-scrollbar-track{background:transparent}.assign-form-body::-webkit-scrollbar-thumb{background:#4a4dc92e;border-radius:99px}.ca-section-label{display:flex;align-items:center;gap:6px;font-size:.66rem;font-weight:700;color:#6b6b6b;text-transform:uppercase;letter-spacing:.08em}.ca-section-divider{height:1px;background:linear-gradient(90deg,#EBEBEB,transparent);margin:2px 0}.ca-sel-count{display:inline-flex;align-items:center;background:#4a4dc91a;color:#4a4dc9;font-size:.63rem;font-weight:700;padding:2px 8px;border-radius:20px;margin-left:4px;text-transform:none;letter-spacing:0}.ca-form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.form-field{display:flex;flex-direction:column;gap:4px}.form-label{font-size:.65rem;font-weight:700;color:#6b6b6b;text-transform:uppercase;letter-spacing:.07em}.form-select,.form-input{background:#f7f7fb;border:1.5px solid #DDDDE8;border-radius:8px;color:#1e1e2d;font-family:"Poppins",inherit;font-size:.8rem;padding:8px 10px;outline:none;transition:border-color .2s,box-shadow .2s,background .2s;width:100%}.form-select:focus,.form-input:focus{border-color:#4a4dc9;box-shadow:0 0 0 3px #4a4dc91a;background:#fff}.form-select:disabled,.form-input:disabled{opacity:.45;cursor:not-allowed}.ca-chapters-empty{background:#f7f7fb;border:1.5px dashed #DDDDE8;border-radius:8px;padding:14px 12px;font-size:.78rem;color:#9b9b9b;font-style:italic;text-align:center;display:flex;align-items:center;justify-content:center;gap:7px}.ca-spinner{width:12px;height:12px;border:2px solid rgba(74,77,201,.2);border-top-color:#4a4dc9;border-radius:50%;animation:ca-spin .7s linear infinite;display:inline-block;flex-shrink:0}@keyframes ca-spin{to{transform:rotate(360deg)}}.ca-chapters-list{max-height:220px;overflow-y:auto;overflow-x:hidden;border:1.5px solid #DDDDE8;border-radius:8px;background:#fff;padding:6px 0;scrollbar-width:thin;scrollbar-color:rgba(74,77,201,.15) transparent}.ca-chapters-list::-webkit-scrollbar{width:4px}.ca-chapters-list::-webkit-scrollbar-track{background:transparent}.ca-chapters-list::-webkit-scrollbar-thumb{background:#4a4dc92e;border-radius:99px}.ca-chapter-item{display:flex;align-items:center;gap:10px;padding:10px 14px;min-height:40px;cursor:pointer;transition:background .1s;border-bottom:1px solid #F5F5F9;-webkit-user-select:none;user-select:none;box-sizing:border-box}.ca-chapter-item:last-child{border-bottom:none}.ca-chapter-item:hover{background:#f5f5ff}.ca-chapter-item--checked{background:#4a4dc90a}.ca-chapter-item--checked:hover{background:#4a4dc912}.ca-chapter-check{width:16px;height:16px;border-radius:4px;border:2px solid #CACACE;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:border-color .15s,background .15s}.ca-chapter-check--on{background:#4a4dc9;border-color:#4a4dc9}.ca-chapter-name{font-size:.78rem;color:#4e4e4e;line-height:1.35;flex:1}.ca-chapter-item--checked .ca-chapter-name{color:#1e1e2d;font-weight:500}.ca-chapters-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.ca-tag{display:inline-flex;align-items:center;gap:4px;background:#4a4dc912;color:#4a4dc9;font-size:.69rem;font-weight:600;padding:4px 6px 4px 9px;border-radius:6px;border:1px solid rgba(74,77,201,.15);max-width:170px}.ca-tag-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ca-tag-remove{background:none;border:none;cursor:pointer;color:#4a4dc9;font-size:.9rem;line-height:1;padding:0 2px;opacity:.5;transition:opacity .15s;flex-shrink:0;display:flex;align-items:center}.ca-tag-remove:hover{opacity:1}.ca-chapters-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;background:#fff;border:1.5px solid #DDDDE8;border-radius:8px;font-size:.875rem;color:#4e4e4e;cursor:pointer;transition:border-color .15s,background .15s;font-family:inherit;text-align:left}.ca-chapters-trigger:hover{border-color:#4a4dc959;background:#f7f7fb}.ca-chapters-trigger-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ca-chapters-trigger-icon{flex-shrink:0;color:#6b6b6b;transition:transform .2s}.ca-chapters-trigger:hover .ca-chapters-trigger-icon{color:#4a4dc9}.ca-chapter-modal-backdrop{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;box-sizing:border-box;animation:caModalFadeIn .2s ease}@keyframes caModalFadeIn{0%{opacity:0}to{opacity:1}}.ca-chapter-modal-box{background:#fff;border-radius:14px;width:100%;max-width:420px;max-height:calc(100vh - 80px);display:flex;flex-direction:column;box-shadow:0 20px 50px #0000002e;border:1px solid #EBEBEB;animation:caModalSlideIn .25s ease}@keyframes caModalSlideIn{0%{opacity:0;transform:scale(.96) translateY(-12px)}to{opacity:1;transform:scale(1) translateY(0)}}.ca-chapter-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid #EBEBEB;flex-shrink:0}.ca-chapter-modal-title{margin:0;font-size:1.1rem;font-weight:700;color:#1e1e2d;font-family:Poppins,sans-serif}.ca-chapter-modal-close{background:none;border:none;cursor:pointer;padding:6px;color:#6b6b6b;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background .15s,color .15s}.ca-chapter-modal-close:hover{background:#f5f5f9;color:#1e1e2d}.ca-chapter-modal-list{padding:10px 0;overflow-y:auto;overflow-x:hidden;min-height:120px;max-height:320px;flex:1 1 auto;scrollbar-width:thin;scrollbar-color:rgba(74,77,201,.2) transparent}.ca-chapter-modal-list::-webkit-scrollbar{width:6px}.ca-chapter-modal-list::-webkit-scrollbar-track{background:transparent}.ca-chapter-modal-list::-webkit-scrollbar-thumb{background:#4a4dc933;border-radius:99px}.ca-chapter-modal-list .ca-chapter-item{margin:0 12px 2px;border-radius:8px;border:none;border-bottom:none}.ca-chapter-modal-list .ca-chapter-item:last-child{margin-bottom:0}.ca-chapter-modal-footer{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-top:1px solid #EBEBEB;background:#fafafc;border-radius:0 0 14px 14px;flex-shrink:0}.ca-chapter-modal-count{font-size:.8rem;color:#6b6b6b;font-weight:500}.ca-chapter-modal-done{padding:8px 20px;background:linear-gradient(135deg,#4a4dc9,#533086);color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;font-family:inherit;transition:box-shadow .2s,transform .1s}.ca-chapter-modal-done:hover{box-shadow:0 4px 14px #4a4dc959;transform:translateY(-1px)}.assign-submit-btn{width:100%;padding:11px;background:var(--gradient-primary, linear-gradient(135deg, #4A4DC9, #533086));color:#fff;border:none;border-radius:9px;font-family:"Poppins",inherit;font-size:.875rem;font-weight:600;cursor:pointer;transition:box-shadow .2s,transform .15s;margin-top:6px;letter-spacing:.01em}.assign-submit-btn:hover:not(:disabled){box-shadow:0 4px 18px #4a4dc959;transform:translateY(-1px)}.assign-submit-btn:active:not(:disabled){transform:scale(.98)}.assign-submit-btn:disabled{opacity:.45;cursor:not-allowed}.assignments-card{background:#fff;border:1px solid #EBEBEB;border-radius:14px;overflow:hidden;box-shadow:0 2px 10px #4a4dc90a}.assignments-header{padding:14px 20px;border-bottom:1px solid #EBEBEB;display:flex;align-items:center;justify-content:space-between;gap:12px;background:linear-gradient(90deg,#fafaff,#fffbf7);flex-wrap:wrap}.assignments-title{font-size:.9rem;font-weight:700;color:#1e1e2d;display:flex;align-items:center;gap:0}.ca-count-badge{display:inline-flex;align-items:center;justify-content:center;background:#4a4dc91a;color:#4a4dc9;font-size:.68rem;font-weight:700;padding:1px 8px;border-radius:20px;margin-left:8px}.assign-search{position:relative}.assign-search input{background:#f7f7fb;border:1.5px solid #DDDDE8;border-radius:8px;color:#1e1e2d;font-family:"Poppins",inherit;font-size:.78rem;padding:7px 10px 7px 30px;outline:none;width:210px;transition:border-color .2s}.assign-search input:focus{border-color:#4a4dc9;box-shadow:0 0 0 3px #4a4dc917;background:#fff}.assign-search input::placeholder{color:#adadad}.assign-search svg{position:absolute;left:9px;top:50%;transform:translateY(-50%);width:13px;height:13px;color:#adadad;pointer-events:none}.ca-filter-select{width:auto!important;font-size:.75rem!important;padding:7px 9px!important;min-width:118px}.assign-table{width:100%;border-collapse:collapse;font-size:.8rem;font-family:Poppins,sans-serif}.assign-table th{padding:10px 16px;text-align:left;font-size:.65rem;font-weight:700;color:#6b6b6b;text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid #EBEBEB;background:#f8f8fc;white-space:nowrap}.assign-table td{padding:12px 16px;border-bottom:1px solid #F3F3F7;color:#6b6b6b;vertical-align:middle}.assign-table tr:last-child td{border-bottom:none}.assign-table tr:hover td{background:#4a4dc905}.ca-assignments-pagination{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;padding:12px 16px;border-top:1px solid #EBEBEB;background:#f8f8fc;font-size:.8rem;color:#6b6b6b}.ca-pagination-info{font-weight:500}.ca-pagination-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.ca-pagination-pagesize{padding:6px 10px;border:1px solid #DDDDE8;border-radius:6px;font-size:.78rem;font-family:inherit;color:#4e4e4e;background:#fff;cursor:pointer}.ca-pagination-btn{padding:6px 14px;border:1px solid #DDDDE8;border-radius:6px;font-size:.78rem;font-weight:600;font-family:inherit;color:#4a4dc9;background:#fff;cursor:pointer;transition:background .15s,border-color .15s}.ca-pagination-btn:hover:not(:disabled){background:#4a4dc90f;border-color:#4a4dc94d}.ca-pagination-btn:disabled{opacity:.45;cursor:not-allowed}.ca-pagination-page{font-weight:500;color:#4e4e4e}.edu-cell{display:flex;align-items:center;gap:9px}.edu-cell-avatar{width:30px;height:30px;border-radius:50%;background:var(--gradient-primary, linear-gradient(135deg, #4A4DC9, #533086));display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0;box-shadow:0 2px 6px #4a4dc938}.edu-cell-name{color:#1e1e2d;font-weight:600;font-size:.8125rem;white-space:nowrap}.ca-chapter-cell{max-width:220px;color:#1e1e2d;font-weight:500;font-size:.8rem;line-height:1.4;white-space:normal}.ca-subject-tag{display:inline-block;background:#4a4dc914;color:#4a4dc9;font-size:.7rem;font-weight:600;padding:3px 10px;border-radius:6px;white-space:nowrap}.ca-standard-tag{display:inline-block;background:#0f9d9d14;color:#0f9d9d;font-size:.7rem;font-weight:600;padding:3px 10px;border-radius:6px;white-space:nowrap}.ca-school-cell{color:#4e4e4e;font-size:.8rem;white-space:nowrap}.ca-date-cell{color:#9b9b9b;font-size:.77rem;white-space:nowrap}.status-select{border:1.5px solid;border-radius:7px;font-family:"Poppins",inherit;font-size:.73rem;font-weight:700;padding:5px 9px;cursor:pointer;outline:none;transition:box-shadow .15s}.status-select:focus{box-shadow:0 0 0 3px #4a4dc91f}.status-select--assigned{background:#64748b14;color:#475569;border-color:#64748b38}.status-select--in-progress{background:#ff721214;color:#d45a00;border-color:#ff721238}.status-select--completed{background:#10b98114;color:#059669;border-color:#10b98138}.status-badge{display:inline-block;border:1.5px solid;border-radius:7px;font-family:"Poppins",inherit;font-size:.73rem;font-weight:700;padding:5px 12px}.status-badge--assigned{background:#64748b14;color:#475569;border-color:#64748b38}.status-badge--in-progress{background:#ff721214;color:#d45a00;border-color:#ff721238}.status-badge--completed{background:#10b98114;color:#059669;border-color:#10b98138}.ca-status-select{appearance:none;-webkit-appearance:none;border:1.5px solid;border-radius:7px;font-family:"Poppins",inherit;font-size:.73rem;font-weight:700;padding:5px 24px 5px 10px;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 7px center;background-size:10px;transition:opacity .15s}.ca-status-select:disabled{opacity:.55;cursor:not-allowed}.ca-status-select--assigned{background-color:#64748b14;color:#475569;border-color:#64748b38}.ca-status-select--in-progress{background-color:#ff721214;color:#d45a00;border-color:#ff721238}.ca-status-select--completed{background-color:#10b98114;color:#059669;border-color:#10b98138}.status-pill{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:.7rem;font-weight:600}.status-pill .dot{width:5px;height:5px;border-radius:50%}.status-pill.assigned{background:#64748b1a;color:#64748b}.status-pill.assigned .dot{background:#94a3b8}.status-pill.in-progress{background:#ff72121a;color:#ff7212}.status-pill.in-progress .dot{background:#ff7212}.status-pill.completed{background:#10b9811a;color:#059669}.status-pill.completed .dot{background:#10b981}.history-table{margin-top:4px;border-radius:10px;overflow:hidden}.history-table thead th{background:#f9fafb}.history-table tbody tr:nth-child(2n) td{background:#fbfbff}.history-table td:nth-child(1),.history-table td:nth-child(5){white-space:nowrap}.history-table td:nth-child(2){max-width:260px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ca-empty-row td{text-align:center;padding:44px 16px}.ca-empty-state{display:flex;flex-direction:column;align-items:center;gap:10px;color:#adadad;font-size:.875rem;font-family:Poppins,sans-serif}.assign-toast{position:fixed;bottom:24px;right:24px;background:#fff;border:1.5px solid rgba(74,77,201,.25);border-radius:10px;padding:12px 20px;font-family:"Poppins",inherit;font-size:.8125rem;color:#4a4dc9;font-weight:600;z-index:1000;box-shadow:0 6px 24px #4a4dc929;animation:ca-slideUp .22s ease}@keyframes ca-slideUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.ca-reassign-btn{border:1.5px solid rgba(74,77,201,.25);background:#4a4dc90f;color:#4a4dc9;font-family:"Poppins",inherit;font-size:.73rem;font-weight:600;padding:5px 14px;border-radius:7px;cursor:pointer;transition:background .15s,border-color .15s}.ca-reassign-btn:hover{background:#4a4dc921;border-color:#4a4dc966}.ca-modal-backdrop{position:fixed;inset:0;z-index:9999;background:#00000073;display:flex;align-items:center;justify-content:center}.ca-reassign-modal{background:#fff;border-radius:14px;width:440px;max-width:92vw;box-shadow:0 8px 32px #0000002e;animation:ca-slideUp .2s ease}.ca-reassign-modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px 14px;border-bottom:1px solid #f0f0f0}.ca-reassign-modal-header h3{margin:0;font-size:1rem;font-weight:700;color:#1e293b}.ca-reassign-modal-close{background:none;border:none;font-size:1.4rem;color:#94a3b8;cursor:pointer;line-height:1}.ca-reassign-modal-close:hover{color:#475569}.ca-reassign-modal-body{padding:18px 22px}.ca-reassign-info{background:#f8fafc;border-radius:8px;padding:12px 14px;margin-bottom:16px}.ca-reassign-info p{margin:0 0 4px;font-size:.8rem;color:#475569}.ca-reassign-info p:last-child{margin-bottom:0}.ca-reassign-label{display:block;font-size:.78rem;font-weight:600;color:#334155;margin-bottom:6px}.ca-reassign-select{width:100%;padding:9px 12px;border:1.5px solid #e2e8f0;border-radius:8px;font-size:.82rem;font-family:"Poppins",inherit}.ca-reassign-loading,.ca-reassign-empty{display:flex;align-items:center;gap:8px;font-size:.8rem;color:#94a3b8;padding:12px 0}.ca-reassign-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:14px 22px 18px;border-top:1px solid #f0f0f0}.ca-reassign-cancel-btn{padding:8px 18px;border:1.5px solid #e2e8f0;border-radius:8px;background:#fff;color:#64748b;font-size:.8rem;font-weight:600;font-family:"Poppins",inherit;cursor:pointer}.ca-reassign-cancel-btn:hover{background:#f8fafc}.ca-reassign-confirm-btn{padding:8px 20px;border:none;border-radius:8px;background:#4a4dc9;color:#fff;font-size:.8rem;font-weight:600;font-family:"Poppins",inherit;cursor:pointer}.ca-reassign-confirm-btn:disabled{opacity:.5;cursor:not-allowed}.ca-reassign-confirm-btn:hover:not(:disabled){background:#3c3fba}.detail-back-btn{display:inline-flex;align-items:center;gap:6px;background:none;border:none;color:var(--color-text-muted, #6B6B6B);font-size:.8125rem;font-family:"Poppins",inherit;font-weight:500;cursor:pointer;padding:0;margin-bottom:20px;transition:color .15s}.detail-back-btn:hover{color:var(--color-primary, #4A4DC9)}.detail-profile-card{background:#fff;border:1px solid var(--color-border-light, #EBEBEB);border-radius:16px;padding:26px;margin-bottom:22px;display:flex;gap:24px;align-items:flex-start;box-shadow:0 2px 12px #4a4dc90f;animation:scaleIn .4s var(--transition-smooth, ease) both;position:relative;overflow:hidden}.detail-profile-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary, linear-gradient(90deg, #4A4DC9, #533086))}.detail-avatar{width:68px;height:68px;border-radius:50%;background:var(--gradient-primary, linear-gradient(135deg, #4A4DC9, #533086));display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:#fff;flex-shrink:0;box-shadow:0 4px 14px #4a4dc94d}.detail-profile-info{flex:1}.detail-name{font-size:1.25rem;font-weight:700;color:var(--color-text, #4E4E4E);margin:0 0 3px;letter-spacing:-.02em}.detail-school{font-size:.8125rem;color:var(--color-text-muted, #6B6B6B);margin:0 0 16px;font-weight:500}.detail-meta{display:flex;flex-wrap:wrap;gap:12px 20px;font-size:.8125rem;color:var(--color-text-muted, #6B6B6B);margin:0 0 16px}.detail-meta span+span{margin-left:0}.detail-loading,.detail-error{padding:24px;text-align:center;color:var(--color-text-muted, #6B6B6B);font-size:.9375rem}.detail-error{color:#b91c1c}.detail-section{background:#fff;border:1px solid var(--color-border-light, #EBEBEB);border-radius:14px;padding:20px 24px;margin-bottom:20px;box-shadow:0 2px 10px #4a4dc90a}.detail-section-title{font-size:.9375rem;font-weight:700;color:var(--color-text, #4E4E4E);margin:0 0 16px;padding-bottom:10px;border-bottom:1px solid var(--color-border-light, #EBEBEB)}.detail-section-title--no-border{margin-bottom:0;padding-bottom:0;border-bottom:none}.detail-section-head-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.detail-date-filters{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.detail-date-field{display:inline-flex;align-items:center;gap:6px;font-size:.72rem;color:var(--color-text-muted, #6B6B6B);font-weight:500}.detail-date-field input[type=date]{border:1px solid var(--color-border-light, #EBEBEB);border-radius:8px;padding:4px 8px;font-size:.72rem;font-family:Poppins,sans-serif;color:var(--color-text, #4E4E4E);background:#fff}.detail-summary-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.detail-summary-chip{display:inline-flex;align-items:center;gap:8px;padding:5px 10px;border-radius:999px;background:#4a4dc914;color:#4a4dc9;border:1px solid rgba(74,77,201,.16);font-size:.72rem;font-weight:600;cursor:pointer;outline:none}.detail-summary-chip strong{font-size:.78rem;font-weight:800}.detail-summary-chip--active{background:#4a4dc9;color:#fff;border-color:#4a4dc9}.status-pill{display:inline-flex;align-items:center;gap:6px;padding:2px 10px;border-radius:999px;font-size:.72rem;font-weight:600;background:#94a3b81f;color:#64748b}.status-pill-dot{width:7px;height:7px;border-radius:50%;background:currentColor}.status-pill--assigned{background:#94a3b81f;color:#64748b}.status-pill--inprogress{background:#ff72121a;color:#c05621}.status-pill--completed{background:#10b9811a;color:#059669}.detail-assignment-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}.detail-assignment-card{padding:14px 16px;background:#4a4dc90d;border:1px solid rgba(74,77,201,.12);border-radius:10px}.detail-assignment-row{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:8px}.detail-assignment-row:last-child{margin-bottom:0}.detail-assignment-label{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted, #6B6B6B)}.detail-assignment-value{font-size:.8125rem;font-weight:600;color:var(--color-text, #4E4E4E)}.detail-assignment-value.subject{color:var(--color-primary, #4A4DC9)}.detail-chapter-list ul{list-style:none;margin:0;padding:0}.detail-chapter-item{display:flex;flex-direction:column;gap:2px;padding:10px 14px;border-bottom:1px solid var(--color-border-light, #EBEBEB);font-size:.875rem}.detail-chapter-item:last-child{border-bottom:none}.detail-chapter-name{font-weight:600;color:var(--color-text, #4E4E4E)}.detail-chapter-meta{font-size:.75rem;color:var(--color-text-muted, #6B6B6B)}.detail-table-wrap{overflow-x:auto}.detail-table{width:100%;border-collapse:collapse;font-size:.8125rem}.detail-table th{padding:10px 14px;text-align:left;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted, #6B6B6B);border-bottom:1px solid var(--color-border-light, #EBEBEB);background:var(--color-bg, #F5F5F5)}.detail-table td{padding:12px 14px;border-bottom:1px solid var(--color-border-light, #EBEBEB);color:var(--color-text-muted, #6B6B6B)}.detail-table tr:last-child td{border-bottom:none}.detail-table tr:hover td{background:#4a4dc905}.detail-table-chapter{font-weight:500;color:var(--color-text, #4E4E4E);max-width:240px;white-space:normal}.detail-empty{margin:0;font-size:.875rem;color:var(--color-text-muted, #6B6B6B);font-style:italic}.detail-stat-row{display:flex;gap:28px;flex-wrap:wrap}.detail-stat{display:flex;flex-direction:column;gap:2px}.detail-stat-label{font-size:.65rem;color:var(--color-text-muted, #6B6B6B);text-transform:uppercase;letter-spacing:.07em;font-weight:700}.detail-stat-value{font-size:1.1rem;font-weight:700;color:var(--color-text, #4E4E4E)}.detail-stat-value.green{color:#10b981}.detail-stat-value.blue{color:var(--color-primary, #4A4DC9)}.engagement-ring{display:flex;flex-direction:column;align-items:center;justify-content:center;width:82px;height:82px;border-radius:50%;border:3px solid;flex-shrink:0}.engagement-ring.high{border-color:#10b981;color:#059669}.engagement-ring.mid{border-color:#ff7212;color:#ff7212}.engagement-ring.low{border-color:#ef4444;color:#ef4444}.engagement-num{font-size:1.25rem;font-weight:700;line-height:1}.engagement-lbl{font-size:.55rem;text-transform:uppercase;letter-spacing:.07em;font-weight:700;margin-top:2px}.detail-tabs{display:flex;gap:3px;background:#fff;border:1px solid var(--color-border-light, #EBEBEB);border-radius:10px;padding:4px;margin-bottom:16px;box-shadow:0 1px 6px #4a4dc90a}.detail-tab{flex:1;padding:8px 14px;border:none;border-radius:7px;background:none;color:var(--color-text-muted, #6B6B6B);font-size:.8rem;font-weight:500;font-family:"Poppins",inherit;cursor:pointer;transition:background .18s,color .18s;text-align:center}.detail-tab:hover{color:var(--color-primary, #4A4DC9);background:#4a4dc90f}.detail-tab.active{background:var(--gradient-primary, linear-gradient(135deg, #4A4DC9, #533086));color:#fff;font-weight:600;box-shadow:0 2px 8px #4a4dc940}.tab-panel{background:#fff;border:1px solid var(--color-border-light, #EBEBEB);border-radius:14px;overflow:hidden;box-shadow:0 2px 10px #4a4dc90a;animation:fadeInUp .3s ease both}.tab-panel-header{padding:13px 20px;border-bottom:1px solid var(--color-border-light, #EBEBEB);font-size:.8125rem;font-weight:700;color:var(--color-text, #4E4E4E);background:linear-gradient(90deg,#fafaff,#fffbf7)}.session-table{width:100%;border-collapse:collapse;font-size:.8125rem}.session-table th{padding:10px 16px;text-align:left;font-size:.675rem;font-weight:700;color:var(--color-text-muted, #6B6B6B);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--color-border-light, #EBEBEB);background:var(--color-bg, #F5F5F5)}.session-table td{padding:12px 16px;border-bottom:1px solid var(--color-border-light, #EBEBEB);color:var(--color-text-muted, #6B6B6B)}.session-table tr:last-child td{border-bottom:none}.session-table tr:hover td{background:#4a4dc905}.session-type-badge{display:inline-block;padding:2px 9px;border-radius:4px;font-size:.7rem;font-weight:700}.session-type-badge.pdf{background:#4a4dc91a;color:#4a4dc9}.session-type-badge.lp{background:#5330861a;color:#533086}.session-type-badge.both{background:#10b9811a;color:#059669}.stat-num{display:inline-flex;align-items:center;justify-content:center;min-width:34px;padding:2px 7px;border-radius:4px;font-size:.7rem;font-weight:700;font-family:Poppins,sans-serif}.stat-num.blue{background:#4a4dc917;color:#4a4dc9}.stat-num.indigo{background:#6366f117;color:#4f46e5}.stat-num.purple{background:#53308617;color:#533086}.stat-num.teal{background:#006d7717;color:#006d77}.stat-num.orange{background:#ff721217;color:#ff7212}.stat-num.red{background:#ef444417;color:#ef4444}.stat-num.gray{background:#64748b17;color:#64748b}.stat-num.green{background:#10b98117;color:#059669}.feedback-list{padding:18px 20px;display:flex;flex-direction:column;gap:12px}.feedback-item{background:var(--color-bg, #F5F5F5);border:1px solid var(--color-border-light, #EBEBEB);border-radius:10px;padding:14px 16px;transition:box-shadow .15s}.feedback-item:hover{box-shadow:0 2px 10px #4a4dc90f}.feedback-item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.feedback-chapter{font-size:.8125rem;font-weight:700;color:var(--color-text, #4E4E4E)}.feedback-date{font-size:.7rem;color:var(--color-text-muted, #6B6B6B);font-weight:500}.feedback-text{font-size:.8rem;color:var(--color-text-muted, #6B6B6B);line-height:1.55;margin:0 0 8px}.feedback-sentiment{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;font-weight:600;padding:2px 9px;border-radius:20px}.feedback-sentiment.positive{background:#10b9811a;color:#059669}.feedback-sentiment.negative{background:#ef44441a;color:#ef4444}.feedback-sentiment.neutral{background:#64748b1a;color:#64748b}.fh-root{display:flex;flex-direction:column;height:100vh;background:#f1f5f9;font-family:Inter,system-ui,-apple-system,sans-serif;overflow:hidden}.fh-navbar{display:flex;align-items:center;justify-content:space-between;padding:0 28px;height:62px;background:linear-gradient(135deg,#1e1b4b,#312e81 55%,#3730a3);box-shadow:0 2px 18px #312e814d;flex-shrink:0;z-index:100}.fh-navbar-brand{display:flex;align-items:center;gap:12px}.fh-brand-icon{width:36px;height:36px;border-radius:10px;background:#ffffff24;display:flex;align-items:center;justify-content:center;color:#fff}.fh-brand-name{display:block;font-size:15px;font-weight:700;color:#fff;letter-spacing:-.3px;line-height:1.2}.fh-brand-sub{display:block;font-size:10px;font-weight:500;color:#a5b4fcd9;letter-spacing:.5px;text-transform:uppercase}.fh-navbar-right{display:flex;align-items:center;gap:14px}.fh-user-pill{display:flex;align-items:center;gap:10px;padding:5px 14px 5px 5px;background:#ffffff1a;border-radius:40px;border:1px solid rgba(255,255,255,.16)}.fh-user-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#a78bfa,#818cf8);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.fh-user-name{display:block;font-size:12.5px;font-weight:600;color:#fff;line-height:1.2}.fh-user-role{display:block;font-size:10px;color:#a5b4fccc;line-height:1.2}.fh-help-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;background:#eef2ff26;border:1px solid rgba(199,210,254,.4);border-radius:8px;color:#c7d2fe;font-size:12.5px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .16s,color .16s}.fh-help-btn:hover{background:#eef2ff47;color:#fff}.fh-logout-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;background:#ffffff14;border:1px solid rgba(255,255,255,.18);border-radius:8px;color:#ffffffd9;font-size:12.5px;font-weight:500;cursor:pointer;transition:background .16s}.fh-logout-btn:hover{background:#ffffff29;color:#fff}.fh-body{display:flex;flex:1;overflow:hidden}.fh-card-actions{display:flex;align-items:center;gap:10px;padding:10px 14px 0}.fh-preview-btn{padding:7px 10px;border-radius:8px;border:1px solid #c7d2fe;background:#6366f114;color:#3730a3;font-size:12.5px;font-weight:700;cursor:pointer}.fh-preview-btn:hover{background:#6366f124}.fh-preview-btn--secondary{border-color:#e5e7eb;background:#0f172a0a;color:#0f172a}.fh-preview-btn--secondary:hover{background:#0f172a14}.fh-tool-url{flex:1;min-width:0;font-size:12px;color:#64748b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fh-tool-preview-backdrop{position:fixed;inset:0;background:#0206178c;display:flex;align-items:center;justify-content:center;padding:18px;z-index:2000}.fh-tool-preview-modal{width:80vw;height:90vh;background:#fff;border-radius:14px;box-shadow:0 16px 60px #00000059;overflow:hidden;display:flex;flex-direction:column}.fh-tool-preview-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-bottom:1px solid #e5e7eb;background:#fafafa}.fh-tool-preview-title{font-weight:800;color:#111827;font-size:14px}.fh-tool-preview-subtitle{font-size:12px;color:#6b7280;margin-top:2px}.fh-tool-preview-close{width:34px;height:34px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;color:#111827;font-size:20px;line-height:1;cursor:pointer}.fh-tool-preview-close:hover{background:#f3f4f6}.fh-tool-preview-body{flex:1;min-height:0}.fh-tool-preview-iframe{width:100%;height:100%;border:0;display:block;background:#fff}.fh-tool-preview-compiling,.fh-tool-preview-error{padding:18px;font-size:13px;color:#334155}.fh-tool-preview-error{color:#b91c1c;background:#fef2f2;border-bottom:1px solid #fee2e2}.fh-attach-body{padding:14px;overflow:auto}.fh-attach-section+.fh-attach-section{margin-top:16px}.fh-attach-heading{font-size:12.5px;font-weight:800;color:#111827;margin-bottom:10px}.fh-attach-empty{font-size:12.5px;color:#64748b}.fh-attach-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.fh-attach-thumb{display:block;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden;background:#fff}.fh-attach-thumb img{width:100%;height:110px;object-fit:cover;display:block}.fh-attach-videos{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}.fh-attach-video{border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;background:#fff}.fh-attach-video video{width:100%;height:180px;display:block;background:#000}.fh-attach-open{display:block;padding:10px 12px;font-size:12px;color:#3730a3;text-decoration:none;border-top:1px solid #e5e7eb}.fh-attach-open:hover{text-decoration:underline}.fh-sidebar{width:292px;flex-shrink:0;background:#fff;border-right:1px solid #e5e7eb;display:flex;flex-direction:column;overflow-y:auto;padding-bottom:24px}.fh-sidebar-header{display:flex;align-items:center;gap:9px;padding:18px 18px 14px;border-bottom:1px solid #f1f5f9}.fh-sidebar-icon{width:28px;height:28px;border-radius:8px;background:#ede9fe;color:#6366f1;display:flex;align-items:center;justify-content:center;flex-shrink:0}.fh-sidebar-title{font-size:13px;font-weight:700;color:#1e1b4b}.fh-progress-wrap{margin:14px 18px 0;height:4px;border-radius:4px;background:#e5e7eb;overflow:hidden}.fh-progress-bar{height:100%;border-radius:4px;background:linear-gradient(90deg,#6366f1,#a78bfa);transition:width .35s ease}.fh-progress-label{font-size:10px;color:#9ca3af;margin:5px 18px 14px}.fh-filter-form{padding:0 14px;display:flex;flex-direction:column;gap:9px}.fh-field{display:flex;flex-direction:column;gap:4px}.fh-label{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:#374151;letter-spacing:.1px}.fh-label-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.fh-dot--school{background:#6366f1}.fh-dot--board{background:#8b5cf6}.fh-dot--medium{background:#a78bfa}.fh-dot--standard{background:#06b6d4}.fh-dot--subject{background:#10b981}.fh-dot--chapter{background:#f59e0b}.fh-check-icon{margin-left:auto;font-size:10px;color:#10b981;font-weight:700}.fh-select-wrap{position:relative;display:flex;align-items:center}.fh-select{width:100%;appearance:none;padding:7.5px 28px 7.5px 10px;border:1.5px solid #e5e7eb;border-radius:8px;background:#f9fafb;font-size:12px;color:#374151;cursor:pointer;transition:border-color .16s,box-shadow .16s;outline:none}.fh-select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;background:#fff}.fh-select:disabled{background:#f3f4f6;color:#9ca3af;cursor:not-allowed;border-color:#e5e7eb}.fh-select option:first-child{color:#9ca3af}.fh-chevron{position:absolute;right:9px;color:#9ca3af;pointer-events:none;flex-shrink:0}.fh-load-btn{display:flex;align-items:center;justify-content:center;gap:7px;padding:10px;margin-top:5px;border-radius:9px;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;font-size:13px;font-weight:600;border:none;cursor:pointer;transition:opacity .16s,box-shadow .16s;box-shadow:0 3px 10px #6366f147}.fh-load-btn:hover:not(:disabled){opacity:.92;box-shadow:0 5px 18px #6366f15c}.fh-load-btn:disabled{background:#d1d5db;box-shadow:none;cursor:not-allowed;color:#9ca3af}.fh-reset-btn{display:flex;align-items:center;justify-content:center;padding:8px;border-radius:9px;border:1.5px solid #e5e7eb;background:transparent;color:#6b7280;font-size:12px;font-weight:500;cursor:pointer;transition:border-color .16s,color .16s}.fh-reset-btn:hover{border-color:#ef4444;color:#ef4444}.fh-spinner{width:13px;height:13px;border-radius:50%;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;animation:fh-spin .65s linear infinite;flex-shrink:0}@keyframes fh-spin{to{transform:rotate(360deg)}}.fh-main{flex:1;overflow-y:auto;padding:26px 30px;display:flex;flex-direction:column;gap:20px}.fh-main-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.fh-main-title{font-size:21px;font-weight:800;color:#1e1b4b;letter-spacing:-.5px;margin:0 0 4px}.fh-main-sub{font-size:13px;color:#6b7280;margin:0}.fh-chapter-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 13px;background:#ede9fe;border-radius:20px;font-size:11.5px;font-weight:600;color:#4f46e5;white-space:nowrap;flex-shrink:0;max-width:240px;overflow:hidden;text-overflow:ellipsis}.fh-stats-row{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}.fh-stat-card{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#fff;border-radius:10px;border:1px solid #e5e7eb;box-shadow:0 1px 4px #0000000a}.fh-stat-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.fh-stat-val{display:block;font-size:22px;font-weight:800;line-height:1;letter-spacing:-.5px}.fh-stat-lbl{display:block;font-size:11px;color:#9ca3af;margin-top:3px;font-weight:500}.fh-tabs{display:flex;gap:4px;border-bottom:2px solid #e5e7eb;padding-bottom:0}.fh-tab{display:flex;align-items:center;gap:6px;padding:9px 16px;background:transparent;border:none;font-size:12.5px;font-weight:600;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .16s,border-color .16s;border-radius:6px 6px 0 0}.fh-tab:hover{color:#4f46e5;background:#f5f3ff}.fh-tab--active{color:#4f46e5;border-bottom-color:#4f46e5}.fh-tab-count{min-width:20px;padding:1px 6px;border-radius:20px;background:#ede9fe;color:#4f46e5;font-size:10.5px;font-weight:700}.fh-tab--active .fh-tab-count{background:#4f46e5;color:#fff}.fh-error-card{display:flex;align-items:center;gap:10px;padding:14px 18px;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;color:#b91c1c;font-size:13.5px}.fh-shimmer-list{display:flex;flex-direction:column;gap:12px}.fh-shimmer-card{height:110px;border-radius:12px;background:linear-gradient(90deg,#f0f0f0 25%,#e8e8e8,#f0f0f0 75%);background-size:200% 100%;animation:fh-shimmer 1.4s infinite}@keyframes fh-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.fh-lightbox-backdrop{position:fixed;inset:0;z-index:10000;background:#000000bf;display:flex;align-items:center;justify-content:center}.fh-lightbox-content{position:relative;max-width:90vw;max-height:90vh}.fh-lightbox-close{position:absolute;top:-12px;right:-12px;width:32px;height:32px;border-radius:50%;border:none;background:#fff;color:#333;font-size:20px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #00000040;z-index:1}.fh-lightbox-close:hover{background:#f3f4f6}.fh-lightbox-img{max-width:90vw;max-height:85vh;border-radius:8px;object-fit:contain;box-shadow:0 4px 24px #0000004d}.fh-idle-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:48px 32px;background:#fff;border-radius:16px;border:1.5px dashed #d1d5db}.fh-idle-icon{width:80px;height:80px;border-radius:20px;background:#ede9fe;color:#6366f1;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.fh-idle-title{font-size:17px;font-weight:700;color:#1e1b4b;margin:0 0 8px}.fh-idle-desc{font-size:13.5px;color:#6b7280;max-width:400px;line-height:1.6;margin:0 auto 24px}.fh-idle-steps{display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:center}.fh-idle-step{display:flex;align-items:center;gap:5px;padding:5px 11px;border-radius:20px;background:#f3f4f6;font-size:11.5px;color:#9ca3af;font-weight:500;transition:all .2s}.fh-idle-step--done{background:#d1fae5;color:#065f46}.fh-idle-step-num{width:17px;height:17px;border-radius:50%;background:#e5e7eb;color:#6b7280;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center}.fh-idle-step--done .fh-idle-step-num{background:#10b981;color:#fff}.fh-no-results{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:52px;background:#fff;border-radius:14px;border:1px solid #e5e7eb}.fh-no-results p{font-size:13.5px;color:#9ca3af;margin:0}.fh-feedback-list{display:flex;flex-direction:column;gap:12px}.fh-feedback-card{background:#fff;border-radius:14px;border:1.5px solid #e5e7eb;overflow:hidden;transition:box-shadow .18s,border-color .18s}.fh-feedback-card:hover{box-shadow:0 4px 20px #00000012}.fh-feedback-card.fh-card--liked{border-left:4px solid #10b981}.fh-feedback-card.fh-card--disliked{border-left:4px solid #ef4444}.fh-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:16px 18px 12px}.fh-card-left{min-width:0;flex:1}.fh-card-topic-id{font-size:14px;font-weight:700;color:#1e1b4b;margin-bottom:3px;font-family:JetBrains Mono,Fira Code,monospace}.fh-card-chapter-name{font-size:12px;color:#6b7280;font-weight:500}.fh-card-badges{display:flex;align-items:center;gap:6px;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end}.fh-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:10.5px;font-weight:700}.fh-badge--liked{background:#d1fae5;color:#065f46}.fh-badge--disliked{background:#fee2e2;color:#b91c1c}.fh-badge--neutral{background:#f3f4f6;color:#6b7280}.fh-badge--done{background:#dbeafe;color:#1e40af}.fh-badge--pending{background:#fef3c7;color:#92400e}.fh-badge--approved{background:#dcfce7;color:#15803d}.fh-badge--rejected{background:#fee2e2;color:#b91c1c}.fh-badge--inactive{background:#f3f4f6;color:#9ca3af}.fh-card-comment{display:flex;gap:9px;align-items:flex-start;margin:0 18px 12px;padding:10px 13px;background:#f8fafc;border-radius:8px;border-left:3px solid #e0e7ff;color:#4b5563}.fh-card-comment svg{flex-shrink:0;margin-top:2px;color:#a5b4fc}.fh-card-comment p{font-size:13px;color:#4b5563;margin:0;line-height:1.55}.fh-card-image{margin:0 18px 12px;border-radius:8px;overflow:hidden;background:#f3f4f6;border:1px solid #e5e7eb;max-width:480px}.fh-feedback-image{display:block;width:100%;max-height:320px;object-fit:contain;border-radius:8px}.fh-feedback-video{display:block;width:100%;max-height:320px;object-fit:contain;border-radius:8px;background:#000}.fh-card-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid #f1f5f9;padding:11px 18px;background:#fafafa}.fh-meta-item{display:flex;align-items:center;gap:8px;padding:0 8px;border-right:1px solid #f1f5f9}.fh-meta-item:first-child{padding-left:0}.fh-meta-item:last-child{border-right:none}.fh-teacher-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#a78bfa,#818cf8);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.fh-meta-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.fh-meta-icon--school{background:#dbeafe;color:#3b82f6}.fh-meta-icon--plan{background:#fef3c7;color:#f59e0b}.fh-meta-icon--date{background:#f0fdf4;color:#10b981}.fh-meta-primary{font-size:12px;font-weight:600;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.fh-meta-secondary{font-size:10px;color:#9ca3af;margin-top:1px}@media(max-width:1100px){.fh-stats-row{grid-template-columns:repeat(2,1fr)}.fh-card-meta{grid-template-columns:repeat(2,1fr);gap:8px}.fh-meta-item{border-right:none;padding:4px 0}}@media(max-width:720px){.fh-body{flex-direction:column}.fh-sidebar{width:100%;border-right:none;border-bottom:1px solid #e5e7eb}.fh-main{padding:18px 14px}.fh-stats-row{grid-template-columns:repeat(2,1fr)}.fh-card-meta{grid-template-columns:1fr 1fr;gap:8px}}.fh-status-wrap{position:relative;display:inline-flex}.fh-status-btn{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;border:none;font-size:11px;font-weight:700;cursor:pointer;transition:opacity .15s,box-shadow .15s;white-space:nowrap}.fh-status-btn:hover:not(:disabled){opacity:.82}.fh-status-btn:disabled{cursor:not-allowed;opacity:.7}.fh-status-btn--done{background:#dbeafe;color:#1e40af;box-shadow:0 0 0 1.5px #1e40af2e}.fh-status-btn--done:hover:not(:disabled){background:#bfdbfe;box-shadow:0 0 0 1.5px #1e40af4d}.fh-status-btn--pending{background:#fef3c7;color:#92400e;box-shadow:0 0 0 1.5px #92400e2e}.fh-status-btn--pending:hover:not(:disabled){background:#fde68a;box-shadow:0 0 0 1.5px #92400e4d}.fh-status-menu{position:absolute;top:calc(100% + 6px);right:0;background:#fff;border:1.5px solid #e5e7eb;border-radius:10px;padding:5px;box-shadow:0 8px 24px #0000001f;z-index:200;min-width:130px;animation:fh-menu-in .14s ease}@keyframes fh-menu-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.fh-status-option{display:flex;align-items:center;gap:7px;width:100%;padding:8px 10px;border:none;border-radius:7px;background:transparent;font-size:12px;font-weight:600;cursor:pointer;color:#374151;transition:background .12s;text-align:left}.fh-status-option:hover{background:#f3f4f6}.fh-status-option--done svg{color:#1e40af}.fh-status-option--pending svg{color:#92400e}.fh-status-option--active{background:#f0f9ff;color:#0369a1}.fh-status-option--done.fh-status-option--active{background:#eff6ff;color:#1e40af}.fh-status-option--pending.fh-status-option--active{background:#fffbeb;color:#92400e}.fh-status-spinner{width:9px;height:9px;border-radius:50%;border:1.5px solid rgba(0,0,0,.2);border-top-color:currentColor;animation:fh-spin .6s linear infinite;flex-shrink:0}.cdh-page{min-height:100vh;background:#f5f6fa;display:flex;flex-direction:column;font-family:Poppins,sans-serif}.cdh-header{background:#1e1e2d;padding:0 28px;height:56px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;box-shadow:0 2px 8px #0000002e}.cdh-header-left{display:flex;align-items:center;gap:12px}.cdh-logo-link{text-decoration:none}.cdh-logo-link h1{font-size:1.1rem;font-weight:700;color:#fff;margin:0;letter-spacing:-.01em}.cdh-header-badge{background:#6366f140;color:#a5b4fc;font-size:.7rem;font-weight:600;padding:3px 10px;border-radius:999px;letter-spacing:.03em;text-transform:uppercase}.cdh-header-right{display:flex;align-items:center;gap:12px}.cdh-user-pill{display:flex;align-items:center;gap:8px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:999px;padding:4px 14px 4px 4px;text-decoration:none;transition:background .15s}.cdh-user-pill:hover{background:#ffffff24}.cdh-user-avatar{width:28px;height:28px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;color:#fff}.cdh-user-name{font-size:.82rem;font-weight:500;color:#e2e8f0}.cdh-logout-btn{background:transparent;border:1px solid rgba(255,255,255,.2);color:#cbd5e1;font-size:.8rem;font-weight:500;padding:6px 14px;border-radius:7px;cursor:pointer;transition:background .15s,border-color .15s;font-family:inherit}.cdh-logout-btn:hover{background:#ffffff14;border-color:#ffffff59;color:#f1f5f9}.cdh-main{flex:1;display:flex;flex-direction:column;align-items:center;padding:40px 24px 60px}.cdh-hero{text-align:center;margin-bottom:28px}.cdh-hero h2{font-size:1.6rem;font-weight:700;color:#1e1e2d;margin:0 0 6px;letter-spacing:-.02em}.cdh-hero p{font-size:.9rem;color:#6b6b6b;margin:0}.cdh-card{background:#fff;border:1px solid #EBEBEB;border-radius:16px;box-shadow:0 4px 20px #4a4dc912;width:100%;max-width:640px;overflow:hidden}.cdh-card-header{padding:20px 28px 16px;border-bottom:1px solid #f0f0f0}.cdh-card-title{font-size:1rem;font-weight:600;color:#1e1e2d;letter-spacing:-.01em}.cdh-form{padding:24px 28px 28px;display:flex;flex-direction:column;gap:18px}.cdh-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.cdh-form-group{display:flex;flex-direction:column;gap:6px}.cdh-label{font-size:.8rem;font-weight:600;color:#4a4a6a;letter-spacing:.01em}.cdh-select-wrapper{position:relative}.cdh-select{width:100%;appearance:none;-webkit-appearance:none;background:#f8f9fc 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='%236B6B6B' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") no-repeat right 12px center;border:1.5px solid #E0E0E0;border-radius:10px;padding:10px 36px 10px 14px;font-size:.875rem;color:#1e1e2d;font-family:inherit;cursor:pointer;transition:border-color .15s,box-shadow .15s,background .15s;outline:none}.cdh-select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11f;background-color:#fff}.cdh-select:disabled{background:#f0f0f5;color:#a0a0b0;cursor:not-allowed;border-color:#e8e8ee}.cdh-form-actions{display:flex;justify-content:flex-end;padding-top:4px}.cdh-validate-btn{background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;border:none;border-radius:10px;padding:11px 28px;font-size:.9rem;font-weight:600;font-family:inherit;cursor:pointer;letter-spacing:.01em;transition:opacity .15s,transform .12s,box-shadow .15s;box-shadow:0 4px 14px #6366f14d}.cdh-validate-btn:hover:not(:disabled){opacity:.92;transform:translateY(-1px);box-shadow:0 6px 20px #6366f166}.cdh-validate-btn:active:not(:disabled){transform:translateY(0)}.cdh-validate-btn:disabled{background:#c7c9e0;box-shadow:none;cursor:not-allowed}@media(max-width:520px){.cdh-form-row{grid-template-columns:1fr}.cdh-card{border-radius:12px}.cdh-form{padding:20px 18px 24px}.cdh-card-header{padding:16px 18px 14px}.cdh-validate-btn{width:100%}.cdh-form-actions{justify-content:stretch}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}.um-root{min-height:100vh;display:flex;flex-direction:column;font-family:Noto Sans Gujarati,Inter,system-ui,sans-serif;font-size:14px;line-height:1.75;color:#1e293b;background:#f8fafc}.um-header{display:flex;align-items:center;justify-content:space-between;padding:14px 28px;background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 4px #0000000f;position:sticky;top:0;z-index:100}.um-header-left{display:flex;align-items:center;gap:12px}.um-logo{width:40px;height:40px;background:#4a4dc9;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.um-header-title{font-size:16px;font-weight:700;color:#4a4dc9;line-height:1.2}.um-header-sub{font-size:12px;color:#64748b;font-weight:500}.um-header-right-actions{display:flex;align-items:center;gap:12px}.um-lang-dropdown{display:flex;align-items:center;gap:6px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;padding:4px 6px 4px 10px;transition:border-color .15s}.um-lang-dropdown:hover{border-color:#4a4dc9}.um-lang-label{display:flex;align-items:center;color:#64748b;flex-shrink:0}.um-lang-select{border:none;background:transparent;font-family:inherit;font-size:13px;font-weight:600;color:#1e293b;cursor:pointer;padding:5px 18px 5px 4px;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%2364748b' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 2px center}.um-lang-select:focus{color:#4a4dc9}.um-print-btn{display:flex;align-items:center;gap:8px;padding:9px 18px;background:#4a4dc9;color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s,transform .1s}.um-print-btn:hover{background:#3730a3}.um-print-btn:active{transform:scale(.97)}.um-body{display:flex;flex:1;min-height:0}.um-sidebar{width:240px;flex-shrink:0;background:#fff;border-right:1px solid #e2e8f0;padding:20px 12px;display:flex;flex-direction:column;gap:2px;overflow-y:auto;position:sticky;top:69px;height:calc(100vh - 69px)}.um-sidebar-title{font-size:10px;font-weight:700;color:#94a3b8;letter-spacing:.08em;text-transform:uppercase;padding:0 8px;margin-bottom:6px}.um-nav-btn{display:block;width:100%;text-align:left;padding:9px 12px;border:none;background:transparent;border-radius:7px;font-size:13px;font-family:inherit;color:#475569;cursor:pointer;transition:background .13s,color .13s;font-weight:500}.um-nav-btn:hover{background:#f1f5f9;color:#1e293b}.um-nav-btn.active{background:#eef2ff;color:#4a4dc9;font-weight:600}.um-content{flex:1;padding:32px 40px;overflow-y:auto;max-width:860px}.um-section-title{font-size:22px;font-weight:700;color:#1e293b;margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid #e2e8f0}.um-lead{font-size:15px;color:#334155;margin-bottom:18px}.um-h3{font-size:15px;font-weight:700;color:#1e293b;margin:22px 0 10px}.um-ul,.um-ol{padding-left:22px;margin-bottom:14px}.um-ul li,.um-ol li{margin-bottom:6px}.um-table{width:100%;border-collapse:collapse;margin:12px 0 18px;font-size:13px;border-radius:8px;overflow:hidden;border:1px solid #e2e8f0}.um-table th{background:#f1f5f9;color:#475569;font-weight:600;padding:10px 14px;text-align:left;border-bottom:1px solid #e2e8f0;font-size:12px;text-transform:uppercase;letter-spacing:.04em}.um-table td{padding:9px 14px;border-bottom:1px solid #f1f5f9;vertical-align:top}.um-table tr:last-child td{border-bottom:none}.um-table tr:nth-child(2n) td{background:#fafbff}.um-callout{display:flex;gap:10px;align-items:flex-start;background:#eff6ff;border-left:3px solid #4a4dc9;padding:12px 16px;border-radius:6px;font-size:13px;margin:12px 0;color:#1e40af}.um-callout--warn{background:#fffbeb;border-color:#f59e0b;color:#92400e}.um-badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:99px;font-size:12px;font-weight:600;white-space:nowrap}.um-badge--blue{background:#dbeafe;color:#1d4ed8}.um-badge--purple{background:#ede9fe;color:#7c3aed}.um-badge--green{background:#dcfce7;color:#15803d}.um-badge--orange{background:#fed7aa;color:#c2410c}.um-status{display:inline-flex;align-items:center;padding:2px 10px;border-radius:99px;font-size:12px;font-weight:600}.um-status--red{background:#fee2e2;color:#dc2626}.um-status--orange{background:#fed7aa;color:#ea580c}.um-status--green{background:#dcfce7;color:#16a34a}.um-panel-diagram{display:flex;gap:6px;align-items:stretch;margin:16px 0}.um-panel{flex:1;border:1.5px dashed #cbd5e1;border-radius:8px;padding:14px 10px;text-align:center}.um-panel--left{background:#eff6ff}.um-panel--mid{background:#f0fdf4;flex:1.5}.um-panel--right{background:#faf5ff}.um-panel-label{font-weight:700;font-size:13px;margin-bottom:3px;color:#1e293b}.um-panel-sub{font-size:11px;color:#64748b}.um-panel-pct{font-size:11px;color:#94a3b8;margin-top:4px}.um-panel-divider{display:flex;align-items:center;color:#94a3b8;font-size:18px;padding:0 2px}.um-tree{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:14px 18px;font-family:Courier New,monospace;font-size:13px;margin:12px 0;line-height:2}.um-tree-item{padding-left:0}.um-tree-item--l1{font-weight:700;color:#1e293b}.um-tree-item--l2{padding-left:20px;color:#334155}.um-tree-item--l3{padding-left:40px;color:#475569}.um-tree-item--l4{padding-left:60px;color:#64748b}.um-screen-mock{border:1px solid #e2e8f0;border-radius:10px;padding:18px 20px;background:#fff;box-shadow:0 2px 8px #0000000d;margin:14px 0}.um-screen-title{font-weight:700;color:#4a4dc9;font-size:14px;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid #f1f5f9}.um-screen-field{margin-bottom:12px}.um-screen-field>span{display:block;font-size:12px;color:#64748b;margin-bottom:4px}.um-input-mock{height:32px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px}.um-btn-mock{display:inline-block;background:#4a4dc9;color:#fff;padding:9px 22px;border-radius:7px;font-size:13px;font-weight:600;cursor:default;margin-top:6px}.um-btn-mock--sm{padding:5px 12px;font-size:12px}.um-btn-mock--disabled{background:#e2e8f0;color:#94a3b8}.um-chapter-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid #f1f5f9;font-size:13px;gap:10px}.um-chapter-row:last-child{border-bottom:none}.um-print-all{display:none}.um-screen-section{display:block}.um-print-section{margin-bottom:24px}.um-print-section h2{font-size:16px;font-weight:700;color:#4a4dc9;border-bottom:1px solid #e2e8f0;padding-bottom:6px;margin-bottom:12px}@media(max-width:700px){.um-body{flex-direction:column}.um-sidebar{width:100%;height:auto;position:static;flex-direction:row;flex-wrap:wrap;padding:10px}.um-content{padding:20px 16px}.um-panel-diagram{flex-direction:column}}.vq-page{min-height:100vh;background:#eef0f8;font-family:inherit;display:flex;flex-direction:column}.vq-hero{background:var(--gradient-primary, linear-gradient(135deg,#4A4DC9 0%,#533086 100%));padding:1.25rem 2rem 1.375rem;position:relative;overflow:hidden}.vq-hero-content{display:flex;align-items:center;gap:1.25rem;position:relative;z-index:1}.vq-hero-icon{width:52px;height:52px;border-radius:14px;background:#ffffff26;border:1.5px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.vq-hero-label{margin:0 0 .25rem;font-size:.72rem;font-weight:700;color:#ffffffa6;text-transform:uppercase;letter-spacing:.1em}.vq-hero-title{margin:0;font-size:1.625rem;font-weight:800;color:#fff;line-height:1.2}.vq-hero-decoration{position:absolute;top:-80px;right:-80px;width:300px;height:300px;border-radius:50%;background:#ffffff0f;pointer-events:none}.vq-hero-decoration:after{content:"";position:absolute;top:60px;left:60px;width:180px;height:180px;border-radius:50%;background:#ffffff0f}.vq-stats-row{display:flex;align-items:stretch;flex-wrap:wrap;background:#fff;border-bottom:1px solid rgba(74,77,201,.1);box-shadow:0 2px 8px #0000000d;padding:0 2rem;gap:0}.vq-stat-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;padding:1rem 1.5rem;border-right:1px solid #f0f0f0;cursor:default;transition:background .15s;min-width:80px}.vq-stat-card:hover{background:#fafbff}.vq-stat-num{font-size:1.625rem;font-weight:800;line-height:1;color:var(--color-primary, #4a4dc9)}.vq-stat-card--easy .vq-stat-num{color:#16a34a}.vq-stat-card--medium .vq-stat-num{color:#d97706}.vq-stat-card--hard .vq-stat-num{color:#dc2626}.vq-stat-label{font-size:.7rem;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:.2rem;white-space:nowrap}.vq-stat-divider{width:1px;background:#e5e7eb;margin:.75rem .5rem;flex-shrink:0}.vq-cog-grid{display:grid;grid-template-columns:repeat(9,max-content);align-items:center;flex:1;padding:.35rem .25rem;gap:0}.vq-stat-fmt{display:flex;align-items:center;gap:.45rem;padding:0 1rem;cursor:default;transition:background .15s}.vq-stat-fmt:hover{background:#fafbff}.vq-stat-fmt-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.vq-stat-fmt-short{font-size:.75rem;font-weight:700;color:#6b7280;letter-spacing:.02em}.vq-stat-fmt-count{font-size:.85rem;font-weight:800}.vq-body-wrapper{flex:1;display:flex;overflow:hidden;min-height:0}.vq-main{flex:1;padding:1.75rem 2rem 3rem;display:flex;flex-direction:column;gap:1.5rem;overflow-y:auto;min-width:0;transition:flex .3s ease}.vq-filters{display:flex;align-items:center;justify-content:space-between;gap:.5rem;flex-wrap:wrap;background:#fff;border-radius:14px;padding:.5rem;box-shadow:0 1px 4px #0000000d,0 4px 12px #0000000a}.vq-filters-left{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.vq-filters-right{display:flex;align-items:center;gap:.5rem;margin-left:auto;flex-shrink:0}.vq-feedback-toggle-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:9px;border:1.5px solid #e5e7eb;background:#fff;color:#6b7280;cursor:pointer;transition:all .18s;padding:0;flex-shrink:0}.vq-feedback-toggle-btn:hover{background:#eef0ff;border-color:#4a4dc9;color:#4a4dc9}.vq-feedback-toggle-btn--active{background:#4a4dc9;border-color:#4a4dc9;color:#fff;box-shadow:0 2px 10px #4a4dc959}.vq-feedback-toggle-btn--active:hover{background:#3d40b5;border-color:#3d40b5}.vq-filters-pagination{display:flex;align-items:center;gap:.25rem;margin-left:auto;flex-shrink:0}.vq-fpag-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;border:1.5px solid #e5e7eb;background:#fff;color:#4a4dc9;cursor:pointer;transition:all .15s;padding:0}.vq-fpag-btn:hover:not(:disabled){background:#eef0ff;border-color:#4a4dc9}.vq-fpag-btn:disabled{opacity:.35;cursor:not-allowed}.vq-fpag-info{display:flex;align-items:center;gap:.2rem;padding:0 .35rem;font-size:.78rem;font-weight:700;color:#374151}.vq-fpag-current{color:#4a4dc9;font-size:.85rem}.vq-fpag-sep{color:#d1d5db}.vq-fpag-total{color:#9ca3af}.vq-ftab{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1.125rem;font-size:.8125rem;font-weight:600;color:#6b7280;background:transparent;border:none;border-radius:10px;cursor:pointer;font-family:inherit;transition:all .15s}.vq-ftab:hover:not(.vq-ftab--active){background:#4a4dc912;color:var(--color-primary, #4a4dc9)}.vq-ftab--active{color:#fff;box-shadow:0 2px 10px #4a4dc94d}.vq-ftab-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;border-radius:6px;font-size:.69rem;font-weight:800;background:#0000001f;padding:0 4px}.vq-ftab--active .vq-ftab-count{background:#ffffff38}.vq-cards{display:flex;flex-direction:column;gap:1.25rem}.vq-empty-state{margin-top:2rem;padding:2rem 1.5rem;border-radius:.75rem;border:1px dashed #e5e7eb;background:#f9fafb;text-align:center;font-size:.88rem;font-weight:600;letter-spacing:.08em;color:#6b7280}.vq-pagination{margin-top:1.25rem;display:flex;align-items:center;justify-content:center;gap:.75rem}.vq-page-btn{min-width:90px;padding:.45rem .9rem;font-size:.82rem;font-weight:600;border-radius:999px;border:1px solid #d1d5db;background:#fff;color:#374151;cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s,color .15s,box-shadow .15s}.vq-page-btn:hover:not(:disabled){background:#f3f4ff;border-color:var(--color-primary, #4a4dc9);color:var(--color-primary, #4a4dc9);box-shadow:0 2px 8px #4a4dc92e}.vq-page-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.vq-page-info{font-size:.8rem;font-weight:600;color:#6b7280}.vq-card{display:flex;background:#fff;border-radius:16px;box-shadow:0 1px 4px #0000000d,0 4px 16px #0000000f;overflow:hidden;transition:box-shadow .2s,transform .15s}.vq-card:hover{box-shadow:0 8px 28px #4a4dc91f,0 2px 8px #0000000f;transform:translateY(-2px)}.vq-card-stripe{width:5px;background:var(--fmt-color, #4a4dc9);flex-shrink:0}.vq-card-body{flex:1;padding:1.5rem 1.625rem 1.375rem;min-width:0;display:flex;flex-direction:column}.vq-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.vq-card-top-left{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap}.vq-card-top-right{display:flex;align-items:center;gap:.4rem;flex-shrink:0;flex-wrap:wrap}.vq-qnum{padding:.25rem .65rem;font-size:.73rem;font-weight:900;color:#fff;background:var(--fmt-color, #4a4dc9);border-radius:7px;letter-spacing:.04em;flex-shrink:0}.vq-fmt-badge{padding:.25rem .75rem;border-radius:20px;font-size:.73rem;font-weight:700}.vq-cog-badge{padding:.25rem .7rem;border-radius:20px;font-size:.71rem;font-weight:600;color:#6b7280;background:#f3f4f6;border:1px solid #eaeaea}.vq-level-chip{display:inline-flex;align-items:center;gap:.3rem;padding:.25rem .7rem;border-radius:20px;font-size:.72rem;font-weight:700}.vq-level-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.vq-rep-chip{padding:.25rem .6rem;border-radius:20px;font-size:.7rem;font-weight:600;color:#b0b0b0;background:#f9f9f9;border:1px solid #efefef}.vq-feedback-status-chip{padding:.25rem .6rem;border-radius:20px;font-size:.7rem;font-weight:600;border:1px solid}.vq-feedback-status-chip--solved{color:#0369a1;background:#e0f2fe;border-color:#bae6fd}.vq-feedback-status-chip--given{color:#15803d;background:#dcfce7;border-color:#bbf7d0}.vq-feedback-status-chip--created{color:#b45309;background:#fef3c7;border-color:#fde68a}.vq-question-text{font-size:1rem;line-height:1.75;color:#1a1a2e;font-weight:500;margin:0 0 1.25rem;flex-grow:0}.vq-figure{margin:0 0 1.25rem;border-radius:12px;overflow:hidden;border:1px solid #eaeaea;background:#f9faff}.vq-img{display:block;max-width:100%;max-height:280px;margin:0 auto;object-fit:contain;padding:1.25rem}.vq-figcaption{font-size:.78rem;color:#6b7280;text-align:center;padding:.5rem 1rem .75rem;background:#f5f6ff;border-top:1px solid #eaeaea;font-style:italic;line-height:1.5;margin:0}.vq-match{display:flex;border:1.5px solid #eaeaea;border-radius:12px;overflow:hidden;margin-bottom:1.25rem}.vq-match-col{flex:1}.vq-match-head{padding:.65rem 1rem;font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:#9ca3af;background:#f9fafb;border-bottom:1.5px solid #eaeaea}.vq-match-col--a .vq-match-head{color:var(--fmt-color, #4a4dc9);background:var(--fmt-light, rgba(74,77,201,.06))}.vq-match-divider{width:1.5px;background:#eaeaea;flex-shrink:0}.vq-match-row{display:flex;align-items:center;gap:.75rem;padding:.7rem 1rem;font-size:.9rem;color:#374151;line-height:1.5;border-bottom:1px solid #f5f5f5}.vq-match-row:last-child{border-bottom:none}.vq-match-id{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:6px;font-size:.72rem;font-weight:800;background:#f3f4f6;color:#6b7280;flex-shrink:0}.vq-match-col--a .vq-match-id{color:var(--fmt-color);background:var(--fmt-light)}.vq-match-id--b{background:#f3f4f6;color:#6b7280}.vq-options{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem}.vq-opt{display:flex;align-items:center;gap:.875rem;padding:.875rem 1rem;border-radius:10px;border:1.5px solid #eaeaea;background:#fafbff;font-size:.925rem;color:#1a1a2e;line-height:1.5;cursor:default;transition:all .14s}.vq-opt:hover{border-color:#4a4dc94d;background:#f0f3ff}.vq-opt--correct{border-color:#86efac!important;background:linear-gradient(90deg,#f0fdf4,#fafff9)!important;color:#14532d!important}.vq-opt--wrong{border-color:#f0f0f0;background:#fafafa;color:silver}.vq-opt-letter{width:34px;height:34px;border-radius:9px;background:#fff;border:1.5px solid #ddd;display:flex;align-items:center;justify-content:center;font-size:.775rem;font-weight:800;color:#555;flex-shrink:0;transition:all .14s}.vq-opt--correct .vq-opt-letter{background:#16a34a;border-color:#16a34a;color:#fff}.vq-opt--wrong .vq-opt-letter{border-color:#e8e8e8;color:#ccc}.vq-opt-text{flex:1}.vq-opt-check{color:#16a34a;flex-shrink:0}.vq-owa{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border-radius:10px;font-size:.925rem;margin-bottom:1.125rem}.vq-owa--show{background:#f0fdf4;border:1.5px solid #86efac}.vq-owa--hide{background:#fafafa;border:1.5px dashed #ddd}.vq-owa-label{font-size:.68rem;font-weight:800;color:#16a34a;text-transform:uppercase;letter-spacing:.08em;flex-shrink:0}.vq-owa-value{font-weight:700;color:#14532d;font-size:.95rem}.vq-owa-hidden{font-size:.82rem;color:#9ca3af;font-style:italic}.vq-desc-chips{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}.vq-desc-chip{padding:.3rem .8rem;border-radius:20px;font-size:.75rem;font-weight:700;background:#fffbeb;color:#b45309;border:1px solid #fde68a}.vq-desc-chip--sub{background:#f3f4f6;color:#6b7280;border-color:#e5e7eb}.vq-answer-reveal{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border-radius:10px;border:1.5px solid;margin-bottom:.875rem;flex-wrap:wrap}.vq-answer-label{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;flex-shrink:0}.vq-answer-opt{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;font-size:.78rem;font-weight:900;color:#fff;flex-shrink:0}.vq-answer-text{font-size:.9rem;font-weight:600;color:#1a1a2e;flex:1}.vq-expl-body{display:flex;gap:.75rem;margin-bottom:.875rem;padding:.875rem 1rem;background:#4a4dc90a;border-radius:10px;border:1px solid rgba(74,77,201,.1)}.vq-expl-icon{width:28px;height:28px;border-radius:8px;background:#4a4dc91a;color:var(--color-primary, #4a4dc9);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:.1rem}.vq-expl-text{margin:0;font-size:.9rem;line-height:1.7;color:#4b5563;flex:1}.vq-card-footer{display:flex;align-items:center;justify-content:space-between;gap:.75rem;border-top:1px solid #f0f0f0;padding-top:1rem;margin-top:auto;flex-wrap:wrap}.vq-footer-left{display:flex;align-items:center;gap:.625rem;flex-wrap:wrap}.vq-feedback-btns{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.vq-like-btn,.vq-dislike-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.42rem .875rem;font-size:.8rem;font-weight:600;border-radius:8px;cursor:pointer;font-family:inherit;border:1.5px solid;transition:all .15s}.vq-like-btn{color:#16a34a;background:transparent;border-color:#d1fae5}.vq-like-btn:hover{background:#f0fdf4;border-color:#86efac}.vq-like-btn--on{background:#16a34a;border-color:#16a34a;color:#fff}.vq-like-btn--on:hover{background:#15803d;border-color:#15803d}.vq-like-btn--loading{opacity:.7;cursor:wait}.vq-like-btn:disabled{cursor:not-allowed}.vq-like-error{font-size:.72rem;color:#dc2626;font-weight:600;align-self:center}.vq-dislike-btn{color:#dc2626;background:transparent;border-color:#fee2e2}.vq-dislike-btn:hover{background:#fef2f2;border-color:#fca5a5}.vq-dislike-btn--on{background:#dc2626;border-color:#dc2626;color:#fff}.vq-dislike-btn--on:hover{background:#b91c1c;border-color:#b91c1c}.vq-dislike-panel{margin-top:.875rem;background:#fff8f8;border:1.5px solid #fecaca;border-radius:12px;padding:1rem 1.125rem;display:flex;flex-direction:column;gap:.75rem;animation:vq-slide-in .15s ease}@keyframes vq-slide-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.vq-dislike-panel-header{display:flex;align-items:center;justify-content:space-between}.vq-dislike-panel-title{font-size:.8125rem;font-weight:700;color:#dc2626}.vq-dislike-close{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:6px;border:none;background:transparent;color:#9ca3af;cursor:pointer;transition:background .15s,color .15s}.vq-dislike-close:hover{background:#fee2e2;color:#dc2626}.vq-dislike-textarea{width:100%;padding:.7rem .875rem;font-size:.875rem;font-family:inherit;color:#1a1a2e;background:#fff;border:1.5px solid #fca5a5;border-radius:8px;resize:vertical;outline:none;line-height:1.6;transition:border-color .15s;box-sizing:border-box}.vq-dislike-textarea:focus{border-color:#dc2626}.vq-dislike-textarea::placeholder{color:#9ca3af}.vq-dislike-actions{display:flex;align-items:center;justify-content:flex-end;gap:.5rem}.vq-dislike-cancel{padding:.42rem 1rem;font-size:.8125rem;font-weight:600;color:#6b7280;background:transparent;border:1.5px solid #e5e7eb;border-radius:8px;cursor:pointer;font-family:inherit;transition:all .15s}.vq-dislike-cancel:hover{background:#f3f4f6;border-color:#d1d5db}.vq-dislike-save{padding:.42rem 1.25rem;font-size:.8125rem;font-weight:700;color:#fff;background:#dc2626;border:1.5px solid #dc2626;border-radius:8px;cursor:pointer;font-family:inherit;transition:all .15s}.vq-dislike-save:hover:not(:disabled){background:#b91c1c;border-color:#b91c1c}.vq-dislike-save:disabled{opacity:.45;cursor:not-allowed}.vq-show-answer-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.48rem 1rem;font-size:.8125rem;font-weight:600;color:var(--color-primary, #4a4dc9);background:#4a4dc912;border:1.5px solid rgba(74,77,201,.2);border-radius:9px;cursor:pointer;font-family:inherit;transition:all .14s}.vq-show-answer-btn:hover{background:#4a4dc924;border-color:var(--color-primary)}.vq-show-answer-btn--on{font-weight:700}.vq-expl-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.48rem 1rem;font-size:.8125rem;font-weight:600;color:#6b7280;background:transparent;border:1.5px solid #e8e8e8;border-radius:9px;cursor:pointer;font-family:inherit;transition:all .14s}.vq-expl-btn:hover{background:#4a4dc90d;border-color:#4a4dc933;color:var(--color-primary, #4a4dc9)}.vq-feedback-panel{width:33.333%;min-width:320px;max-width:480px;background:#fff;border-left:1px solid #e5e7eb;display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;animation:vq-panel-slide-in .25s cubic-bezier(.22,1,.36,1)}@keyframes vq-panel-slide-in{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}.vq-fdbk-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #f0f0f0;background:#fafbff;position:sticky;top:0;z-index:2}.vq-fdbk-title-row{display:flex;align-items:center;gap:.5rem}.vq-fdbk-icon{color:#4a4dc9}.vq-fdbk-title{font-size:.9rem;font-weight:700;color:#1a1a2e;letter-spacing:.01em}.vq-fdbk-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;border:none;background:transparent;color:#9ca3af;cursor:pointer;transition:all .15s;padding:0}.vq-fdbk-close:hover{background:#f3f4f6;color:#374151}.vq-fdbk-body{flex:1;padding:1.5rem 1.25rem;display:flex;flex-direction:column;gap:1.25rem}.vq-fdbk-hint{font-size:.825rem;color:#6b7280;line-height:1.6;margin:0;padding:.875rem 1rem;background:#4a4dc90d;border-radius:10px;border:1px solid rgba(74,77,201,.1)}.vq-fdbk-empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.625rem;padding:3rem 1.5rem;text-align:center}.vq-fdbk-empty-icon{color:#d1d5db}.vq-fdbk-empty-text{font-size:.925rem;font-weight:700;color:#9ca3af;margin:0}.vq-fdbk-empty-sub{font-size:.8rem;color:#c4c9d4;margin:0;line-height:1.5}.vq-fdbk-stats{display:flex;gap:.75rem;margin-bottom:1rem}.vq-fdbk-stat-card{flex:1;min-width:0;padding:.6rem .8rem;border-radius:10px;background:#f9fafb;border:1px solid #e5e7eb;display:flex;flex-direction:column;gap:.2rem}.vq-fdbk-stat-card--like{background:#ecfdf3;border-color:#bbf7d0}.vq-fdbk-stat-card--dislike{background:#fef2f2;border-color:#fecaca}.vq-fdbk-stat-card--pending{background:#fffbeb;border-color:#fde68a}.vq-fdbk-stat-card--done{background:#eff6ff;border-color:#bfdbfe}.vq-fdbk-stat-label{font-size:.75rem;font-weight:600;color:#6b7280}.vq-fdbk-stat-value{font-size:1.1rem;font-weight:800;color:#111827}.vq-fdbk-error{font-size:.82rem;color:#dc2626;font-weight:600;margin:0 0 .75rem}.vq-fdbk-list{display:flex;flex-direction:column;gap:.75rem}.vq-fdbk-card{border-radius:10px;border:1px solid #e5e7eb;padding:.85rem .9rem;background:#fff}.vq-fdbk-card-top{display:flex;align-items:center;justify-content:space-between;gap:.4rem;margin-bottom:.4rem;flex-wrap:wrap}.vq-fdbk-card-top-left{display:flex;align-items:center;gap:.35rem}.vq-fdbk-filters{display:flex;flex-wrap:wrap;gap:5px}.vq-fdbk-ftab{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:999px;border:1.5px solid #e5e7eb;background:#fff;font-size:.68rem;font-weight:600;color:#6b7280;cursor:pointer;transition:all .15s ease;white-space:nowrap}.vq-fdbk-ftab:hover{border-color:#a5b4fc;color:#4f46e5}.vq-fdbk-ftab--active{color:#fff!important;border-color:transparent!important}.vq-fdbk-ftab-count{font-size:.62rem;font-weight:700;opacity:.85}.vq-fdbk-checkbox-section{border:1px solid #e5e7eb;border-radius:10px;padding:.7rem;background:#f9fafb;max-height:200px;overflow-y:auto}.vq-fdbk-checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(42px,1fr));gap:4px}.vq-fdbk-checkbox-item{display:flex;align-items:center;gap:2px;padding:3px 4px;border-radius:6px;border:1px solid #e5e7eb;background:#fff;cursor:default;font-size:.65rem;font-weight:600;color:#9ca3af;transition:all .15s ease}.vq-fdbk-checkbox-item--checked{background:#eef2ff;border-color:#a5b4fc;color:#4f46e5}.vq-fdbk-grid-checkbox{width:13px;height:13px;accent-color:#4f46e5;cursor:default;margin:0;flex-shrink:0}.vq-fdbk-checkbox-label{line-height:1}.vq-fdbk-qnum{font-size:.7rem;font-weight:800;padding:.18rem .55rem;border-radius:999px;background:#eef2ff;color:#4f46e5}.vq-fdbk-chip{font-size:.72rem;font-weight:600;padding:.18rem .5rem;border-radius:999px;border:1px solid #e5e7eb;background:#f9fafb}.vq-fdbk-question{font-size:.9rem;color:#111827;margin:0 0 .35rem}.vq-fdbk-answer{font-size:.82rem;color:#374151;margin:0 0 .5rem}.vq-fdbk-answer-label{font-weight:700;color:#4b5563}.vq-fdbk-status-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.vq-fdbk-status-pill{font-size:.72rem;font-weight:600;padding:.18rem .55rem;border-radius:999px}.vq-fdbk-status-pill--pending{background:#fef3c7;color:#b45309}.vq-fdbk-status-pill--done{background:#dcfce7;color:#15803d}.vq-fdbk-pill{font-size:.75rem;font-weight:700;padding:.18rem .6rem;border-radius:999px}.vq-fdbk-pill--like{background:#dcfce7;color:#166534}.vq-fdbk-pill--dislike{background:#fee2e2;color:#b91c1c}.vq-fdbk-pill--neutral{background:#e5e7eb;color:#374151}.vq-fdbk-reason{font-size:.8rem;color:#b91c1c}.vq-fdbk-pagination{margin-top:1rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.vq-fdbk-page-btn{padding:.35rem .9rem;font-size:.78rem;font-weight:600;border-radius:999px;border:1px solid #d1d5db;background:#fff;color:#374151;cursor:pointer;transition:background .15s,border-color .15s}.vq-fdbk-page-btn:hover:not(:disabled){background:#eef2ff;border-color:#4f46e5}.vq-fdbk-page-btn:disabled{opacity:.5;cursor:not-allowed}.vq-fdbk-page-info{font-size:.78rem;font-weight:600;color:#6b7280}@media(max-width:640px){.vq-hero{padding:1.5rem 1rem 1.375rem}.vq-main{padding:1.25rem 1rem 2.5rem}.vq-card-body{padding:1.125rem}.vq-stats-row{padding:0 1rem}.vq-hero-title{font-size:1.25rem}}.slow-net-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:11000;animation:slowNetFadeIn .25s ease-out}@keyframes slowNetFadeIn{0%{opacity:0}to{opacity:1}}@keyframes slowNetSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.slow-net-popup{position:relative;background:#fff;border-radius:16px;padding:32px 28px 24px;max-width:360px;width:90%;text-align:center;box-shadow:0 20px 60px #00000040;animation:slowNetSlideUp .3s ease-out}.slow-net-close{position:absolute;top:12px;right:12px;background:none;border:none;cursor:pointer;color:#94a3b8;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:color .2s,background .2s}.slow-net-close:hover{color:#475569;background:#f1f5f9}.slow-net-icon{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:50%;background:#fef2f2;color:#ef4444;margin:0 auto 16px}.slow-net-title{font-size:1.125rem;font-weight:600;color:#1e293b;margin:0 0 8px}.slow-net-msg{font-size:.875rem;color:#64748b;line-height:1.5;margin:0 0 20px}.slow-net-btn{display:inline-block;padding:10px 28px;border:none;border-radius:8px;background:#3b82f6;color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s}.slow-net-btn:hover{background:#2563eb}#root{min-height:100vh}
