*{margin:0;padding:0;box-sizing:border-box}:root,:root[data-theme=dark]{--color-bg: #252529;--color-bg-secondary: #1a1a1f;--color-bg-tertiary: #35353a;--color-text: #f8f8f8;--color-text-secondary: #c8c8c8;--color-text-muted: #8a8a8a;--color-primary: #E97A93;--color-primary-hover: #d66a82;--color-success: #7AE98F;--color-error: #E97A7A;--color-border: #454548;--spacing-xs: .5rem;--spacing-sm: .75rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--border-radius: 8px;--border-radius-sm: 6px;--transition: all .2s ease}:root[data-theme=light]{--color-bg: #FFF9FA;--color-bg-secondary: #FDF2F4;--color-bg-tertiary: #F5EAED;--color-text: #3A3A3A;--color-text-secondary: #5A5A5A;--color-text-muted: #6B6B6B;--color-primary: #E97A93;--color-primary-hover: #d66a82;--color-success: #4CAF7A;--color-error: #D64545;--color-border: #E8DDE0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-bg);color:var(--color-text);line-height:1.6}html{-webkit-text-size-adjust:100%;text-size-adjust:100%}.app-header,.app-footer,.problem-display,.named-column,.diagram-grid,.diagram-grid-container,.answer-choices,.answer-choice,.answer-wrapper,.column-header,button,.clickable-title{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-webkit-touch-callout:none}input,textarea,.feedback-textarea{user-select:text;-webkit-user-select:text}canvas{-webkit-user-drag:none}.app{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}.app-header{background-color:var(--color-bg);border-bottom:1px solid var(--color-border);padding:var(--spacing-lg) var(--spacing-md)}.header-content{max-width:1400px;margin:0 auto;display:flex;flex-direction:column;gap:var(--spacing-lg)}.title-section{display:block}.title-section h1{font-size:1.75rem;margin-bottom:var(--spacing-xs);color:var(--color-text)}.clickable-title{cursor:pointer;transition:var(--transition);-webkit-user-select:none;user-select:none}.clickable-title:hover{color:var(--color-primary)}.title-section .subtitle{font-size:.9rem;color:var(--color-text-muted)}.controls{display:flex;flex-direction:column;gap:var(--spacing-md)}.app-main{flex:1;padding:var(--spacing-xl) var(--spacing-md);width:100%;background-color:var(--color-bg-secondary)}.app-main>*{max-width:1400px;margin:0 auto}.app-footer{background-color:var(--color-bg);border-top:1px solid var(--color-border);padding:var(--spacing-lg) var(--spacing-md)}.footer-content{max-width:1400px;margin:0 auto;display:flex;flex-direction:row;justify-content:space-between;align-items:center;gap:var(--spacing-md);width:100%;min-height:60px}@media (min-width: 768px){.footer-zone{display:flex;align-items:center;min-width:0}.footer-zone-left{flex:1 1 auto;justify-content:flex-start;min-width:0}.footer-zone-center{flex:0 0 auto;justify-content:center;margin:0 var(--spacing-md)}.footer-zone-right{flex:1 1 auto;justify-content:flex-end;min-width:0}.footer-zone-center{display:flex}}.footer-actions{display:flex;gap:var(--spacing-md);align-items:center}@media (min-width: 768px){.header-content{flex-direction:row;justify-content:space-between;align-items:center}.controls{flex-direction:row;align-items:center}.title-section h1{font-size:2rem}}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:var(--spacing-lg)}.spinner{width:48px;height:48px;border:4px solid var(--color-bg-tertiary);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:.3}50%{opacity:.5}}.skeleton-grid{pointer-events:none}.answer-choice.skeleton{pointer-events:none;cursor:default;border:2px solid transparent}.error-message{text-align:center;padding:var(--spacing-2xl);max-width:600px;margin:0 auto}.error-message h2{color:var(--color-error);margin-bottom:var(--spacing-md)}.error-message p{color:var(--color-text-secondary);margin-bottom:var(--spacing-xl)}.error-message .primary-button{padding:var(--spacing-md) var(--spacing-xl);border:none;border-radius:var(--border-radius);font-size:1rem;cursor:pointer;transition:var(--transition);background-color:var(--color-primary);color:#fff}.error-message .primary-button:hover{background-color:var(--color-primary-hover)}.problem-display{display:grid;grid-template-columns:1fr;gap:var(--spacing-xl)}@media (min-width: 768px){.problem-display{grid-template-columns:repeat(3,1fr);gap:var(--spacing-xl)}}.named-column{background-color:var(--color-bg);border-radius:var(--border-radius);padding:var(--spacing-lg);border:1px solid var(--color-border);box-shadow:0 1px 3px #0003}.column-header h2{font-size:1.5rem;text-align:center;margin-bottom:var(--spacing-lg);color:var(--color-text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.diagram-grid-container{display:flex;flex-direction:row;gap:var(--spacing-md);justify-content:center;flex-wrap:wrap}.answer-choices{display:flex;flex-direction:row;gap:var(--spacing-md);justify-content:center;flex-wrap:wrap;align-items:flex-start}@media (min-width: 768px){.diagram-grid-container{flex-direction:column;align-items:center}.answer-choices{flex-direction:column;align-items:center;gap:var(--spacing-xs)}}.diagram-grid{transition:var(--transition)}.diagram-grid.clickable:focus{outline:2px solid var(--color-primary);outline-offset:2px}.hint-button-footer{background-color:var(--color-primary);color:#fff;border:none;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius);font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition);min-height:44px}.hint-button-footer:hover{background-color:var(--color-primary-hover)}.answer-wrapper{position:relative;display:flex;flex-direction:column;align-items:center;overflow:visible;margin:0;padding:0}.rule-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(-8px);background-color:var(--color-bg-secondary);color:var(--color-text);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius);font-size:.9rem;white-space:nowrap;z-index:100;box-shadow:0 4px 12px #0000004d;border:2px solid var(--color-border);animation:tooltipFadeIn .2s ease-out;pointer-events:none;max-width:calc(100vw - 32px);transition:transform .15s ease-out}@media (max-width: 767px){.rule-tooltip{z-index:100;white-space:normal;max-width:min(calc(100vw - 32px),300px)}}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%) translateY(-4px)}to{opacity:1;transform:translate(-50%) translateY(-8px)}}.answer-choice{background:none;border:none;padding:0!important;margin:0;min-height:0;cursor:pointer;transition:var(--transition);border-radius:var(--border-radius-sm);box-sizing:border-box;display:block;line-height:0;flex-shrink:0;box-shadow:0 0 0 3px transparent}.answer-choice:disabled{cursor:default}.answer-choice:not(:disabled):hover{box-shadow:0 0 0 3px var(--color-primary)}.answer-choice.correct{box-shadow:0 0 0 3px var(--color-success),0 0 12px #22c55e66}.answer-choice.incorrect{box-shadow:0 0 0 3px var(--color-error),0 0 12px #ef444466}.answer-choice.faded{opacity:.4;transition:opacity .3s ease}.answer-choice.highlighted{box-shadow:0 0 0 3px var(--color-primary),0 0 12px #3b82f699}.selection-indicator{position:absolute;font-size:2rem;color:var(--color-primary);font-weight:700;pointer-events:none}@media (max-width: 767px){.selection-indicator{top:-1.5rem;left:50%;transform:translate(-50%) rotate(-90deg);z-index:1}}@media (min-width: 768px){.selection-indicator{top:50%;left:-2.5rem;transform:translateY(-50%)}}.answer-indicator{position:absolute;display:flex;align-items:center;justify-content:center;pointer-events:none}.indicator-icon{font-weight:700;pointer-events:auto;cursor:default;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.indicator-icon.correct{color:var(--color-success)}.indicator-icon.incorrect{color:var(--color-error)}@media (max-width: 767px){.answer-indicator{display:none}}@media (min-width: 768px){.answer-indicator{top:50%;right:-50px;transform:translateY(-50%)}.indicator-icon{font-size:2.5rem}}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.difficulty-selector-mobile{display:flex;align-items:center;gap:var(--spacing-xs)}.difficulty-label-mobile{font-size:.875rem;color:var(--color-text-secondary);white-space:nowrap}.difficulty-selector-desktop{display:none}.difficulty-select{padding:var(--spacing-xs) var(--spacing-md) var(--spacing-xs) var(--spacing-sm);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--border-radius);color:var(--color-text);font-size:1rem;font-weight:700;cursor:pointer;min-width:60px;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%2394a3b8' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center;background-size:12px}.difficulty-select:focus{outline:2px solid var(--color-primary);outline-offset:0}@media (min-width: 768px){.difficulty-selector-mobile{display:none}.difficulty-selector-desktop{display:flex;flex-direction:column;gap:var(--spacing-xs);min-width:200px}}.difficulty-selector label{font-size:.9rem;color:var(--color-text-secondary)}.difficulty-value{font-weight:700;color:var(--color-primary);margin-left:var(--spacing-xs)}.difficulty-slider{width:100%;height:6px;border-radius:var(--border-radius-sm);background:var(--color-bg-tertiary);outline:none;-webkit-appearance:none}.difficulty-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--color-primary);cursor:pointer;transition:var(--transition)}.difficulty-slider::-webkit-slider-thumb:hover{background:var(--color-primary-hover);transform:scale(1.2)}.difficulty-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:none;transition:var(--transition)}.difficulty-slider::-moz-range-thumb:hover{background:var(--color-primary-hover);transform:scale(1.2)}.difficulty-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--color-text-muted)}.theme-toggle{background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);padding:var(--spacing-xs) var(--spacing-sm);min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius);cursor:pointer;transition:var(--transition)}.theme-toggle:hover{background-color:var(--color-border);transform:scale(1.05)}.theme-icon{font-size:1.25rem}.accessibility-toggle{background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);padding:var(--spacing-xs) var(--spacing-sm);min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius);cursor:pointer;transition:var(--transition)}.accessibility-toggle:hover{background-color:var(--color-border);transform:scale(1.05)}.accessibility-toggle.active{background-color:var(--color-primary);border-color:var(--color-primary)}.accessibility-toggle.active:hover{background-color:var(--color-primary-hover)}.accessibility-box{width:20px;height:20px;border:2px solid var(--color-text);border-radius:3px;display:flex;align-items:center;justify-content:center;position:relative}.accessibility-toggle.active .accessibility-box{border-color:#fff}.accessibility-star{font-size:1rem;font-weight:700;color:#fff;line-height:1;transform:translateY(1px)}.account-menu{position:relative;display:flex;align-items:center}.account-trigger{display:flex;align-items:center;gap:var(--spacing-xs);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--border-radius);padding:var(--spacing-xs) var(--spacing-sm);cursor:pointer;transition:var(--transition);min-height:44px}.account-trigger:hover{background-color:var(--color-border)}.account-avatar{width:28px;height:28px;background-color:var(--color-primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600;flex-shrink:0}.account-name{font-size:.875rem;color:var(--color-text);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.account-caret{font-size:.625rem;color:var(--color-text-muted);margin-left:2px}@media (max-width: 480px){.account-name,.account-caret{display:none}}@media (min-width: 768px){.account-name{max-width:150px}}.account-dropdown{position:absolute;top:calc(100% + 4px);right:0;min-width:200px;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--border-radius);box-shadow:0 4px 12px #0000004d;z-index:1000;animation:dropdownFadeIn .15s ease-out}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.account-dropdown-header{padding:var(--spacing-sm) var(--spacing-md)}.account-dropdown-email{font-size:.8rem;color:var(--color-text-muted);word-break:break-all}.account-dropdown-divider{height:1px;background-color:var(--color-border)}.account-dropdown-item{display:block;width:100%;padding:var(--spacing-sm) var(--spacing-md);background:none;border:none;text-align:left;font-size:.9rem;color:var(--color-text);cursor:pointer;transition:var(--transition);min-height:40px;text-decoration:none}.account-dropdown-item:hover{background-color:var(--color-bg-tertiary)}.account-dropdown-item:last-child{border-radius:0 0 var(--border-radius) var(--border-radius)}.login-button{background-color:var(--color-primary);color:#fff;border:none;padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--border-radius);font-size:.875rem;font-weight:500;cursor:pointer;transition:var(--transition);min-height:44px;white-space:nowrap}.login-button:hover{background-color:var(--color-primary-hover);transform:scale(1.05)}.login-button:focus{outline:2px solid var(--color-primary);outline-offset:2px}button{font-family:inherit;font-size:1rem;padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--border-radius);cursor:pointer;transition:var(--transition);font-weight:500;min-height:44px;touch-action:manipulation;white-space:nowrap}.next-button{background-color:var(--color-primary);color:#fff;font-size:1.1rem;padding:var(--spacing-md) var(--spacing-xl)}.next-button:hover{background-color:var(--color-primary-hover);box-shadow:0 4px 12px #3b82f64d}.share-button{background-color:var(--color-bg-tertiary);color:var(--color-text);display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);font-size:.875rem}.share-button:hover{background-color:var(--color-border)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-lg);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background-color:var(--color-bg-secondary);border-radius:var(--border-radius);max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #00000080;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.modal-header h3{font-size:1.25rem;margin:0}.modal-close{background:none;border:none;color:var(--color-text-muted);font-size:2rem;line-height:1;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-sm);transition:var(--transition)}.modal-close:hover{background-color:var(--color-bg-tertiary);color:var(--color-text)}.feedback-toggle{background-color:transparent;color:var(--color-text-muted);border:1px solid var(--color-border);padding:var(--spacing-sm) var(--spacing-md);font-size:.9rem}.feedback-toggle:hover{background-color:var(--color-bg-tertiary);color:var(--color-text)}.feedback-modal{padding:var(--spacing-xl)}.feedback-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.feedback-hint{font-size:.9rem;color:var(--color-text-muted);margin:0}.form-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.checkbox-label{display:flex;align-items:flex-start;gap:var(--spacing-sm);cursor:pointer;font-size:.95rem;color:var(--color-text-secondary)}.checkbox-label input[type=checkbox]{margin-top:2px;cursor:pointer;width:18px;height:18px;flex-shrink:0}.feedback-textarea{width:100%;padding:var(--spacing-md);background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--border-radius);color:var(--color-text);font-family:inherit;font-size:.95rem;resize:vertical;min-height:120px}.feedback-textarea:focus{outline:2px solid var(--color-primary);outline-offset:0;border-color:var(--color-primary)}.feedback-error{color:#dc3545;font-size:var(--font-size-sm);margin:0;padding:var(--spacing-sm);background-color:#dc35451a;border-radius:var(--border-radius-sm)}.feedback-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-sm)}.submit-button{background-color:var(--color-primary);color:#fff;flex:1}.submit-button:hover{background-color:var(--color-primary-hover)}.cancel-button{background-color:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border)}.cancel-button:hover{background-color:var(--color-bg-tertiary)}.feedback-success{text-align:center;padding:var(--spacing-2xl)}.success-icon{font-size:3rem;color:var(--color-success);margin-bottom:var(--spacing-md)}.feedback-success h3{color:var(--color-success);margin-bottom:var(--spacing-sm)}.feedback-success p{color:var(--color-text-muted);font-size:.95rem}@media (max-width: 767px){.app-header,.app-main,.app-footer{padding:var(--spacing-md) var(--spacing-sm)}.header-content{flex-direction:row;justify-content:space-between;align-items:center;gap:var(--spacing-md)}.title-section{margin-bottom:0;display:flex;flex-direction:row;justify-content:space-between;align-items:center}.title-section h1{font-size:1.5rem;margin-bottom:0}.title-section .subtitle{font-size:.85rem;display:none}.controls{display:flex;flex-direction:row;gap:var(--spacing-sm);align-items:center}.share-button,.hint-button-footer,.footer-actions .feedback-toggle{display:none}.named-column{padding:var(--spacing-md) var(--spacing-sm)}.column-header h2{font-size:.875rem;margin-bottom:var(--spacing-sm);text-align:left;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.diagram-grid-container,.answer-choices{gap:var(--spacing-sm)}.footer-actions{display:flex;gap:var(--spacing-sm);align-items:stretch}.feedback-toggle,.share-button{flex-shrink:0;padding:var(--spacing-sm) var(--spacing-md);font-size:.875rem;min-height:44px}}@media (max-width: 767px) and (orientation: portrait){.app{height:100svh;max-height:100svh;overflow:hidden;display:grid;grid-template-rows:auto 1fr auto}@supports (height: 100dvh){.app{height:100dvh;max-height:100dvh}}.app-header,.app-footer{padding:var(--spacing-xs) var(--spacing-sm)}.app-main{padding:var(--spacing-xs) var(--spacing-sm);overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.problem-display{display:flex;flex-direction:column;gap:var(--spacing-xs);height:100%}.named-column{flex:1;min-height:0;padding:var(--spacing-xs);display:flex;flex-direction:column}.column-header h2{font-size:.75rem;margin-bottom:4px;padding-bottom:4px;flex-shrink:0}.diagram-grid-container,.answer-choices{flex:1;flex-wrap:nowrap;gap:4px;justify-content:space-evenly;align-items:center}.footer-content{gap:4px}.next-button{font-size:.9rem;padding:var(--spacing-xs) var(--spacing-md)}}@media (max-width: 1023px) and (orientation: landscape){.app-footer,.hidden-landscape{display:none!important}.app{grid-template-rows:auto 1fr}.app-header{padding:4px var(--spacing-sm)}.header-content{gap:var(--spacing-lg)}.title-section h1{font-size:1rem;margin-bottom:0}.title-section .subtitle{display:none!important}.controls{gap:var(--spacing-md);align-items:center}.mobile-landscape-buttons{display:flex;gap:var(--spacing-lg);align-items:center}.help-button-landscape{width:28px;height:28px;padding:0;font-size:.8rem;background-color:transparent;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.next-button-landscape{padding:6px var(--spacing-md);font-size:.875rem;min-height:32px;max-height:32px;background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--border-radius);cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}.next-button-landscape:hover:not(:disabled){background-color:var(--color-primary-hover)}.next-button-landscape:disabled{opacity:.5;cursor:not-allowed}.difficulty-selector-mobile{gap:4px}.difficulty-label-mobile{font-size:.7rem}.difficulty-select{padding:2px 6px;font-size:.8rem;min-width:50px;min-height:28px}.mobile-menu-button{min-width:28px;min-height:28px;padding:4px 6px;font-size:1rem}.app-main{padding:var(--spacing-xs) var(--spacing-sm)}.problem-display{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-sm)}.diagram-grid-container,.answer-choices{flex-direction:column;align-items:center;gap:4px}.column-header h2{font-size:.75rem;margin-bottom:4px}.named-column{padding:var(--spacing-xs)}.app-footer{padding:4px var(--spacing-sm)}.footer-content{gap:var(--spacing-xs)}.next-button{padding:4px var(--spacing-sm);font-size:.85rem;min-height:32px}.selection-indicator{top:50%;left:-1.5rem;transform:translateY(-50%) rotate(0)}.answer-indicator{display:flex;top:50%;right:-35px;transform:translateY(-50%)}.indicator-icon{font-size:1.5rem}}.kb-controls-button{background-color:transparent;color:var(--color-text-muted);border:1px solid var(--color-border);padding:var(--spacing-sm) var(--spacing-md);font-size:.9rem;display:none;align-items:center;gap:var(--spacing-xs)}.kb-controls-button:hover{background-color:var(--color-bg-tertiary);color:var(--color-text)}.kb-icon{font-size:1rem}.kb-label{font-weight:500}@media (min-width: 768px){.kb-controls-button{display:flex}}.kb-controls-modal{padding:var(--spacing-xl);max-width:500px}.kb-controls-content{display:flex;flex-direction:column;gap:var(--spacing-lg)}.kb-section{display:flex;flex-direction:column;gap:var(--spacing-sm)}.kb-section h4{color:var(--color-primary);font-size:1rem;font-weight:600;margin:0}.kb-hint{color:var(--color-text-muted);font-size:.85rem;font-style:italic;margin:var(--spacing-xs) 0 0 0}.kb-hint kbd{font-style:normal}.kb-shortcuts{display:flex;flex-direction:column;gap:var(--spacing-sm)}.kb-shortcut{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm);background-color:var(--color-bg);border-radius:var(--border-radius-sm)}.kb-shortcut kbd{display:inline-block;padding:.25rem .5rem;background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:4px;font-family:Monaco,Menlo,Courier New,monospace;font-size:.875rem;color:var(--color-text);box-shadow:0 2px #0003;min-width:2rem;text-align:center}.kb-shortcut span{color:var(--color-text-secondary);font-size:.9rem}.mobile-menu-button{display:none}.desktop-controls{display:flex;gap:var(--spacing-sm)}@media (max-width: 767px){.mobile-menu-button{display:flex;align-items:center;justify-content:center;background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);padding:var(--spacing-xs) var(--spacing-sm);min-width:44px;min-height:44px;border-radius:var(--border-radius);cursor:pointer;transition:var(--transition);font-size:1.5rem;color:var(--color-text)}.mobile-menu-button:hover{background-color:var(--color-border);transform:scale(1.05)}.desktop-controls{display:none}}.mobile-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#000000bf;z-index:999;animation:fadeIn .2s ease-out}.mobile-menu-panel{position:fixed;top:0;right:0;bottom:0;width:280px;max-width:85vw;background-color:var(--color-bg-secondary);border-left:1px solid var(--color-border);box-shadow:-4px 0 12px #0000004d;z-index:1000;display:flex;flex-direction:column;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.mobile-menu-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.mobile-menu-header h3{font-size:1.25rem;margin:0;color:var(--color-text)}.mobile-menu-close{background:none;border:none;color:var(--color-text-muted);font-size:2rem;line-height:1;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-sm);transition:var(--transition);min-height:32px}.mobile-menu-close:hover{background-color:var(--color-bg-tertiary);color:var(--color-text)}.mobile-menu-content{flex:1;overflow-y:auto;padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-xl)}.mobile-menu-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.mobile-menu-section h4{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin:0}.mobile-menu-buttons{display:flex;flex-direction:column;gap:var(--spacing-sm)}.mobile-menu-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm);background-color:var(--color-bg);border-radius:var(--border-radius-sm);border:1px solid var(--color-border)}.mobile-menu-item span{color:var(--color-text-secondary);font-size:.95rem}.hint-button-mobile{background-color:var(--color-primary);color:#fff;border:none;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius);font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition);width:100%;text-align:center}.hint-button-mobile:hover{background-color:var(--color-primary-hover)}.mobile-feedback-btn,.mobile-help-btn{width:100%}.help-button{background-color:var(--color-primary);color:#fff;border:none;padding:var(--spacing-sm) var(--spacing-md);border-radius:50%;width:44px;height:44px;font-size:1.25rem;font-weight:700;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}.help-button:hover{background-color:var(--color-primary-hover);transform:scale(1.05)}.help-button-text{border-radius:var(--border-radius);width:100%;font-size:.9rem;padding:var(--spacing-sm) var(--spacing-md)}.help-modal{max-width:600px;padding:var(--spacing-xl)}.help-content{display:flex;flex-direction:column;gap:var(--spacing-xl);max-height:70vh;overflow-y:auto;padding-right:var(--spacing-sm);margin-right:calc(-1 * var(--spacing-sm))}.help-content::-webkit-scrollbar{width:8px}.help-content::-webkit-scrollbar-track{background:var(--color-bg);border-radius:4px}.help-content::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px;transition:var(--transition)}.help-content::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.help-content{scrollbar-width:thin;scrollbar-color:var(--color-border) var(--color-bg)}.help-section{display:flex;flex-direction:column;gap:var(--spacing-sm)}.help-section h4{color:var(--color-primary);font-size:1.1rem;font-weight:600;margin:0}.help-section p{color:var(--color-text-secondary);font-size:.95rem;line-height:1.6;margin:0}.help-list{margin:0;padding-left:var(--spacing-lg);color:var(--color-text-secondary);font-size:.95rem}.help-list li{margin-bottom:var(--spacing-xs);line-height:1.6}.help-list li strong{color:var(--color-text)}.help-list kbd{display:inline-block;padding:.2rem .4rem;background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:4px;font-family:Monaco,Menlo,Courier New,monospace;font-size:.875rem;color:var(--color-text)}.help-hint{font-size:.9rem;color:var(--color-text-muted);font-style:italic;margin:var(--spacing-xs) 0}.help-example{display:flex;gap:var(--spacing-lg);margin-top:var(--spacing-sm);padding:var(--spacing-md);background-color:var(--color-bg);border-radius:var(--border-radius);border:1px solid var(--color-border)}.help-example-column{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm);align-items:center}.help-example-column h5{font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin:0}.help-diagrams{display:flex;flex-direction:column;gap:var(--spacing-xs);align-items:center}.help-diagram-wrapper{position:relative;display:flex;flex-direction:column;align-items:center;border-radius:var(--border-radius-sm);border:3px solid transparent;transition:var(--transition)}.help-correct-answer{border-color:var(--color-success);box-shadow:0 0 8px #22c55e4d}.help-link{color:var(--color-primary);text-decoration:none;font-weight:500;transition:var(--transition)}.help-link:hover{text-decoration:underline;color:var(--color-primary-hover)}@media (max-width: 767px){.help-modal{max-width:100%;padding:var(--spacing-lg)}.help-example{flex-direction:column;gap:var(--spacing-lg)}.help-example-column h5{font-size:.85rem}.help-diagrams{flex-direction:row;flex-wrap:wrap;gap:var(--spacing-xs);justify-content:center}}.streak-display{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--border-radius);font-size:.95rem;color:var(--color-text-secondary);position:relative;transition:var(--transition)}.streak-display:hover{background-color:var(--color-border)}.streak-emoji{font-size:1.2rem}.streak-text{font-weight:500;white-space:nowrap}.streak-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:8px;padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--border-radius-sm);font-size:.85rem;color:var(--color-text);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease;box-shadow:0 4px 12px #0000004d}.streak-display:hover .streak-tooltip{opacity:1}.streak-display-mobile{width:100%;justify-content:center;font-size:1rem;padding:var(--spacing-md);border:2px solid var(--color-primary);background-color:var(--color-bg);align-items:center}.streak-display-mobile .streak-emoji{align-self:flex-start;margin-top:2px}.streak-display-mobile:hover{transform:none}.streak-mobile-content{display:flex;flex-direction:column;gap:4px;align-items:center}.streak-text-muted{font-size:.85rem;color:var(--color-text-muted);font-weight:400}@media (max-width: 767px){.streak-display-desktop,.footer-zone-center{display:none!important}.footer-content{flex-direction:row;justify-content:space-between;gap:var(--spacing-sm)}.footer-zone{display:flex;align-items:center}.footer-zone-right{flex:1;order:-1;justify-content:flex-start}.footer-zone-left{flex:0 0 auto;order:1;justify-content:flex-end}.next-button{width:100%;padding:var(--spacing-sm) var(--spacing-lg);font-size:1rem}}@media (min-width: 768px) and (max-width: 1024px){.streak-display-desktop{font-size:.8rem}.footer-actions button{padding:var(--spacing-xs) var(--spacing-sm);font-size:.85rem}.next-button{padding:var(--spacing-sm) var(--spacing-md);font-size:.9rem}}.not-found{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg);padding:var(--spacing-lg)}.not-found-content{text-align:center;max-width:400px}.not-found-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:150px;height:150px;margin:0 auto var(--spacing-xl)}.not-found-grid .grid-cell{background-color:var(--color-bg-secondary);border-radius:var(--border-radius-sm);border:2px solid var(--color-border)}.not-found-grid .grid-cell.filled{background-color:var(--color-success);border-color:var(--color-success)}.not-found h1{font-size:2rem;margin-bottom:var(--spacing-sm);color:var(--color-text)}.not-found p{color:var(--color-text-secondary);margin-bottom:var(--spacing-xl)}.not-found .home-button{background-color:var(--color-primary);color:#fff;border:none;padding:var(--spacing-sm) var(--spacing-xl);font-size:1rem;border-radius:var(--border-radius);cursor:pointer;transition:var(--transition)}.not-found .home-button:hover{opacity:.9;transform:translateY(-1px)}
