#custom-titlebar{-webkit-app-region:drag;height:32px;display:flex;align-items:center;position:fixed;top:0;left:0;right:0;z-index:100;background-color:var(--bg-primary);border-bottom:1px solid var(--border-color);transition:background-color .2s}#custom-titlebar.mac-style{padding-left:12px}#custom-titlebar.windows-style{padding-left:12px;justify-content:flex-end;flex-direction:row-reverse}.window-controls{-webkit-app-region:no-drag;display:flex;gap:8px}.traffic-light{width:12px;height:12px;border-radius:50%;cursor:pointer;transition:opacity .2s}.traffic-light:hover{opacity:.8}.traffic-light.close{background-color:#ff5f56;border:1px solid #e0443e}.traffic-light.minimize{background-color:#ffbd2e;border:1px solid #dea123}.traffic-light.maximize{background-color:#27c93f;border:1px solid #1aab29}.window-btn{width:46px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s;border:none;background:none;color:var(--text-secondary);font-size:12px;font-weight:600}.window-btn:hover{background-color:var(--bg-tertiary)}.window-btn.close:hover{background-color:#e81123;color:#fff}.window-btn.minimize:hover,.window-btn.maximize:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}#sidebar{width:72px;min-width:72px;background-color:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;align-items:center;padding:1rem 0;gap:.5rem;transition:all .3s;flex-shrink:0}.nav-button{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:12px;color:var(--text-secondary);transition:all .2s;position:relative}.nav-button:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.nav-button.active{background-color:var(--accent-light);color:var(--accent-primary)}.nav-button.active:before{content:"";position:absolute;left:-12px;width:3px;height:24px;background-color:var(--accent-primary);border-radius:0 3px 3px 0}.card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;transition:all .2s}.card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md)}.card-interactive{cursor:pointer}.card-interactive:hover{transform:translateY(-2px)}.subject-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;padding:2rem;transition:all .3s;cursor:pointer;position:relative;overflow:hidden}.subject-card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.subject-card-icon{width:64px;height:64px;border-radius:16px;background-color:var(--accent-light);color:var(--accent-primary);display:flex;align-items:center;justify-content:center;margin-bottom:1rem}.subject-card-title{font-size:1.5rem;font-weight:600;margin-bottom:.5rem;color:var(--text-primary)}.subject-card-meta{color:var(--text-secondary);font-size:.875rem}.progress-bar{width:100%;height:8px;background-color:var(--bg-tertiary);border-radius:4px;overflow:hidden;margin:.5rem 0}.progress-fill{height:100%;background-color:var(--accent-primary);border-radius:4px;transition:width .5s ease-out}.badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;background-color:var(--accent-light);color:var(--accent-primary)}.badge-success{background-color:var(--success-light);color:var(--success)}.modal-overlay{position:fixed;inset:0;background-color:#00000080;backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s}.modal-content{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;padding:2rem;max-width:500px;width:90%;box-shadow:var(--shadow-lg);animation:slideIn .3s}.modal-header{margin-bottom:1.5rem}.modal-title{font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.btn{padding:.75rem 1.5rem;border-radius:8px;font-weight:500;font-size:.875rem;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem}.btn-primary{background-color:var(--accent-primary);color:#fff}.btn-primary:hover{background-color:var(--accent-hover)}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover{background-color:var(--border-hover)}.btn-ghost{background-color:transparent;color:var(--text-secondary)}.btn-ghost:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}input[type=text],input[type=password],input[type=email],input[type=date],input[type=time],textarea,select{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;font-family:inherit;transition:all .2s;cursor:text}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-light)}input:disabled,textarea:disabled,select:disabled{opacity:.5;cursor:not-allowed;background-color:var(--bg-tertiary)}textarea{resize:vertical;min-height:100px}.spinner{width:20px;height:20px;border:2px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}.checkbox{width:20px;height:20px;border:2px solid var(--border-color);border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.checkbox.checked{background-color:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.planner-banner{background:linear-gradient(135deg,var(--accent-light) 0%,var(--bg-secondary) 100%);border:1px solid var(--border-color);border-radius:12px;padding:1rem 1.5rem;margin:0 auto 1.5rem;animation:slideDown .3s ease-out;box-sizing:border-box;max-width:900px}.planner-banner-content{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.icon-button{padding:.5rem;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:6px;transition:all .2s;display:inline-flex;align-items:center;justify-content:center}.icon-button:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}#questionnaire-overlay .modal-content{animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.planner-tab{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:8px;border:1px solid transparent;background-color:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:all .2s;white-space:nowrap;font-size:.875rem}.planner-tab:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.planner-tab.active{background-color:var(--accent-light);color:var(--accent-primary);border-color:var(--accent-primary);font-weight:500}.planner-tab i{width:16px;height:16px;flex-shrink:0}.planner-day-card{padding:1rem;border-radius:12px;border:2px solid var(--border-color);background-color:var(--bg-secondary);cursor:pointer;transition:all .2s;text-align:center;min-height:120px;display:flex;flex-direction:column;justify-content:center}.planner-day-card:hover{border-color:var(--accent-primary);background-color:var(--bg-tertiary);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.planner-day-card.selected{border-color:var(--accent-primary);background-color:var(--accent-light);box-shadow:0 0 0 3px var(--accent-light)}.planner-day-card.today{border-color:var(--accent-primary);border-width:3px}.planner-day-card.today:before{content:"";display:block;width:6px;height:6px;border-radius:50%;background-color:var(--accent-primary);margin:0 auto .5rem}.success-light{background-color:#dcfce7}@media(max-width:768px){#sidebar{position:fixed;left:0;top:32px;bottom:0;transform:translate(-100%);z-index:50}#sidebar.open{transform:translate(0)}.planner-banner-content{flex-direction:column;align-items:stretch}.planner-banner-content>div:last-child{justify-content:stretch}.planner-banner-content button{flex:1}}#spotlight-overlay{position:fixed;inset:0;background-color:#0009;backdrop-filter:blur(8px);z-index:9999;display:flex;align-items:flex-start;justify-content:center;padding-top:15vh;opacity:0;pointer-events:none;transition:opacity .2s ease}#spotlight-overlay.active{opacity:1;pointer-events:auto}.spotlight-container{width:90%;max-width:640px;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 20px 60px #0006;overflow:hidden;transform:translateY(-20px) scale(.95);transition:all .2s ease}#spotlight-overlay.active .spotlight-container{transform:translateY(0) scale(1)}.spotlight-search{display:flex;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color);gap:1rem}.spotlight-search-icon{color:var(--text-tertiary);flex-shrink:0}.spotlight-input{flex:1;background:none;border:none;outline:none;font-size:1.125rem;color:var(--text-primary);font-weight:500}.spotlight-input::placeholder{color:var(--text-tertiary)}.spotlight-results{max-height:400px;overflow-y:auto;padding:.5rem}.spotlight-results::-webkit-scrollbar{width:6px}.spotlight-results::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.spotlight-result-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:8px;cursor:pointer;transition:all .15s ease;margin-bottom:.25rem}.spotlight-result-item:hover,.spotlight-result-item.selected{background-color:var(--accent-light)}.spotlight-result-item.selected{border-left:3px solid var(--accent-primary);padding-left:calc(1rem - 3px)}.spotlight-result-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;background-color:var(--accent-light);color:var(--accent-primary);flex-shrink:0}.spotlight-result-content{flex:1;min-width:0}.spotlight-result-title{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin-bottom:.125rem;display:flex;align-items:center;gap:.5rem}.spotlight-result-code{font-family:Courier New,monospace;font-weight:700;color:var(--accent-primary)}.spotlight-result-meta{font-size:.75rem;color:var(--text-secondary);display:flex;align-items:center;gap:.375rem}.spotlight-result-separator{color:var(--text-tertiary)}.spotlight-highlight{background-color:var(--accent-light);color:var(--accent-primary);font-weight:600;padding:0 2px;border-radius:2px}.spotlight-empty{padding:3rem 2rem;text-align:center;color:var(--text-secondary)}.spotlight-empty-icon{width:64px;height:64px;margin:0 auto 1rem;color:var(--text-tertiary)}.spotlight-empty-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.spotlight-empty-text{font-size:.875rem}.spotlight-footer{padding:.75rem 1.5rem;border-top:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;font-size:.75rem;color:var(--text-tertiary)}.spotlight-footer-hint{display:flex;align-items:center;gap:1rem}.spotlight-kbd{display:inline-block;padding:.125rem .375rem;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;font-family:Courier New,monospace;font-size:.6875rem;font-weight:600;color:var(--text-secondary)}.spotlight-loading{padding:2rem;text-align:center}.spotlight-spinner{width:24px;height:24px;border:2px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}@media(max-width:640px){#spotlight-overlay{padding-top:10vh}.spotlight-container{width:95%;max-width:none}.spotlight-results{max-height:300px}.spotlight-footer-hint{display:none}}@keyframes spotlightFadeIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes spotlightFadeOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-20px) scale(.95)}}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 0 0 0 var(--accent-primary)}50%{transform:scale(1.02);box-shadow:0 0 0 10px #ff6b2b00}}[data-topic-code]{scroll-margin-top:100px}[data-topic-code].highlight{animation:pulse .5s ease}.questionnaire-option{background:var(--bg-tertiary);border:2px solid var(--border-color);transition:all .3s cubic-bezier(.4,0,.2,1)}.questionnaire-option:hover{border-color:var(--border-hover);transform:translateY(-1px)}.questionnaire-option.selected{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-color:#10b981;box-shadow:0 0 0 3px #10b98133}.questionnaire-option .icon-container{background:var(--bg-tertiary);transition:background .3s ease}.questionnaire-option.selected .icon-container{background:#10b9811f}.questionnaire-option i{color:var(--accent-primary);transition:color .3s ease}.questionnaire-option.selected i{color:#10b981}.questionnaire-option .option-label{color:var(--text-primary);transition:color .3s ease}.questionnaire-option.selected .option-label{color:#065f46}.questionnaire-option .option-description{color:var(--text-secondary);transition:color .3s ease}.questionnaire-option.selected .option-description{color:#047857}.radio-indicator{border:2px solid var(--border-color);background:transparent;transition:all .3s ease}.questionnaire-option.selected .radio-indicator{border-color:#10b981;background:#10b981}.questionnaire-option .check-icon{opacity:0;transform:scale(.5);transition:all .3s ease}.questionnaire-option.selected .check-icon{opacity:1;transform:scale(1)}:root{--ai-sidebar-width: 380px}.ai-sidebar{position:fixed;top:0;right:0;height:100%;width:var(--ai-sidebar-width);background-color:var(--sidebar-bg);box-shadow:-4px 0 20px #00000026;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;z-index:999;border-left:1px solid var(--border-color)}.ai-sidebar.collapsed{transform:translate(100%)}.ai-sidebar-header{padding:20px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;background:var(--sidebar-bg)}.ai-header-left{display:flex;align-items:center;gap:12px}.ai-status-dot{width:8px;height:8px;background-color:var(--muted-text);border-radius:50%;transition:background-color .3s}.ai-status-dot.active{background-color:var(--accent-primary);box-shadow:0 0 5px var(--accent-primary)}.ai-sidebar-title{margin:0;font-size:1rem;font-weight:600;color:var(--sidebar-text)}.ai-sidebar-subtitle{margin:0;font-size:.75rem;color:var(--muted-text)}.ai-clear-btn{background:transparent;border:none;color:var(--muted-text);cursor:pointer;font-size:.8rem;padding:6px 10px;border-radius:6px;transition:all .2s;font-family:inherit}.ai-clear-btn:hover{background:var(--card-bg);color:var(--text-primary)}.ai-chatbox{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px;scroll-behavior:smooth}.ai-chatbox::-webkit-scrollbar{width:6px}.ai-chatbox::-webkit-scrollbar-track{background:transparent}.ai-chatbox::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.ai-chatbox::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}.ai-message{max-width:85%;padding:12px 16px;border-radius:12px;font-size:.95rem;line-height:1.5;position:relative;word-wrap:break-word;animation:ai-fadeIn .3s ease}@keyframes ai-fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.ai-message.user{background-color:var(--accent-primary);color:#fff;align-self:flex-end;border-bottom-right-radius:2px}.ai-message.bot{background-color:#2a2a2a;color:#e8e8e8;align-self:flex-start;border-bottom-left-radius:2px;padding-right:28px;border:1px solid rgba(255,255,255,.1)}.ai-message-img{max-width:100%;border-radius:8px;margin-bottom:8px;display:block}.ai-file-attachment{display:flex;align-items:center;gap:8px;background:#0000001a;padding:8px 12px;border-radius:6px;margin-bottom:8px;font-size:.85rem}.ai-file-icon{width:20px;height:20px;flex-shrink:0}.ai-message.bot pre{background:#1e1e1e;padding:10px;border-radius:6px;overflow-x:auto;margin:10px 0;border:1px solid rgba(255,255,255,.1)}.ai-message.bot code{font-family:Consolas,Monaco,monospace;font-size:.9em;background:#1e1e1e;padding:2px 4px;border-radius:3px}.ai-message.bot p{margin:0 0 8px}.ai-message.bot p:last-child{margin:0}.ai-message.bot ul,.ai-message.bot ol{margin:8px 0;padding-left:20px}.ai-message.bot h1,.ai-message.bot h2,.ai-message.bot h3{font-weight:600;margin:12px 0 6px;line-height:1.3}.ai-message.bot h1{font-size:1.25em}.ai-message.bot h2{font-size:1.15em}.ai-message.bot h3{font-size:1.05em}.ai-message.bot strong{font-weight:600}.ai-sources{margin-top:12px;padding-top:8px;border-top:1px solid var(--border-color);font-size:.8rem}.ai-sources-title{color:var(--muted-text);font-size:.75rem;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.ai-source-chip{display:inline-flex;align-items:center;background:var(--main-bg);color:var(--accent-primary);padding:4px 8px;border-radius:4px;margin-right:6px;margin-bottom:6px;text-decoration:none;transition:background .2s;font-size:.75rem}.ai-source-chip:hover{background:var(--border-hover)}.ai-message-tools{position:absolute;top:6px;right:6px;opacity:0;transition:opacity .2s;display:flex;gap:4px;background:var(--sidebar-bg);backdrop-filter:blur(4px);border-radius:6px;padding:3px;border:1px solid var(--border-color)}.ai-message:hover .ai-message-tools{opacity:1}.ai-action-btn{background:transparent;border:none;color:var(--muted-text);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.ai-action-btn:hover{background:var(--card-bg);color:var(--text-primary)}.ai-input-area{padding:16px;background-color:var(--sidebar-bg);border-top:1px solid var(--border-color)}.ai-file-preview{display:flex;gap:8px;margin-bottom:12px;overflow-x:auto;padding:2px}.ai-preview-item{position:relative;width:56px;height:56px;border-radius:10px;border:2px solid var(--border-color);background-size:cover;background-position:center;background-color:var(--card-bg);flex-shrink:0;transition:all .2s}.ai-preview-item:hover{border-color:var(--accent-primary);transform:scale(1.05)}.ai-preview-remove{position:absolute;top:-8px;right:-8px;width:20px;height:20px;background:var(--accent-primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;cursor:pointer;border:2px solid var(--sidebar-bg);transition:all .2s}.ai-preview-remove:hover{background:var(--accent-hover);transform:scale(1.1)}.ai-input-container{display:flex;align-items:center;background:#2a2a2a;border-radius:14px;padding:8px 12px;border:1.5px solid rgba(255,255,255,.1);transition:all .3s ease;gap:6px;box-shadow:0 2px 8px #0003}.ai-input-container:focus-within{border-color:var(--accent-primary);box-shadow:0 0 0 3px #5865f233,0 4px 12px #0000004d}.ai-input-container textarea{flex:1;background:transparent;border:none;color:#e8e8e8;padding:6px 8px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.9rem;font-weight:400;resize:none;height:38px;min-height:38px;max-height:120px;outline:none;line-height:1.5}.ai-input-container textarea::placeholder{color:#fff6;opacity:1}.ai-icon-btn{background:#ffffff0d;color:#fff9;border:none;width:36px;height:36px;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);flex-shrink:0;position:relative}.ai-icon-btn:hover{background:#ffffff1a;color:#ffffffe6;transform:translateY(-1px)}.ai-icon-btn:active{transform:translateY(0)}.ai-icon-btn.active{background:var(--accent-light);color:var(--accent-primary)}.ai-icon-btn.active:after{content:"";position:absolute;top:4px;right:4px;width:6px;height:6px;background:var(--accent-primary);border-radius:50%;box-shadow:0 0 4px var(--accent-primary)}.ai-send-btn{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-hover) 100%);color:#fff;box-shadow:0 2px 8px #5865f24d;position:relative;z-index:10;flex-shrink:0}.ai-send-btn:hover{box-shadow:0 4px 12px #5865f266;transform:translateY(-2px)}.ai-send-btn:disabled{background:var(--border-color);color:var(--muted-text);cursor:not-allowed;opacity:.5;box-shadow:none;transform:none}.ai-cursor{display:inline-block;width:6px;height:16px;background-color:var(--accent-primary);animation:ai-blink 1s step-end infinite;vertical-align:middle;margin-left:4px}@keyframes ai-blink{50%{opacity:0}}.ai-toggle-btn{position:fixed;top:50%;right:20px;transform:translateY(-50%);background-color:var(--sidebar-bg);color:var(--sidebar-text);border:1px solid var(--border-color);width:44px;height:44px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-md);z-index:998}.ai-sidebar:not(.collapsed)+.ai-toggle-btn{right:calc(var(--ai-sidebar-width) + 20px)}.ai-toggle-btn:hover{background-color:var(--card-bg);box-shadow:var(--shadow-lg)}.ai-typing-indicator{padding:12px 16px!important}.ai-typing-dots{display:flex;gap:4px;align-items:center}.ai-typing-dots span{width:8px;height:8px;background:#ffffff80;border-radius:50%;animation:ai-typing-pulse 1.4s infinite}.ai-typing-dots span:nth-child(2){animation-delay:.2s}.ai-typing-dots span:nth-child(3){animation-delay:.4s}@keyframes ai-typing-pulse{0%,60%,to{opacity:.4;transform:scale(1)}30%{opacity:1;transform:scale(1.2)}}.ai-search-indicator{padding:12px 16px}.ai-search-status{display:flex;align-items:center;gap:10px;color:var(--text-secondary);font-size:14px}.ai-search-spinner{animation:ai-search-spin 1.5s linear infinite;color:var(--accent-primary)}@keyframes ai-search-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ai-typing-container{display:flex;align-items:center;gap:12px}.ai-stop-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;padding:6px 10px;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;gap:4px;font-size:12px;transition:all .2s ease}.ai-stop-btn:hover{background:var(--error);color:#fff;border-color:var(--error)}.ai-message-tools.user-tools{opacity:0;transition:opacity .2s ease}.ai-message.user:hover .ai-message-tools.user-tools{opacity:1}.ai-send-btn.cancel-mode{pointer-events:auto!important;cursor:pointer!important;opacity:1!important}.ai-send-btn.cancel-mode svg{fill:var(--error);stroke:none}.ai-send-btn.cancel-mode:hover{background:var(--bg-tertiary)}.ai-send-btn.editing{background:var(--success-light)!important;border-color:var(--success)!important}@media(max-width:768px){:root{--ai-sidebar-width: 100%}.ai-toggle-btn{bottom:20px;top:auto}}:root{--notes-nav-width: 320px;--notes-transition: .25s cubic-bezier(.4, 0, .2, 1)}.notes-container{display:flex;height:100%;overflow:hidden;background:var(--bg-primary)}.notes-nav{width:var(--notes-nav-width);min-width:var(--notes-nav-width);background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.notes-nav-header{padding:20px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:12px}.notes-back-btn{display:flex;align-items:center;gap:8px;padding:8px 12px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:8px;transition:all var(--notes-transition);font-size:14px;font-weight:500}.notes-back-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.notes-nav-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.notes-nav-content{flex:1;overflow-y:auto;padding:12px}.notes-section{margin-bottom:8px;border-radius:12px;overflow:hidden;background:var(--card-bg);border:1px solid var(--border-color);transition:all var(--notes-transition)}.notes-section:hover{border-color:var(--accent-primary)}.notes-section-header{display:flex;align-items:center;padding:14px 16px;cursor:pointer;user-select:none;transition:all var(--notes-transition)}.notes-section-header:hover{background:var(--bg-tertiary)}.notes-progress-ring{width:28px;height:28px;margin-right:12px;position:relative;flex-shrink:0}.notes-progress-ring svg{transform:rotate(-90deg);width:100%;height:100%}.notes-progress-ring-bg{fill:none;stroke:var(--border-color);stroke-width:3}.notes-progress-ring-fill{fill:none;stroke:var(--accent-primary);stroke-width:3;stroke-linecap:round;transition:stroke-dashoffset .5s ease}.notes-section-info{flex:1;min-width:0}.notes-section-title{font-size:14px;font-weight:600;color:var(--text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notes-section-meta{font-size:12px;color:var(--text-tertiary);margin-top:2px}.notes-section-chevron{width:20px;height:20px;color:var(--text-tertiary);transition:transform var(--notes-transition);flex-shrink:0}.notes-section.expanded .notes-section-chevron{transform:rotate(180deg)}.notes-topics-list{max-height:0;overflow:hidden;transition:max-height .3s ease;background:var(--bg-secondary)}.notes-section.expanded .notes-topics-list{max-height:500px}.notes-topic-item{display:flex;align-items:center;padding:10px 16px 10px 44px;cursor:pointer;transition:all var(--notes-transition);position:relative}.notes-topic-item:before{content:"";position:absolute;left:24px;top:0;bottom:0;width:1px;background:var(--border-color)}.notes-topic-item:last-child:before{bottom:50%}.notes-topic-item:hover{background:var(--bg-tertiary)}.notes-topic-item.active{background:#5865f233}.notes-topic-check{width:20px;height:20px;border-radius:50%;border:2px solid var(--border-color);margin-right:12px;display:flex;align-items:center;justify-content:center;transition:all var(--notes-transition);flex-shrink:0;cursor:pointer;background:transparent}.notes-topic-check:hover{border-color:var(--accent-primary);transform:scale(1.1)}.notes-topic-check.completed{background:var(--success);border-color:var(--success)}.notes-topic-check.completed svg{color:#fff;width:12px;height:12px}.notes-topic-check svg{opacity:0;transition:opacity var(--notes-transition)}.notes-topic-check.completed svg{opacity:1}.notes-topic-name{font-size:13px;color:var(--text-secondary);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notes-topic-item.active .notes-topic-name{color:var(--accent-primary);font-weight:500}.notes-content-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-primary)}.notes-content-scroll{flex:1;overflow-y:auto;padding:32px 48px}.notes-card{background:var(--card-bg);border-radius:16px;border:1px solid var(--border-color);overflow:hidden;animation:notesCardFadeIn .4s ease}@keyframes notesCardFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.notes-card-content{padding:32px 40px;color:var(--text-primary);line-height:1.7}.notes-card-content h1{font-size:28px;font-weight:700;color:var(--text-primary);margin:0 0 24px;padding-bottom:16px;border-bottom:2px solid var(--border-color)}.notes-card-content h2{font-size:20px;font-weight:600;color:var(--text-primary);margin:32px 0 16px}.notes-card-content h3{font-size:16px;font-weight:600;color:var(--text-secondary);margin:24px 0 12px}.notes-card-content p{margin:0 0 16px;color:var(--text-secondary)}.notes-card-content ul,.notes-card-content ol{margin:0 0 16px;padding-left:24px}.notes-card-content li{margin-bottom:8px;color:var(--text-secondary)}.notes-card-content strong{color:var(--text-primary);font-weight:600}.notes-card-content code{background:var(--bg-tertiary);padding:2px 8px;border-radius:4px;font-family:Fira Code,monospace;font-size:13px;color:var(--accent-primary)}.notes-card-content pre{background:var(--bg-secondary);border-radius:12px;padding:20px;margin:16px 0;overflow-x:auto;border:1px solid var(--border-color)}.notes-card-content pre code{background:transparent;padding:0;color:var(--text-primary);font-size:14px}.notes-card-content blockquote{border-left:4px solid var(--accent-primary);margin:16px 0;padding:12px 20px;background:rgba(var(--accent-primary-rgb),.1);border-radius:0 8px 8px 0;color:var(--text-secondary)}.notes-card-content blockquote strong{color:var(--accent-primary)}.notes-card-content table{width:100%;border-collapse:collapse;margin:16px 0;background:var(--bg-secondary);border-radius:8px;overflow:hidden}.notes-card-content th,.notes-card-content td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-color)}.notes-card-content th{background:var(--bg-tertiary);font-weight:600;color:var(--text-primary)}.notes-card-content td{color:var(--text-secondary)}.notes-card-content tr:last-child td{border-bottom:none}.notes-card-content hr{border:none;height:1px;background:var(--border-color);margin:24px 0}.notes-selection-view{max-width:900px;margin:0 auto;padding:32px;animation:notesFadeIn .4s ease}@keyframes notesFadeIn{0%{opacity:0}to{opacity:1}}.notes-selection-header{margin-bottom:32px}.notes-selection-title{font-size:28px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.notes-selection-subtitle{font-size:15px;color:var(--text-secondary);margin:0}.notes-subject-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.notes-subject-card{background:var(--card-bg);border-radius:16px;border:2px solid var(--border-color);padding:24px;cursor:pointer;transition:all var(--notes-transition);position:relative;overflow:hidden}.notes-subject-card:hover{border-color:var(--accent-primary);transform:translateY(-4px);box-shadow:0 12px 40px #00000026}.notes-subject-card.placeholder{opacity:.6;cursor:not-allowed}.notes-subject-card.placeholder:hover{transform:none;border-color:var(--border-color);box-shadow:none}.notes-subject-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;background:var(--accent-light)}.notes-subject-icon svg{width:24px;height:24px;color:var(--accent-primary)}.notes-subject-name{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 4px}.notes-subject-code{font-size:13px;color:var(--text-tertiary);margin:0 0 16px}.notes-subject-stats{display:flex;gap:16px;font-size:13px;color:var(--text-secondary)}.notes-subject-badge{display:inline-block;background:var(--accent-primary);color:#fff;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500;margin-top:12px}@media(max-width:900px){.notes-nav{width:280px;min-width:280px}.notes-content-scroll,.notes-card-content{padding:24px}}@media(max-width:768px){.notes-container{flex-direction:column}.notes-nav{width:100%;min-width:100%;max-height:50vh;border-right:none;border-bottom:1px solid var(--border-color)}.notes-content-scroll{padding:16px}}.notes-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:48px}.notes-empty-icon{width:80px;height:80px;border-radius:20px;background:var(--accent-light);display:flex;align-items:center;justify-content:center;margin-bottom:24px}.notes-empty-icon svg{width:40px;height:40px;color:var(--accent-primary)}.notes-empty-title{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.notes-empty-text{font-size:14px;color:var(--text-secondary);margin:0}:root{--pp-nav-width: 300px;--pp-transition: .25s cubic-bezier(.4, 0, .2, 1)}.pp-container{display:flex;height:100%;overflow:hidden;background:var(--bg-primary)}.pp-nav{width:var(--pp-nav-width);min-width:var(--pp-nav-width);background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.pp-board-tabs{display:flex;padding:12px;gap:4px;border-bottom:1px solid var(--border-color);background:var(--bg-tertiary)}.pp-board-tab{flex:1;padding:8px 12px;border:none;background:transparent;border-radius:8px;font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--pp-transition)}.pp-board-tab:hover{background:var(--bg-secondary);color:var(--text-primary)}.pp-board-tab.active{background:var(--card-bg);color:var(--text-primary);box-shadow:0 1px 3px #0000001a}.pp-nav-content{flex:1;overflow-y:auto;padding:12px}.pp-section{margin-bottom:8px;border-radius:12px;overflow:hidden;background:var(--card-bg);border:1px solid var(--border-color);transition:border-color var(--pp-transition)}.pp-section:hover{border-color:var(--accent-primary)}.pp-section-header{display:flex;align-items:center;padding:14px 16px;cursor:pointer;user-select:none;transition:background var(--pp-transition)}.pp-section-header:hover{background:var(--bg-tertiary)}.pp-section-icon{width:32px;height:32px;border-radius:8px;background:var(--accent-light);display:flex;align-items:center;justify-content:center;margin-right:12px;flex-shrink:0}.pp-section-icon svg{width:16px;height:16px;color:var(--accent-primary)}.pp-section-info{flex:1;min-width:0}.pp-section-title{font-size:14px;font-weight:600;color:var(--text-primary);margin:0}.pp-section-meta{font-size:12px;color:var(--text-tertiary);margin:2px 0 0}.pp-section-chevron{width:18px;height:18px;color:var(--text-tertiary);transition:transform var(--pp-transition);flex-shrink:0}.pp-section.expanded .pp-section-chevron{transform:rotate(180deg)}.pp-section-content{max-height:0;overflow:hidden;transition:max-height .3s ease;background:var(--bg-secondary)}.pp-section.expanded .pp-section-content{max-height:1000px}.pp-year{border-top:1px solid var(--border-color)}.pp-year-header{display:flex;align-items:center;padding:10px 16px;cursor:pointer;transition:background var(--pp-transition)}.pp-year-header:hover{background:var(--bg-tertiary)}.pp-year-icon{width:16px;height:16px;color:var(--text-secondary);margin-right:10px}.pp-year-label{flex:1;font-size:13px;font-weight:500;color:var(--text-primary)}.pp-year-chevron{width:14px;height:14px;color:var(--text-tertiary);transition:transform var(--pp-transition)}.pp-year.expanded .pp-year-chevron{transform:rotate(180deg)}.pp-year-content{max-height:0;overflow:hidden;transition:max-height .25s ease;padding-left:16px}.pp-year.expanded .pp-year-content{max-height:500px}.pp-session-header{display:flex;align-items:center;padding:8px 12px;cursor:pointer;transition:background var(--pp-transition);border-radius:6px;margin:2px 0}.pp-session-header:hover{background:var(--bg-tertiary)}.pp-session-icon{width:14px;height:14px;color:var(--text-tertiary);margin-right:8px}.pp-session-label{flex:1;font-size:12px;color:var(--text-secondary)}.pp-session-chevron{width:12px;height:12px;color:var(--text-tertiary);transition:transform var(--pp-transition)}.pp-session.expanded .pp-session-chevron{transform:rotate(180deg)}.pp-session-content{max-height:0;overflow:hidden;transition:max-height .2s ease;padding-left:22px}.pp-session.expanded .pp-session-content{max-height:300px}.pp-variant{display:flex;align-items:center;padding:8px 12px;cursor:pointer;transition:all var(--pp-transition);border-radius:6px;margin:2px 0}.pp-variant:hover{background:var(--bg-tertiary)}.pp-variant.active{background:#5865f226}.pp-variant-icon{width:14px;height:14px;color:var(--text-tertiary);margin-right:8px;transition:color var(--pp-transition)}.pp-variant.active .pp-variant-icon{color:var(--accent-primary)}.pp-variant-label{font-size:12px;color:var(--text-secondary);transition:color var(--pp-transition)}.pp-variant.active .pp-variant-label{color:var(--accent-primary);font-weight:500}.pp-content-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-primary)}.pp-content-scroll{flex:1;overflow-y:auto;padding:24px 32px}.pp-viewer-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;animation:ppFadeIn .4s ease}@keyframes ppFadeIn{0%{opacity:0}to{opacity:1}}.pp-empty-icon{width:80px;height:80px;border-radius:20px;background:var(--accent-light);display:flex;align-items:center;justify-content:center;margin-bottom:24px}.pp-empty-icon svg{width:40px;height:40px;color:var(--accent-primary)}.pp-empty-title{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.pp-empty-text{font-size:14px;color:var(--text-secondary);margin:0}.pp-empty-state{padding:32px 16px;text-align:center;color:var(--text-tertiary);font-size:13px}.pp-viewer-card{background:var(--card-bg);border-radius:16px;border:1px solid var(--border-color);overflow:hidden;animation:ppCardFadeIn .4s ease}@keyframes ppCardFadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.pp-viewer-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:16px}.pp-viewer-title h1{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.pp-viewer-title p{font-size:13px;color:var(--text-secondary);margin:4px 0 0}.pp-view-toggle{display:flex;background:var(--bg-tertiary);border-radius:10px;padding:4px;gap:2px}.pp-view-btn{padding:8px 16px;border:none;background:transparent;border-radius:8px;font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--pp-transition)}.pp-view-btn:hover:not(.active){color:var(--text-primary)}.pp-view-btn.active{background:var(--card-bg);color:var(--text-primary);box-shadow:0 1px 3px #0000001a}.pp-pdf-area{min-height:500px;display:flex;align-items:center;justify-content:center}.pp-pdf-embed{width:100%;height:80vh;min-height:500px;border:none;background:var(--bg-tertiary);border-radius:0 0 16px 16px}.pp-pdf-placeholder{text-align:center;color:var(--text-tertiary);padding:48px}.pp-pdf-placeholder svg{width:48px;height:48px;opacity:.4;margin-bottom:16px}.pp-pdf-placeholder h3{font-size:16px;font-weight:600;color:var(--text-secondary);margin:0 0 8px}.pp-pdf-placeholder p{font-size:13px;margin:0 0 16px}.pp-pdf-placeholder code{display:inline-block;background:var(--bg-tertiary);padding:8px 16px;border-radius:8px;font-size:11px;font-family:monospace}@media(max-width:768px){.pp-container{flex-direction:column}.pp-nav{width:100%;min-width:100%;max-height:45vh;border-right:none;border-bottom:1px solid var(--border-color)}.pp-content-scroll{padding:16px}.pp-viewer-header{flex-direction:column;align-items:flex-start}.pp-view-toggle{width:100%}.pp-view-btn{flex:1;text-align:center}}.pp-sessions-list{padding:8px 0}.pp-session-item{display:flex;align-items:center;padding:10px 16px;cursor:pointer;transition:all var(--pp-transition);border-radius:8px;margin:2px 8px}.pp-session-item:hover{background:var(--bg-tertiary)}.pp-session-item.active{background:#5865f226}.pp-session-item .pp-session-icon{width:16px;height:16px;color:var(--text-tertiary);margin-right:10px;flex-shrink:0}.pp-session-item.active .pp-session-icon{color:var(--accent-primary)}.pp-session-item .pp-session-label{flex:1;font-size:13px;font-weight:500;color:var(--text-primary)}.pp-session-item.active .pp-session-label{color:var(--accent-primary)}.pp-session-count{font-size:11px;color:var(--text-tertiary);background:var(--bg-tertiary);padding:2px 8px;border-radius:10px}.pp-session-view{animation:ppFadeIn .3s ease}.pp-session-header{margin-bottom:24px}.pp-session-title h1{font-size:24px;font-weight:600;color:var(--text-primary);margin:0}.pp-session-title p{font-size:14px;color:var(--text-secondary);margin:4px 0 0}.pp-papers-list{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}.pp-paper-entry{display:flex;align-items:center;padding:14px 18px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all var(--pp-transition)}.pp-paper-entry:hover{border-color:var(--accent-primary);background:var(--bg-secondary)}.pp-paper-entry.active{border-color:var(--accent-primary);background:#5865f21a}.pp-paper-icon{width:18px;height:18px;color:var(--text-tertiary);margin-right:12px;flex-shrink:0}.pp-paper-entry.active .pp-paper-icon{color:var(--accent-primary)}.pp-paper-label{flex:1;font-size:14px;font-weight:500;color:var(--text-primary)}.pp-paper-entry.active .pp-paper-label{color:var(--accent-primary)}.pp-paper-variants{font-size:12px;color:var(--text-tertiary)}.pp-examiner-report{border-left:3px solid var(--accent-secondary, #f59e0b)}.pp-examiner-report .pp-paper-icon{color:var(--accent-secondary, #f59e0b)}.pp-no-papers{text-align:center;color:var(--text-tertiary);padding:24px;font-size:14px}.pp-paper-viewer-card{background:var(--card-bg);border-radius:16px;border:1px solid var(--border-color);overflow:hidden;animation:ppCardFadeIn .4s ease}.pp-paper-viewer-card .pp-viewer-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:12px}.pp-paper-viewer-card .pp-viewer-title h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.pp-paper-viewer-empty{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-tertiary);font-size:14px}.pp-variant-selector{display:flex;gap:4px;background:var(--bg-tertiary);border-radius:8px;padding:4px}.pp-variant-btn{padding:6px 12px;border:none;background:transparent;border-radius:6px;font-size:12px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all var(--pp-transition)}.pp-variant-btn:hover:not(.active){color:var(--text-primary)}.pp-variant-btn.active{background:var(--card-bg);color:var(--accent-primary);box-shadow:0 1px 3px #0000001a}.pp-viewer-area{margin-top:16px}:root{--practice-nav-width: 320px;--practice-transition: .25s cubic-bezier(.4, 0, .2, 1)}.practice-container{display:flex;height:100%;overflow:hidden;background:var(--bg-primary)}.practice-nav{width:var(--practice-nav-width);min-width:var(--practice-nav-width);background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.practice-nav-header{padding:20px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:12px}.practice-back-btn{display:flex;align-items:center;gap:8px;padding:8px 12px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:8px;transition:all var(--practice-transition);font-size:14px;font-weight:500}.practice-back-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.practice-nav-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.practice-nav-content{flex:1;overflow-y:auto;padding:12px}.practice-section{margin-bottom:8px;border-radius:12px;overflow:hidden;background:var(--card-bg);border:1px solid var(--border-color);transition:all var(--practice-transition)}.practice-section:hover{border-color:var(--accent-primary)}.practice-section-header{display:flex;align-items:center;padding:14px 16px;cursor:pointer;user-select:none;transition:all var(--practice-transition)}.practice-section-header:hover{background:var(--bg-tertiary)}.practice-progress-ring{width:28px;height:28px;margin-right:12px;position:relative;flex-shrink:0}.practice-progress-ring svg{transform:rotate(-90deg);width:100%;height:100%}.practice-progress-ring-bg{fill:none;stroke:var(--border-color);stroke-width:3}.practice-progress-ring-fill{fill:none;stroke:var(--accent-primary);stroke-width:3;stroke-linecap:round;transition:stroke-dashoffset .5s ease}.practice-section-info{flex:1;min-width:0}.practice-section-title{font-size:14px;font-weight:600;color:var(--text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.practice-section-meta{font-size:12px;color:var(--text-tertiary);margin-top:2px}.practice-section-chevron{width:20px;height:20px;color:var(--text-tertiary);transition:transform var(--practice-transition);flex-shrink:0}.practice-section.expanded .practice-section-chevron{transform:rotate(180deg)}.practice-topics-list{max-height:0;overflow:hidden;transition:max-height .3s ease;background:var(--bg-secondary)}.practice-section.expanded .practice-topics-list{max-height:800px}.practice-topic-item{display:flex;align-items:center;padding:10px 16px 10px 20px;cursor:pointer;transition:all var(--practice-transition);position:relative;border-radius:8px;margin:2px 8px}.practice-topic-item:hover{background:var(--bg-tertiary)}.practice-topic-item.active{background:#5865f226}.practice-topic-item.active .practice-topic-name{color:var(--accent-primary);font-weight:500}.practice-topic-progress{display:flex;align-items:center;justify-content:center;min-width:36px;height:20px;border-radius:10px;font-size:11px;font-weight:600;margin-right:10px;flex-shrink:0;background:var(--bg-tertiary);color:var(--text-tertiary)}.practice-topic-progress.has-progress{background:#5865f226;color:var(--accent-primary)}.practice-topic-progress.complete{background:var(--success);color:#fff}.practice-topic-name{font-size:13px;color:var(--text-secondary);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.practice-topic-empty{font-size:11px;color:var(--text-tertiary);padding:2px 8px;background:var(--bg-tertiary);border-radius:6px;flex-shrink:0;margin-left:4px}.practice-content-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-primary)}.practice-content-header{padding:24px 32px 0;border-bottom:1px solid var(--border-color);background:var(--bg-primary)}.practice-content-title{font-size:22px;font-weight:700;color:var(--text-primary);margin:0 0 4px}.practice-content-subtitle{font-size:13px;color:var(--text-tertiary);margin:0 0 16px}.practice-tabs{display:flex;gap:0;margin-bottom:-1px}.practice-tab{padding:10px 20px;border:none;background:transparent;color:var(--text-tertiary);font-size:14px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;transition:all var(--practice-transition)}.practice-tab:hover{color:var(--text-primary)}.practice-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.practice-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;border-radius:10px;background:var(--bg-tertiary);color:var(--text-tertiary);font-size:11px;font-weight:600;margin-left:6px;padding:0 6px}.practice-tab.active .practice-tab-count{background:#5865f226;color:var(--accent-primary)}.practice-content-scroll{flex:1;overflow-y:auto;padding:24px 32px 48px}.practice-question-nav{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.practice-q-pill{width:36px;height:36px;border-radius:10px;border:1.5px solid var(--border-color);background:var(--card-bg);color:var(--text-secondary);font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--practice-transition)}.practice-q-pill:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.practice-q-pill.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.practice-q-pill.answered-correct{background:var(--success);border-color:var(--success);color:#fff}.practice-q-pill.answered-incorrect{background:var(--error);border-color:var(--error);color:#fff}.practice-question-card{background:var(--card-bg);border-radius:16px;border:1px solid var(--border-color);overflow:hidden;animation:practiceCardFadeIn .3s ease}@keyframes practiceCardFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.practice-question-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-color)}.practice-question-number{font-size:13px;font-weight:600;color:var(--accent-primary);text-transform:uppercase;letter-spacing:.5px}.practice-question-marks{font-size:12px;color:var(--text-tertiary);background:var(--bg-tertiary);padding:4px 10px;border-radius:8px;font-weight:500}.practice-question-body{padding:24px}.practice-question-text{font-size:15px;line-height:1.7;color:var(--text-primary);margin:0 0 20px;white-space:pre-wrap}.practice-mcq-options{display:flex;flex-direction:column;gap:10px}.practice-mcq-option{display:flex;align-items:center;gap:14px;padding:14px 18px;background:var(--bg-secondary);border:1.5px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all var(--practice-transition);font-size:14px;color:var(--text-primary)}.practice-mcq-option:hover:not(.disabled){border-color:var(--accent-primary);background:#5865f20d}.practice-mcq-option.selected{border-color:var(--accent-primary);background:#5865f21a}.practice-mcq-option.correct{border-color:var(--success);background:#10b9811a}.practice-mcq-option.incorrect{border-color:var(--error);background:#ef44441a}.practice-mcq-option.correct-answer{border-color:var(--success);background:#10b98114}.practice-mcq-option.disabled{cursor:default;opacity:.8}.practice-mcq-letter{width:32px;height:32px;border-radius:8px;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:var(--text-secondary);flex-shrink:0;transition:all var(--practice-transition)}.practice-mcq-option.selected .practice-mcq-letter{background:var(--accent-primary);color:#fff}.practice-mcq-option.correct .practice-mcq-letter{background:var(--success);color:#fff}.practice-mcq-option.incorrect .practice-mcq-letter{background:var(--error);color:#fff}.practice-mcq-option.correct-answer .practice-mcq-letter{background:var(--success);color:#fff}.practice-mcq-text{flex:1;line-height:1.5}.practice-mcq-icon{width:20px;height:20px;flex-shrink:0;display:none}.practice-mcq-option.correct .practice-mcq-icon,.practice-mcq-option.incorrect .practice-mcq-icon,.practice-mcq-option.correct-answer .practice-mcq-icon{display:block}.practice-explanation{margin-top:16px;padding:16px 20px;background:#5865f20f;border-radius:12px;border-left:4px solid var(--accent-primary);animation:practiceCardFadeIn .3s ease}.practice-explanation-title{font-size:13px;font-weight:600;color:var(--accent-primary);margin:0 0 8px;text-transform:uppercase;letter-spacing:.5px}.practice-explanation-text{font-size:14px;line-height:1.6;color:var(--text-secondary);margin:0}.practice-structured-actions{display:flex;align-items:center;gap:12px;margin-top:20px;flex-wrap:wrap}.practice-action-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:10px;border:1.5px solid var(--border-color);background:var(--card-bg);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--practice-transition)}.practice-action-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary);background:#5865f20d}.practice-action-btn.primary{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.practice-action-btn.primary:hover{opacity:.9}.practice-action-btn svg{width:16px;height:16px}.practice-ai-checker{margin-top:16px;border-radius:12px;border:1.5px solid var(--border-color);overflow:hidden;animation:practiceCardFadeIn .3s ease;background:var(--bg-secondary)}.practice-ai-checker-header{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);font-size:13px;font-weight:600;color:var(--text-primary)}.practice-ai-checker-header svg{width:16px;height:16px;color:var(--accent-primary)}.practice-ai-checker-input{padding:16px}.practice-ai-textarea{width:100%;min-height:100px;padding:12px 16px;border:1.5px solid var(--border-color);border-radius:10px;background:var(--card-bg);color:var(--text-primary);font-size:14px;line-height:1.6;resize:vertical;font-family:inherit;transition:border-color var(--practice-transition)}.practice-ai-textarea:focus{outline:none;border-color:var(--accent-primary)}.practice-ai-textarea::placeholder{color:var(--text-tertiary)}.practice-ai-submit-row{display:flex;align-items:center;justify-content:flex-end;gap:8px;margin-top:10px}.practice-ai-response{padding:16px;border-top:1px solid var(--border-color);font-size:14px;line-height:1.7;color:var(--text-secondary)}.practice-ai-response p{margin:0 0 8px}.practice-ai-response strong{color:var(--text-primary)}.practice-ai-loading{display:flex;align-items:center;gap:10px;padding:16px;color:var(--text-tertiary);font-size:13px}.practice-ai-loading .spinner{width:16px;height:16px;border:2px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:practiceAiSpin .6s linear infinite}@keyframes practiceAiSpin{to{transform:rotate(360deg)}}.practice-mark-scheme{margin-top:16px;padding:16px 20px;background:#10b9810f;border-radius:12px;border-left:4px solid var(--success);animation:practiceCardFadeIn .3s ease}.practice-mark-scheme-title{font-size:13px;font-weight:600;color:var(--success);margin:0 0 8px;text-transform:uppercase;letter-spacing:.5px}.practice-mark-scheme-text{font-size:14px;line-height:1.7;color:var(--text-secondary);margin:0;white-space:pre-wrap}.practice-question-footer{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.practice-footer-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--text-tertiary);text-decoration:none;cursor:pointer;transition:color var(--practice-transition);border:none;background:none;padding:0}.practice-footer-link:hover{color:var(--accent-primary)}.practice-footer-link svg{width:14px;height:14px}.practice-selection-view{max-width:900px;margin:0 auto;padding:32px;animation:practiceFadeIn .4s ease}@keyframes practiceFadeIn{0%{opacity:0}to{opacity:1}}.practice-selection-header{margin-bottom:32px}.practice-selection-title{font-size:28px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.practice-selection-subtitle{font-size:15px;color:var(--text-secondary);margin:0}.practice-subject-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.practice-subject-card{background:var(--card-bg);border-radius:16px;border:2px solid var(--border-color);padding:24px;cursor:pointer;transition:all var(--practice-transition);position:relative;overflow:hidden}.practice-subject-card:hover{border-color:var(--accent-primary);transform:translateY(-4px);box-shadow:0 12px 40px #00000026}.practice-subject-card.placeholder{opacity:.6;cursor:not-allowed}.practice-subject-card.placeholder:hover{transform:none;border-color:var(--border-color);box-shadow:none}.practice-subject-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;background:var(--accent-light)}.practice-subject-icon svg{width:24px;height:24px;color:var(--accent-primary)}.practice-subject-name{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 4px}.practice-subject-code{font-size:13px;color:var(--text-tertiary);margin:0 0 16px}.practice-subject-stats{display:flex;gap:16px;font-size:13px;color:var(--text-secondary)}.practice-subject-badge{display:inline-block;background:var(--accent-primary);color:#fff;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500;margin-top:12px}.practice-subject-badge.coming-soon{background:var(--bg-tertiary);color:var(--text-tertiary)}.practice-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:48px}.practice-empty-icon{width:80px;height:80px;border-radius:20px;background:var(--accent-light);display:flex;align-items:center;justify-content:center;margin-bottom:24px}.practice-empty-icon svg{width:40px;height:40px;color:var(--accent-primary)}.practice-empty-title{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.practice-empty-text{font-size:14px;color:var(--text-secondary);margin:0}.practice-topic-score{display:flex;align-items:center;gap:16px;padding:16px 20px;background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color);margin-bottom:20px}.practice-score-circle{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0}.practice-score-circle.good{background:#10b9811f;color:var(--success)}.practice-score-circle.medium{background:#f59e0b1f;color:#f59e0b}.practice-score-circle.low{background:#ef44441f;color:var(--error)}.practice-score-circle.none{background:var(--bg-tertiary);color:var(--text-tertiary)}.practice-score-details{flex:1}.practice-score-label{font-size:14px;font-weight:600;color:var(--text-primary);margin:0 0 2px}.practice-score-sub{font-size:12px;color:var(--text-tertiary);margin:0}.practice-score-reset{padding:6px 12px;border-radius:8px;border:1px solid var(--border-color);background:transparent;color:var(--text-tertiary);font-size:12px;cursor:pointer;transition:all var(--practice-transition)}.practice-score-reset:hover{border-color:var(--error);color:var(--error)}.practice-back-banner{display:flex;align-items:center;gap:10px;padding:10px 16px;background:#5865f214;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background var(--practice-transition)}.practice-back-banner:hover{background:#5865f224}.practice-back-banner svg{width:16px;height:16px;color:var(--accent-primary)}.practice-back-banner span{font-size:13px;font-weight:500;color:var(--accent-primary)}@media(max-width:900px){.practice-nav{width:280px;min-width:280px}.practice-content-scroll{padding:20px}.practice-content-header{padding:20px 20px 0}}@media(max-width:768px){.practice-container{flex-direction:column}.practice-nav{width:100%;min-width:100%;max-height:50vh;border-right:none;border-bottom:1px solid var(--border-color)}.practice-content-scroll{padding:16px}.practice-content-header{padding:16px 16px 0}.practice-structured-actions{flex-direction:column;align-items:stretch}.practice-question-footer{flex-direction:column;gap:10px}}
