.memorize-overall{margin-bottom:24px}.memorize-overall-bar{height:8px;background:var(--gray-4);border-radius:4px;overflow:hidden;margin-top:8px}.memorize-overall-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--violet-9),var(--cyan-9));transition:width .5s ease}.memorize-categories{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;margin-bottom:32px}.memorize-cat-card{padding:16px;border-radius:var(--radius-3);border:1px solid var(--gray-5);background:var(--gray-2);cursor:pointer;transition:border-color .2s ease,background .2s ease}.memorize-cat-card:hover{border-color:var(--violet-7);background:var(--gray-3)}.memorize-cat-card--active{border-color:var(--violet-8)}.memorize-cat-icon{font-size:36px;margin-bottom:6px;display:block}.memorize-cat-name{font-weight:600;font-size:var(--font-size-5);color:var(--gray-12);margin-bottom:4px}.memorize-cat-count{font-size:var(--font-size-4);color:var(--gray-9)}.memorize-modes{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}.memorize-progress{height:6px;background:var(--gray-4);border-radius:3px;overflow:hidden;margin-top:8px}.memorize-progress-fill{height:100%;border-radius:3px;transition:width .4s ease}.memorize-progress-fill--novice{background:var(--gray-8)}.memorize-progress-fill--beginner{background:var(--orange-9)}.memorize-progress-fill--intermediate{background:var(--blue-9)}.memorize-progress-fill--proficient{background:var(--cyan-9)}.memorize-progress-fill--expert{background:var(--grass-9)}.flashcard-fullscreen{position:fixed;inset:0;z-index:100;background:var(--color-background);display:flex;flex-direction:column;overflow:hidden}.flashcard-fullscreen-header{display:flex;align-items:center;gap:12px;padding:12px 16px;flex-shrink:0}.flashcard-split-wrapper{flex:1;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr auto;gap:16px;min-height:0;padding:0 16px 16px}.flashcard-left{grid-column:1;grid-row:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px;border-radius:var(--radius-3);border:1px solid var(--gray-5);background:var(--gray-2);cursor:pointer;overflow-y:auto;min-height:0}.flashcard-answer{text-align:left;width:100%;margin-top:16px;padding-top:16px;border-top:1px solid var(--gray-5)}.flashcard-right{grid-column:2;grid-row:1;border-radius:var(--radius-3);border:1px solid var(--gray-5);overflow:hidden;min-height:0}.flashcard-right iframe{width:100%;height:100%;border:none;background:var(--gray-1)}.flashcard-controls{grid-column:1/-1;grid-row:2;display:flex;flex-direction:column;align-items:center;gap:8px;flex-shrink:0}.flashcard-property{font-size:52px;font-weight:700;color:var(--violet-11);font-family:var(--font-mono,monospace);margin-bottom:12px}.flashcard-prompt{font-size:var(--font-size-5);color:var(--gray-9)}.flashcard-category-badge{display:inline-block;padding:2px 10px;border-radius:9999px;font-size:var(--font-size-3);font-weight:600;margin-bottom:16px}.flashcard-description{font-size:var(--font-size-5);color:var(--gray-12);line-height:1.7;margin-bottom:12px}.flashcard-values{list-style:none;padding:0;margin:0 0 16px}.flashcard-value{padding:6px 0;border-bottom:1px solid var(--gray-4);font-size:var(--font-size-4);line-height:1.6}.flashcard-value code{font-family:var(--font-mono,monospace);background:var(--violet-3);padding:1px 6px;border-radius:var(--radius-1);font-weight:600;font-size:.9em}.flashcard-value-desc{color:var(--gray-9);margin-left:8px}.flashcard-demo-wrapper{margin-top:auto;border-radius:var(--radius-2);overflow:hidden;border:1px solid var(--gray-4)}.flashcard-rating{display:flex;gap:8px;justify-content:center;margin-top:16px;flex-shrink:0}.flashcard-counter{text-align:center;font-size:var(--font-size-3);color:var(--gray-9);margin-bottom:12px;flex-shrink:0}.flashcard-nav{display:flex;gap:8px;justify-content:center;margin-top:8px;flex-shrink:0}.flashcard-hint{font-size:var(--font-size-3);color:var(--violet-10);font-style:italic;margin-top:8px;padding:8px 12px;border-radius:var(--radius-2);border-left:3px solid var(--violet-6)}.fill-blank-container{margin:0 auto}.fill-blank-code{font-size:var(--font-size-4);line-height:1.8;background:var(--gray-2);padding:16px;border-radius:var(--radius-3);border:1px solid var(--gray-5);margin-bottom:16px;white-space:pre-wrap}.fill-blank-code,.fill-blank-input{font-family:var(--font-mono,monospace)}.fill-blank-input{font-size:inherit;background:var(--violet-3);border:1px solid var(--violet-7);border-radius:var(--radius-1);padding:2px 8px;color:var(--violet-11);font-weight:600;outline:none;min-width:100px;transition:border-color .2s}.fill-blank-input:focus{border-color:var(--violet-9);box-shadow:0 0 0 2px var(--violet-4)}.fill-blank-input--correct{background:var(--grass-3);border-color:var(--grass-7);color:var(--grass-11)}.fill-blank-input--incorrect{background:var(--red-3);border-color:var(--red-7);color:var(--red-11)}.fill-blank-preview{margin-top:16px}.fill-blank-preview iframe{width:100%;height:140px;border:1px solid var(--gray-4);border-radius:var(--radius-2);background:var(--gray-1)}.fill-blank-controls{display:flex;gap:8px;justify-content:center;margin-top:16px}.matcher-container,.matcher-mode{flex:1;display:flex;flex-direction:column;min-height:0}.matcher-container{margin:0 auto;width:100%}.matcher-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:stretch;flex:1;min-height:0}@media (max-width:640px){.matcher-grid{grid-template-columns:1fr}}.matcher-preview{border:1px solid var(--gray-5);border-radius:var(--radius-3);overflow:hidden;display:flex;flex-direction:column;flex:1;min-height:0}.matcher-preview-label{padding:8px 12px;background:var(--gray-3);font-size:var(--font-size-3);font-weight:600;color:var(--gray-11);border-bottom:1px solid var(--gray-5)}.matcher-preview iframe{width:100%;height:auto!important;flex:1;min-height:100px;border:none;background:var(--gray-1)}.matcher-options{display:flex;flex-direction:column;gap:8px;justify-content:center;min-height:0;overflow-y:auto}.matcher-option{padding:12px 16px;border:1px solid var(--gray-5);border-radius:var(--radius-2);background:var(--gray-2);cursor:pointer;font-family:var(--font-mono,monospace);font-size:var(--font-size-4);line-height:1.6;transition:border-color .2s,background .2s;text-align:left;white-space:pre-wrap}.matcher-option:hover{border-color:var(--violet-7)}.matcher-option--selected{border-color:var(--violet-8);background:var(--violet-3)}.matcher-option--correct{border-color:var(--grass-8);background:var(--grass-3)}.matcher-option--incorrect{border-color:var(--red-8);background:var(--red-3)}.matcher-left{flex-direction:column;gap:12px}.matcher-css-context,.matcher-left{display:flex;min-height:0;overflow:hidden}.matcher-css-context{border:1px solid var(--gray-5);border-radius:var(--radius-3);flex:1;flex-direction:column}.matcher-css-label{padding:8px 12px;background:var(--gray-3);font-size:var(--font-size-3);font-weight:600;color:var(--gray-11);border-bottom:1px solid var(--gray-5)}.matcher-css-code{font-family:var(--font-mono,monospace);font-size:var(--font-size-2);line-height:1.6;padding:12px;margin:0;background:var(--gray-2);overflow-x:auto;white-space:pre;flex:1;min-height:0;overflow-y:auto}.matcher-css-line{padding:1px 4px;border-radius:2px}.matcher-css-line--blank{background:var(--violet-3);border-left:3px solid var(--violet-8);padding-left:8px;margin-left:-4px}.matcher-css-line--correct{background:var(--grass-3);border-left:3px solid var(--grass-8);padding-left:8px;margin-left:-4px}.matcher-css-line--revealed{background:var(--orange-3);border-left:3px solid var(--orange-8);padding-left:8px;margin-left:-4px}.matcher-feedback{grid-column:1/-1;text-align:center;padding:12px;border-radius:var(--radius-2);font-weight:600;font-size:var(--font-size-5)}.matcher-feedback--correct{background:var(--grass-3);color:var(--grass-11)}.matcher-feedback--incorrect{background:var(--red-3);color:var(--red-11)}.matcher-feedback-title{font-size:var(--font-size-5);font-weight:600;margin-bottom:8px}.matcher-feedback-explanation{font-size:var(--font-size-2);font-weight:400;line-height:1.5;text-align:left;max-width:520px;margin:0 auto}.matcher-feedback-explanation p{margin:4px 0}.matcher-feedback-explanation p:first-child{color:var(--grass-11);font-weight:500}.matcher-feedback-explanation p:last-child:not(:first-child){color:var(--red-11);opacity:.85}.drill-container{margin:0 auto;text-align:center}.drill-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding:12px 16px;background:var(--gray-2);border-radius:var(--radius-3);border:1px solid var(--gray-5)}.drill-timer{font-size:40px;font-weight:700;font-family:var(--font-mono,monospace);color:var(--gray-12)}.drill-timer--warning{color:var(--orange-9)}.drill-timer--danger{color:var(--red-9)}.drill-score{font-size:var(--font-size-5);font-weight:700;color:var(--violet-11)}.drill-streak{font-size:var(--font-size-3);color:var(--orange-9);font-weight:600}.drill-question{margin-bottom:24px}.drill-property{font-size:48px;font-weight:700;font-family:var(--font-mono,monospace);color:var(--violet-11);margin-bottom:8px}.drill-prompt{font-size:var(--font-size-4);color:var(--gray-9)}.drill-options{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}@media (max-width:480px){.drill-options{grid-template-columns:1fr}}.drill-option{padding:12px 16px;border:2px solid var(--gray-5);border-radius:var(--radius-2);background:var(--gray-2);cursor:pointer;font-size:var(--font-size-5);font-weight:500;transition:border-color .15s,background .15s;text-align:left}.drill-option:hover{border-color:var(--violet-7)}.drill-option--correct{border-color:var(--grass-8);background:var(--grass-3);color:var(--grass-11)}.drill-option--incorrect{border-color:var(--red-8);background:var(--red-3);color:var(--red-11)}.drill-results{padding:24px;background:var(--gray-2);border-radius:var(--radius-3);border:1px solid var(--gray-5)}.drill-results-score{font-size:64px;font-weight:800;color:var(--violet-11);margin-bottom:8px}.drill-results-stat{font-size:var(--font-size-4);color:var(--gray-9);margin-bottom:4px}.explorer-container{margin:0 auto}.explorer-search{width:100%;padding:10px 16px;border:1px solid var(--gray-6);border-radius:var(--radius-2);background:var(--gray-2);font-size:var(--font-size-5);color:var(--gray-12);margin-bottom:16px;outline:none;transition:border-color .2s}.explorer-search:focus{border-color:var(--violet-8);box-shadow:0 0 0 2px var(--violet-4)}.explorer-tabs{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid var(--gray-4)}.explorer-tab{padding:6px 14px;border:none;border-radius:9999px;background:var(--gray-3);font-size:var(--font-size-3);font-weight:500;color:var(--gray-11);cursor:pointer;transition:background .2s,color .2s}.explorer-tab:hover{background:var(--gray-4)}.explorer-tab--active{background:var(--violet-9);color:var(--gray-1)}.explorer-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.explorer-card{padding:16px;border:1px solid var(--gray-5);border-radius:var(--radius-3);background:var(--gray-2);cursor:pointer;transition:border-color .2s,background .2s}.explorer-card:hover{border-color:var(--violet-7);background:var(--gray-3)}.explorer-card--expanded{grid-column:1/-1;background:var(--gray-1);border-color:var(--violet-6)}.explorer-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.explorer-card-property{font-family:var(--font-mono,monospace);font-weight:600;font-size:var(--font-size-5);color:var(--gray-12)}.explorer-card-desc{font-size:var(--font-size-4);color:var(--gray-9);line-height:1.6;margin-top:6px}.explorer-card-detail{margin-top:16px;padding-top:16px;border-top:1px solid var(--gray-4)}.explorer-card-values{list-style:none;padding:0;margin:0 0 16px}.explorer-card-value{padding:4px 0;font-size:var(--font-size-3);line-height:1.6}.explorer-card-value code{font-family:var(--font-mono,monospace);background:var(--violet-3);padding:1px 6px;border-radius:var(--radius-1);font-weight:600;font-size:.9em}.explorer-card-demo{border:1px solid var(--gray-4);border-radius:var(--radius-2);overflow:hidden}.explorer-card-demo iframe{width:100%;height:140px;border:none;background:var(--gray-1)}.memorize-empty{text-align:center;padding:48px 24px;color:var(--gray-9)}.memorize-empty-icon{font-size:56px;margin-bottom:12px;display:block}.memorize-kbd{display:inline-block;padding:2px 6px;background:var(--gray-3);border:1px solid var(--gray-6);border-radius:var(--radius-1);font-family:var(--font-mono,monospace);font-size:15px;color:var(--gray-10);margin-left:4px}.mode-tip{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--indigo-2);border-left:3px solid var(--indigo-7);border-radius:var(--radius-2);margin-bottom:12px}.mode-tip-dismiss{background:none;border:none;cursor:pointer;font-size:18px;color:var(--gray-8);padding:0 4px;line-height:1;flex-shrink:0}.mode-tip-dismiss:hover{color:var(--gray-11)}.due-review-card{padding:16px;border-radius:var(--radius-3);border:1px solid var(--crimson-5);background:var(--crimson-2);margin-bottom:24px}.due-review-card--clear{border-color:var(--green-5);background:var(--green-2)}.due-review-list{display:flex;flex-direction:column;gap:6px}.due-review-item{padding:8px 12px;border-radius:var(--radius-2);background:var(--gray-1);border:1px solid var(--gray-4)}.due-review-prop{font-family:var(--font-mono,monospace);font-weight:600;font-size:var(--font-size-3);color:var(--gray-12)}.science-sidebar{margin-bottom:24px;border:1px solid var(--gray-5);border-radius:var(--radius-3);overflow:hidden}.science-sidebar-toggle{width:100%;padding:12px 16px;background:var(--gray-2);border:none;cursor:pointer;text-align:left;transition:background .2s}.science-sidebar-toggle:hover{background:var(--gray-3)}.science-sidebar-icon{font-size:18px}.science-sidebar-chevron{font-size:10px;color:var(--gray-8);transition:transform .2s;margin-left:auto}.science-sidebar-chevron--open{transform:rotate(180deg)}.science-sidebar-content{padding:12px 16px 16px;border-top:1px solid var(--gray-4)}.science-sidebar-groups{display:flex;flex-direction:column;gap:8px}.science-group-card{overflow:hidden}.science-group-header{width:100%;display:flex;align-items:center;background:none;border:none;cursor:pointer;padding:0;text-align:left}.science-group-tip{padding:8px 12px;border-left:3px solid var(--violet-7);border-radius:var(--radius-2)}.science-paper{padding:8px 0;border-bottom:1px solid var(--gray-3)}.science-paper:last-child{border-bottom:none}.session-checkin-overlay,.session-summary-overlay{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;padding:16px}.session-checkin-card,.session-summary-card{background:var(--color-background);border-radius:var(--radius-4);padding:24px;max-width:420px;width:100%;box-shadow:0 8px 32px rgba(0,0,0,.2)}.session-checkin-emoji{font-size:28px;padding:8px;border:2px solid var(--gray-5);border-radius:var(--radius-2);background:var(--gray-2);cursor:pointer;transition:border-color .15s,background .15s,transform .15s;flex:1;min-width:48px}.session-checkin-emoji:hover{border-color:var(--violet-7);transform:scale(1.05)}.session-checkin-emoji--active{border-color:var(--violet-8);background:var(--violet-3);transform:scale(1.1)}.session-summary-stats{display:flex;gap:16px;justify-content:center;margin-bottom:12px}.session-summary-stat{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1}.session-summary-pill{padding:6px 12px;border:1px solid var(--gray-5);border-radius:9999px;background:var(--gray-2);font-size:var(--font-size-2);color:var(--gray-11);cursor:pointer;transition:border-color .15s,background .15s}.session-summary-pill:hover{border-color:var(--violet-7)}.session-summary-pill--active{border-color:var(--violet-8);background:var(--violet-3);color:var(--violet-11);font-weight:600}.insights-section{margin-top:24px;border:1px solid var(--gray-5);border-radius:var(--radius-3);overflow:hidden}.insights-toggle{width:100%;padding:12px 16px;background:var(--gray-2);border:none;cursor:pointer;text-align:left;transition:background .2s}.insights-toggle:hover{background:var(--gray-3)}.insights-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;padding:16px}.insights-card{padding:16px;border:1px solid var(--gray-4);border-radius:var(--radius-2);background:var(--gray-1);text-align:center;display:flex;flex-direction:column;align-items:center;gap:2px}.insights-card--wide{grid-column:span 2;text-align:left;align-items:stretch}.insights-bar{width:100%;flex:1;border-radius:2px;min-width:8px;transition:height .3s ease}