*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--sidebar-width: 320px;--sidebar-collapsed: -320px;--right-sidebar-width: 300px;--primary-bg: #777b8f;--secondary-bg: #ffffff;--tertiary-bg: #f5f0e1;--border-color: #d4cfc4;--accent-color: #1d6b12;--accent-hover: #155a0c;--text-primary: #2d2d2d;--text-secondary: #6b6b6b;--success: #2e7d32;--error: #c62828;--warning: #f59e0b;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--overlay-bg: rgba(0, 0, 0, .35);--code-bg: #eef1e8;--code-color: #1d6b12;--grid-vignette: rgba(0, 0, 0, .42);--grid-pattern-opacity: 1}[data-theme=dark]{--primary-bg: #262731;--secondary-bg: #1e1e1e;--tertiary-bg: #2a2a2a;--border-color: #333333;--accent-color: #5aa84f;--accent-hover: #4a9340;--text-primary: #e8e8e8;--text-secondary: #a0a0a0;--success: #4caf50;--error: #ef5350;--warning: #fbbf24;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .5);--overlay-bg: rgba(0, 0, 0, .75);--code-bg: rgba(90, 168, 79, .12);--code-color: #7dd67f;--grid-vignette: rgba(0, 0, 0, .56);--grid-pattern-opacity: .75}body{font-family:Segoe UI,system-ui,sans-serif;position:relative;isolation:isolate;background-color:var(--primary-bg);background-image:radial-gradient(circle at center,transparent 52%,var(--grid-vignette) 100%);background-attachment:fixed;background-size:auto;background-position:center;background-repeat:no-repeat;color:var(--text-primary);min-height:100vh;line-height:1.6;overflow-x:hidden;transition:background-color .2s ease,background-image .2s ease,color .2s ease}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:-1;opacity:var(--grid-pattern-opacity);background-image:url("data:image/svg+xml,%3csvg%20viewBox='0%200%20210%20200'%20xmlns='http://www.w3.org/2000/svg'%20aria-hidden='true'%3e%3cg%20fill='none'%20stroke='%23afadad'%20stroke-linecap='round'%3e%3cpath%20d='M%2010%20100%20H%2070'%20stroke-width='4'%20stroke-dasharray='20%2020'%20opacity='0.2'%20/%3e%3cpath%20d='M%20140%20100%20H%20200'%20stroke-width='4'%20stroke-dasharray='20%2020'%20opacity='0.2'%20/%3e%3cpath%20d='M%20105%205%20V%2065'%20stroke-width='4'%20stroke-dasharray='20%2020'%20opacity='0.2'%20/%3e%3cpath%20d='M%20105%20135%20V%20195'%20stroke-width='4'%20stroke-dasharray='20%2020'%20opacity='0.2'%20/%3e%3cpath%20d='M%2090%20100%20H%20120%20M%20105%2085%20V%20115'%20stroke-width='8'%20opacity='0.2'%20/%3e%3c/g%3e%3c/svg%3e");background-size:168px 160px;background-repeat:repeat;background-position:0 0}.sidebar,.right-sidebar,.section,.result-container,.option,.question,.fc-container{transition:background-color .2s ease,color .2s ease,border-color .2s ease,box-shadow .2s ease}.layout{display:flex;min-height:100vh}.sidebar{position:fixed;left:0;top:0;width:var(--sidebar-width);height:100vh;background:var(--secondary-bg);border-right:1px solid var(--border-color);z-index:1000;overflow-y:auto;transition:transform .3s ease;display:flex;flex-direction:column;box-shadow:4px 0 16px #0000000f}[data-theme=dark] .sidebar{box-shadow:4px 0 16px #00000059}.filter-list::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.sidebar.hidden{transform:translate(var(--sidebar-collapsed))}.sidebar-header{padding:1.5rem;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background:var(--secondary-bg);z-index:10}.sidebar-header h2{font-size:1.2rem;color:var(--accent-color);margin:0}.close-sidebar{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;padding:.25rem;line-height:1;border-radius:4px;transition:all .2s}.close-sidebar:hover{color:var(--text-primary);background:#0000000f}[data-theme=dark] .close-sidebar:hover{background:#ffffff14}.tree-nav{padding:1rem 0;flex:1}.tree-item{list-style:none}.tree-section{margin-bottom:.5rem}.tree-toggle{width:100%;display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:none;border:none;color:var(--text-primary);font-size:.95rem;font-weight:600;cursor:pointer;text-align:left;transition:all .2s;border-left:3px solid transparent}.tree-toggle:hover{background:color-mix(in srgb,var(--accent-color) 10%,transparent);border-left-color:var(--accent-color)}.tree-toggle.active{background:color-mix(in srgb,var(--accent-color) 15%,transparent);border-left-color:var(--accent-color);color:var(--accent-color)}.tree-icon{font-size:.8rem;transition:transform .2s;color:var(--text-secondary);width:16px;display:inline-block}.tree-section.collapsed .tree-icon{transform:rotate(-90deg)}.tree-questions{list-style:none;overflow:hidden;transition:max-height .3s ease;max-height:1000px}.tree-section.collapsed .tree-questions{max-height:0}.tree-question{margin:0}.tree-question a{display:block;padding:.5rem 1.5rem .5rem 3rem;color:var(--text-secondary);text-decoration:none;font-size:.9rem;border-left:3px solid transparent;transition:all .2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-question a:hover{background:#0000000a;color:var(--text-primary);border-left-color:var(--accent-color)}.tree-question a.active{color:var(--accent-color);background:color-mix(in srgb,var(--accent-color) 10%,transparent);border-left-color:var(--accent-color)}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--overlay-bg);z-index:999;opacity:0;visibility:hidden;transition:all .3s}.sidebar-overlay.visible{opacity:1;visibility:visible}.main-content{flex:1;margin-left:var(--sidebar-width);padding:0 2rem 2rem;transition:margin-left .3s ease,margin-right .3s ease;min-height:100vh}.main-content.full-width{margin-left:0}.main-content.with-right-sidebar{margin-right:var(--right-sidebar-width)}.top-bar{position:sticky;top:0;z-index:100;display:flex;justify-content:stretch;margin-bottom:5rem;margin-left:-2rem;margin-right:-2rem}.top-bar-actions{position:relative;display:flex;align-items:center;gap:.75rem;width:100%;padding:1rem 2rem 1.1rem;min-height:70px;background:transparent;box-shadow:0 1px #ffffff59 inset,0 10px 24px #00000014}.top-bar-paper-edge{position:absolute;left:0;top:0;width:100%;height:150px;object-fit:fill;object-position:center center;opacity:.98;filter:contrast(1.08) drop-shadow(0 10px 14px rgba(0,0,0,.12));pointer-events:none;z-index:1}.top-bar-actions .right-sidebar-toggle{margin-left:auto}.top-bar-btn,.menu-toggle,.right-sidebar-toggle{position:relative;z-index:2;background:#fffaeeb8;border:1px solid rgba(120,100,67,.22);color:#4d3d24;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:1rem;display:flex;align-items:center;gap:.5rem;transition:all .2s;box-shadow:0 1px #ffffff80 inset,0 2px 6px #45351c14}.top-bar-btn:hover,.menu-toggle:hover,.right-sidebar-toggle:hover{background:#fff7e4eb;border-color:#78644357}.top-bar-btn.hidden,.menu-toggle.hidden,.right-sidebar-toggle.hidden{opacity:0;pointer-events:none}h1{text-align:center;font-size:1.8rem;margin-bottom:2rem;color:var(--accent-color);letter-spacing:.5px;margin-top:3rem}.section{background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;margin-bottom:2rem;scroll-margin-top:2rem;box-shadow:0 2px 8px #0000000d}[data-theme=dark] .section{box-shadow:0 2px 8px #00000040}.section-title{font-size:1.3rem;font-weight:700;color:var(--accent-color);margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.question{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px dashed var(--border-color);scroll-margin-top:6rem}.question:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.question-label{font-weight:600;margin-bottom:.8rem;font-size:1.05rem;color:var(--text-primary)}.question-image,.fc-question-image img{display:block;max-width:100%;height:auto;margin:.75rem 0 1rem;border-radius:12px;border:1px solid var(--border-color);background:var(--secondary-bg)}.fc-question-image{margin-bottom:1rem}.options{display:flex;flex-direction:column;gap:.5rem}.option{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem;border-radius:6px;transition:background .2s}.option:hover{background:#0000000a}[data-theme=dark] .option:hover{background:#ffffff0f}.option.partial-correct{background:color-mix(in srgb,var(--warning) 18%,transparent)}[data-theme=dark] .option.partial-correct{background:color-mix(in srgb,var(--warning) 22%,transparent)}.option.correct{background:color-mix(in srgb,var(--success) 12%,transparent)}[data-theme=dark] .option.correct{background:color-mix(in srgb,var(--success) 16%,transparent)}.option.wrong{background:color-mix(in srgb,var(--error) 12%,transparent)}[data-theme=dark] .option.wrong{background:color-mix(in srgb,var(--error) 16%,transparent)}.option input[type=radio],.option input[type=checkbox]{accent-color:var(--accent-color);width:1.1rem;height:1.1rem}.text-input-wrap{margin:.5rem 0}.text-input-wrap input[type=text]{width:100%;max-width:500px;padding:.5rem;border:1px solid var(--border-color);border-radius:6px;background:var(--secondary-bg);color:var(--text-primary);font-family:monospace}.text-input-wrap input[type=text]:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-color) 10%,transparent)}.text-answer-hint{font-size:.85rem;color:var(--text-secondary);margin-top:.3rem;font-style:italic}.feedback{display:none;margin-top:.8rem;padding:.75rem;border-radius:6px;font-size:.95rem;font-weight:500}.feedback.feedback-visible{display:block}.feedback-correct-answer{margin-top:.4rem;font-size:.92rem;opacity:.9}.feedback-explanation{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border-color);font-size:.88rem;opacity:.85;font-style:italic}.feedback-partial{margin-top:.4rem;font-weight:600}.feedback.correct{background:color-mix(in srgb,var(--success) 10%,transparent);color:var(--success);border:1px solid color-mix(in srgb,var(--success) 25%,transparent)}.feedback.incorrect{background:color-mix(in srgb,var(--error) 10%,transparent);color:var(--error);border:1px solid color-mix(in srgb,var(--error) 25%,transparent)}.actions{display:flex;gap:1rem;justify-content:center;margin-top:2rem;margin-bottom:2rem;flex-wrap:wrap}.actions-secondary{margin-top:0;margin-bottom:0}.action-btn{color:#fff;font-size:.95rem;padding:.6rem 1.4rem}.action-btn-shuffle{background:#7c3aed}.action-btn-practice{background:#b45309;display:none}.action-btn-review{background:#92400e;display:none}.action-btn-clear-wrong{background:#7f1d1d;display:none}.quiz-load-error{color:var(--error);padding:1rem;line-height:1.5}.quiz-load-error code{color:var(--accent-color)}.btn{padding:.8rem 2rem;border:none;border-radius:8px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .2s}.btn-primary{background:var(--accent-color);color:#fff}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px)}.btn-secondary{background:var(--text-secondary);color:var(--secondary-bg)}.btn-secondary:hover{background:var(--text-primary)}.result-container{display:none;text-align:center;margin-top:2rem;padding:1.5rem;background:var(--secondary-bg);border:1px solid var(--accent-color);border-radius:12px;font-size:1.2rem;color:var(--text-primary)}.result-container strong{color:var(--accent-color);font-size:1.5rem}.progress-bar{width:100%;height:8px;background:var(--border-color);border-radius:4px;margin-top:1rem;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-color),var(--accent-hover));transition:width .5s ease}@media (max-width: 768px){:root{--sidebar-width: 280px;--sidebar-collapsed: -280px}.main-content{padding:1rem;margin-left:0;padding-top:0}.main-content.with-right-sidebar{margin-right:0}.right-sidebar{width:min(86vw,var(--right-sidebar-width));z-index:1100}.top-bar{margin-bottom:3.8rem;margin-left:-1rem;margin-right:-1rem}.top-bar-actions{padding:.75rem 1rem;justify-content:flex-start}.top-bar-paper-edge{height:124px}h1{font-size:1.5rem;margin-top:1rem}.section{padding:1rem}.top-bar-btn,.menu-toggle,.right-sidebar-toggle{justify-content:center;flex:0 0 auto}.fc-container{min-height:calc(100vh - 5rem);border-radius:14px}.fc-footer{flex-direction:column;align-items:stretch}.fc-footer-meta,.fc-footer-actions{justify-content:space-between}}.flashcard-btn-sidebar{display:flex;align-items:center;gap:.6rem;width:calc(100% - 3rem);margin:1rem 1.5rem .5rem;padding:.65rem 1rem;background:var(--accent-color);border:none;border-radius:8px;color:#fff;font-size:.95rem;cursor:pointer}.storage-info-wrap{text-align:center;margin-top:.5rem;margin-bottom:1rem}#storage-info{color:var(--text-secondary);font-size:.82rem}#normal-mode-view.hidden,#flashcard-view{display:none}#flashcard-view.active{display:block}.progress-fill,.fc-progress-fill{width:0%}.fc-footer-actions{display:flex;gap:.5rem}.fc-container{background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:16px;width:100%;max-width:920px;min-height:calc(100vh - 7rem);margin:0 auto;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #00000038}[data-theme=dark] .fc-container{box-shadow:0 20px 60px #0006}.fc-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);background:color-mix(in srgb,var(--accent-color) 5%,transparent);flex-shrink:0}.fc-title{font-size:1rem;font-weight:700;color:var(--accent-color)}.fc-close{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;line-height:1;padding:.2rem .4rem;border-radius:4px;transition:all .2s}.fc-close:hover{color:var(--text-primary);background:#0000000f}[data-theme=dark] .fc-close:hover{background:#ffffff14}.fc-progress-wrap{padding:.75rem 1.5rem 0;flex-shrink:0}.fc-progress-info{display:flex;justify-content:space-between;font-size:.82rem;color:var(--text-secondary);margin-bottom:.4rem}.fc-progress-bar{height:6px;background:var(--border-color);border-radius:3px;overflow:hidden}.fc-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-color),var(--accent-hover));transition:width .4s ease;border-radius:3px}.fc-score-row{display:flex;gap:1rem;margin-top:.5rem;font-size:.82rem}.fc-score-correct{color:var(--success)}.fc-score-wrong{color:var(--error)}.fc-score-left{color:var(--text-secondary)}.fc-body{padding:1.5rem;flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:1.2rem}.fc-question-text{font-size:1.08rem;font-weight:600;line-height:1.55;color:var(--text-primary)}.fc-question-text code{background:color-mix(in srgb,var(--accent-color) 12%,transparent);padding:.1em .35em;border-radius:4px;font-size:.95em;color:var(--accent-color)}.fc-options{display:flex;flex-direction:column;gap:.5rem}.fc-option{display:flex;align-items:flex-start;gap:.7rem;padding:.65rem .9rem;border:1.5px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .18s;background:transparent;color:var(--text-primary);text-align:left;font-size:.95rem;line-height:1.45;width:100%}.fc-option:hover:not(:disabled){border-color:var(--accent-color);background:color-mix(in srgb,var(--accent-color) 8%,transparent)}.fc-option.correct{border-color:var(--success);background:color-mix(in srgb,var(--success) 10%,transparent);color:var(--success)}.fc-option.selected{border-color:var(--accent-color);background:color-mix(in srgb,var(--accent-color) 12%,transparent)}.fc-option.wrong{border-color:var(--error);background:color-mix(in srgb,var(--error) 10%,transparent);color:var(--error)}.fc-option.partial-correct{border-color:var(--warning);background:color-mix(in srgb,var(--warning) 16%,transparent);color:var(--text-primary)}.fc-option:disabled{cursor:default}.fc-option-letter{font-weight:700;min-width:1.2rem;opacity:.6;font-size:.88rem;margin-top:.05rem}.fc-option.correct .fc-option-letter,.fc-option.wrong .fc-option-letter,.fc-option.partial-correct .fc-option-letter{opacity:1}.fc-text-wrap{display:flex;flex-direction:column;gap:.5rem}.fc-text-input{width:100%;padding:.6rem .8rem;border:1.5px solid var(--border-color);border-radius:8px;background:var(--primary-bg);color:var(--text-primary);font-family:monospace;font-size:.95rem;transition:border-color .2s}.fc-text-input:focus{outline:none;border-color:var(--accent-color)}.fc-text-input.correct{border-color:var(--success);background:color-mix(in srgb,var(--success) 8%,transparent)}.fc-text-input.wrong{border-color:var(--error);background:color-mix(in srgb,var(--error) 8%,transparent)}.fc-submit-text{align-self:flex-start;padding:.5rem 1.2rem;background:var(--accent-color);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:600;transition:background .2s}.fc-submit-text:hover{background:var(--accent-hover)}.fc-feedback{display:none;padding:.75rem 1rem;border-radius:8px;font-size:.92rem;line-height:1.5}.fc-feedback.correct{background:color-mix(in srgb,var(--success) 10%,transparent);border:1px solid color-mix(in srgb,var(--success) 30%,transparent);color:var(--success)}.fc-feedback.wrong{background:color-mix(in srgb,var(--error) 10%,transparent);border:1px solid color-mix(in srgb,var(--error) 30%,transparent);color:var(--error)}.fc-feedback.active{display:block}.fc-correct-answer{margin-top:.4rem;font-weight:600;color:var(--text-primary)}.fc-explanation{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border-color);font-style:italic;opacity:.85;color:var(--text-primary)}.fc-feedback-partial{margin-top:.4rem;font-weight:600;color:var(--text-primary)}.fc-footer{padding:1rem 1.5rem;border-top:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-shrink:0}.fc-footer-meta{display:flex;align-items:center;gap:.75rem;min-width:0}.fc-btn{padding:.6rem 1.4rem;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.fc-btn-next{background:var(--accent-color);color:#fff}.fc-btn-next:hover{background:var(--accent-hover)}.fc-btn-next:disabled{opacity:.4;cursor:default}.fc-btn-end{background:var(--text-secondary);color:var(--secondary-bg)}.fc-btn-end:hover{background:var(--text-primary)}.fc-btn-reset{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);padding-inline:1rem;flex-shrink:0}.fc-btn-reset:hover{color:var(--text-primary);border-color:var(--text-secondary);background:color-mix(in srgb,var(--secondary-bg) 80%,transparent)}.fc-hint{font-size:.82rem;color:var(--text-secondary);font-style:italic;min-width:0}.fc-final{text-align:center;padding:2rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.fc-final-emoji{font-size:3rem}.fc-final-score{font-size:1.6rem;font-weight:700;color:var(--accent-color)}.fc-final-score-large{font-size:2rem}.fc-text-hint{font-size:.82rem;color:var(--text-secondary);font-style:italic}.fc-final-detail{color:var(--text-secondary);font-size:.95rem}.fc-final-actions{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center;margin-top:.5rem}@media (max-width: 768px){.fc-container{min-height:calc(100vh - 5rem);border-radius:14px}.fc-footer{flex-direction:column;align-items:stretch}.fc-footer-meta,.fc-footer-actions{justify-content:space-between}}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.section{animation:fadeIn .3s ease-in-out}.sidebar::-webkit-scrollbar{width:8px}.sidebar::-webkit-scrollbar-track{background:var(--primary-bg)}.sidebar::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.sidebar::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.right-sidebar{position:fixed;right:0;top:0;width:var(--right-sidebar-width);height:100vh;background:var(--secondary-bg);border-left:1px solid var(--border-color);z-index:950;overflow-y:auto;transition:transform .3s ease;box-shadow:-4px 0 16px #0000000f}[data-theme=dark] .right-sidebar{box-shadow:-4px 0 16px #00000059}.right-sidebar.hidden{transform:translate(100%)}.right-sidebar-header{padding:1.5rem;border-bottom:1px solid var(--border-color);background:var(--tertiary-bg);display:flex;justify-content:space-between;align-items:center}.sidebar-header-actions{display:flex;gap:.4rem;align-items:center}.right-sidebar-header h2{font-size:1.2rem;color:var(--accent-color)}.shortcut-settings-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;border-radius:4px;padding:.35rem .5rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.02em;transition:all .2s}.shortcut-settings-btn:hover{color:var(--text-primary);background:#0000000f}[data-theme=dark] .shortcut-settings-btn:hover{background:#ffffff14}.shortcut-settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay-bg);z-index:3000;display:none;align-items:center;justify-content:center;padding:1rem}.shortcut-settings-overlay.visible{display:flex}.shortcut-settings-panel{width:min(420px,100%);background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:14px;box-shadow:var(--shadow-md);overflow:hidden}.shortcut-settings-header{padding:1rem 1.25rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color);background:var(--tertiary-bg)}.shortcut-settings-header h2{font-size:1.1rem;color:var(--accent-color)}.shortcut-settings-row{padding:1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.shortcut-settings-row p{margin-top:.35rem;color:var(--text-secondary);font-family:monospace}.shortcut-capture-hint{min-height:1.5rem;padding:0 1.25rem 1.25rem;color:var(--accent-color);font-size:.9rem}.command-palette-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay-bg);z-index:3200;display:none;align-items:flex-start;justify-content:center;padding:12vh 1rem 1rem}.command-palette-overlay.visible{display:flex}.command-palette{width:min(560px,100%);background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:14px;overflow:hidden;box-shadow:var(--shadow-md)}.command-palette-input{width:100%;padding:1rem 1.1rem;border:none;border-bottom:1px solid var(--border-color);background:var(--secondary-bg);color:var(--text-primary);font-size:1rem;outline:none}.command-palette-list{max-height:340px;overflow-y:auto;padding:.4rem}.command-palette-item{width:100%;border:none;border-radius:8px;background:transparent;color:var(--text-primary);cursor:pointer;padding:.75rem .9rem;text-align:left;font-size:.95rem}.command-palette-item:hover,.command-palette-item.active{background:color-mix(in srgb,var(--accent-color) 12%,transparent);color:var(--accent-color)}.storage-info-active{color:var(--accent-color)!important;font-weight:600}.app-error{background:color-mix(in srgb,var(--error) 10%,var(--secondary-bg));border:1px solid color-mix(in srgb,var(--error) 35%,var(--border-color));border-radius:12px;color:var(--text-primary);margin:2rem 0;padding:1.25rem}.app-error strong{color:var(--error)}.filter-section{border-bottom:1px solid var(--border-color);background:color-mix(in srgb,var(--accent-color) 5%,transparent)}.filter-header{padding:1rem 1.5rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;font-weight:600;color:var(--accent-color);transition:background .2s}.filter-header:hover{background:color-mix(in srgb,var(--accent-color) 10%,transparent)}.filter-icon{font-size:.8rem;transition:transform .2s;display:inline-block}.filter-section.collapsed .filter-icon{transform:rotate(-90deg)}.filter-content{padding:1rem 1.5rem;border-top:1px solid var(--border-color);overflow:hidden;transition:max-height .3s ease;max-height:500px}.filter-section.collapsed .filter-content{max-height:0;padding:0 1.5rem;border-top:none}.filter-actions{display:flex;gap:.5rem;margin-bottom:1rem}.filter-actions button{flex:1;padding:.4rem;background:var(--border-color);border:1px solid var(--border-color);color:var(--text-primary);border-radius:4px;cursor:pointer;font-size:.85rem;transition:all .2s}.filter-actions button:hover{background:var(--accent-color);border-color:var(--accent-color)}.filter-list{max-height:200px;overflow-y:auto;margin-bottom:1rem;padding-right:.5rem}.filter-item{display:flex;align-items:center;gap:.5rem;padding:.4rem 0;cursor:pointer;font-size:.9rem}.filter-item input[type=checkbox]{accent-color:var(--accent-color);width:1rem;height:1rem;cursor:pointer}.filter-item label{cursor:pointer;flex:1;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.filter-item:hover label{color:var(--text-primary)}.apply-filter-btn{width:100%;padding:.6rem;background:var(--accent-color);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;transition:background .2s}.apply-filter-btn:hover{background:var(--accent-hover)}.quiz-set-selector{border-bottom:1px solid var(--border-color);background:color-mix(in srgb,var(--accent-color) 5%,transparent)}.quiz-set-selector.collapsed .quiz-set-list{max-height:0;padding:0 1.5rem;border-top:none}.quiz-set-selector.collapsed #quiz-set-icon{transform:rotate(-90deg)}.quiz-set-selector-header{padding:1rem 1.5rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;font-weight:600;color:var(--accent-color);transition:background .2s}.quiz-set-selector-header:hover{background:color-mix(in srgb,var(--accent-color) 10%,transparent)}.quiz-set-list{padding:1rem 1.5rem;border-top:1px solid var(--border-color);overflow:hidden;transition:max-height .3s ease;max-height:500px;display:flex;flex-direction:column;gap:.5rem}.quiz-set-btn{padding:.75rem 1rem;background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:.9rem;font-weight:500;text-align:left;transition:all .2s;width:100%}.quiz-set-btn:hover{background:color-mix(in srgb,var(--accent-color) 15%,transparent);border-color:var(--accent-color)}.quiz-set-btn.active{background:var(--accent-color);border-color:var(--accent-color);color:#fff;font-weight:600}.theme-toggle{background:none;border:none;cursor:pointer;padding:.3rem;border-radius:4px;transition:all .2s;color:var(--text-secondary);width:36px;height:36px;display:flex;align-items:center;justify-content:center}.theme-toggle img{width:24px;height:24px;opacity:.7;transition:opacity .2s,filter .2s;filter:brightness(0) opacity(.6)}.theme-toggle img[data-theme-icon=sun]{width:28px;height:28px}[data-theme=dark] .theme-toggle img{filter:brightness(0) invert(1) opacity(.7)}.theme-toggle:hover img{opacity:1}.theme-toggle:hover{color:var(--text-primary);background:#0000000f}[data-theme=dark] .theme-toggle:hover{background:#ffffff14}.filter-list::-webkit-scrollbar{width:6px}
