@charset "UTF-8";:root{--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--bg-hover: #f1f5f9;--text-primary: #0d1d24;--text-secondary: #374151;--text-tertiary: #4b5563;--text-inverse: #ffffff;--border-primary: #e2e8f0;--border-secondary: #cbd5e1;--border-light: #f1f5f9;--color-interactive: #1f7084;--color-interactive-hover: #193946;--color-interactive-active: #132b35;--color-interactive-light: #d4e8ed;--color-interactive-lighter: #f0f7f9;--color-accent: #F5751C;--color-accent-hover: #d66118;--color-accent-light: #ffe8d5;--color-accent-lighter: #fff5ed;--color-success: #22c55e;--color-success-bg: #f0fdf4;--color-error: #dc2626;--color-error-bg: #fef2f2;--color-warning: #f59e0b;--color-warning-bg: #fefce8;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-interactive: rgba(24, 101, 242, .4);--shadow-interactive-light: rgba(24, 101, 242, .1);--overlay-bg: rgba(0, 0, 0, .5);--bg-info: #f1f5f9;--text-disabled: #6b7280;--bg-gradient-start: #193946;--bg-gradient-end: #0d1d24}[data-theme=dark]{--bg-primary: #1a1a1a;--bg-secondary: #242424;--bg-tertiary: #2d2d2d;--bg-hover: #333333;--text-primary: #f1f5f9;--text-secondary: #9ca3af;--text-tertiary: #6b7280;--text-inverse: #0d1d24;--border-primary: #3a3a3a;--border-secondary: #4a4a4a;--border-light: #2d2d2d;--color-interactive: #52a3b7;--color-interactive-hover: #268ca5;--color-interactive-active: #1f7084;--color-interactive-light: #0d1d24;--color-interactive-lighter: rgba(31, 112, 132, .1);--color-accent: #ff9f4d;--color-accent-hover: #F5751C;--color-accent-light: rgba(249, 143, 78, .15);--color-accent-lighter: rgba(249, 143, 78, .08);--color-success: #22c55e;--color-success-bg: rgba(34, 197, 94, .15);--color-error: #ef4444;--color-error-bg: rgba(239, 68, 68, .15);--color-warning: #f59e0b;--color-warning-bg: rgba(251, 191, 36, .25);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .5);--shadow-interactive: rgba(82, 163, 183, .4);--shadow-interactive-light: rgba(82, 163, 183, .1);--overlay-bg: rgba(0, 0, 0, .7);--bg-info: rgba(224, 242, 254, .1);--text-disabled: #4b5563;--bg-gradient-start: #1f7084;--bg-gradient-end: #132b35}.bg-primary{background-color:var(--bg-primary)}.bg-secondary{background-color:var(--bg-secondary)}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.border-primary{border-color:var(--border-primary)}.theme-toggle{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;padding:8px 12px;font-size:20px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;line-height:1}.theme-toggle:hover{background:var(--bg-hover);border-color:var(--color-interactive);transform:scale(1.05)}.theme-toggle:active{transform:scale(.95)}*{font-family:Helvetica,"sans-serif";font-size:14px;box-sizing:border-box}html{scrollbar-gutter:stable;background:var(--bg-primary);overflow-x:hidden}body{margin:0;padding:0;overflow-y:auto;overflow-x:hidden;background:var(--bg-primary);color:var(--text-primary)}.math-skill-category{margin-bottom:20px}.math-skill-category-label{font-size:24px;font-weight:700;margin-bottom:5px}.math-skills{margin-top:15px;display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,400px),1fr));gap:15px}.math-skill{font-size:16px;cursor:pointer;margin:0}.math-skill-checkbox{cursor:pointer;margin:0 5px 0 0}.math-skill-description{cursor:pointer}.math-skill-description-clickable{font-size:16px;cursor:pointer;color:var(--color-interactive);line-height:1.5;text-decoration:none;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;display:flex;align-items:center;flex-wrap:wrap;gap:6px}.math-skill-description-clickable:hover{color:var(--color-interactive-hover)}.math-skill--auxiliary{opacity:.85}.math-skill-auxiliary-badge{display:inline-flex;align-items:center;gap:3px;padding:1px 6px;font-size:11px;font-weight:600;color:var(--text-secondary);background:var(--bg-tertiary);border-radius:3px;cursor:help;white-space:nowrap}.math-skill-auxiliary-badge:before{content:"■";font-size:7px;opacity:.7}.math-skill-selector{padding:0 25px;max-width:100%;overflow-x:hidden}.answer-input{color:var(--text-primary);background:var(--bg-primary);border-radius:3px;border-width:1px;border:1px solid var(--border-primary);font-size:20px;line-height:20px;height:40px;padding:4px 5px;text-align:left;margin:0;display:block}.answer-input::placeholder{text-align:left;color:var(--text-tertiary)}.answer-input:focus{outline:none;box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--color-interactive)}.answer-input.answer-input-medium{width:300px;max-width:100%}.answer-input.answer-input-large,.arithmetic-problem .answer-input.answer-input-large{width:100%!important;max-width:500px!important}.arithmetic-problem .answer-input:focus{outline:none;border-color:var(--color-interactive-hover);box-shadow:0 0 0 3px var(--color-interactive-lighter)}.disabled-input{background-color:var(--bg-info);color:var(--text-disabled)}.answer-label{display:block;font-size:18px;font-weight:600;margin-bottom:5px;text-align:left}.answer-input-set{margin-bottom:20px;text-align:left}.category-column{display:flex;flex-direction:column;min-width:0;overflow-wrap:break-word}.category-header{font-weight:700;color:var(--text-secondary);margin:0 0 8px;font-size:18px;border-bottom:1px solid var(--border-primary);padding-bottom:4px;cursor:pointer;text-decoration:none}.category-header:hover{color:var(--color-interactive-hover)}@media (max-width: 480px){.math-skill-category-label{font-size:1.25rem}}.demo-banner{background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%);color:#fff;padding:12px 20px;font-size:1.1rem;font-weight:600;box-shadow:var(--shadow-md);animation:slideDown .3s ease-out;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:24px}.demo-banner .demo-banner-content{display:flex;flex-direction:column;gap:4px;text-align:center}.demo-banner .demo-banner-text{font-size:1.1rem;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.2)}.demo-banner .demo-banner-subtitle{font-size:.9rem;font-weight:400;opacity:.95;text-shadow:0 1px 2px rgba(0,0,0,.2)}.demo-banner .demo-banner-cta{background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.5);padding:8px 20px;border-radius:6px;font-weight:600;font-size:.95rem;text-decoration:none;transition:all .2s ease;white-space:nowrap}.demo-banner .demo-banner-cta:hover{background:#ffffff4d;border-color:#fffc;transform:translateY(-1px)}@media (max-width: 600px){.demo-banner{flex-direction:column;gap:12px}}.verification-banner{background:#fef3c7;color:#92400e;text-align:center;padding:10px 20px;font-size:.95rem;display:flex;align-items:center;justify-content:center;gap:12px;animation:slideDown .3s ease-out}.verification-banner .verification-banner-text{font-weight:500}.verification-banner .verification-banner-link{color:#92400e;font-weight:600;text-decoration:underline;cursor:pointer}.verification-banner .verification-banner-link:hover{color:#78350f}.verification-banner .verification-banner-dismiss{background:none;border:none;color:#92400e;font-size:1.1rem;cursor:pointer;padding:2px 6px;border-radius:4px;line-height:1;opacity:.7;transition:opacity .2s,background .2s}.verification-banner .verification-banner-dismiss:hover{opacity:1;background:#0000001a}.payment-success-banner{background:#d1fae5;color:#065f46;padding:16px 20px;border-radius:8px;margin-bottom:20px;text-align:center}.payment-success-banner p{margin:0;font-weight:600}.payment-success-banner .verification-note{font-weight:400;margin-top:8px;font-size:.9rem}.resend-verification-btn{margin-left:12px;font-size:.85rem}.checkout-complete-page{display:flex;justify-content:center;align-items:center;min-height:60vh;padding:40px 20px}.checkout-complete-loading{text-align:center}.checkout-complete-loading .spinner{width:40px;height:40px;border:4px solid var(--border-primary);border-top-color:var(--color-interactive);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}.checkout-complete-loading p{font-size:1.1rem;color:var(--text-secondary)}.checkout-complete-error{text-align:center}.checkout-complete-error p{font-size:1.1rem;color:var(--text-secondary);margin-bottom:20px}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.demo-user-badge{display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:6px;background:var(--bg-secondary);border:1px solid var(--border-primary)}.demo-user-badge .demo-user-name{font-weight:500;color:var(--text-primary)}.demo-user-badge .demo-badge{background:var(--accent-color);color:#fff;padding:2px 8px;border-radius:4px;font-size:.75rem;font-weight:700;letter-spacing:.5px}.demo-badge-inline{background:var(--accent-color);color:#fff;padding:2px 6px;border-radius:3px;font-size:.7rem;font-weight:700;letter-spacing:.5px;margin-left:6px}.header{background:var(--bg-primary);border-bottom:1px solid var(--border-primary);box-shadow:var(--shadow-sm)}.nav{display:flex;align-items:center;background:var(--bg-primary);color:var(--text-primary);padding:2px 24px;height:51px;max-width:1400px;margin:0 auto}.logo-and-title{cursor:pointer;display:flex;align-items:center;text-decoration:none;transition:opacity .2s}.logo-and-title:hover{opacity:.8}.logo{margin-right:8px;display:block}.title{font-size:1.35rem;font-weight:600;color:var(--color-interactive)}.nav-links{list-style:none;display:flex;gap:8px;margin:0;padding:0}.nav-links li a{font-size:1.05rem;font-weight:500;color:var(--text-primary);text-decoration:none;cursor:pointer;padding:8px 16px;border-radius:6px;transition:background .2s,color .2s;display:block}.nav-links li a:hover{background:var(--bg-hover);color:var(--color-interactive)}.nav-links li a.active{background:var(--color-interactive-light);color:var(--color-interactive);font-weight:600}.nav-links li a.active:hover{background:var(--color-interactive-light);color:var(--color-interactive-hover)}.nav-left{flex:1;margin-left:32px}.nav-right{margin-left:auto}.sound-toggle-button{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;padding:8px;border-radius:6px;color:var(--text-secondary);transition:background .2s,color .2s}.sound-toggle-button:hover{background:var(--bg-hover);color:var(--color-interactive)}.settings-icon-link{display:flex;align-items:center;padding:8px;margin-left:8px;text-decoration:none;color:var(--text-primary);transition:background .2s,color .2s;border-radius:6px}.settings-icon-link:hover{background:var(--bg-secondary);color:var(--color-interactive)}.settings-icon-link .settings-icon{font-size:1.5rem}.user-menu{position:relative}.user-menu .user-menu-trigger{display:flex;align-items:center;gap:8px;cursor:pointer;padding:8px 16px;border-radius:6px;transition:background .2s}.user-menu .user-menu-trigger:hover{background:var(--bg-hover)}.user-menu .user-menu-trigger .username{font-size:1.05rem;font-weight:500;color:var(--text-primary)}.user-menu .user-menu-trigger .gear-icon{font-size:1.1rem;color:var(--text-secondary);transition:transform .2s,color .2s}.user-menu .user-menu-trigger:hover .gear-icon{color:var(--color-interactive)}.user-menu .dropdown{position:absolute;top:100%;right:0;margin-top:10px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:4px;box-shadow:var(--shadow-md);min-width:150px;z-index:1000;list-style:none;padding:0}.user-menu .dropdown li{margin:0}.user-menu .dropdown li a{display:block;padding:12px 16px;color:var(--text-primary);text-decoration:none;font-size:1rem;font-weight:400;transition:background .2s}.user-menu .dropdown li a:hover{background:var(--bg-hover);color:var(--color-interactive)}.user-menu .dropdown li:first-child a{border-radius:4px 4px 0 0}.user-menu .dropdown li:last-child a{border-radius:0 0 4px 4px}.user-menu .dropdown-open{animation:dropdownFadeIn .15s ease-out}.language-menu{position:relative}.language-menu .language-menu-trigger{display:flex;align-items:center;cursor:pointer;padding:8px;border-radius:6px;color:var(--text-secondary);transition:background .2s,color .2s}.language-menu .language-menu-trigger:hover{background:var(--bg-hover);color:var(--color-interactive)}.language-menu .dropdown{position:absolute;top:100%;right:0;margin-top:10px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:4px;box-shadow:var(--shadow-md);min-width:140px;z-index:1000;list-style:none;padding:0}.language-menu .dropdown li{margin:0}.language-menu .dropdown li a{display:block;padding:10px 16px;color:var(--text-primary);text-decoration:none;font-size:.95rem;font-weight:400;transition:background .2s}.language-menu .dropdown li a:hover{background:var(--bg-hover);color:var(--color-interactive)}.language-menu .dropdown li a.active{font-weight:600;color:var(--color-interactive)}.language-menu .dropdown li:first-child a{border-radius:4px 4px 0 0}.language-menu .dropdown li:last-child a{border-radius:0 0 4px 4px}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.menu-toggle{display:none;font-size:1.5rem;background:none;border:none;color:var(--text-primary);cursor:pointer;padding:8px;margin-left:auto;transition:background .2s;border-radius:6px}.menu-toggle:hover{background:var(--bg-hover)}.mobile-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--overlay-bg);z-index:999;opacity:0;pointer-events:none;transition:opacity .3s}.mobile-menu-overlay.active{opacity:1;pointer-events:auto}.mobile-menu{position:fixed;top:0;right:-280px;width:280px;height:100%;background:var(--bg-primary);z-index:1000;box-shadow:var(--shadow-lg);transition:right .3s ease-in-out;overflow-y:auto;display:flex;flex-direction:column}.mobile-menu.active{right:0}.mobile-menu-close{position:absolute;top:12px;right:12px;background:none;border:none;font-size:2rem;line-height:1;color:var(--text-secondary);cursor:pointer;padding:4px 8px;transition:color .2s,background .2s;border-radius:4px;z-index:1}.mobile-menu-close:hover{color:var(--text-primary);background:var(--bg-hover)}.mobile-menu-close:active{background:var(--bg-hover)}.mobile-menu-user{padding:56px 16px 20px;border-bottom:1px solid var(--border-primary);background:var(--bg-secondary)}.mobile-menu-email{font-size:.95rem;font-weight:600;color:var(--color-interactive);word-break:break-word}.mobile-menu-section{padding:8px 0;border-bottom:1px solid var(--border-primary)}.mobile-menu-section:first-of-type{padding-top:56px}.mobile-menu-section.mobile-menu-secondary{margin-top:auto;border-top:1px solid var(--border-primary);border-bottom:none}.mobile-menu-section.mobile-menu-language{border-bottom:none}.mobile-menu-language-row{display:flex;align-items:center;gap:8px;padding:8px 16px;color:var(--text-secondary)}.mobile-lang-button{background:none;border:1px solid var(--border-primary);border-radius:4px;padding:6px 12px;font-size:.9rem;font-weight:400;color:var(--text-primary);cursor:pointer;transition:background .2s,border-color .2s,color .2s}.mobile-lang-button:hover{background:var(--bg-hover)}.mobile-lang-button.active{font-weight:600;color:var(--color-interactive);border-color:var(--color-interactive);background:var(--color-interactive-light)}.mobile-menu-sound-row{display:flex;align-items:center;gap:8px;padding:8px 16px;color:var(--text-secondary)}.mobile-menu-item{display:block;padding:12px 16px;color:var(--text-primary);text-decoration:none;font-size:1rem;font-weight:500;transition:background .2s,color .2s}.mobile-menu-item:hover{background:var(--bg-hover);color:var(--color-interactive)}.mobile-menu-item:active{background:var(--bg-hover)}.mobile-menu-item.active{background:var(--color-interactive-light);color:var(--color-interactive);font-weight:600}.mobile-menu-item.active:hover{background:var(--color-interactive-light);color:var(--color-interactive-hover)}.page{display:flex;flex-direction:column;min-height:100vh;background:var(--bg-primary)}.loading-container{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:1.2rem;color:var(--text-secondary)}.main{flex:1;background:var(--bg-primary)}.footer{padding:24px 20px;border-top:1px solid var(--border-primary);background:var(--bg-secondary)}.footer__content{display:flex;flex-direction:column;align-items:center;gap:12px;max-width:1200px;margin:0 auto}.footer__contact{display:flex;gap:20px;align-items:center}.footer__link{display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:color .2s ease}.footer__link:hover{color:var(--accent-primary)}.footer__copyright{font-size:.875rem;color:var(--text-secondary)}.practice-title{font-size:2rem;text-align:center;padding:0 20px}.practice-grade-filter{display:flex;align-items:center;justify-content:center;gap:12px;margin:16px 0 24px;padding:0 20px}.practice-grade-filter-label{font-size:1rem;font-weight:500;color:var(--text-secondary)}.practice-grade-select{font-size:1rem;padding:8px 32px 8px 12px;border:1px solid var(--border-primary);border-radius:8px;background-color:var(--bg-secondary);color:var(--text-primary);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;min-width:160px}.practice-grade-select:hover{border-color:var(--border-hover)}.practice-grade-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-primary-transparent)}.practice-problem{display:flex;justify-content:center;min-width:400px;padding-bottom:120px}.practice-problem-footer{position:fixed;bottom:0;width:100%;background-color:var(--bg-primary);border-top:1px solid var(--border-primary);z-index:1000;padding:0 0 0 40px}.practice-problem-buttons{padding:10px 0;display:flex;gap:20px;align-items:center}.practice-problem-body{margin:10px 0 0;outline:none}.prerequisites-section{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:0 10px 12px 20px;padding:8px 12px;background:var(--bg-secondary);border-radius:6px;width:fit-content;max-width:calc(100% - 40px)}.prerequisites-label{font-size:13px;font-weight:500;color:var(--text-secondary);margin-right:4px}.prerequisites-badges{display:flex;flex-wrap:wrap;gap:6px}.prerequisite-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500;text-decoration:none;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.prerequisite-badge:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.prerequisite-badge.prerequisite-mastered{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.prerequisite-badge.prerequisite-learning{background-color:#fff3cd;color:#856404;border:1px solid #ffeaa7}.prerequisite-badge.prerequisite-not-started{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}@media (max-width: 480px){.prerequisites-section{margin:0 10px 10px;padding:6px 10px}.prerequisites-label{font-size:12px}.prerequisite-badge{font-size:11px;padding:3px 8px}}.problem-header{margin:0 10px 6px;width:fit-content;padding:0 10px;display:flex;flex-wrap:wrap;column-gap:16px;row-gap:8px;align-items:baseline}.problem-header h1{border-bottom:1px solid var(--border-primary);font-size:32px;padding:0 0 2px}.problem-header h2{font-size:20px}.problem-header .header-right{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.problem-header .difficulty-dropdown-container{display:flex;align-items:center;gap:8px}.problem-header .difficulty-dropdown-container .difficulty-label{font-size:14px;font-weight:500;color:var(--text-secondary);white-space:nowrap}.problem-header .difficulty-dropdown-container .difficulty-dropdown{padding:4px 8px;border:1px solid var(--border-primary);border-radius:4px;background-color:var(--bg-primary);color:var(--text-primary);font-size:14px;cursor:pointer;transition:border-color .2s}.problem-header .difficulty-dropdown-container .difficulty-dropdown:hover{border-color:var(--border-hover)}.problem-header .difficulty-dropdown-container .difficulty-dropdown:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-primary-alpha)}.problem-header .difficulty-badge{font-size:13px;font-weight:600;padding:4px 10px;border-radius:4px}.problem-header .difficulty-badge--easy{background-color:#d4edda;color:#155724}.problem-header .difficulty-badge--medium{background-color:#fff3cd;color:#856404}.problem-header .difficulty-badge--hard{background-color:#f8d7da;color:#721c24}.problem-header .flow-progress-inline{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text-secondary);padding:4px 10px;background:var(--bg-secondary);border-radius:4px}.problem-header .flow-auto-badge{font-size:11px;font-weight:600;color:var(--text-inverse);background:var(--color-interactive);padding:2px 6px;border-radius:3px;text-transform:uppercase;letter-spacing:.5px}.show-example-button{padding:6px 12px;font-size:14px;font-weight:500;color:var(--color-interactive);background:transparent;border:1px solid var(--color-interactive);border-radius:6px;cursor:pointer;transition:all .15s ease;white-space:nowrap}.show-example-button:hover{background:var(--color-interactive);color:var(--text-inverse)}.worked-example-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.worked-example-modal{background:var(--bg-primary);border-radius:12px;max-width:700px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0000004d}.arithmetic-problem{padding:0 25px}.arithmetic-problem .katex *{font-size:30px!important}.arithmetic-katex{margin:20px 0;word-wrap:break-word;word-break:break-word;overflow-wrap:break-word;white-space:normal;max-width:100%}.arithmetic-problem-type{font-size:22px;text-align:left;margin-bottom:20px;color:var(--text-primary)}@media (max-width: 768px){.nav{height:48px;padding:2px 12px;gap:8px}.nav-links{display:none}.menu-toggle{display:block}.demo-user-badge{display:none}.settings-icon-link{padding:4px;margin-left:4px}.settings-icon-link .settings-icon{font-size:1.3rem}.logo{width:32px;height:32px}.title{font-size:1.1rem}.problem-header h1{font-size:1.5rem;margin:0}}@media (max-width: 480px){.problem-header{margin:0 10px 15px}.practice-title{font-size:1.5rem}.practice-grade-filter{margin:12px 0 16px}.practice-grade-select{min-width:140px;font-size:16px}.arithmetic-problem-type{font-size:1.2rem}.arithmetic-problem .katex *{font-size:20px!important}}.btn{padding:.875rem 1.5rem;border:none;border-radius:6px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background-color:var(--color-accent);color:var(--text-inverse);text-decoration:none}.btn-primary:hover:not(:disabled){box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--color-accent);color:var(--text-inverse)}.btn-primary:visited{color:var(--text-inverse)}.btn-primary:disabled{background-color:var(--bg-info);color:var(--text-disabled)}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary);border:2px solid var(--border-secondary)}.btn-secondary:hover:not(:disabled){background-color:var(--border-secondary);border-color:var(--border-primary)}.btn-danger{background-color:var(--color-error);color:var(--text-inverse)}.btn-danger:hover:not(:disabled){box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--color-error)}.btn-small{padding:.5rem 1rem;font-size:.875rem}.skip-button{all:unset;cursor:pointer;color:var(--color-accent);font-size:1.2rem;font-weight:700;width:65px;text-align:center;height:3rem}.skip-button:hover{text-decoration:underline;text-decoration-thickness:2px}.tooltip-container{position:relative;display:inline-block}.tooltip{visibility:hidden;opacity:0;background-color:var(--bg-primary);color:var(--text-primary);text-align:center;border-radius:6px;padding:8px 12px;position:absolute;bottom:125%;left:50%;transform:translate(-50%);white-space:nowrap;z-index:1000;box-shadow:0 2px 8px #00000026;border:1px solid var(--border-secondary);font-size:14px;font-weight:400;transition:opacity .3s,visibility .3s}.tooltip:after{content:"";position:absolute;top:100%;left:50%;margin-left:-5px;border-width:5px;border-style:solid;border-color:var(--bg-primary) transparent transparent transparent}.tooltip-container:hover .tooltip{visibility:visible;opacity:1}.tooltip-left{visibility:hidden;opacity:0;background-color:var(--bg-primary);color:var(--text-primary);text-align:left;border-radius:6px;padding:8px 12px;position:absolute;bottom:125%;left:50%;white-space:nowrap;z-index:1000;box-shadow:0 2px 8px #00000026;border:1px solid var(--border-secondary);font-size:14px;font-weight:400;transition:opacity .3s,visibility .3s;margin-left:-30px}.tooltip-left:after{content:"";position:absolute;top:100%;left:35px;margin-left:-7px;border-width:5px;border-style:solid;border-color:var(--bg-primary) transparent transparent transparent}.tooltip-container:hover .tooltip-left{visibility:visible;opacity:1}.check-button{min-width:130px;height:3rem;cursor:pointer;border:none;border-radius:6px;font-size:1.2rem;font-weight:700;background-color:var(--color-accent);color:var(--text-inverse)}.check-button:hover{box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--color-accent)}.next-question-button{min-width:215px;height:3rem;cursor:pointer;border:none;border-radius:6px;font-size:1.2rem;font-weight:700;background-color:var(--color-accent);color:var(--text-inverse)}.next-question-button:hover{box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--color-accent)}.revealed-answer{margin-top:16px;margin-bottom:16px}.revealed-answer-label{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.revealed-answer-value{font-size:16px;font-weight:400;color:var(--text-primary)}.arithmetic-problem .answer-input.disabled-input{background-color:#f8fafc;color:var(--text-disabled);cursor:not-allowed}.arithmetic-problem .dsl-fraction-visual{display:inline-block!important;vertical-align:top;margin:20px 30px!important}.arithmetic-problem .dsl-fraction-visual .fraction-bar-container{width:300px!important}.arithmetic-problem .dsl-fraction-visual:nth-of-type(3){margin-left:60px!important}.inline-expression{display:flex;align-items:center;gap:16px;margin:20px 0}.inline-expression .arithmetic-katex.inline{margin:0;font-size:2.4rem}.inline-comparison-dropdown{display:flex;align-items:center}.inline-comparison-dropdown .inline-dropdown{font-size:1.8rem;font-weight:500;padding:8px 12px;border:2px solid var(--border-light);border-radius:8px;background-color:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:all .2s ease;min-width:60px;text-align:center}.inline-comparison-dropdown .inline-dropdown:hover{background-color:var(--bg-secondary);border-color:var(--color-interactive)}.inline-comparison-dropdown .inline-dropdown:focus{outline:none;border-color:var(--color-interactive);box-shadow:0 0 0 3px var(--shadow-interactive-light)}.inline-comparison-dropdown .inline-dropdown option{font-size:1.6rem;padding:4px 8px}.dsl-widget-fraction-input{margin:20px 0}.dsl-widget-fraction-input .answer-input{text-align:center;width:120px;margin:0 auto;display:block}.dsl-widget-grid-select{margin:20px 0}.dsl-widget-grid-select .factor-grid{max-width:500px}.dsl-geometry-visual{margin:20px 0;display:flex;justify-content:center;align-items:center}.dsl-geometry-visual .geometry-visual{text-align:center}.dsl-geometry-visual .geometry-visual .geometry-problem-text{font-size:1.4rem;font-weight:600;color:var(--text-primary);margin-bottom:15px}.dsl-geometry-visual .geometry-visual .geometry-shape{max-width:100%;max-height:300px;width:auto;height:auto}.dsl-geometry-visual .geometry-visual .geometry-hint{margin-top:15px;font-size:1.2rem;color:var(--text-secondary)}.dsl-geometry-visual .geometry-visual .geometry-hint div{margin:4px 0}.arithmetic-problem{max-height:90vh;overflow-y:auto;overflow-x:auto;padding:10px 20px 10px 40px;scroll-behavior:smooth}.arithmetic-problem .answer-input{margin:0;display:block}.arithmetic-problem .dsl-widget-fraction-input,.arithmetic-problem .dsl-widget-grid-select,.arithmetic-problem .dsl-widget-text-input,.arithmetic-problem .dsl-widget-numeric-input{margin-bottom:20px}.arithmetic-problem .result,.arithmetic-problem .revealed-answer{margin-bottom:40px}.arithmetic-problem>*:last-child{margin-bottom:60px}@media (max-height: 700px){.arithmetic-problem{max-height:85vh;padding-top:0}.arithmetic-problem .dsl-geometry-visual .geometry-visual .geometry-shape{max-height:250px}}@media (max-height: 600px){.arithmetic-problem{max-height:80vh}.arithmetic-problem .dsl-geometry-visual .geometry-visual .geometry-shape{max-height:200px}}@media (max-width: 768px){.arithmetic-problem{padding:0 20px}}.dsl-angle-visual{margin:20px 0;display:flex;justify-content:flex-start;align-items:center}.dsl-angle-visual svg{max-width:100%;height:auto}.hint-box{background:var(--color-warning-bg);border:2px solid var(--color-warning);border-radius:8px;padding:20px}.hint-box p{margin:8px 0;font-size:16px;color:var(--text-primary)}.hint-box ul{margin:10px 0;padding-left:20px;text-align:left}.hint-box li{margin:4px 5px 4px 0;font-size:14px;color:var(--text-primary);font-family:monospace;background:var(--color-warning-bg);padding:4px 8px;border-radius:4px;display:inline-block}.hint-caret{margin-right:8px;font-size:13px;color:var(--text-primary);transition:color .2s ease}.hint-content{margin-top:12px;padding:16px;background:var(--color-warning-bg);border:1px solid var(--color-warning);border-radius:6px;width:100%;max-width:100%;box-sizing:border-box;overflow-wrap:break-word;color:var(--text-primary);font-size:14px}.hint-content p{margin:8px 0;font-size:14px;color:var(--text-primary)}.hint-content ul{margin:10px 0;padding-left:20px;text-align:left;color:var(--text-primary)}.hint-content li{margin:4px 0 8px;font-size:13px;color:var(--text-primary);font-family:monospace;background:var(--color-warning-bg);padding:4px 8px;border-radius:4px;display:block;word-break:break-all;overflow-wrap:anywhere}.radio-options{display:flex;gap:30px}.radio-option{display:flex;align-items:center;cursor:pointer;padding:15px 25px;border:2px solid #cbd5e1;border-radius:8px;transition:all .2s}.radio-option:hover{border-color:var(--color-interactive);background-color:var(--bg-secondary)}.radio-option input[type=radio]{margin-right:10px;transform:scale(1.2)}.radio-option input[type=radio]:checked+.radio-label{color:var(--color-interactive-hover)}.radio-label{font-size:18px;font-weight:500;color:var(--text-secondary)}.skill-description{text-align:center;font-size:16px;color:var(--text-secondary);margin:10px 0 20px;font-style:italic}.clickable-numbers-container{display:flex;justify-content:left;align-items:center;gap:30px;margin:30px auto}.clickable-numbers-container .clickable-number{display:flex;align-items:center;justify-content:center;min-width:120px;padding:20px 35px;font-size:42px;font-weight:700;border:3px solid var(--border-secondary);border-radius:12px;background-color:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:all .2s ease}.clickable-numbers-container .clickable-number:hover{border-color:var(--color-interactive);background-color:var(--bg-hover);transform:scale(1.05)}.clickable-numbers-container .clickable-number.selected{background-color:var(--color-interactive);border-color:var(--color-interactive);color:var(--text-inverse);box-shadow:0 0 12px var(--shadow-interactive)}@media (max-width: 480px){.clickable-numbers-container{gap:15px;margin:20px auto}.clickable-numbers-container .clickable-number{min-width:80px;padding:12px 20px;font-size:28px;border-width:2px;border-radius:8px}}.clickable-numbers-container .inline-dropdown-container{display:flex;align-items:center;justify-content:center}.clickable-numbers-container .inline-dropdown-container .inline-dropdown{font-size:32px;font-weight:700;padding:15px 20px;border:3px solid var(--border-secondary);border-radius:8px;background-color:var(--bg-primary);color:var(--text-primary);cursor:pointer;min-width:80px;text-align:center;transition:all .2s ease}.clickable-numbers-container .inline-dropdown-container .inline-dropdown:hover:not(:disabled){border-color:var(--color-interactive);background-color:var(--bg-hover)}.clickable-numbers-container .inline-dropdown-container .inline-dropdown:focus{outline:none;border-color:var(--color-interactive);box-shadow:0 0 0 3px var(--shadow-interactive-light)}.clickable-numbers-container .inline-dropdown-container .inline-dropdown:disabled{cursor:not-allowed;opacity:.6}.clickable-numbers-container .inline-dropdown-container .inline-dropdown option{font-size:24px;padding:8px}.dsl-line-plot{margin:30px 0;padding:20px;background:var(--bg-primary);border-radius:8px;border:2px solid var(--border-light);display:inline-block;min-width:400px}.dsl-line-plot .line-plot-visual{width:500px;height:auto;display:block}.line-plot-visual{width:100%;max-width:500px;height:auto;display:block}@keyframes fadeIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.dsl-image{margin:20px 0;text-align:center}.dsl-image img{max-width:100%;height:auto;border-radius:8px}.dsl-svg{margin:16px 0;text-align:left;display:flex;justify-content:flex-start}.dsl-svg svg{max-width:320px;height:auto}.dsl-table{margin:20px 0;border-collapse:collapse;border:2px solid var(--border-light)}.dsl-table th,.dsl-table td{border:1px solid var(--border-light);padding:12px;text-align:center}.dsl-table th{background-color:var(--bg-secondary);font-weight:600;color:var(--text-primary)}.dsl-table td{color:var(--text-primary)}.dsl-number-line{margin:20px 0;padding:20px}.dsl-fraction-visual{margin:20px 0;padding:20px;text-align:center}.dsl-list{margin:20px 0;padding-left:40px}.dsl-list li{margin-bottom:8px;line-height:1.5;color:var(--text-primary)}.dsl-explanation{margin:20px 0;padding:16px;background-color:var(--bg-secondary);border-left:4px solid var(--accent-primary);border-radius:4px;color:var(--text-primary);line-height:1.6}.dsl-widget-comparison{margin-top:20px;text-align:center}.dsl-widget-comparison .answer-label{display:block;font-size:18px;color:var(--text-secondary);margin-bottom:16px}.dsl-widget-multiple-choice{margin-top:20px;text-align:center}.dsl-widget-multiple-choice .answer-label{display:block;font-size:18px;color:var(--text-secondary);margin-bottom:16px}.dsl-widget-dropdown{margin-top:20px;text-align:center}.dsl-widget-dropdown .answer-label{display:block;font-size:18px;color:var(--text-secondary);margin-bottom:10px}.dsl-widget-dropdown .input-hint{display:block;font-size:14px;color:var(--text-secondary);margin-bottom:8px;font-style:italic}.dsl-widget-dropdown select.answer-input{font-size:24px;font-weight:600;padding:12px 20px;border:2px solid var(--border-secondary);border-radius:8px;background-color:var(--bg-primary);color:var(--text-primary);cursor:pointer;min-width:120px;transition:all .2s ease}.dsl-widget-dropdown select.answer-input:hover:not(:disabled){border-color:var(--color-interactive);background-color:var(--bg-hover)}.dsl-widget-dropdown select.answer-input:focus{outline:none;border-color:var(--color-interactive);box-shadow:0 0 0 3px var(--shadow-interactive-light)}.dsl-widget-dropdown select.answer-input:disabled{cursor:not-allowed;opacity:.6}.hints-section{margin-top:20px;margin-bottom:16px}.hints-section .hints-toggle{background:none;border:none;padding:0;font-size:14px;font-weight:400;cursor:pointer;text-align:left;color:var(--text-primary)}.hints-section .hints-toggle:hover{text-decoration:underline;color:var(--color-interactive)}.hints-section .hints-content{margin-top:12px}.hints-section .hints-content .hint-item{margin-bottom:10px;line-height:1.5;font-size:14px;color:var(--text-secondary)}.hints-section .hints-content .hint-item:last-child{margin-bottom:0}.language-selector{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;background-color:var(--bg-secondary);border-radius:6px;border:1px solid var(--border-light)}.language-selector-label{font-size:14px;font-weight:500;color:var(--text-secondary);margin:0}.language-selector-dropdown{padding:4px 8px;font-size:14px;border:1px solid var(--border-light);border-radius:4px;background-color:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:border-color .2s ease}.language-selector-dropdown:hover{border-color:var(--primary-color)}.language-selector-dropdown:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px rgba(var(--primary-color-rgb),.1)}.scratch-pad-canvas-container{text-align:center;display:block;margin-left:auto;margin-right:auto;overflow-x:auto}.scratch-pad-canvas{border:2px solid black}.scratch-pad-toolbar{display:flex;gap:10px;justify-content:center;margin-top:10px}.scratch-pad-tool-button{border:1px solid var(--border-secondary);padding:8px 12px;border-radius:4px;cursor:pointer}.number-line-canvas{border:1px solid black;cursor:pointer}.number-line-info{margin-top:10px}.estimate-tip{font-size:14px;color:#666}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;min-height:200px}.loading-spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#1f7084;border-radius:50%;animation:spin 1s linear infinite}.loading-message{margin-top:16px;font-size:16px;color:var(--text-secondary);text-align:center}.widget-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:30px 20px;min-height:150px;text-align:center;color:var(--text-secondary);font-size:14px}.widget-loading:before{content:"";display:block;width:32px;height:32px;margin-bottom:12px;border:3px solid #e2e8f0;border-top-color:#1f7084;border-radius:50%;animation:spin 1s linear infinite}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:var(--bg-primary);border-radius:12px;box-shadow:0 4px 20px #00000026;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;position:relative}.report-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-light)}.report-modal .modal-header h2{margin:0;font-size:1.5rem;color:var(--text-primary)}.report-modal .modal-header .modal-close-btn{background:none;border:none;font-size:2rem;line-height:1;color:var(--text-secondary);cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.report-modal .modal-header .modal-close-btn:hover{background-color:var(--bg-secondary);color:var(--text-primary)}.report-modal .modal-body{padding:1.5rem}.report-modal .modal-body .report-description{font-size:.875rem;color:var(--text-secondary);margin-bottom:1.5rem;line-height:1.5}.report-modal .modal-body .form-group{margin-bottom:1.25rem}.report-modal .modal-body .form-group .form-label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary);font-size:.9375rem}.report-modal .modal-body .form-group .form-label .required-asterisk{color:var(--color-error)}.report-modal .modal-body .form-group .form-label .optional-text{font-weight:400;color:var(--text-secondary);font-size:.875rem}.report-modal .modal-body .form-group .form-select{width:100%;padding:.625rem;border:1px solid var(--border-light);border-radius:6px;font-size:.9375rem;background-color:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:border-color .2s}.report-modal .modal-body .form-group .form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.report-modal .modal-body .form-group .form-select:disabled{opacity:.6;cursor:not-allowed}.report-modal .modal-body .form-group .form-textarea{width:100%;padding:.625rem;border:1px solid var(--border-light);border-radius:6px;font-size:.9375rem;background-color:var(--bg-primary);color:var(--text-primary);font-family:inherit;resize:vertical;min-height:100px;transition:border-color .2s}.report-modal .modal-body .form-group .form-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.report-modal .modal-body .form-group .form-textarea:disabled{opacity:.6;cursor:not-allowed}.report-modal .modal-body .form-group .character-count{text-align:right;font-size:.8125rem;color:var(--text-secondary);margin-top:.375rem}.report-modal .modal-body .error-message{background-color:var(--bg-error);color:var(--color-error);padding:.75rem;border-radius:6px;font-size:.875rem;margin-bottom:1rem}.report-modal .modal-body .modal-footer{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem}.report-modal .modal-body .modal-footer button{padding:.625rem 1.25rem;font-size:.9375rem;border-radius:6px;border:none;cursor:pointer;font-weight:500;transition:all .2s}.report-modal .modal-body .modal-footer button:disabled{opacity:.6;cursor:not-allowed}.report-modal .modal-body .modal-footer .btn-secondary{background-color:var(--bg-secondary);color:var(--text-primary)}.report-modal .modal-body .modal-footer .btn-secondary:hover:not(:disabled){background-color:var(--bg-tertiary)}.report-modal .modal-body .modal-footer .btn-primary{background-color:var(--color-primary);color:#fff}.report-modal .modal-body .modal-footer .btn-primary:hover:not(:disabled){background-color:var(--color-primary-dark)}.practice-problem-footer-layout{display:flex;align-items:center;justify-content:space-between;width:100%;gap:1rem}.footer-left{display:flex;align-items:center}.report-problem-button{background:none;border:none;color:var(--text-secondary);font-size:.875rem;padding:.5rem .75rem;cursor:pointer;border-radius:4px;transition:all .2s;text-decoration:underline}.report-problem-button:hover{color:var(--text-primary);background-color:var(--bg-secondary)}.report-problem-button:active{background-color:var(--bg-tertiary)}@media (max-width: 768px){.modal-content{max-width:100%;border-radius:12px 12px 0 0;max-height:95vh}.report-modal .modal-header{padding:1rem}.report-modal .modal-header h2{font-size:1.25rem}.report-modal .modal-body{padding:1rem}.report-modal .modal-body .modal-footer{flex-direction:column-reverse}.report-modal .modal-body .modal-footer button{width:100%}.practice-problem-footer-layout{flex-direction:row;gap:.5rem}.footer-left{width:100%;justify-content:center}.report-problem-button{font-size:.8125rem}}.auth-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;background-color:var(--bg-secondary);padding:40px 16px 32px}.auth-card{background:var(--bg-primary);border-radius:8px;box-shadow:var(--shadow-md);padding:48px 40px;width:100%;max-width:480px}.auth-card.wide{max-width:680px}.auth-content{width:100%;display:flex;flex-direction:column;gap:1.5rem}.auth-header{text-align:center;margin-bottom:2rem}.auth-title{font-size:2rem;font-weight:700;color:var(--color-interactive);margin:0 0 .5rem}.auth-subtitle{font-size:1rem;color:var(--text-secondary);margin:0}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-size:.875rem;font-weight:600;color:var(--text-primary)}.form-input,.form-select{padding:.75rem 1rem;border:2px solid var(--border-light);border-radius:6px;font-size:1rem;transition:border-color .2s;background-color:var(--bg-primary);color:var(--text-primary);width:100%}.form-input.error,.form-select.error{border-color:var(--color-error)}select.form-input,select.form-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;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='%23666' d='M6 8L0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}.form-error{font-size:.875rem;color:var(--color-error);margin-top:.25rem}.password-input-container{position:relative;display:flex;align-items:center}.password-input-container input{width:100%;padding-right:3rem}.password-input-container .password-toggle-button{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:color .2s}.password-input-container .password-toggle-button:hover:not(:disabled){color:var(--text-primary)}.password-input-container .password-toggle-button:focus{outline:none;color:var(--color-interactive)}.password-input-container .password-toggle-button:disabled{cursor:not-allowed;opacity:.5}.password-input-container .password-toggle-button svg{display:block}.form-input-wrapper{position:relative}.form-input-status{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:.875rem}.form-input-status.checking{color:#666}.form-input-status.available{color:#22c55e}.form-input-status.taken{color:#ef4444}.form-help-text{font-size:.875rem;color:#666;margin-top:.25rem}.form-help{font-size:.875rem;margin-top:.25rem}.form-help.error{color:var(--color-error)}.input-icon{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:1rem;pointer-events:none}.input-icon.success{color:var(--color-success)}.input-icon.error{color:var(--color-error)}.forgot-password-link{margin-top:.5rem;text-align:right}.forgot-password-link a{color:var(--color-interactive);text-decoration:none;font-size:.875rem;font-weight:500}.forgot-password-link a:hover{text-decoration:underline}.link-button{background:none;border:none;color:var(--color-interactive);text-decoration:none;font-size:inherit;font-weight:500;cursor:pointer;padding:0}.link-button:hover{text-decoration:underline}.form-button{padding:.875rem 1.5rem;border:none;border-radius:6px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s}.form-button.primary{background-color:var(--color-accent);color:var(--text-inverse)}.form-button.primary:hover:not(:disabled){box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--color-accent)}.form-button.primary:disabled{background-color:var(--bg-info);color:var(--text-disabled);cursor:not-allowed}.form-button.secondary{background-color:var(--bg-tertiary);color:var(--text-primary)}.form-button.secondary:hover:not(:disabled){background-color:var(--border-secondary)}.auth-form-actions{display:flex;gap:1rem}.auth-form-actions .auth-form-submit{flex:1}.auth-link{text-align:center;margin-top:1.5rem;font-size:.875rem;color:var(--text-secondary)}.auth-link a{color:var(--color-interactive);text-decoration:none;font-weight:600}.auth-link a:hover{text-decoration:underline}.auth-alert{padding:.75rem 1rem;border-radius:6px;font-size:.875rem;margin-bottom:1.5rem}.auth-alert.error{background-color:var(--color-error-bg);color:var(--color-error);border:1px solid var(--color-error)}.auth-alert.success{background-color:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-success)}.register-steps{display:flex;justify-content:center;gap:2rem;margin-bottom:2.5rem}.register-step{display:flex;align-items:center;gap:.5rem}.step-number{width:2rem;height:2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;border:2px solid var(--border-secondary);color:var(--text-secondary);background-color:var(--bg-primary)}.step-number.active{background-color:var(--color-accent);border-color:var(--color-accent);color:var(--text-inverse)}.step-number.completed{background-color:var(--color-success);border-color:var(--color-success);color:var(--text-inverse)}.step-label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.step-label.active{color:#f5751c;font-weight:700}.step-label.completed{color:var(--color-success)}.account-type-selection{display:flex;flex-direction:column;gap:1rem;margin:0 auto 1.5rem;max-width:400px;width:100%}.account-type-button{padding:1.5rem;border:2px solid var(--border-light);border-radius:8px;cursor:pointer;transition:all .2s;background-color:var(--bg-primary);display:flex;align-items:center;gap:1rem;text-align:left;width:100%}.account-type-button:hover{border-color:var(--color-interactive);background-color:var(--bg-hover)}.account-type-button.selected{border-color:var(--color-accent);background-color:var(--color-accent-lighter)}.account-type-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.account-type-icon.account-type-student{background-color:#e0f2fe;border:2px solid #0ea5e9}.account-type-icon.account-type-parent{background-color:#fce7f3;border:2px solid #ec4899}.account-type-info{flex:1}.account-type-options{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.account-type-option{padding:1.5rem;border:2px solid var(--border-light);border-radius:8px;cursor:pointer;transition:all .2s;background-color:var(--bg-primary)}.account-type-option:hover{border-color:var(--color-interactive);background-color:var(--bg-hover)}.account-type-option.selected{border-color:var(--color-accent);background-color:var(--color-accent-lighter)}.account-type-title{font-size:1.125rem;font-weight:700;color:var(--color-interactive);margin:0 0 .5rem}.account-type-description{font-size:.875rem;color:var(--text-tertiary);margin:0;line-height:1.5}.children-list{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:1.5rem}.child-form-group{padding:1.5rem;border:2px solid var(--border-light);border-radius:8px;background-color:var(--bg-secondary)}.child-form-group .form-group{margin-bottom:1rem}.child-form-group .form-group:last-child{margin-bottom:0}.child-form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.child-form-header h4{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.child-form-row{display:grid;grid-template-columns:2fr 1fr 1fr;gap:1rem}@media (max-width: 768px){.child-form-row{grid-template-columns:1fr;gap:.75rem}}.form-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer}.form-checkbox input[type=checkbox]{width:1.125rem;height:1.125rem;cursor:pointer}.form-checkbox label{font-size:.875rem;color:var(--text-primary);cursor:pointer}.auth-actions{display:flex;gap:1rem;justify-content:space-between}.auth-actions button{flex:1}.auth-actions.single-button{justify-content:flex-end}.auth-actions.single-button button{flex:0 1 auto;min-width:150px}.page-container{min-height:100vh;display:flex;flex-direction:column}.animated-dots:after{content:"...";display:inline-block;animation:dots .8s steps(4,end) infinite;width:1.5em;text-align:left}@keyframes dots{0%,20%{content:""}40%{content:"."}60%{content:".."}80%,to{content:"..."}}.plan-billing-section{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-secondary)}.plan-section-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem}.plan-price-display{text-align:center;margin:1rem 0;padding:1rem;background:var(--bg-secondary);border-radius:8px}.parent-options-section{margin-top:1rem}.plan-total-display{text-align:center;margin-top:1rem;padding:1rem;background:var(--color-accent-lighter);border-radius:8px}.plan-total-label{font-size:1rem;font-weight:600;color:var(--text-secondary)}.plan-total-amount{font-size:1.5rem;font-weight:800;color:var(--color-interactive)}.plan-total-period{font-size:1rem;color:var(--text-tertiary)}.children-section{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-secondary)}.auth-loading{display:flex;justify-content:center;padding:2rem}.pricing-overview-toggle{display:flex;justify-content:center;gap:0;margin-bottom:1.5rem;background:var(--bg-secondary);border-radius:8px;padding:.25rem;width:fit-content;margin-left:auto;margin-right:auto}.pricing-overview-option{padding:.75rem 1.25rem;border-radius:6px;background:transparent;text-align:center;position:relative;min-width:140px}.pricing-overview-option-badge{position:absolute;top:-8px;right:-8px;background:var(--color-success);color:var(--text-inverse);padding:.125rem .5rem;border-radius:10px;font-size:.625rem;font-weight:700;white-space:nowrap}.pricing-overview-option-header{font-size:.75rem;font-weight:600;color:var(--text-secondary);margin-bottom:.25rem}.pricing-overview-option-price{display:flex;align-items:baseline;justify-content:center;gap:.25rem}.pricing-overview-regular{font-size:.875rem;color:var(--text-tertiary);text-decoration:line-through}.pricing-overview-founding{font-size:1.25rem;font-weight:800;color:var(--color-interactive)}.pricing-overview-option-period{font-size:.625rem;color:var(--text-tertiary)}.pricing-overview-option-per-student{font-size:.625rem;color:var(--text-secondary);margin-top:.125rem}.pricing-overview-founding-banner{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:.5rem}.pricing-overview-founding-banner .founding-member-badge-compact{background:var(--color-accent);color:var(--text-inverse);padding:.2rem .5rem;border-radius:4px;font-size:.75rem;font-weight:700}.pricing-overview-discount{font-size:.875rem;font-weight:600;color:var(--color-success)}.pricing-overview-note{font-size:.75rem;color:var(--text-secondary);text-align:center;margin:0;font-style:italic}@media (max-width: 768px){.auth-container{padding:24px 16px 32px}.auth-card{padding:32px 24px;max-width:100%}.auth-title{font-size:1.5rem}.register-steps{gap:12px}.step-label{display:none}.account-type-selection{max-width:100%}.account-type-button{padding:1rem}.account-type-icon{flex-shrink:0}.child-form-group{padding:1rem}.children-list{gap:1rem}.auth-actions{flex-direction:column}.auth-actions button{width:100%}.form-group{gap:.375rem}.pricing-overview-toggle{flex-direction:column;width:100%;max-width:200px}.pricing-overview-option{min-width:auto}.pricing-overview-option-badge{top:.25rem;right:.25rem}}.dashboard-container{max-width:1200px;margin:0 auto;padding:2rem 1rem}.dashboard-title{font-size:2rem;font-weight:700;color:var(--color-interactive);margin:0}.dashboard-loading,.dashboard-error{text-align:center;padding:3rem 1rem;font-size:1.125rem;color:var(--text-tertiary)}.dashboard-error{color:var(--color-error)}.dashboard-content{display:flex;flex-direction:column;gap:2rem}.dashboard-section{background:var(--bg-primary);border-radius:8px;box-shadow:var(--shadow-md);padding:1.5rem}.section-title{font-size:1.5rem;font-weight:700;color:var(--color-interactive);margin:0 0 1.5rem}.empty-message{text-align:center;color:var(--text-secondary);font-style:italic;padding:2rem}.stats-section{background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%);color:var(--text-inverse)}.stats-section .section-title{color:var(--text-inverse)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.5rem}.stat-card{text-align:center;padding:.75rem;background:var(--bg-tertiary);border-radius:6px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.stat-value{font-size:1.5rem;font-weight:700;color:var(--text-inverse);margin-bottom:.25rem}.stat-label{font-size:.7rem;color:var(--text-inverse);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.streak-section{background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-accent-hover) 100%);color:var(--text-inverse)}.streak-section .section-title{color:var(--text-inverse)}.streak-display{display:flex;justify-content:center;align-items:center;gap:2rem;padding:1rem}.streak-item{text-align:center;flex:1;max-width:200px}.streak-number{font-size:3rem;font-weight:700;color:var(--text-inverse);margin-bottom:.5rem}.streak-label{font-size:.875rem;color:var(--text-inverse);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.streak-divider{width:2px;height:60px;background:var(--bg-info)}.skills-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.skill-card{border:2px solid var(--border-light);border-radius:8px;padding:1rem;background:var(--bg-primary);transition:all .2s}.skill-card:hover{border-color:var(--color-interactive);box-shadow:var(--shadow-md)}.skill-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.skill-id{font-weight:700;color:var(--color-interactive);font-size:1rem}.skill-name{font-size:.9rem;font-weight:500;color:var(--text-primary)}.skill-mastery{font-size:.875rem;color:var(--color-accent);font-weight:600}.skill-meta{display:flex;justify-content:flex-start;margin-top:.25rem}.skill-attempts{font-size:.7rem;color:var(--text-secondary);font-weight:500}.skill-stats{display:flex;gap:1rem;margin-bottom:.75rem;font-size:.875rem}.skill-stat{display:flex;gap:.25rem}.skill-stat-label{color:var(--text-tertiary);font-weight:500}.skill-stat-value{color:var(--text-primary);font-weight:700}.skill-progress-bar{height:8px;background-color:var(--border-primary);border-radius:4px;overflow:hidden}.skill-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-interactive) 0%,var(--color-interactive) -hover 100%);transition:width .3s ease}.activity-list{display:flex;flex-direction:column;gap:.5rem}.activity-item{display:flex;align-items:center;gap:1rem;padding:.5rem .75rem;border:1px solid var(--border-light);border-radius:6px;background:var(--bg-primary);transition:background-color .2s}.activity-item:hover{background-color:var(--bg-secondary)}.activity-date{font-weight:600;color:var(--color-interactive);min-width:90px;font-size:.9rem}.activity-problems,.activity-accuracy{font-size:.9rem;color:var(--text-primary);white-space:nowrap}.children-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.child-card{border:2px solid var(--border-light);border-radius:8px;padding:1.5rem;background:var(--bg-primary);transition:all .2s}.child-card:hover{border-color:var(--color-interactive);box-shadow:var(--shadow-md)}.child-header{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-light)}.child-name{font-size:1.25rem;font-weight:700;color:var(--color-interactive);margin:0 0 .5rem}.child-last-active{font-size:.875rem;color:var(--text-secondary)}.child-streak{display:flex;justify-content:center;padding:1rem;margin-bottom:1rem;background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-accent-hover) 100%);border-radius:6px}.child-streak .streak-item{display:flex;flex-direction:column;align-items:center}.child-streak .streak-number{font-size:2rem;color:var(--text-inverse)}.child-streak .streak-label{color:var(--text-inverse)}.child-stats{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.stat-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:var(--bg-secondary);border-radius:4px}.stat-item .stat-label{color:var(--text-tertiary);font-size:.875rem;font-weight:500;text-transform:none}.stat-item .stat-value{color:var(--color-interactive);font-weight:700;font-size:1rem}.child-card-inactive{opacity:.65;background:var(--bg-secondary)}.child-card-inactive .child-streak{background:var(--bg-tertiary)}.child-card-inactive .child-streak .streak-number,.child-card-inactive .child-streak .streak-label{color:var(--text-secondary)}.child-header-top{display:flex;align-items:center;gap:.5rem}.child-inactive-badge{display:inline-block;padding:.15rem .5rem;font-size:.75rem;font-weight:600;color:var(--color-accent);background:var(--color-error-bg);border:1px solid var(--color-accent);border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.child-actions{display:flex;gap:.5rem;padding-top:1rem;border-top:1px solid var(--border-light)}.child-details-btn{flex:1}.child-toggle-btn,.child-delete-btn{flex-shrink:0}.child-detail-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--border-light)}.child-detail-header .dashboard-title{margin-bottom:.5rem}.child-detail-header .child-last-active{color:var(--text-secondary);font-size:.875rem}@media (max-width: 768px){.dashboard-container{padding:1rem}.dashboard-title{font-size:1.5rem}.section-title{font-size:1.25rem}.stats-grid{grid-template-columns:1fr;gap:1rem}.streak-display{flex-direction:column;gap:1rem}.streak-divider{width:60px;height:2px}.skills-list,.children-list{grid-template-columns:1fr}}@media (max-width: 480px){.dashboard-section{padding:1rem}.stat-value{font-size:2rem}.streak-number{font-size:2.5rem}}.customizable-dashboard-page{padding:1rem 2rem;max-width:1400px;margin:0 auto}.customizable-dashboard-page .btn{padding:.625rem 1.25rem;font-size:.9rem;font-weight:600;border-radius:6px;border:none;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block;line-height:1.5}.customizable-dashboard-page .btn:disabled{opacity:.5;cursor:not-allowed}.customizable-dashboard-page .btn-primary{background:var(--color-accent);color:var(--text-inverse)}.customizable-dashboard-page .btn-primary:hover:not(:disabled){background:var(--color-accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.customizable-dashboard-page .btn-secondary{background:var(--bg-primary);color:var(--color-interactive);border:2px solid var(--color-interactive)}.customizable-dashboard-page .btn-secondary:hover:not(:disabled){background:var(--color-interactive-lighter);transform:translateY(-1px);box-shadow:var(--shadow-md)}.customizable-dashboard-page .btn-text{background:transparent;color:var(--text-secondary);border:2px solid transparent}.customizable-dashboard-page .btn-text:hover:not(:disabled){color:var(--text-primary);background:var(--bg-tertiary)}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem;margin-bottom:2rem;grid-auto-rows:1fr;align-items:stretch}@media (min-width: 500px){.dashboard-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.625rem}}@media (min-width: 768px){.dashboard-grid{grid-template-columns:repeat(auto-fill,minmax(115px,1fr));gap:.75rem}}@media (min-width: 900px){.dashboard-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.875rem}}@media (min-width: 1100px){.dashboard-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:1rem}}@media (min-width: 1400px){.dashboard-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem}}.dashboard-grid.edit-mode{padding:1rem;background:var(--bg-secondary);border-radius:8px;border:2px dashed var(--color-interactive)}.dashboard-grid.edit-mode .widget-container{cursor:move}.dashboard-grid.edit-mode .widget-container:hover{border-color:var(--color-interactive)}.widget-container{position:relative;background:var(--bg-primary);border-radius:8px;padding:.5rem;box-shadow:var(--shadow-md);transition:all .3s cubic-bezier(.4,0,.2,1);border:2px solid var(--border-primary);display:flex;flex-direction:column;aspect-ratio:1/1;overflow:hidden;justify-content:space-between}@media (min-width: 768px){.widget-container{padding:.625rem}}@media (min-width: 1024px){.widget-container{padding:.75rem;border-radius:10px}}.widget-container:hover:not(.dragging){transform:translateY(-2px) scale(1.02);box-shadow:0 4px 16px #0000001f}.widget-container[draggable=true]{-webkit-user-select:none;user-select:none;cursor:move}.widget-container.dragging{opacity:.5;transform:scale(1.05);box-shadow:0 8px 24px #0003;z-index:1000;cursor:grabbing!important}.widget-container.dragging *{pointer-events:none}.widget-container:active:not(.dragging){cursor:grabbing}.widget-container.empty-widget-view{background:transparent;border:none;box-shadow:none;padding:0}.widget-container.empty-widget-view:hover{transform:none;box-shadow:none}.widget-container.widget-actionable{cursor:pointer;border-color:rgba(var(--color-accent),.2)}.widget-container.widget-actionable:hover{transform:translateY(-3px) scale(1.01);box-shadow:0 6px 20px #00000026;border-color:var(--color-accent)}.widget-container.widget-actionable:active{transform:translateY(-1px) scale(.99)}.widget-container.widget-informational{border-color:rgba(var(--border-secondary),.15)}.widget-container.widget-informational:hover{transform:translateY(-1px);box-shadow:0 3px 12px #00000014;border-color:rgba(var(--border-secondary),.25)}.widget-container.widget-expanded{max-height:none;overflow:visible}.widget-container .widget-action-icon{position:absolute;top:.5rem;right:.5rem;font-size:1.2rem;color:var(--color-accent);font-weight:700;opacity:.6;transition:all .2s;pointer-events:none;z-index:5}.widget-container.widget-actionable:hover .widget-action-icon{opacity:1;transform:translate(2px)}.widget-container .widget-edit-controls{position:absolute;top:.5rem;right:.5rem;display:flex;justify-content:flex-end;gap:.35rem;z-index:10}@media (min-width: 768px){.widget-container .widget-edit-controls{top:.625rem;right:.625rem}}@media (min-width: 1024px){.widget-container .widget-edit-controls{top:.75rem;right:.75rem}}.widget-container .widget-edit-controls .widget-control-btn{width:28px;height:28px;border-radius:5px;border:1px solid var(--border-primary);background:var(--bg-secondary);color:var(--text-primary);display:flex;align-items:center;justify-content:center;font-size:1.1rem;cursor:pointer;transition:all .2s}.widget-container .widget-edit-controls .widget-control-btn:hover{transform:scale(1.1);box-shadow:var(--shadow-md);background:var(--bg-hover);border-color:var(--color-interactive);color:var(--color-interactive)}.widget-container .widget-edit-controls .widget-control-btn.widget-remove-btn{color:var(--color-error);font-size:1.5rem;line-height:1}.widget-container .widget-edit-controls .widget-control-btn.widget-remove-btn:hover{background:var(--color-error-bg);border-color:var(--color-error)}.widget-container .widget-edit-controls .widget-control-btn.widget-settings-btn:hover{background:var(--color-interactive-lighter);border-color:var(--color-interactive)}.widget-container .widget-header{margin-bottom:.5rem;padding-bottom:.4rem;border-bottom:1px solid var(--border-light)}.widget-container .widget-title-wrapper{display:flex;align-items:center;gap:.4rem}.widget-container .widget-title-wrapper:hover .widget-title-edit-btn{opacity:1}.widget-container .widget-title{font-size:.9rem;font-weight:600;color:var(--text-primary);margin:0}.widget-container .widget-title-edit-btn{background:transparent;border:none;font-size:.9rem;cursor:pointer;padding:.25rem;opacity:0;transition:opacity .2s,transform .2s;color:var(--text-secondary)}.widget-container .widget-title-edit-btn:hover{transform:scale(1.1);color:var(--color-interactive)}.widget-container .widget-title-input{width:100%;font-size:.9rem;font-weight:600;color:var(--text-primary);border:1px solid var(--color-interactive);border-radius:4px;padding:.3rem .4rem;background:var(--bg-primary);outline:none;transition:box-shadow .2s;margin-bottom:.4rem}.widget-container .widget-title-input:focus{box-shadow:0 0 0 3px rgba(var(--color-interactive),.1)}.widget-container .widget-subtitle-input{width:100%;font-size:.875rem;font-weight:400;color:var(--text-secondary);border:1px solid var(--border-light);border-radius:4px;padding:.375rem .5rem;background:var(--bg-primary);outline:none;transition:box-shadow .2s,border-color .2s}.widget-container .widget-subtitle-input:focus{border-color:var(--color-interactive);box-shadow:0 0 0 3px rgba(var(--color-interactive),.1)}.widget-container .widget-subtitle-input::placeholder{color:var(--text-tertiary);font-style:italic}.widget-container .widget-subtitle{margin:.4rem 0 0;font-size:.8rem;font-weight:400;color:var(--text-secondary);line-height:1.4}.widget-container .widget-content{flex:1;display:flex;flex-direction:column;min-height:80px}.widget-container .empty-widget{display:flex;align-items:center;justify-content:center;flex:1;background:var(--bg-secondary);border:2px dashed var(--border-secondary);border-radius:8px;color:var(--text-secondary);font-style:italic}.widget-container .widget-settings-panel{margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid var(--border-light)}.widget-container .widget-settings-panel h4{margin:0 0 1rem;font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}.widget-container .widget-settings-panel .settings-form{display:flex;flex-direction:column;gap:1rem}.widget-container .widget-settings-panel .settings-form .form-group{display:flex;flex-direction:column;gap:.5rem}.widget-container .widget-settings-panel .settings-form .form-group label{font-size:.875rem;font-weight:500;color:var(--text-primary)}.widget-container .widget-settings-panel .settings-form .form-group .form-select{padding:.5rem;border:1px solid var(--border-light);border-radius:6px;font-size:.875rem;background:var(--bg-primary);cursor:pointer}.widget-container .widget-settings-panel .settings-form .form-group .form-select:focus{outline:none;border-color:var(--color-interactive);box-shadow:0 0 0 3px rgba(var(--color-interactive),.1)}.widget-container .widget-settings-panel .settings-form .form-group .form-help-text{font-size:.75rem;color:var(--text-secondary);margin:0}.widget-container .widget-settings-panel .settings-form .theme-picker{display:flex;gap:.5rem}.widget-container .widget-settings-panel .settings-form .theme-picker .theme-option{width:40px;height:40px;border-radius:8px;border:2px solid transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-inverse);font-weight:700;transition:all .2s}.widget-container .widget-settings-panel .settings-form .theme-picker .theme-option:hover{transform:scale(1.1);box-shadow:0 2px 8px #0003}.widget-container .widget-settings-panel .settings-form .theme-picker .theme-option.active{border-color:var(--text-primary);box-shadow:0 0 0 3px #0000001a}.widget-container.theme-blue{border-color:var(--color-interactive)}.widget-container.theme-blue .widget-title{color:var(--color-interactive)}.widget-container.theme-green{border-color:var(--color-success)}.widget-container.theme-green .widget-title{color:var(--color-success)}.widget-container.theme-orange{border-color:var(--color-accent)}.widget-container.theme-orange .widget-title{color:var(--color-accent)}.widget-container.theme-purple{border-color:#a855f7}.widget-container.theme-purple .widget-title{color:#a855f7}.widget-container.theme-red{border-color:var(--color-error)}.widget-container.theme-red .widget-title{color:var(--color-error)}.widget-container.theme-default{border-color:var(--border-primary)}.widget-container.theme-default .widget-title{color:var(--text-primary)}.widget-compact-content{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;text-align:center;gap:.25rem}@media (min-width: 768px){.widget-compact-content{gap:.35rem}}@media (min-width: 1024px){.widget-compact-content{gap:.4rem}}@media (min-width: 1440px){.widget-compact-content{gap:.5rem}}.widget-emoji-icon{font-size:2rem;line-height:1;margin:0;-webkit-user-select:none;user-select:none}@media (min-width: 500px){.widget-emoji-icon{font-size:2.125rem}}@media (min-width: 768px){.widget-emoji-icon{font-size:2.25rem}}@media (min-width: 900px){.widget-emoji-icon{font-size:2.375rem}}@media (min-width: 1100px){.widget-emoji-icon{font-size:2.5rem}}@media (min-width: 1400px){.widget-emoji-icon{font-size:2.75rem}}.widget-title-compact{font-size:.8rem;font-weight:700;margin:0;line-height:1.2;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}@media (min-width: 500px){.widget-title-compact{font-size:.85rem}}@media (min-width: 768px){.widget-title-compact{font-size:.875rem}}@media (min-width: 900px){.widget-title-compact{font-size:.9rem}}@media (min-width: 1100px){.widget-title-compact{font-size:.95rem}}@media (min-width: 1400px){.widget-title-compact{font-size:1rem}}.widget-subtitle-compact{font-size:.7rem;color:var(--text-secondary);margin:0;line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical}@media (min-width: 500px){.widget-subtitle-compact{font-size:.75rem;-webkit-line-clamp:2}}@media (min-width: 768px){.widget-subtitle-compact{font-size:.77rem}}@media (min-width: 900px){.widget-subtitle-compact{font-size:.8rem}}@media (min-width: 1100px){.widget-subtitle-compact{font-size:.85rem}}@media (min-width: 1400px){.widget-subtitle-compact{font-size:.9rem}}.widget-badge{position:absolute;top:.25rem;right:.25rem;background:var(--color-error);color:#fff;font-size:.6rem;font-weight:700;padding:.15rem .35rem;border-radius:8px;min-width:16px;text-align:center;box-shadow:0 2px 4px #0003;z-index:10}@media (min-width: 768px){.widget-badge{top:.375rem;right:.375rem;font-size:.65rem;padding:.175rem .4rem;min-width:18px}}@media (min-width: 1024px){.widget-badge{top:.5rem;right:.5rem;font-size:.7rem;padding:.2rem .45rem;min-width:20px}}.widget-quick-action{position:absolute;bottom:.25rem;right:.25rem;font-size:.85rem;opacity:.6;z-index:5}@media (min-width: 768px){.widget-quick-action{bottom:.375rem;right:.375rem;font-size:.9rem}}@media (min-width: 1024px){.widget-quick-action{bottom:.5rem;right:.5rem;font-size:1rem}}.emoji-picker-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.emoji-picker-content{background:var(--bg-primary);border-radius:12px;padding:1.5rem;max-width:90%;width:320px;box-shadow:0 10px 40px #0000004d}.emoji-picker-content h4{margin:0 0 1rem;font-size:1.1rem;color:var(--text-primary);text-align:center}.emoji-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}.emoji-grid .emoji-option{aspect-ratio:1/1;font-size:2rem;border:2px solid var(--border-primary);background:var(--bg-secondary);border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.emoji-grid .emoji-option:hover{transform:scale(1.1);border-color:var(--color-interactive);box-shadow:0 4px 12px #00000026}.emoji-grid .emoji-option.selected{border-color:var(--color-interactive);background:var(--color-interactive-lighter);box-shadow:0 0 0 3px rgba(var(--color-interactive),.2)}.widget-title{font-size:1.25rem;font-weight:600;margin:0 0 .75rem}.widget-description{font-size:.875rem;color:var(--text-secondary);margin:0 0 1rem}.widget-error{padding:1rem;background:var(--color-error-bg);border:1px solid var(--color-error);border-radius:6px;color:var(--color-error);text-align:center}.widget-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(70px,1fr));gap:.5rem;margin:.75rem 0}.widget-stats .stat-item{display:flex;flex-direction:column;gap:.2rem;text-align:center}.widget-stats .stat-item .stat-label{font-size:.7rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px}.widget-stats .stat-item .stat-value{font-size:1.3rem;font-weight:700;color:var(--text-primary)}.widget-compact-info{margin:.5rem 0 0;padding:.4rem .75rem;background:var(--bg-secondary);border-radius:4px;text-align:center}.widget-compact-info .compact-label{font-size:.75rem;color:var(--text-secondary)}.widget-action-btn{width:100%;margin-top:1rem}.widget-action-btn:disabled{opacity:.6;cursor:not-allowed;background:var(--border-secondary)!important}.widget-action-btn:disabled:hover{transform:none!important;box-shadow:none!important}.widget-show-more-button{width:100%;padding:.5rem 1rem;margin-top:.75rem;background:transparent;border:1px solid var(--border-secondary);border-radius:6px;font-size:.875rem;font-weight:500;color:var(--color-interactive);cursor:pointer;transition:all .2s}.widget-show-more-button:hover{background:var(--bg-secondary);border-color:var(--color-interactive)}.widget-show-more-button:active{transform:scale(.98)}.timed-sprint-widget .widget-personal-best{background:linear-gradient(135deg,var(--color-interactive) 0%,#9333ea 100%);color:var(--text-inverse);padding:1rem;border-radius:8px;text-align:center;margin:1rem 0}.timed-sprint-widget .widget-personal-best .personal-best-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;opacity:.9}.timed-sprint-widget .widget-personal-best .personal-best-value{font-size:1.5rem;font-weight:700;margin-top:.25rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--overlay-bg);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal-content{background:var(--bg-primary);border-radius:12px;max-width:800px;max-height:90vh;overflow:auto;animation:slideUp .3s ease;box-shadow:0 20px 60px #0000004d;border:2px solid var(--border-primary)}@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;padding:1.5rem;border-bottom:1px solid var(--border-light)}.modal-header h2{margin:0;font-size:1.75rem;color:var(--text-primary)}.modal-header .modal-close{background:none;border:none;font-size:2rem;line-height:1;color:var(--text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.modal-header .modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.add-widget-modal{max-width:1200px;width:95vw;max-height:90vh;display:flex;flex-direction:column}.add-widget-modal .modal-header{flex-shrink:0}.add-widget-modal .widget-types-container{padding:1.5rem;display:flex;flex-direction:column;gap:2rem;overflow-y:auto;flex:1}.add-widget-modal .widget-types-section{display:flex;flex-direction:column;gap:1rem}.add-widget-modal .widget-types-section .widget-section-header{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary);padding-bottom:.5rem;border-bottom:2px solid var(--border-light)}.add-widget-modal .widget-types-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.add-widget-modal .widget-types-grid .widget-type-card{background:var(--bg-primary);border:2px solid var(--border-light);border-radius:12px;padding:1.5rem;text-align:center;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:.5rem}.add-widget-modal .widget-types-grid .widget-type-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:var(--color-interactive)}.add-widget-modal .widget-types-grid .widget-type-card .widget-type-icon{font-size:2.5rem;margin-bottom:.5rem}.add-widget-modal .widget-types-grid .widget-type-card h3{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.add-widget-modal .widget-types-grid .widget-type-card p{margin:0;font-size:.75rem;color:var(--text-secondary);line-height:1.4}@media (max-width: 768px){.modal-overlay{align-items:stretch;justify-content:stretch;padding:0}.modal-content.add-widget-modal{width:100vw;height:100vh;max-width:100vw;max-height:100vh;border-radius:0;border:none;margin:0;overflow:hidden}.modal-content.add-widget-modal .widget-types-container{padding:1rem}.modal-content.add-widget-modal .widget-types-grid{grid-template-columns:1fr;gap:.75rem}.modal-content.add-widget-modal .widget-types-grid .widget-type-card{padding:1rem}}.widget-activity-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg-primary);z-index:2000;display:flex;flex-direction:column;animation:slideIn .3s ease}.widget-activity-overlay.with-demo-banner{top:68px}@media (max-width: 768px){.widget-activity-overlay.with-demo-banner{top:64px}}@keyframes slideIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.widget-activity-header{padding:2px 24px;height:51px;border-bottom:1px solid var(--border-primary);background:var(--bg-primary);display:flex;align-items:center;gap:1.5rem;box-shadow:var(--shadow-sm)}@media (max-width: 768px){.widget-activity-header{padding:8px 12px;gap:.75rem}}.widget-activity-back-btn{background:transparent;border:1px solid var(--border-secondary);border-radius:6px;padding:.5rem 1rem;font-size:.95rem;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all .2s;white-space:nowrap}.widget-activity-back-btn:hover{background:var(--bg-tertiary);border-color:var(--color-interactive);color:var(--color-interactive)}@media (max-width: 768px){.widget-activity-back-btn{padding:.4rem .75rem;font-size:.85rem}}.widget-activity-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}@media (max-width: 768px){.widget-activity-title{font-size:1.1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}.widget-activity-content{flex:1;overflow:auto;padding:0}.widget-not-found-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg-primary);z-index:2000;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease}.widget-not-found-content{max-width:500px;padding:3rem;text-align:center;background:var(--bg-secondary);border-radius:12px;border:2px solid var(--border-secondary)}.widget-not-found-content h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 1rem}.widget-not-found-content p{font-size:1rem;color:var(--text-secondary);margin:0 0 1.5rem;line-height:1.6}.widget-not-found-content .btn{margin-top:.5rem}.timed-sprint-header{display:flex;align-items:center;gap:2rem;margin-top:1rem}.timer-display{display:flex;align-items:center;gap:.5rem;font-size:2rem;font-weight:700;color:var(--color-interactive);padding:.75rem 1.5rem;background:var(--color-interactive-lighter);border-radius:12px;border:2px solid var(--color-interactive)-200}.timer-display .timer-icon{font-size:1.75rem}.timer-display.timer-warning{color:var(--color-accent);background:var(--color-error-bg);border-color:var(--color-accent);animation:pulse 1s infinite}.timer-display.timer-expired{color:var(--color-error);background:var(--color-error-bg);border-color:var(--color-error)}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.sprint-complete{text-align:center;padding:3rem 2rem;max-width:600px;margin:0 auto}.sprint-complete h2{font-size:2.5rem;color:var(--color-interactive);margin:0 0 2rem}.sprint-complete .sprint-results{background:var(--bg-secondary);border-radius:12px;padding:2rem;margin-bottom:2rem}.sprint-complete .sprint-results .result-stat{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.sprint-complete .sprint-results .result-stat .result-label{font-size:1rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.sprint-complete .sprint-results .result-stat .result-value{font-size:3rem;font-weight:700;color:var(--color-interactive)}.sprint-complete .sprint-results .result-breakdown{display:flex;justify-content:center;padding-top:1rem;border-top:1px solid var(--bg-tertiary)}.timed-sprint-config{display:flex;flex-direction:column;gap:1.5rem;max-height:600px;overflow-y:auto}.timed-sprint-config .form-help-text{margin:.5rem 0 0;font-size:.85rem;color:var(--text-tertiary)}.widget-activity-setup{padding:2rem;max-width:800px;margin:0 auto}.widget-activity-setup h3{margin:0 0 .5rem;font-size:1.5rem;color:var(--color-interactive)}.widget-activity-setup .setup-description{margin:0 0 2rem;font-size:1rem;color:var(--text-tertiary)}.skill-selector{display:flex;flex-direction:column;gap:1rem;width:100%}.skill-selector .skill-selector-header{display:flex;flex-direction:column;gap:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-primary)}.skill-selector .search-bar{position:relative;width:100%}.skill-selector .search-bar .search-input{width:100%;padding:.625rem 2.5rem .625rem 1rem;font-size:.9rem;border:1px solid var(--border-secondary);border-radius:6px;transition:all .2s}.skill-selector .search-bar .search-input:focus{outline:none;border-color:var(--color-interactive);box-shadow:0 0 0 3px rgba(var(--color-interactive),.1)}.skill-selector .search-bar .search-input::placeholder{color:var(--text-tertiary)}.skill-selector .search-bar .search-clear{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:.25rem .5rem;line-height:1;transition:color .2s}.skill-selector .search-bar .search-clear:hover{color:var(--text-primary)}.skill-selector .tree-controls{display:flex;gap:.5rem}.skill-selector .tree-controls .tree-control-btn{padding:.4rem .875rem;font-size:.8rem;font-weight:500;color:var(--color-interactive);background:var(--bg-primary);border:1px solid var(--border-secondary);border-radius:4px;cursor:pointer;transition:all .2s}.skill-selector .tree-controls .tree-control-btn:hover{background:var(--color-interactive-lighter);border-color:var(--color-interactive)}.skill-selector .selection-summary{font-size:.9rem;font-weight:600;color:var(--text-primary)}.skill-selector .skill-tree{display:flex;flex-direction:column;gap:.75rem;overflow-y:auto;padding:.5rem 0 2rem}.skill-selector .skill-tree::-webkit-scrollbar{width:8px}.skill-selector .skill-tree::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:4px}.skill-selector .skill-tree::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:4px}.skill-selector .skill-tree::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.skill-selector .grade-level{border:1px solid var(--border-primary);border-radius:8px;overflow:hidden;background:var(--bg-primary)}.skill-selector .grade-level .grade-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);cursor:pointer}.skill-selector .grade-level .grade-header .grade-toggle{display:flex;align-items:center;gap:.5rem;flex:1;background:none;border:none;cursor:pointer;padding:0;text-align:left;font-size:1rem;font-weight:600;color:var(--text-primary);transition:color .2s}.skill-selector .grade-level .grade-header .grade-toggle:hover,.skill-selector .grade-level .grade-header .grade-toggle:hover .toggle-icon{color:var(--color-interactive)}.skill-selector .grade-level .grade-header .grade-toggle .toggle-icon{font-size:.8rem;color:var(--text-secondary);transition:color .2s}.skill-selector .grade-level .grade-header .grade-toggle .grade-name{flex:1}.skill-selector .grade-level .grade-header .grade-toggle .grade-count{font-size:.85rem;font-weight:500;color:var(--text-tertiary);margin-left:.5rem}.skill-selector .grade-level .grade-header .select-all-btn{padding:.4rem .875rem;font-size:.8rem;font-weight:500;color:var(--color-interactive);background:var(--bg-primary);border:1px solid var(--border-secondary);border-radius:4px;cursor:pointer;transition:all .2s}.skill-selector .grade-level .grade-header .select-all-btn:hover{background:var(--color-interactive-lighter);border-color:var(--color-interactive)}.skill-selector .grade-level .grade-categories{padding:.5rem;display:flex;flex-direction:column;gap:.5rem}.skill-selector .skill-category{border:1px solid var(--border-primary);border-radius:6px;overflow:hidden;background:var(--bg-primary)}.skill-selector .skill-category .category-header{display:flex;align-items:center;justify-content:space-between;padding:.625rem .875rem;background:var(--bg-secondary);cursor:pointer}.skill-selector .skill-category .category-header .category-toggle{display:flex;align-items:center;gap:.5rem;flex:1;background:none;border:none;cursor:pointer;padding:0;text-align:left;font-size:.9rem;font-weight:600;color:var(--text-primary);transition:color .2s}.skill-selector .skill-category .category-header .category-toggle:hover,.skill-selector .skill-category .category-header .category-toggle:hover .toggle-icon{color:var(--color-interactive)}.skill-selector .skill-category .category-header .category-toggle .toggle-icon{font-size:.7rem;color:var(--text-secondary);transition:color .2s}.skill-selector .skill-category .category-header .category-toggle .category-name{flex:1}.skill-selector .skill-category .category-header .category-toggle .category-count{font-size:.8rem;font-weight:500;color:var(--text-tertiary);margin-left:.5rem}.skill-selector .skill-category .category-header .select-all-btn{padding:.3rem .75rem;font-size:.75rem;font-weight:500;color:var(--color-interactive);background:var(--bg-primary);border:1px solid var(--border-secondary);border-radius:4px;cursor:pointer;transition:all .2s}.skill-selector .skill-category .category-header .select-all-btn:hover{background:var(--color-interactive-lighter);border-color:var(--color-interactive)}.skill-selector .skill-category .skill-list{padding:.5rem;display:flex;flex-direction:column;gap:.25rem}.skill-selector .skill-item{padding:.5rem;border-radius:4px;transition:background .2s}.skill-selector .skill-item:hover{background:var(--color-interactive-lighter)}.skill-selector .skill-item .skill-checkbox{display:flex;align-items:center;gap:.75rem;cursor:pointer;-webkit-user-select:none;user-select:none}.skill-selector .skill-item .skill-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer;flex-shrink:0;accent-color:var(--color-interactive);margin:0}.skill-selector .skill-item .skill-checkbox .skill-description{font-size:1rem;color:var(--text-primary);line-height:20px;flex:1;font-style:normal;font-weight:600;margin:5px 0}@media (max-width: 768px){.skill-selector .skill-tree{max-height:400px}.skill-selector .tree-controls{flex-direction:column}.skill-selector .tree-controls .tree-control-btn{width:100%}}.sprint-start-screen{display:flex;align-items:center;justify-content:center;min-height:400px;padding:3rem 2rem}.sprint-start-screen .start-screen-content{max-width:500px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.sprint-start-screen .start-screen-icon{font-size:4rem;line-height:1;animation:pulse 2s ease-in-out infinite}.sprint-start-screen h2{font-size:2rem;font-weight:700;color:var(--text-primary);margin:0}.sprint-start-screen .start-screen-info{display:flex;flex-direction:column;gap:.75rem;width:100%;padding:1.5rem;background:var(--color-interactive-lighter);border-radius:8px;border:2px solid var(--color-interactive)}.sprint-start-screen .start-screen-info p{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.sprint-start-screen .start-screen-info .start-screen-time{color:var(--color-interactive)}.sprint-start-screen .start-screen-info .start-screen-skills{color:var(--text-primary)}.sprint-start-screen .start-screen-warning{font-size:.95rem;font-weight:500;color:var(--color-accent);background:var(--color-accent)-50;padding:.875rem 1.25rem;border-radius:6px;border:1px solid var(--color-accent)-200;margin:0}.sprint-start-screen .start-sprint-btn{font-size:1.25rem;padding:1rem 3rem;margin-top:.5rem;box-shadow:0 4px 12px rgba(var(--color-interactive),.3)}.sprint-start-screen .start-sprint-btn:hover:not(:disabled){box-shadow:0 6px 16px rgba(var(--color-interactive),.4)}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}@media (max-width: 768px){.sprint-start-screen{padding:2rem 1rem;min-height:300px}.sprint-start-screen h2{font-size:1.5rem}.sprint-start-screen .start-screen-icon{font-size:3rem}.sprint-start-screen .start-screen-info p{font-size:1rem}.sprint-start-screen .start-sprint-btn{font-size:1.1rem;padding:.875rem 2.5rem}}.dashboard-empty-state{display:flex;justify-content:center;align-items:center;padding:4rem 2rem;min-height:400px}.dashboard-empty-state .empty-state-content{text-align:center;max-width:500px}.dashboard-empty-state .empty-state-content h2{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0 0 1rem}.dashboard-empty-state .empty-state-content p{font-size:1.1rem;color:var(--text-secondary);line-height:1.6;margin:0 0 2rem}.dashboard-empty-state .empty-state-content .btn{font-size:1.1rem;padding:.875rem 2rem}@media (max-width: 768px){.dashboard-empty-state{padding:3rem 1rem;min-height:300px}.dashboard-empty-state .empty-state-content h2{font-size:1.5rem}.dashboard-empty-state .empty-state-content p{font-size:1rem}.dashboard-empty-state .empty-state-content .btn{font-size:1rem;padding:.75rem 1.5rem}}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-light);gap:2rem}.dashboard-header .back-btn{margin-bottom:1rem}@media (max-width: 768px){.dashboard-header{flex-direction:column;align-items:flex-start;gap:1rem}}.page-navigation{flex:1}@media (max-width: 768px){.page-navigation{width:100%}}.page-selector-dropdown{width:100%;max-width:300px;padding:.75rem 3rem .75rem 1rem;font-size:1.125rem;font-weight:600;color:var(--text-primary);background:var(--bg-secondary);border:2px solid var(--border-light);border-radius:8px;cursor:pointer;transition:all .2s;-webkit-appearance:none;-moz-appearance:none;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='%23666' d='M6 8L0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}.page-selector-dropdown:hover{border-color:var(--color-interactive)}.page-selector-dropdown:focus{outline:none;border-color:var(--color-interactive);box-shadow:0 0 0 3px #3b82f61a}@media (max-width: 768px){.page-selector-dropdown{max-width:100%;font-size:1rem}}.page-edit-list{width:100%;display:flex;flex-direction:column;gap:.5rem;max-height:400px;overflow-y:auto;padding:.5rem;background:var(--bg-secondary);border-radius:8px;border:2px solid var(--border-light)}.page-edit-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-primary);border-radius:6px;border:2px solid transparent;transition:all .2s}.page-edit-item.active{border-color:var(--color-interactive);background:var(--bg-tertiary)}.page-edit-item:hover{background:var(--bg-tertiary)}.page-name-btn{flex:1;text-align:left;padding:.25rem .5rem;background:transparent;border:none;font-size:1rem;font-weight:600;color:var(--text-primary);cursor:pointer;transition:color .2s}.page-name-btn:hover,.page-edit-item.active .page-name-btn{color:var(--color-interactive)}.page-edit-actions{display:flex;gap:.5rem;align-items:center}.page-action-btn{width:32px;height:32px;border-radius:6px;color:var(--text-inverse);font-size:1rem;font-weight:600;line-height:1;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;padding:0;border:none;background:var(--text-tertiary)}.page-action-btn:hover{background:var(--color-interactive);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.page-action-btn:active{transform:translateY(0)}.page-action-btn.page-delete{background:var(--color-error)}.page-action-btn.page-delete:hover{background:var(--color-error);opacity:.85}@media (max-width: 768px){.page-action-btn{width:36px;height:36px;font-size:1.125rem}}.dashboard-controls{display:flex;gap:.75rem;align-items:center;flex-shrink:0}@media (max-width: 768px){.dashboard-controls{width:100%}.dashboard-controls .btn{flex:1;font-size:.85rem;padding:.65rem .75rem}}.page-modal{max-width:500px;width:90%}.page-modal .modal-body{padding:1.5rem}.page-modal .modal-description{margin:0 0 1.5rem;color:var(--text-secondary);font-size:.95rem;line-height:1.5}.page-modal .modal-description.modal-warning{color:var(--color-error);font-weight:500}.page-modal .page-name-input{width:100%;padding:.75rem 1rem;border:2px solid var(--border-secondary);border-radius:8px;font-size:1rem;background:var(--bg-primary);color:var(--text-primary);transition:all .2s}.page-modal .page-name-input:focus{outline:none;border-color:var(--color-interactive);box-shadow:0 0 0 3px rgba(var(--color-interactive),.1)}.page-modal .page-name-input::placeholder{color:var(--text-tertiary)}.page-modal .modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-light)}.page-modal .btn-danger{background:var(--color-error);color:var(--text-inverse)}.page-modal .btn-danger:hover:not(:disabled){background:var(--color-error);opacity:.9;transform:translateY(-1px);box-shadow:var(--shadow-md)}@media (max-width: 768px){.customizable-dashboard-page{padding:1rem}.page-navigation{margin-bottom:1rem}.page-modal{margin:1rem}.page-modal .modal-header h2{font-size:1.25rem}.page-modal .modal-footer{flex-direction:column}.page-modal .modal-footer button{width:100%}}.widget-edit-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:1rem;pointer-events:auto}@media (max-width: 768px){.widget-edit-modal-overlay{padding:0;background:var(--bg-primary);-webkit-backdrop-filter:none;backdrop-filter:none}}.widget-edit-modal-content{background:var(--bg-primary);border-radius:12px;max-width:600px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;pointer-events:auto}@media (max-width: 768px){.widget-edit-modal-content{max-width:100%;max-height:100vh;height:100vh;border-radius:0;box-shadow:none}}.widget-edit-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.75rem;border-bottom:1px solid var(--border-primary)}.widget-edit-modal-header h2{margin:0;font-size:1.5rem;color:var(--text-primary)}.widget-edit-modal-header .modal-close-btn{background:none;border:none;font-size:2rem;color:var(--text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.widget-edit-modal-header .modal-close-btn:hover{background:var(--bg-secondary)}.widget-edit-modal-body{flex:1;overflow-y:auto}.widget-edit-modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:1px solid var(--border-primary)}@media (max-width: 480px){.widget-edit-modal-footer{flex-direction:column}.widget-edit-modal-footer button{width:100%}}.modal-section{margin-bottom:2rem}.modal-section:last-child{margin-bottom:0}.modal-section-toggle{width:100%;display:flex;justify-content:space-between;align-items:center;padding:1rem;background:transparent;border:none;border-bottom:2px solid var(--border-primary);cursor:pointer;transition:border-color .2s}.modal-section-toggle:hover{border-bottom-color:var(--color-interactive)}.modal-section-toggle:hover .section-title{color:var(--color-interactive)}.modal-section-toggle .section-title{font-weight:600;font-size:1.5rem;color:var(--text-primary);transition:color .2s;margin:0}.modal-section-toggle .toggle-icon{color:var(--text-secondary);font-size:1rem;transition:transform .2s}.modal-section-content{padding:1rem;background:transparent}.form-section{margin-bottom:1.5rem}.form-section:last-child{margin-bottom:0}.form-label{display:block;font-weight:600;color:var(--text-primary);margin-bottom:.5rem;font-size:.95rem}.form-input,.form-select{width:100%;padding:.75rem;border:1px solid var(--border-primary);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-size:1rem;transition:border-color .2s}.form-input:focus,.form-select:focus{outline:none;border-color:var(--color-interactive)}.form-helper-text{font-size:.875rem;color:var(--text-secondary);margin-top:.25rem}.emoji-picker-toggle{width:100%;padding:.75rem 1rem;border:2px solid var(--border-primary);background:var(--bg-secondary);border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;font-size:1rem;color:var(--text-primary);transition:all .2s;margin-bottom:.5rem}.emoji-picker-toggle:hover{border-color:var(--color-interactive);background:var(--bg-hover)}.emoji-picker-toggle .current-emoji{font-size:2rem;margin-right:.5rem}.emoji-picker-toggle .toggle-text{color:var(--text-secondary);font-size:.875rem}.emoji-grid-modal{display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:.75rem;margin-top:.5rem;max-height:300px;overflow-y:auto;padding:.5rem;border:1px solid var(--border-primary);border-radius:8px;background:var(--bg-primary)}.emoji-option-modal{aspect-ratio:1/1;font-size:2rem;border:2px solid var(--border-primary);background:var(--bg-secondary);border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.emoji-option-modal:hover{border-color:var(--color-interactive);transform:scale(1.05)}.emoji-option-modal.selected{border-color:var(--color-interactive);background:var(--color-interactive-light);box-shadow:0 0 0 3px rgba(var(--color-interactive-rgb),.2)}.emoji-option-modal.no-emoji{font-size:.875rem;font-weight:600;color:var(--text-secondary)}.theme-picker-modal{display:flex;gap:.75rem;flex-wrap:wrap}.theme-option-modal{width:48px;height:48px;border-radius:8px;border:2px solid transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:#fff;transition:all .2s}.theme-option-modal:hover{transform:scale(1.1)}.theme-option-modal.active{border-color:var(--text-primary);box-shadow:0 0 0 3px #0000001a}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;border:none}.btn-primary{background:var(--color-interactive);color:#fff}.btn-primary:hover{background:var(--color-interactive-hover);transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-primary)}.btn-secondary:hover{background:var(--bg-tertiary)}.parent-dashboard{max-width:1200px;margin:0 auto;padding:1.5rem 1rem}.parent-dashboard-header{margin-bottom:1.5rem}.parent-dashboard-title{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0}.parent-dashboard-loading,.parent-dashboard-error{text-align:center;padding:3rem 1rem;font-size:1.125rem;color:var(--text-tertiary)}.parent-dashboard-error{color:var(--color-error)}.parent-dashboard-empty{text-align:center;padding:3rem;background:var(--bg-secondary);border-radius:12px;color:var(--text-secondary)}.parent-dashboard-content{display:flex;flex-direction:column;gap:1.5rem}.children-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.child-card-wrapper{background:var(--bg-primary);border:2px solid var(--border-light);border-radius:12px;cursor:pointer;transition:all .2s ease;overflow:hidden}.child-card-wrapper:hover{border-color:var(--color-interactive);box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.child-card-wrapper:focus{outline:none;border-color:var(--color-interactive);box-shadow:0 0 0 3px #3b82f633}.child-card-wrapper.child-card-inactive{opacity:.6;background:var(--bg-secondary);cursor:not-allowed}.child-card-wrapper.child-card-inactive:hover{transform:none;box-shadow:none;border-color:var(--border-light)}.child-card-content{padding:1.25rem}.child-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.child-card-info{display:flex;flex-direction:column;gap:.25rem}.child-card-name{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.child-card-grade{font-size:.875rem;color:var(--text-secondary)}.child-card-stats{display:flex;gap:1rem;padding:.75rem;background:var(--bg-secondary);border-radius:8px;margin-bottom:1rem}.child-stat{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center}.child-stat-value{font-size:1.5rem;font-weight:700;color:var(--color-interactive);line-height:1.2}.child-stat-label{font-size:.7rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.child-card-footer{text-align:center}.child-card-footer .child-last-active{font-size:.8rem;color:var(--text-tertiary)}.child-detail-page{max-width:1000px;margin:0 auto;padding:1.5rem 1rem}.child-detail-loading,.child-detail-error{text-align:center;padding:3rem 1rem;font-size:1.125rem;color:var(--text-tertiary)}.child-detail-error{color:var(--color-error)}.back-link{display:inline-flex;align-items:center;gap:.5rem;background:none;border:none;color:var(--color-interactive);font-size:.95rem;font-weight:500;cursor:pointer;padding:.5rem 0;margin-bottom:1rem;transition:color .2s}.back-link:hover{color:var(--color-interactive-hover)}.back-link:before{content:"←"}.child-detail-header{margin-bottom:2rem}.child-detail-title-row{display:flex;align-items:baseline;gap:1rem;flex-wrap:wrap}.child-detail-name{font-size:2rem;font-weight:700;color:var(--text-primary);margin:0}.child-detail-grade{font-size:1rem;color:var(--text-secondary);background:var(--bg-secondary);padding:.25rem .75rem;border-radius:16px}.child-detail-content{display:flex;flex-direction:column;gap:2rem}.child-detail-section{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:12px;padding:1.5rem}.child-detail-section .section-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem}.login-info-section{background:var(--bg-secondary)}.login-info-card{display:flex;flex-direction:column;gap:.75rem}.login-info-row{display:flex;align-items:center;gap:1rem;padding:.75rem;background:var(--bg-primary);border-radius:8px}.login-info-label{font-size:.875rem;color:var(--text-secondary);min-width:100px}.login-info-value{font-size:1rem;font-weight:600;color:var(--text-primary);font-family:monospace}.login-info-note{font-size:.8rem;color:var(--text-tertiary);margin:0;font-style:italic}.stats-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.stat-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg-secondary);border-radius:10px}.stat-card-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:var(--bg-primary);border-radius:10px}.stat-card-content{display:flex;flex-direction:column}.stat-card-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);line-height:1.2}.stat-card-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.weekly-activity-chart{display:flex;justify-content:space-between;align-items:flex-end;gap:.5rem;height:150px;padding-top:1rem}.activity-bar-container{flex:1;display:flex;flex-direction:column;align-items:center;gap:.25rem;height:100%}.activity-bar-wrapper{flex:1;width:100%;display:flex;flex-direction:column;justify-content:flex-end;background:var(--bg-secondary);border-radius:4px 4px 0 0;overflow:hidden}.activity-bar{width:100%;background:var(--color-interactive);border-radius:4px 4px 0 0;transition:height .3s ease;min-height:4px}.activity-bar-label{font-size:.7rem;color:var(--text-secondary);font-weight:500}.activity-bar-count{font-size:.75rem;font-weight:600;color:var(--text-primary)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.skill-progress-card{padding:1rem;background:var(--bg-secondary);border-radius:8px;border-left:4px solid var(--border-secondary)}.skill-progress-card.mastery-high{border-left-color:var(--color-success)}.skill-progress-card.mastery-medium{border-left-color:var(--color-accent)}.skill-progress-card.mastery-low{border-left-color:var(--color-error)}.skill-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.skill-progress-name{font-size:.9rem;font-weight:600;color:var(--text-primary)}.skill-progress-mastery{font-size:.875rem;font-weight:700;color:var(--color-interactive)}.skill-progress-bar-container{height:6px;background:var(--bg-primary);border-radius:3px;overflow:hidden;margin-bottom:.5rem}.skill-progress-bar{height:100%;background:var(--color-interactive);border-radius:3px;transition:width .3s ease}.skill-progress-accuracy{font-size:.75rem;color:var(--text-tertiary)}.strengths-weaknesses-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.strengths-section,.weaknesses-section{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:12px;padding:1.25rem}.strengths-list,.weaknesses-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.strength-item,.weakness-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:var(--bg-secondary);border-radius:6px;font-size:.9rem;color:var(--text-primary)}.strength-icon{color:var(--color-success)}.weakness-icon{color:var(--text-tertiary)}.recent-activity-section{background:var(--bg-secondary);border:2px solid var(--color-interactive)}.recent-activity-card{display:flex;flex-direction:column;gap:1rem}.recent-activity-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem}.recent-activity-date{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.recent-activity-summary{display:flex;gap:1.5rem}.recent-activity-stat{display:flex;flex-direction:column;align-items:center}.recent-activity-stat .stat-value{font-size:1.5rem;font-weight:700;color:var(--color-interactive)}.recent-activity-stat .stat-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase}.recent-activity-skills{border-top:1px solid var(--border-light);padding-top:1rem}.skills-practiced-label{display:block;font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:.75rem}.recent-skills-grid{display:flex;flex-wrap:wrap;gap:.5rem}.recent-skill-chip{display:flex;flex-direction:column;gap:.125rem;padding:.5rem .75rem;background:var(--bg-primary);border-radius:8px;border:1px solid var(--border-light)}.skill-chip-name{font-size:.875rem;font-weight:600;color:var(--text-primary)}.skill-chip-details{font-size:.75rem;color:var(--text-secondary)}.activity-history-section{background:var(--bg-primary)}.activity-history-loading{padding:2rem;text-align:center;color:var(--text-tertiary)}.activity-history-list{display:flex;flex-direction:column;gap:.75rem}.activity-day-card{padding:1rem;background:var(--bg-secondary);border-radius:8px;border-left:3px solid var(--color-interactive)}.activity-day-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.activity-day-date{font-size:1rem;font-weight:600;color:var(--text-primary)}.activity-day-summary{display:flex;gap:1rem;font-size:.875rem;color:var(--text-secondary)}.activity-day-problems{font-weight:500}.activity-day-accuracy{color:var(--color-interactive)}.activity-day-skills{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-light)}.activity-skills-label{display:block;font-size:.75rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;margin-bottom:.5rem}.activity-skills-list{display:flex;flex-direction:column;gap:.375rem}.activity-skill-item{display:flex;justify-content:space-between;align-items:center;padding:.375rem .5rem;background:var(--bg-primary);border-radius:4px;font-size:.875rem}.activity-skill-name{color:var(--text-primary)}.activity-skill-stats{color:var(--text-secondary);font-size:.8rem}@media (max-width: 768px){.parent-dashboard{padding:1rem}.parent-dashboard-title{font-size:1.5rem}.children-grid{grid-template-columns:1fr}.child-detail-page{padding:1rem}.child-detail-name{font-size:1.5rem}.stats-cards{grid-template-columns:1fr}.stat-card{padding:.75rem}.stat-card-value{font-size:1.25rem}.skills-grid,.strengths-weaknesses-row{grid-template-columns:1fr}.weekly-activity-chart{height:120px}.recent-activity-header{flex-direction:column;align-items:flex-start}.recent-activity-summary{width:100%;justify-content:space-around}.activity-day-header{flex-direction:column;align-items:flex-start}.activity-day-summary{flex-direction:column;gap:.25rem}}.widget-config{display:flex;flex-direction:column;gap:1.5rem;padding:0}.widget-config .config-section{display:flex;flex-direction:column;gap:1rem}.widget-config .config-section h3{margin:0 0 .5rem;font-size:1.25rem;font-weight:600;color:var(--color-interactive)}.widget-config .config-section>p{margin:0 0 1rem;font-size:.95rem;color:var(--text-tertiary);line-height:1.5}.widget-config .config-field{display:flex;flex-direction:column;gap:.5rem}.widget-config .config-field .config-label{font-weight:600;font-size:.875rem;color:var(--text-primary);margin:0}.widget-config .config-field .config-input,.widget-config .config-field .config-select{width:100%;padding:.625rem .75rem;border:1px solid var(--border-secondary);border-radius:6px;font-size:.95rem;background:var(--bg-primary);transition:all .2s ease}.widget-config .config-field .config-input:hover,.widget-config .config-field .config-select:hover{border-color:var(--border-secondary)}.widget-config .config-field .config-input:focus,.widget-config .config-field .config-select:focus{outline:none;border-color:var(--color-interactive);box-shadow:0 0 0 3px #1f70841a}.widget-config .config-field .config-input:disabled,.widget-config .config-field .config-select:disabled{background:var(--bg-secondary);cursor:not-allowed;opacity:.6}.widget-config .config-field .config-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%234b5563' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.5rem}.widget-config .config-field .config-hint{font-size:.85rem;color:var(--text-tertiary);margin:0;line-height:1.4}.widget-config .time-limit-group{display:flex;gap:.75rem;align-items:center}.widget-config .time-limit-group .config-input{flex:1}.widget-config .time-limit-group .btn-clear-time-limit{padding:.625rem 1rem;border:1px solid var(--border-secondary);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.widget-config .time-limit-group .btn-clear-time-limit:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--border-secondary)}.widget-config .time-limit-group .btn-clear-time-limit:disabled{opacity:.5;cursor:not-allowed}.widget-config .config-actions{display:flex;flex-direction:column;gap:.75rem;padding-top:1.5rem;border-top:1px solid var(--border-light);margin-top:.5rem}.widget-config .config-actions .btn{width:100%;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;border-radius:6px;border:none;cursor:pointer;transition:all .2s ease}.widget-config .config-actions .btn.btn-primary{background:var(--color-accent);color:var(--text-inverse)}.widget-config .config-actions .btn.btn-primary:hover:not(:disabled){background:var(--color-accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.widget-config .config-actions .btn.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.widget-config .config-actions .btn.btn-secondary{background:var(--bg-primary);color:var(--color-interactive);border:2px solid var(--color-interactive)}.widget-config .config-actions .btn.btn-secondary:hover:not(:disabled){background:var(--bg-hover)}.widget-config .config-actions .btn.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.widget-config .config-error,.widget-config .config-warning{font-size:.9rem;padding:.75rem;border-radius:6px;text-align:center;margin:0}.widget-config .config-error{color:var(--color-error);background:var(--color-error-bg);border:1px solid var(--color-error)}.widget-config .config-warning{color:var(--text-primary);background:#fef3c7;border:1px solid var(--color-warning)}.widget-activity-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg-secondary);z-index:2000;display:flex;flex-direction:column;animation:slideIn .3s cubic-bezier(.4,0,.2,1)}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.widget-activity-header{background:var(--bg-primary);padding:2px 24px;height:51px;border-bottom:1px solid var(--border-primary);display:flex;align-items:center;gap:1.5rem;box-shadow:var(--shadow-sm)}.widget-activity-header .widget-activity-back-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:var(--bg-primary);border:1px solid var(--border-secondary);border-radius:6px;color:var(--text-primary);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.widget-activity-header .widget-activity-back-btn:hover{background:var(--bg-secondary);border-color:var(--color-interactive);color:var(--color-interactive)}.widget-activity-header h2{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.widget-activity-content{flex:1;overflow-y:auto;padding:0}.widget-activity-content.centered{display:flex;justify-content:center}.widget-activity-content.centered>*{width:100%;max-width:900px}.widget-activity-setup{background:var(--bg-primary);border-radius:12px;padding:2.5rem;margin:2rem;box-shadow:0 4px 16px #00000014}.widget-activity-setup h3{margin:0 0 1rem;font-size:1.75rem;font-weight:700;color:var(--color-interactive)}.widget-activity-setup .setup-description{font-size:1rem;color:var(--text-tertiary);margin:0 0 2rem;line-height:1.6}.widget-activity-setup .widget-config{margin-top:2rem}@media (max-width: 768px){.widget-activity-header{padding:2px 1.5rem;height:48px}.widget-activity-header h2{font-size:1.25rem}.widget-activity-header .widget-activity-back-btn{padding:.5rem .75rem;font-size:.85rem}.widget-activity-setup{padding:1.5rem}.widget-activity-setup h3{font-size:1.375rem}.widget-config .time-limit-group{flex-direction:column;align-items:stretch}.widget-config .time-limit-group .btn-clear-time-limit{width:100%}.widget-config .config-actions .btn{padding:.875rem 1.25rem}}.settings-container{max-width:1100px;margin:0 auto;padding:2rem 1rem}.settings-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--border-light)}.settings-title{font-size:2rem;font-weight:700;color:var(--color-interactive);margin:0}.settings-loading,.settings-error{grid-column:1/-1;text-align:center;padding:3rem 1rem;font-size:1.125rem;color:var(--text-tertiary)}.settings-error{color:var(--color-error)}.settings-content{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}.settings-section-wide{grid-column:1/-1}.settings-section{background:var(--bg-primary);border-radius:8px;box-shadow:var(--shadow-md);padding:1.5rem}.section-title{font-size:1.5rem;font-weight:700;color:var(--color-interactive);margin:0 0 1rem}.section-description{font-size:.875rem;color:var(--text-tertiary);margin:0 0 1.5rem;line-height:1.5}.settings-group{display:flex;flex-direction:column;gap:1.5rem}.settings-item{display:flex;flex-direction:column;gap:.5rem}.settings-label{font-size:.875rem;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}.settings-value{font-size:1rem;color:var(--text-primary);padding:.5rem 0}.settings-toggle-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;border:1px solid var(--border-light);border-radius:6px;transition:background-color .2s}.settings-toggle-item:hover{background-color:var(--bg-secondary)}.toggle-info{flex:1}.toggle-label{font-size:1rem;font-weight:600;color:var(--text-primary);display:block;margin-bottom:.25rem;cursor:pointer}.toggle-description{font-size:.875rem;color:var(--text-tertiary);margin:0;line-height:1.4}.toggle-switch{position:relative;display:inline-block;width:52px;height:28px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-switch input:checked+.toggle-slider{background-color:var(--color-accent)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}.toggle-switch input:focus+.toggle-slider{box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--color-accent)}.toggle-switch input:disabled+.toggle-slider{background-color:var(--bg-info);cursor:not-allowed}.toggle-switch input:disabled:checked+.toggle-slider{background-color:var(--text-tertiary)}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--border-secondary);transition:.3s;border-radius:28px}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:var(--bg-primary);transition:.3s;border-radius:50%}.settings-actions{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1.5rem;background:var(--bg-primary);border-radius:8px;box-shadow:var(--shadow-md)}.settings-save-btn{min-width:200px}.save-success-message{font-size:.875rem;color:var(--color-success);font-weight:600;padding:.5rem 1rem;background-color:var(--color-success-bg);border-radius:4px;border:1px solid var(--color-success)}.save-error-message{font-size:.875rem;color:var(--color-error);font-weight:600;padding:.5rem 1rem;background-color:var(--color-error-bg);border-radius:4px;border:1px solid var(--color-error)}.password-strength-container{margin-top:.75rem}.password-strength-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.password-strength-indicator{display:flex;align-items:center;gap:.75rem}.password-strength-bars{display:flex;gap:4px;flex:1;max-width:200px}.password-strength-bar{height:4px;background:var(--border-light);border-radius:2px;flex:1;transition:background-color .3s}.password-strength-weak .password-strength-bar:nth-child(1){background:#ef4444}.password-strength-weak .password-strength-text{color:#ef4444}.password-strength-medium .password-strength-bar:nth-child(1),.password-strength-medium .password-strength-bar:nth-child(2){background:#f59e0b}.password-strength-medium .password-strength-text{color:#f59e0b}.password-strength-strong .password-strength-bar{background:#22c55e}.password-strength-strong .password-strength-text{color:#22c55e}.password-strength-text{font-size:.875rem;font-weight:600}.password-strength-hints{margin-top:.5rem}.password-strength-hint{font-size:.75rem;color:var(--text-tertiary);font-style:italic}.settings-section-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:0;border:none;background:none;cursor:pointer;text-align:left}.settings-section-toggle:hover .section-title-compact{color:var(--color-accent)}.section-title-compact{font-size:1rem;font-weight:600;margin:0;transition:color .2s}.section-title-danger{color:var(--text-secondary)}.section-title-danger:hover{color:var(--color-error)!important}.settings-chevron{font-size:.875rem;color:var(--text-tertiary);transition:transform .2s;transform:rotate(0)}.settings-chevron-open{transform:rotate(90deg)}.settings-collapsible-content{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-light)}.danger-description{color:var(--text-primary)}.btn-danger{padding:.75rem 1.5rem;border:2px solid var(--color-error);border-radius:6px;background:var(--color-error);color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-danger:hover:not(:disabled){background:#dc2626;border-color:#dc2626}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.delete-confirmation{display:flex;flex-direction:column;gap:1.5rem;margin-top:1rem}.delete-warning{padding:1rem;background:#fef2f2;border-left:4px solid var(--color-error);border-radius:4px}.delete-warning strong{display:block;color:var(--color-error);margin-bottom:.5rem;font-size:1rem}.delete-warning p{margin:0;font-size:.875rem;color:var(--text-primary);line-height:1.5}.delete-confirmation-instruction{font-size:.875rem;color:var(--text-secondary);margin:.5rem 0;line-height:1.5}.delete-confirmation-phrase{display:inline-block;padding:.125rem .5rem;background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:4px;font-family:Courier New,monospace;font-size:.875rem;font-weight:600;color:var(--color-error)}.delete-actions{display:flex;gap:1rem;justify-content:flex-start}.deleting-message{font-size:1rem;color:var(--text-secondary);font-style:italic}.settings-subsection-actions{display:flex;align-items:center;gap:1rem;margin-top:1rem}@media (max-width: 768px){.settings-container{padding:1rem}.settings-content{grid-template-columns:1fr}.settings-title{font-size:1.5rem}.section-title{font-size:1.25rem}.settings-section{padding:1rem}.settings-toggle-item{flex-direction:column;align-items:flex-start;gap:1rem}.toggle-switch{align-self:flex-end}}@media (max-width: 480px){.settings-save-btn{width:100%;min-width:unset}}.subscription-status{width:100%}.subscription-loading,.subscription-error{text-align:center;padding:1rem;font-size:.875rem;color:var(--text-tertiary)}.subscription-error{color:var(--color-error)}.subscription-active{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:8px;padding:1.5rem}.subscription-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.subscription-badge{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.subscription-badge-active{background:var(--color-success-bg, #e8f5e9);color:var(--color-success-text, #2e7d32)}.subscription-badge-inactive{background:var(--bg-tertiary);color:var(--text-secondary)}.subscription-badge-founding{background:linear-gradient(135deg,var(--color-success, #4caf50),var(--color-success-dark, #388e3c));color:#fff}.subscription-plan{font-size:1.25rem;font-weight:700;margin:0}.subscription-details{margin-bottom:1rem}.subscription-period{font-size:.875rem;color:var(--text-secondary);margin:0}.subscription-warning{background:var(--bg-tertiary);padding:.75rem;border-radius:6px;margin-top:.75rem}.subscription-warning p{margin:0;font-size:.875rem;font-weight:600}.subscription-actions{display:flex;align-items:center;gap:1rem}.portal-error{font-size:.875rem;color:var(--color-error)}.subscription-inactive{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:8px;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.subscription-inactive-info{display:flex;align-items:center;gap:1rem}.subscription-inactive-desc{margin:0;font-size:.875rem;color:var(--text-secondary)}.subscription-inactive-pricing{display:flex;align-items:center;gap:1rem}.subscription-inline-price{display:flex;align-items:baseline;gap:.25rem}.subscription-inline-price-symbol{font-size:.875rem;font-weight:600;color:var(--text-secondary)}.subscription-inline-price-amount{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.subscription-inline-price-period{font-size:.875rem;color:var(--text-tertiary)}.subscribe-container{max-width:1200px;margin:0 auto;padding:3rem 1rem}.subscribe-header{text-align:center;margin-bottom:3rem}.subscribe-title{font-size:2.5rem;font-weight:800;color:var(--color-interactive);margin:0 0 1rem}.subscribe-subtitle{font-size:1.25rem;color:var(--text-tertiary);margin:0}.billing-toggle{display:flex;justify-content:center;gap:0;margin-bottom:2rem;background:var(--bg-secondary);border-radius:8px;padding:4px;width:fit-content;margin-left:auto;margin-right:auto}.billing-toggle-btn{padding:.5rem 1.5rem;border:none;border-radius:6px;background:transparent;color:var(--text-secondary);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;position:relative}.billing-toggle-btn:hover:not(.billing-toggle-btn-active){color:var(--text-primary)}.billing-toggle-btn-active{background:var(--bg-primary);color:var(--color-interactive);box-shadow:0 1px 3px #0000001a}.billing-save-badge{display:inline-block;margin-left:.375rem;padding:.125rem .5rem;background:var(--color-accent-lighter);color:var(--color-accent);border-radius:10px;font-size:.75rem;font-weight:700}.founding-member-banner{background:linear-gradient(135deg,var(--color-success, #4caf50),var(--color-success-dark, #388e3c));padding:1rem 2rem;border-radius:8px;text-align:center;margin-bottom:2rem;max-width:600px;margin-left:auto;margin-right:auto;display:flex;flex-direction:column;align-items:center;gap:.25rem}.founding-member-badge{font-weight:700;font-size:1.25rem;color:#fff;display:block}.founding-member-tagline{font-size:.9375rem;color:#ffffffe6}.founding-member-discount{display:inline-block;margin-top:.25rem;padding:.25rem .75rem;background:#fff3;color:#fff;border-radius:12px;font-size:.875rem;font-weight:700}.price-regular-strikethrough{text-decoration:line-through;color:var(--text-tertiary);font-size:1.25rem;margin-right:.5rem;opacity:.7}.founding-member-banner-compact{background:linear-gradient(135deg,var(--color-success, #4caf50),var(--color-success-dark, #388e3c));padding:.75rem 1.5rem;border-radius:8px;text-align:center;margin-bottom:1rem;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.5rem}.founding-member-badge-compact{font-weight:700;font-size:1rem;color:#fff}.founding-member-tagline-compact{font-size:.875rem;color:#ffffffe6}.founding-member-discount-compact{display:inline-block;padding:.125rem .5rem;background:#fff3;color:#fff;border-radius:10px;font-size:.75rem;font-weight:700}.plan-total-regular-strikethrough{text-decoration:line-through;color:var(--text-tertiary);font-size:1rem;margin-right:.5rem;opacity:.7}.founding-member-limited-offer{text-align:center;font-size:.875rem;color:var(--text-secondary);margin:0 0 1.5rem;font-style:italic}.pricing-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem;max-width:800px;margin:0 auto 2rem}.pricing-card{background:var(--bg-primary);border-radius:12px;border:2px solid var(--border-light);padding:2rem;display:flex;flex-direction:column;position:relative;transition:all .3s ease}.pricing-card:hover{border-color:var(--color-accent);box-shadow:0 8px 24px #0000001f;transform:translateY(-4px)}.pricing-card-featured{border-color:var(--color-accent);border-width:3px;box-shadow:0 4px 16px #0000001a}.pricing-card-featured .pricing-card-title{color:var(--color-accent)}.pricing-card-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-accent-hover) 100%);color:var(--text-inverse);padding:.375rem 1rem;border-radius:20px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 8px #00000026}.pricing-card-header{text-align:center;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:2px solid var(--border-light)}.pricing-card-title{font-size:1.75rem;font-weight:700;color:var(--color-interactive);margin:0 0 1rem}.pricing-card-price{display:flex;align-items:baseline;justify-content:center;gap:.25rem}.price-currency{font-size:1.5rem;font-weight:700;color:var(--text-secondary)}.price-amount{font-size:3rem;font-weight:800;color:var(--color-interactive);line-height:1}.price-period{font-size:1rem;color:var(--text-tertiary)}.pricing-card-features{flex:1;margin-bottom:1.5rem}.features-list{list-style:none;padding:0;margin:0}.feature-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 0;font-size:.9375rem;line-height:1.5;color:var(--text-primary)}.feature-item:not(:last-child){border-bottom:1px solid var(--border-light)}.feature-icon{flex-shrink:0;width:1.25rem;height:1.25rem;display:flex;align-items:center;justify-content:center;background:var(--color-accent-lighter);color:var(--color-accent);border-radius:50%;font-size:.875rem;font-weight:700}.feature-text{flex:1}.pricing-card-action{margin-top:auto}.pricing-button{width:100%;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;text-align:center;text-decoration:none;display:inline-block}.pricing-button:disabled{opacity:.6;cursor:not-allowed}.checkout-error-message{max-width:600px;margin:2rem auto;padding:1rem;background:var(--color-error-bg);border:1px solid var(--color-error);border-radius:6px;text-align:center}.checkout-error-message p{margin:0;color:var(--color-error);font-weight:600}.subscribe-footer{text-align:center;margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border-light)}.subscribe-note{font-size:.875rem;color:var(--text-tertiary);margin:.5rem 0}@media (max-width: 768px){.subscribe-container{padding:2rem 1rem}.subscribe-title{font-size:2rem}.subscribe-subtitle{font-size:1rem}.pricing-cards{grid-template-columns:1fr;gap:1.5rem}.pricing-card{padding:1.5rem}.price-amount{font-size:2.5rem}.subscription-active{padding:1.25rem}.subscription-inactive-info{flex-direction:column;align-items:flex-start;gap:.5rem}.subscription-inactive-pricing{flex-direction:column;align-items:flex-start}.subscription-actions{flex-direction:column;align-items:stretch}}.subscribe-status-banner{width:100%;max-width:900px;margin:0 auto 2rem;padding:1.5rem 2rem;border-radius:8px;text-align:center}.subscribe-status-banner h2{margin:0 0 .5rem;font-size:1.25rem}.subscribe-status-banner p{margin:0;font-size:.9375rem}.subscribe-status-success{background-color:var(--color-success-bg, #e8f5e9);border:1px solid var(--color-success, #4caf50);color:var(--color-success-text, #2e7d32)}.subscribe-status-cancel{background-color:var(--color-warning-bg, #fff3e0);border:1px solid var(--color-warning, #ff9800);color:var(--color-warning-text, #e65100)}@media (max-width: 480px){.subscribe-header{margin-bottom:2rem}.subscribe-title{font-size:1.75rem}.pricing-card-title{font-size:1.5rem}.price-amount{font-size:2rem}.feature-item{font-size:.875rem}}.home-page{background:var(--bg-primary)}.home-page .hero{text-align:center;padding:80px 40px;background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%);color:var(--text-inverse)}.home-page .hero h1{font-size:3rem;font-weight:700;margin:0 0 20px;color:var(--text-inverse)}.home-page .hero .subtitle{font-size:1.3rem;font-weight:400;margin:0 auto 40px;max-width:600px;color:var(--text-inverse);line-height:1.6}.home-page .hero .cta-buttons{display:flex;gap:20px;justify-content:center;flex-wrap:wrap}.home-page .hero .cta-buttons .button{padding:14px 32px;font-size:1.1rem;font-weight:600;border-radius:6px;text-decoration:none;cursor:pointer;transition:all .2s;border:2px solid transparent;display:inline-block}.home-page .hero .cta-buttons .button-primary{background:var(--color-accent);color:var(--text-inverse)}.home-page .hero .cta-buttons .button-primary:hover{background:var(--color-accent-hover);transform:translateY(-2px);box-shadow:0 4px 12px #0003}.home-page .hero .cta-buttons .button-secondary{background:var(--bg-primary);color:var(--color-interactive);border-color:var(--text-inverse)}.home-page .hero .cta-buttons .button-secondary:hover{background:transparent;color:var(--text-inverse);transform:translateY(-2px);box-shadow:0 4px 12px #0003}.home-page .features{padding:80px 40px;max-width:1200px;margin:0 auto}.home-page .features h2{text-align:center;font-size:2.5rem;font-weight:700;color:var(--color-interactive);margin:0 0 60px}.home-page .features .features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:40px}.home-page .features .feature-card{text-align:center;padding:30px 20px;background:var(--bg-primary);border:2px solid var(--border-light);border-radius:8px;transition:all .3s}.home-page .features .feature-card:hover{transform:translateY(-4px);box-shadow:0 6px 20px #0000001a;border-color:var(--color-accent)}.home-page .features .feature-card .feature-icon{font-size:3rem;margin-bottom:20px}.home-page .features .feature-card h3{font-size:1.3rem;font-weight:600;color:var(--color-interactive);margin:0 0 12px}.home-page .features .feature-card p{font-size:1rem;color:var(--text-secondary);line-height:1.6;margin:0}.home-page .join-beta-cta{text-align:center;padding:60px 40px;background:var(--bg-secondary);border-top:1px solid var(--border-light)}.home-page .join-beta-cta p{font-size:1.25rem;color:var(--text-primary);max-width:600px;margin:0 auto 24px}.home-page .join-beta-cta .button{padding:14px 32px;font-size:1.1rem;font-weight:600;border-radius:6px;text-decoration:none;cursor:pointer;transition:all .2s;display:inline-block}.home-page .join-beta-cta .button-primary{background:var(--color-accent);color:var(--text-inverse)}.home-page .join-beta-cta .button-primary:hover{background:var(--color-accent-hover);transform:translateY(-2px);box-shadow:0 4px 12px #0003}.placeholder-page{padding:80px 40px;text-align:center;max-width:800px;margin:0 auto}.placeholder-page h1{font-size:2.5rem;font-weight:700;color:var(--color-interactive);margin:0 0 20px}.placeholder-page p{font-size:1.2rem;color:var(--text-secondary);margin:0}@media (max-width: 768px){.home-page .hero{padding:60px 20px}.home-page .hero h1{font-size:2rem}.home-page .hero .subtitle{font-size:1.1rem}.home-page .hero .cta-buttons{flex-direction:column;align-items:center}.home-page .hero .cta-buttons .button{width:100%;max-width:300px}.home-page .features{padding:60px 20px}.home-page .features h2{font-size:2rem;margin-bottom:40px}.home-page .features .features-grid{gap:30px}.home-page .join-beta-cta{padding:40px 20px}.home-page .join-beta-cta p{font-size:1.1rem}.placeholder-page{padding:60px 20px}.placeholder-page h1{font-size:2rem}.placeholder-page p{font-size:1.1rem}}.how-it-works-page,.skills-page,.faq-page{background:var(--bg-primary);min-height:calc(100vh - 60px)}.how-it-works-page .content-section,.skills-page .content-section,.faq-page .content-section{max-width:900px;margin:0 auto;padding:60px 40px}.how-it-works-page .content-section h1,.skills-page .content-section h1,.faq-page .content-section h1{font-size:2.8rem;font-weight:700;color:var(--color-interactive);margin:0 0 16px;text-align:center}.how-it-works-page .content-section .subtitle,.skills-page .content-section .subtitle,.faq-page .content-section .subtitle{font-size:1.2rem;color:var(--text-secondary);text-align:center;margin:0 auto 50px;max-width:700px;line-height:1.6}.how-it-works-page .content-section h2,.skills-page .content-section h2,.faq-page .content-section h2{font-size:1.8rem;font-weight:600;color:var(--color-interactive);margin:40px 0 16px}.how-it-works-page .content-section p,.skills-page .content-section p,.faq-page .content-section p{font-size:1.05rem;color:var(--text-secondary);line-height:1.7;margin:0 0 16px}.how-it-works-page .content-section ul,.skills-page .content-section ul,.faq-page .content-section ul{font-size:1.05rem;color:var(--text-secondary);line-height:1.7;margin:16px 0;padding-left:24px}.how-it-works-page .content-section ul li,.skills-page .content-section ul li,.faq-page .content-section ul li{margin-bottom:8px}.how-it-works-page .feature-sections{margin-top:40px}.how-it-works-page .feature-section{margin-bottom:50px;padding:30px;background:var(--bg-secondary);border-radius:8px;border-left:4px solid var(--color-accent)}.how-it-works-page .feature-section:last-child{background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%);color:var(--text-inverse);border-left-color:var(--color-accent)}.how-it-works-page .feature-section:last-child h2,.how-it-works-page .feature-section:last-child p,.how-it-works-page .feature-section:last-child li{color:var(--text-inverse)}.how-it-works-page .feature-section h2{margin-top:0;color:var(--color-interactive)}.how-it-works-page .feature-section p:last-child{margin-bottom:0}.how-it-works-page .feature-section ul{margin:16px 0}.skills-page .content-section{max-width:1000px;padding:40px 40px 50px}.skills-page .content-section h1{margin-bottom:10px}.skills-page .content-section .subtitle{margin-bottom:30px}.skills-page .skills-intro{margin-bottom:40px;padding:16px;background:var(--color-interactive-lighter);border-radius:6px;text-align:center}.skills-page .skills-intro p{margin:0;font-size:1rem;color:var(--color-interactive);font-weight:500}.skills-page .grades-container{display:grid;grid-template-columns:repeat(2,1fr);gap:40px;margin-bottom:40px}.skills-page .grade-section{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:8px;padding:24px}.skills-page .grade-section .grade-header{margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid var(--color-accent)}.skills-page .grade-section .grade-header h2{font-size:1.5rem;margin:0 0 4px;color:var(--color-interactive)}.skills-page .grade-section .grade-header .grade-description{font-size:.9rem;color:var(--text-secondary)}.skills-page .grade-section .category-list{margin:0;padding:0;list-style:none;display:grid;grid-template-columns:1fr;gap:8px}.skills-page .grade-section .category-list li{padding:8px 12px;background:var(--bg-secondary);border-radius:4px;font-size:.95rem;color:var(--text-primary)}.skills-page .join-beta-cta{text-align:center;padding:40px;margin-top:20px;background:var(--bg-secondary);border-radius:8px}.skills-page .join-beta-cta p{font-size:1.15rem;color:var(--text-primary);max-width:600px;margin:0 auto 20px}.skills-page .join-beta-cta .button{padding:12px 28px;font-size:1rem;font-weight:600;border-radius:6px;text-decoration:none;cursor:pointer;transition:all .2s;display:inline-block}.skills-page .join-beta-cta .button-primary{background:var(--color-accent);color:var(--text-inverse)}.skills-page .join-beta-cta .button-primary:hover{background:var(--color-accent-hover);transform:translateY(-2px);box-shadow:0 4px 12px #0003}.faq-page .faq-list{margin-top:40px}.faq-page .faq-item{margin-bottom:32px;padding:28px;background:var(--bg-primary);border:2px solid var(--border-light);border-radius:8px;transition:all .2s}.faq-page .faq-item:hover{border-color:var(--color-accent);box-shadow:0 2px 8px #0000000f}.faq-page .faq-item h2{font-size:1.4rem;margin:0 0 16px;color:var(--color-interactive);font-weight:600}.faq-page .faq-item h2:before{content:"Q: ";color:var(--color-accent);font-weight:700}.faq-page .faq-item p{margin:0 0 12px;padding-left:20px}.faq-page .faq-item p:last-child{margin-bottom:0}.faq-page .faq-item ul{padding-left:40px;margin:12px 0}.faq-page .faq-item ul li{margin-bottom:6px}.home-page .hero .hero-note{margin-top:20px;font-size:.95rem;color:var(--text-inverse);font-weight:500}@media (max-width: 768px){.how-it-works-page .content-section,.skills-page .content-section,.faq-page .content-section{padding:40px 20px}.how-it-works-page .content-section h1,.skills-page .content-section h1,.faq-page .content-section h1{font-size:2rem}.how-it-works-page .content-section .subtitle,.skills-page .content-section .subtitle,.faq-page .content-section .subtitle{font-size:1.05rem}.how-it-works-page .content-section h2,.skills-page .content-section h2,.faq-page .content-section h2{font-size:1.5rem}.how-it-works-page .content-section p,.how-it-works-page .content-section ul,.skills-page .content-section p,.skills-page .content-section ul,.faq-page .content-section p,.faq-page .content-section ul{font-size:1rem}.skills-page .content-section{padding:30px 20px 40px}.skills-page .grades-container{grid-template-columns:1fr;gap:30px}.skills-page .grade-section{padding:20px}.skills-page .grade-section .grade-header h2{font-size:1.3rem}.skills-page .grade-section .category-list li{font-size:.9rem;padding:6px 10px}.skills-page .join-beta-cta{padding:30px 20px}.skills-page .join-beta-cta p{font-size:1.05rem}.how-it-works-page .feature-section{padding:20px;margin-bottom:30px}.faq-page .faq-item{padding:20px}.faq-page .faq-item h2{font-size:1.2rem}}@media (max-width: 480px){.how-it-works-page .content-section,.skills-page .content-section,.faq-page .content-section{padding:30px 16px}.skills-page .grade-section{padding:16px}}.not-found-container{max-width:600px;margin:0 auto;padding:80px 40px;text-align:center}.not-found-container .not-found-title{font-size:8rem;font-weight:700;color:var(--color-accent);margin:0;line-height:1}.not-found-container .not-found-subtitle{font-size:2rem;font-weight:600;color:var(--text-primary);margin:20px 0}.not-found-container .not-found-message{font-size:1.1rem;color:var(--text-secondary);margin:20px 0 40px;line-height:1.6}.not-found-container .not-found-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.not-found-container .not-found-actions .button{padding:12px 32px;font-size:1rem;text-decoration:none;border-radius:6px;transition:all .2s;font-weight:500}.not-found-container .not-found-actions .button.button-primary{background:var(--color-interactive);color:#fff;border:2px solid var(--color-interactive)}.not-found-container .not-found-actions .button.button-primary:hover{filter:brightness(.9);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.not-found-container .not-found-actions .button.button-secondary{background:transparent;color:var(--color-interactive);border:2px solid var(--color-interactive)}.not-found-container .not-found-actions .button.button-secondary:hover{background:var(--color-interactive);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}@media (max-width: 768px){.not-found-container{padding:60px 20px}.not-found-container .not-found-title{font-size:5rem}.not-found-container .not-found-subtitle{font-size:1.5rem}.not-found-container .not-found-actions{flex-direction:column}.not-found-container .not-found-actions .button{width:100%}}.tests-container{max-width:1200px;margin:0 auto;padding:25px}.tests-title{font-size:28px;font-weight:700;margin-bottom:10px;color:var(--text-primary)}.tests-description{font-size:16px;color:var(--text-primary);margin-bottom:30px}.tests-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.test-card{background:var(--bg-primary);border:2px solid var(--border-light);border-radius:8px;padding:20px;display:flex;flex-direction:column;gap:12px;transition:transform .2s,box-shadow .2s,border-color .2s}.test-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-interactive)}.test-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.test-card-title{font-size:20px;font-weight:700;margin:0;color:var(--text-primary)}.test-difficulty{padding:4px 12px;border-radius:12px;font-size:13px;font-weight:600;white-space:nowrap}.test-difficulty.test-difficulty-easy{background:var(--color-success-bg);color:var(--color-success)}.test-difficulty.test-difficulty-medium{background:var(--color-warning-bg);color:var(--text-primary)}.test-difficulty.test-difficulty-hard{background:var(--color-error-bg);color:var(--color-error)}.test-card-description{color:var(--text-primary);font-size:14px;margin:0;line-height:1.4}.test-card-details{display:flex;flex-wrap:wrap;gap:15px;padding-top:10px;border-top:1px solid var(--border-light)}.test-detail{display:flex;gap:6px;font-size:14px}.test-detail-label{font-weight:600;color:var(--text-primary)}.test-detail-value{color:var(--text-primary)}.test-card-skills{border-top:1px solid var(--border-light);padding-top:12px}.test-skills-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.test-skill-tag{background:var(--bg-tertiary);padding:4px 10px;border-radius:6px;font-size:12px;color:var(--text-primary)}.test-start-button{margin-top:auto;width:100%;height:48px;cursor:pointer;border:none;border-radius:6px;font-size:16px;font-weight:700;background-color:var(--color-accent);color:var(--text-inverse);transition:all .2s}.test-start-button:hover{box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--color-accent)}.test-taking-container{max-width:900px;margin:0 auto;padding:25px}.test-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px;padding-bottom:15px;border-bottom:2px solid var(--border-primary)}.test-header-actions{display:flex;gap:10px;align-items:center}.test-exit-button{padding:8px 16px;border-radius:6px;border:1px solid var(--border-primary);background:var(--bg-primary);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.test-exit-button:hover{background:var(--bg-secondary);border-color:var(--color-error);color:var(--color-error)}.test-name{font-size:24px;font-weight:700;margin:0 0 8px;color:var(--text-primary)}.test-progress{font-size:16px;color:var(--text-primary);font-weight:600}.test-timer{display:flex;flex-direction:column;align-items:flex-end;padding:1rem;background:var(--bg-secondary);border-radius:8px;min-width:120px}.test-timer.test-timer-warning{background:var(--color-warning-bg);border:2px solid var(--color-warning)}.test-timer.test-timer-warning .test-timer-value{color:var(--text-primary)}.test-timer-label{font-size:.875rem;color:var(--text-secondary);margin-bottom:.25rem}.test-timer-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums}.test-problem-area{min-height:400px;margin-bottom:2rem}.test-navigation{display:flex;justify-content:space-between;align-items:center;gap:15px;margin-bottom:30px}.test-navigation>button{height:48px;min-width:130px;cursor:pointer;border:none;border-radius:6px;font-size:16px;font-weight:700;background-color:var(--color-accent);color:var(--text-inverse);transition:all .2s}.test-navigation>button:hover:not(:disabled){box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--color-accent)}.test-navigation>button:disabled{opacity:.5;cursor:not-allowed}.test-question-legend{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;align-items:center;flex:1;max-width:600px}.test-question-dot{width:36px;height:36px;border-radius:50%;border:2px solid var(--border-primary);background:var(--bg-secondary);color:var(--text-primary);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.test-question-dot:hover{transform:scale(1.1);border-color:var(--color-interactive)}.test-question-dot.answered{background:var(--color-success-bg);border-color:var(--color-success);color:var(--color-success)}.test-question-dot.unanswered{background:var(--bg-secondary);border-color:var(--border-primary);color:var(--text-secondary)}.test-question-dot.current{border-width:3px;border-color:var(--color-accent);box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--color-accent)}.test-question-dot.current.answered{border-color:var(--color-accent)}.test-results-container{max-width:800px;margin:0 auto;padding:25px;text-align:center}.test-results-container h1{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:10px}.test-results-container h2{font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:30px}.results-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:30px;margin:30px 0;padding:30px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-light)}.result-stat{display:flex;flex-direction:column;gap:8px}.result-label{font-size:13px;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}.result-value{font-size:20px;font-weight:700;color:var(--text-primary)}.result-value.result-score{font-size:42px;color:var(--color-interactive)}.result-badge{display:inline-block;padding:8px 24px;border-radius:24px;font-size:16px;font-weight:700}.result-badge.result-passed{background:var(--color-success);color:var(--text-inverse)}.result-badge.result-failed{background:var(--color-warning);color:var(--text-primary)}.results-actions{display:flex;justify-content:center;gap:15px;margin-top:30px}.results-actions button{height:48px;min-width:150px;cursor:pointer;border:none;border-radius:6px;font-size:16px;font-weight:700;background-color:var(--color-accent);color:var(--text-inverse);transition:all .2s}.results-actions button:hover{box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--color-accent)}.test-warning-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--overlay-bg);display:flex;align-items:center;justify-content:center;z-index:1000}.test-warning-dialog{background:var(--bg-primary);padding:2rem;border-radius:12px;max-width:500px;box-shadow:0 8px 24px #0003;border:2px solid var(--border-primary)}.test-warning-dialog h3{margin-top:0;color:var(--text-primary)}.test-warning-dialog p{margin:1rem 0;line-height:1.6}.test-warning-dialog.test-warning h3{color:var(--text-primary)}.test-warning-dialog.test-confirm h3{color:var(--color-interactive)}.test-warning-actions{display:flex;gap:15px;justify-content:flex-end;margin-top:20px}.test-warning-actions button{height:40px;min-width:120px;cursor:pointer;border:none;border-radius:6px;font-size:14px;font-weight:700;transition:all .2s}.test-warning-actions button:first-child{background-color:var(--border-primary);color:var(--text-primary)}.test-warning-actions button:first-child:hover{background-color:var(--border-secondary)}.test-warning-actions button:last-child{background-color:var(--color-accent);color:var(--text-inverse)}.test-warning-actions button:last-child:hover{box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--color-accent)}.test-error{text-align:center;padding:60px 25px}.test-error h2{margin-bottom:30px;font-size:24px;font-weight:700;color:var(--text-primary)}.test-error button{height:48px;min-width:150px;cursor:pointer;border:none;border-radius:6px;font-size:16px;font-weight:700;background-color:var(--color-accent);color:var(--text-inverse);transition:all .2s}.test-error button:hover{box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--color-accent)}.test-review{margin-top:3rem;text-align:left}.test-review h2{font-size:24px;font-weight:700;margin-bottom:1.5rem;color:var(--text-primary);text-align:center}.review-item{border:1px solid var(--border-light);border-radius:8px;padding:1.25rem;margin-bottom:1.25rem;background:var(--bg-primary);transition:box-shadow .2s}.review-item:hover{box-shadow:var(--shadow-md)}.review-item.correct{border-left:4px solid var(--color-success)}.review-item.incorrect{border-left:4px solid var(--color-error)}.review-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-light)}.review-header h3{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.correctness-icon{font-size:1.75rem;line-height:1;font-weight:700;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0}.correctness-icon.correct{color:var(--color-success);background:var(--color-success-bg)}.correctness-icon.incorrect{color:var(--color-error);background:var(--color-error-bg)}.review-question{margin-bottom:1rem}.review-question .question-text{font-size:16px;line-height:1.6;color:var(--text-primary);margin:0;white-space:pre-wrap}.answer-comparison{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.answer-comparison .user-answer,.answer-comparison .correct-answer{padding:.75rem;border-radius:6px;font-size:15px;line-height:1.5}.answer-comparison .user-answer strong,.answer-comparison .correct-answer strong{font-weight:600;display:inline}.answer-comparison .user-answer{background:var(--bg-secondary);border:1px solid var(--border-light)}.answer-comparison .correct-answer{background:var(--color-success-bg);border:1px solid var(--color-success);color:var(--text-primary)}.collapsible-section{margin-top:1rem}.collapsible-section button.toggle{background:none;border:1px solid var(--border-light);padding:.625rem 1rem;cursor:pointer;border-radius:6px;font-size:14px;font-weight:600;color:var(--text-primary);width:100%;text-align:left;transition:all .2s;display:flex;align-items:center;gap:.5rem}.collapsible-section button.toggle:hover{background:var(--bg-secondary);border-color:var(--color-interactive)}.collapsible-section .collapsible-content{margin-top:.75rem;padding:1rem;background:var(--bg-secondary);border-radius:6px;font-size:14px;line-height:1.6;color:var(--text-primary)}.collapsible-section .collapsible-content p{margin:0;white-space:pre-wrap}.collapsible-section.hints-section .collapsible-content{background:var(--color-info-bg)}.collapsible-section.explanation-section .collapsible-content{background:var(--color-success-bg)}.collapsible-section .hint-item{margin-bottom:.75rem}.collapsible-section .hint-item:last-child{margin-bottom:0}.collapsible-section .hint-item strong{font-weight:600;color:var(--text-primary)}@media (max-width: 768px){.tests-grid{grid-template-columns:1fr}.test-header{flex-direction:column;align-items:stretch}.test-timer{align-items:flex-start;margin-top:15px}.test-navigation{flex-direction:column}.test-navigation>button{width:100%}.test-navigation .test-question-legend{order:-1;margin-bottom:15px}.results-summary{grid-template-columns:1fr}.test-warning-dialog{margin:15px;max-width:calc(100% - 30px)}.results-actions{flex-direction:column}.results-actions button{width:100%}}.admin-layout{display:flex;flex-direction:column;min-height:100vh;background-color:#f5f7fa}.admin-navbar{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #0000001a;position:sticky;top:0;z-index:1000}.admin-navbar .navbar-container{max-width:1400px;margin:0 auto;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;height:64px}.admin-navbar .navbar-brand{display:flex;align-items:center;gap:1rem;color:#fff;font-size:1.5rem;font-weight:700;text-decoration:none}.admin-navbar .navbar-brand .brand-icon{font-size:1.75rem}.admin-navbar .navbar-brand .brand-text{letter-spacing:-.5px}.admin-navbar .navbar-nav{display:flex;gap:.5rem;flex:1;justify-content:center;align-items:center}.admin-navbar .navbar-user{display:flex;align-items:center;gap:1rem;color:#fff}.admin-navbar .navbar-user .navbar-version{font-size:.75rem;font-family:monospace;opacity:.7;padding-right:.5rem;border-right:1px solid rgba(255,255,255,.3)}.admin-navbar .navbar-user .navbar-username{font-weight:500;font-size:.95rem}.admin-navbar .navbar-user .navbar-logout-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.admin-navbar .navbar-user .navbar-logout-btn:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-1px)}.admin-navbar .navbar-user .navbar-logout-btn:active{transform:translateY(0)}.admin-nav-link{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;color:#ffffffe6;text-decoration:none;border-radius:8px;font-weight:500;font-size:.95rem;transition:all .2s ease;position:relative}.admin-nav-link .nav-icon{font-size:1.1rem}.admin-nav-link:hover{background:#ffffff26;color:#fff}.admin-nav-link.active{background:#ffffff40;color:#fff}.admin-nav-link.active:after{content:"";position:absolute;bottom:-2px;left:1.25rem;right:1.25rem;height:3px;background:#fff;border-radius:2px 2px 0 0}.admin-main{flex:1;max-width:1400px;width:100%;margin:0 auto;padding:2rem}.admin-page{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:2rem}.admin-page .page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #e5e7eb}.admin-page .page-header h1{font-size:2rem;font-weight:700;color:#1f2937;margin:0}.admin-welcome{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #e5e7eb}.admin-welcome h1{font-size:2rem;font-weight:700;color:#1f2937;margin:0 0 .5rem}.admin-welcome p{color:#6b7280;font-size:1rem;margin:0}.admin-info-page{max-width:600px;margin:4rem auto;text-align:center;padding:3rem 2rem;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a}.admin-info-page h1{font-size:2rem;font-weight:700;color:#1f2937;margin:0 0 1rem}.admin-info-page p{color:#6b7280;font-size:1rem;margin:0 0 1.5rem}.admin-info-page p:last-child{margin-bottom:0}.admin-info-page .button{margin-top:.5rem}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:1.5rem;color:#fff;box-shadow:0 4px 6px #0000001a;transition:transform .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 6px 12px #00000026}.stat-card .stat-icon{font-size:2rem;margin-bottom:.5rem;opacity:.9}.stat-card .stat-title{font-size:.9rem;font-weight:500;opacity:.9;margin-bottom:.5rem}.stat-card .stat-value{font-size:2.5rem;font-weight:700;margin-bottom:.25rem}.stat-card .stat-description{font-size:.85rem;opacity:.8}.table-container{overflow-x:auto;border-radius:8px;border:1px solid #e5e7eb;margin-top:1rem}.admin-table{width:100%;border-collapse:collapse;font-size:.95rem}.admin-table thead{background-color:#f9fafb}.admin-table thead tr{border-bottom:2px solid #e5e7eb}.admin-table thead th{padding:1rem;text-align:left;font-weight:600;color:#374151;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.admin-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background-color .15s ease}.admin-table tbody tr:hover{background-color:#f9fafb}.admin-table tbody tr:last-child{border-bottom:none}.admin-table tbody td{padding:1rem;color:#4b5563}.badge{display:inline-flex;align-items:center;padding:.375rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:500}.badge.badge-student{background-color:#dbeafe;color:#1e40af}.badge.badge-parent{background-color:#fce7f3;color:#9f1239}.badge.badge-teacher{background-color:#fef3c7;color:#92400e}.badge.badge-admin{background-color:#ede9fe;color:#5b21b6}.badge.badge-success{background-color:#d1fae5;color:#065f46}.badge.badge-warning{background-color:#fed7aa;color:#92400e}.badge.badge-error{background-color:#fee2e2;color:#991b1b}.badge.badge-danger{background-color:#fecaca;color:#991b1b}.badge.badge-info{background-color:#e0e7ff;color:#3730a3}.search-filters{margin-bottom:1.5rem}.filter-row{display:flex;gap:1rem;align-items:center}.filter-row .input{flex:1;max-width:400px}.filter-row .select{min-width:200px}.admin-form-container{max-width:800px;margin:0 auto}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-weight:500;color:#374151;margin-bottom:.5rem;font-size:.95rem}.form-group .input,.form-group .textarea,.form-group .select{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.95rem;transition:all .2s ease}.form-group .input:focus,.form-group .textarea:focus,.form-group .select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group .input:disabled,.form-group .textarea:disabled,.form-group .select:disabled{background-color:#f3f4f6;cursor:not-allowed}.form-group .input.input-error,.form-group .textarea.input-error,.form-group .select.input-error{border-color:#dc2626}.form-group .input.input-error:focus,.form-group .textarea.input-error:focus,.form-group .select.input-error:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.form-group .textarea{resize:vertical;min-height:100px;font-family:inherit}.form-group .checkbox-label{display:flex;align-items:center;gap:.5rem;font-weight:400;cursor:pointer}.form-group .checkbox-label input[type=checkbox]{width:auto;cursor:pointer}.form-group .radio-group{display:flex;flex-direction:column;gap:.75rem}.form-group .radio-label{display:flex;align-items:center;gap:.5rem;font-weight:400;cursor:pointer}.form-group .radio-label input[type=radio]{width:auto;cursor:pointer}.form-help{display:block;color:#6b7280;font-size:.875rem;margin-top:.5rem}.field-error{display:block;color:#dc2626;font-size:.875rem;margin-top:.5rem}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.success-alert{background-color:#d1fae5;border:1px solid #6ee7b7;border-radius:6px;padding:1rem;margin-bottom:1.5rem}.success-alert .success-message{color:#065f46;font-size:.95rem;margin:0}.search-loading{padding:1rem;text-align:center;color:#6b7280;font-size:.95rem}.search-loading p{margin:0}.parent-search-results{border:1px solid #e5e7eb;border-radius:6px;margin-top:.5rem;max-height:300px;overflow-y:auto}.parent-search-results .search-results-label{padding:.75rem 1rem;background-color:#f9fafb;border-bottom:1px solid #e5e7eb;font-weight:500;color:#374151;margin:0;font-size:.9rem}.parent-result-item{padding:1rem;border-bottom:1px solid #e5e7eb;cursor:pointer;transition:background-color .15s ease}.parent-result-item:last-child{border-bottom:none}.parent-result-item:hover{background-color:#f9fafb}.parent-result-item.selected{background-color:#ede9fe;border-left:3px solid #667eea}.parent-result-item .parent-result-email{font-weight:500;color:#1f2937;margin-bottom:.25rem}.parent-result-item .parent-result-type{font-size:.875rem;color:#6b7280}.search-no-results{padding:1.5rem;text-align:center;color:#6b7280;font-size:.95rem;border:1px solid #e5e7eb;border-radius:6px;margin-top:.5rem}.search-no-results p{margin:0}.selected-parent-info{margin-top:1rem;padding:1rem;background-color:#f0fdf4;border:1px solid #86efac;border-radius:6px}.selected-parent-info .selected-parent-label{font-weight:500;color:#166534;margin:0 0 .5rem;font-size:.9rem}.selected-parent-info .selected-parent-details{display:flex;justify-content:space-between;align-items:center;color:#166534}.selected-parent-info .selected-parent-details div{flex:1}.selected-parent-info .selected-parent-details strong{font-weight:600}.button{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.button:disabled{opacity:.5;cursor:not-allowed}.button.button-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.button.button-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 8px #667eea4d}.button.button-secondary{background-color:#f3f4f6;color:#374151}.button.button-secondary:hover:not(:disabled){background-color:#e5e7eb}.button.button-danger{background-color:#dc2626;color:#fff}.button.button-danger:hover:not(:disabled){background-color:#b91c1c;transform:translateY(-1px);box-shadow:0 4px 8px #dc26264d}.button.button-small{padding:.5rem 1rem;font-size:.875rem}.button-group{display:flex;gap:.5rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:600px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-content.modal-small{max-width:400px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.modal-header h2{font-size:1.5rem;font-weight:600;color:#1f2937;margin:0}.modal-header .modal-close{background:none;border:none;font-size:2rem;color:#9ca3af;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.modal-header .modal-close:hover{background-color:#f3f4f6;color:#374151}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:1px solid #e5e7eb}.info-card{background:#fff;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;border:1px solid #e5e7eb}.info-card h2{font-size:1.25rem;font-weight:600;color:#1f2937;margin:0 0 1.5rem;padding-bottom:1rem;border-bottom:2px solid #e5e7eb}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.info-item{display:flex;flex-direction:column;gap:.5rem}.info-item .info-label{font-size:.875rem;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.info-item .info-value{font-size:1rem;color:#1f2937;word-break:break-all}.empty-state{text-align:center;padding:3rem 1rem;color:#6b7280}.empty-state p{font-size:1rem;margin:0}.loading-container{display:flex;align-items:center;justify-content:center;padding:3rem}.loading-container p{color:#6b7280;font-size:1rem}.error-alert{background-color:#fef2f2;border:1px solid #fecaca;border-radius:6px;padding:1rem;margin-bottom:1rem}.error-alert .error-message{color:#991b1b;font-size:.95rem;margin:0}.admin-test-checkout-page{max-width:600px;margin:0 auto}.admin-test-checkout-page h1{font-size:2rem;font-weight:700;color:#1f2937;margin:0 0 1rem}.admin-test-checkout-page .admin-test-checkout-description{color:#6b7280;font-size:1rem;margin-bottom:2rem}.admin-test-checkout-page .admin-test-checkout-success{background-color:#d1fae5;border:1px solid #6ee7b7;border-radius:6px;padding:1rem;margin-bottom:1.5rem}.admin-test-checkout-page .admin-test-checkout-success p{color:#065f46;font-size:.95rem;margin:0}.admin-test-checkout-page .admin-test-checkout-cancel{background-color:#fef3c7;border:1px solid #fcd34d;border-radius:6px;padding:1rem;margin-bottom:1.5rem}.admin-test-checkout-page .admin-test-checkout-cancel p{color:#92400e;font-size:.95rem;margin:0}.admin-test-checkout-page .admin-test-checkout-error{background-color:#fee2e2;border:1px solid #fecaca;border-radius:6px;padding:1rem;margin-bottom:1.5rem}.admin-test-checkout-page .admin-test-checkout-error p{color:#991b1b;font-size:.95rem;margin:0 0 1rem}.admin-test-checkout-page .admin-test-checkout-actions{display:flex;gap:1rem;margin-bottom:2rem}.admin-test-checkout-page .admin-test-checkout-invoices{margin-top:2rem;padding-top:2rem;border-top:1px solid #e5e7eb}.admin-test-checkout-page .admin-test-checkout-invoices h2{font-size:1.25rem;font-weight:600;color:#374151;margin:0 0 1rem}.admin-test-checkout-page .admin-test-checkout-invoices .invoice-loading,.admin-test-checkout-page .admin-test-checkout-invoices .invoice-empty{color:#6b7280;font-style:italic}.admin-test-checkout-page .admin-test-checkout-invoices .invoice-error{color:#991b1b}.admin-test-checkout-page .admin-test-checkout-invoices .invoice-table-container{overflow-x:auto;border-radius:8px;border:1px solid #e5e7eb}.admin-test-checkout-page .admin-test-checkout-invoices .invoice-pdf-btn{margin-left:.5rem}.admin-test-checkout-page .admin-test-checkout-info{margin-top:2rem;padding-top:2rem;border-top:1px solid #e5e7eb}.admin-test-checkout-page .admin-test-checkout-info h2{font-size:1.25rem;font-weight:600;color:#374151;margin:0 0 1rem}.admin-test-checkout-page .admin-test-checkout-info ul{margin:0;padding-left:1.5rem;color:#6b7280}.admin-test-checkout-page .admin-test-checkout-info ul li{margin-bottom:.5rem;line-height:1.5}.admin-test-checkout-page .admin-test-checkout-info ul li:last-child{margin-bottom:0}@media (max-width: 768px){.admin-navbar .navbar-container{flex-wrap:wrap;height:auto;padding:1rem}.admin-navbar .navbar-nav{width:100%;justify-content:flex-start;flex-wrap:wrap;margin-top:1rem;order:3}.admin-navbar .navbar-user .navbar-version,.admin-navbar .navbar-user .navbar-username{display:none}.admin-main,.admin-page{padding:1rem}.admin-page .page-header{flex-direction:column;align-items:flex-start;gap:1rem}.filter-row{flex-direction:column}.filter-row .input,.filter-row .select{max-width:100%;width:100%}.admin-stats-grid,.info-grid{grid-template-columns:1fr}}.fraction-visual-container{margin:30px auto;display:flex;justify-content:center;align-items:center;min-height:200px}.fraction-bar-container{display:flex;border:2px solid var(--text-primary);border-radius:4px;overflow:hidden;width:300px;height:60px;background-color:var(--bg-primary)}.fraction-segment{flex:1;border-right:1px solid var(--text-primary);display:flex;align-items:center;justify-content:center;min-height:60px;min-width:10px}.fraction-segment:last-child{border-right:none}.fraction-segment.shaded{background-color:var(--color-interactive);color:var(--text-inverse)}.fraction-segment.unshaded{background-color:var(--bg-primary);color:var(--text-primary)}.fraction-circle{display:flex;flex-direction:column;align-items:center;gap:15px}.fraction-circle svg{width:150px;height:150px}.fraction-circle .fraction-segment.shaded{fill:var(--color-interactive)}.fraction-circle .fraction-segment.unshaded{fill:var(--text-inverse)}.fraction-squares{display:inline-block}.fraction-squares .fraction-grid-container{display:grid;gap:2px;padding:4px;border:2px solid var(--text-primary);border-radius:4px;background-color:var(--text-primary);width:fit-content;height:fit-content}.fraction-squares .fraction-grid-container.grid-cols-2{grid-template-columns:repeat(2,50px);grid-template-rows:repeat(2,50px)}.fraction-squares .fraction-grid-container.grid-cols-3{grid-template-columns:repeat(3,50px);grid-template-rows:repeat(3,50px)}.fraction-squares .fraction-grid-container.grid-cols-4{grid-template-columns:repeat(4,50px);grid-template-rows:repeat(4,50px)}.fraction-squares .fraction-grid-container.grid-cols-5{grid-template-columns:repeat(5,45px);grid-template-rows:repeat(5,45px)}.fraction-squares .fraction-grid-container.grid-cols-6{grid-template-columns:repeat(6,40px);grid-template-rows:repeat(6,40px)}.fraction-squares .fraction-grid-container.grid-cols-7{grid-template-columns:repeat(7,35px);grid-template-rows:repeat(7,35px)}.fraction-squares .fraction-grid-container.grid-cols-8{grid-template-columns:repeat(8,35px);grid-template-rows:repeat(8,35px)}.fraction-squares .fraction-grid-container .grid-square{width:100%;height:100%;box-sizing:border-box}.fraction-squares .fraction-grid-container .grid-square.shaded{background-color:var(--color-interactive)}.fraction-squares .fraction-grid-container .grid-square.unshaded{background-color:var(--bg-primary)}.fraction-label{font-size:24px;font-weight:600;color:var(--text-primary)}.fraction-comparison-container{display:flex;justify-content:center;align-items:center;gap:30px;margin:30px auto;min-height:250px;max-width:800px}.fraction-comparison-container.no-visual{justify-content:flex-start;margin:20px 0;min-height:auto;gap:20px}.fraction-option{cursor:pointer;padding:15px;border:3px solid transparent;border-radius:8px;transition:all .2s ease}.fraction-option:hover{border-color:var(--border-secondary)}.fraction-option.selected{border-color:var(--color-interactive);border-width:4px;background-color:var(--bg-hover);transform:scale(1.05);box-shadow:0 0 12px var(--shadow-interactive)}.fraction-option.selected .fraction-bar-container{border-color:var(--color-interactive);border-width:3px}.fraction-option.selected .fraction-circle svg{filter:drop-shadow(0 0 6px var(--shadow-interactive))}.fraction-vs{font-size:24px;font-weight:700;color:var(--text-secondary);margin:0 20px}.fraction-vs-section{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;min-width:100px}.fraction-vs-section .comparison-select{font-size:24px;font-weight:600;padding:8px 16px;border:2px solid var(--border-secondary);border-radius:8px;background-color:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:all .2s ease;min-width:80px;text-align:center}.fraction-vs-section .comparison-select:hover:not(:disabled){background-color:var(--bg-secondary);border-color:var(--color-interactive)}.fraction-vs-section .comparison-select:focus{outline:none;border-color:var(--color-interactive);box-shadow:0 0 0 3px var(--shadow-interactive-light)}.fraction-vs-section .comparison-select:disabled{cursor:not-allowed;opacity:.6}.fraction-vs-section .comparison-select option{font-size:20px;padding:4px 8px}.fraction-equal-option{display:flex;justify-content:center;margin-top:20px}.equal-button{all:unset;background-color:var(--bg-primary);border:2px solid var(--border-secondary);border-radius:8px;padding:12px 24px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.equal-button:hover{border-color:var(--color-interactive);background-color:var(--bg-hover)}.equal-button.selected{background-color:var(--color-interactive);color:var(--text-inverse);border-color:var(--color-interactive)}.equal-button:disabled{cursor:not-allowed;opacity:.6}.equal-button:disabled:hover{border-color:var(--border-secondary);background-color:var(--bg-primary)}.arithmetic-problem .dsl-fraction-visual{display:inline-block;margin:20px 40px;vertical-align:top;width:300px}.arithmetic-problem .dsl-fraction-visual .fraction-bar-container{margin-bottom:15px}.arithmetic-problem h2.arithmetic-problem-type+.dsl-fraction-visual{margin-top:30px}.arithmetic-problem .dsl-fraction-visual+.dsl-fraction-visual{margin-left:80px}.fraction-comparison-layout{display:flex;justify-content:center;align-items:flex-start;gap:80px;margin:30px 0}.fraction-comparison-layout .fraction-item{text-align:center}.fraction-comparison-layout .fraction-item .fraction-label{margin-top:15px;font-size:16px;color:var(--text-secondary);font-weight:600}@media (max-width: 768px){.fraction-comparison-container{flex-direction:row;gap:10px;margin:20px auto;min-height:auto}.fraction-option{padding:8px;flex:1}.fraction-option.selected{transform:scale(1.02)}.fraction-bar-container{width:100%;max-width:140px;height:40px}.fraction-circle svg{width:80px;height:80px}.fraction-squares .fraction-grid-container.grid-cols-2{grid-template-columns:repeat(2,30px);grid-template-rows:repeat(2,30px)}.fraction-squares .fraction-grid-container.grid-cols-3{grid-template-columns:repeat(3,30px);grid-template-rows:repeat(3,30px)}.fraction-squares .fraction-grid-container.grid-cols-4{grid-template-columns:repeat(4,25px);grid-template-rows:repeat(4,25px)}.fraction-squares .fraction-grid-container.grid-cols-5{grid-template-columns:repeat(5,22px);grid-template-rows:repeat(5,22px)}.fraction-squares .fraction-grid-container.grid-cols-6{grid-template-columns:repeat(6,20px);grid-template-rows:repeat(6,20px)}.fraction-squares .fraction-grid-container.grid-cols-7{grid-template-columns:repeat(7,18px);grid-template-rows:repeat(7,18px)}.fraction-squares .fraction-grid-container.grid-cols-8{grid-template-columns:repeat(8,16px);grid-template-rows:repeat(8,16px)}.fraction-vs{font-size:16px;margin:0}.fraction-vs-section{min-width:60px;gap:5px}.fraction-vs-section .comparison-select{font-size:18px;padding:4px 8px;min-width:50px}.arithmetic-problem .dsl-fraction-visual{display:block;margin:20px auto;width:250px}.arithmetic-problem .dsl-fraction-visual+.dsl-fraction-visual{margin-left:auto;margin-top:30px}.fraction-comparison-layout{flex-direction:column;gap:30px}}.factor-grid-container{margin:20px 0}.factor-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(50px,1fr));gap:8px;max-width:600px}.factor-button{all:unset;display:flex;justify-content:center;align-items:center;width:50px;height:50px;border:2px solid var(--border-secondary);border-radius:8px;background-color:var(--bg-primary);font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.factor-button:hover{border-color:var(--color-interactive);background-color:var(--bg-hover)}.factor-button.selected{background-color:var(--color-interactive);color:var(--text-inverse);border-color:var(--color-interactive)}.factor-button.disabled{cursor:not-allowed;opacity:.6}.factor-button.disabled:hover{border-color:var(--border-secondary);background-color:var(--bg-primary)}.factor-pairs-visual{margin:30px 0;text-align:center}.factor-pairs-visual h4{font-size:18px;color:var(--text-primary);margin-bottom:20px}.rectangles-container{display:flex;flex-wrap:wrap;justify-content:center;gap:20px;margin-bottom:20px}.factor-pair-item{display:flex;flex-direction:column;align-items:center}.rectangle-with-label{display:flex;flex-direction:column;align-items:center;gap:10px}.factor-rectangle{margin-bottom:5px}.pair-label{display:flex;flex-direction:column;align-items:center;gap:4px}.pair-text{font-weight:600;color:var(--text-primary);font-size:16px}.pair-dimensions{font-size:14px;color:var(--text-secondary);font-family:monospace}.visual-explanation{background:var(--bg-secondary);border:2px solid var(--border-primary);border-radius:8px;padding:15px;margin-top:20px}.visual-explanation p{margin:8px 0;font-size:16px;color:var(--text-primary)}.factor-pairs-input{margin:30px 0;text-align:left;width:100%;max-width:500px}.factor-pairs-input .answer-input{width:100%}.answer-feedback{background:var(--color-success-bg);border:2px solid var(--color-success);border-radius:8px;padding:15px;margin-top:15px}.answer-feedback p{margin:0;color:var(--color-success);font-size:16px}.prime-composite-explanation{margin:30px 0;display:flex;flex-direction:column;gap:20px}.definition-box{background:var(--color-interactive-lighter);border:2px solid var(--color-interactive);border-radius:8px;padding:20px}.definition-box p{margin:10px 0;font-size:16px;color:var(--text-primary)}.prime-composite-input{margin:30px 0;display:flex;flex-direction:column;align-items:flex-start;width:100%;max-width:500px}.word-problem-content{background:var(--bg-secondary);border:2px solid var(--border-light);border-radius:12px;padding:24px;margin:20px auto;box-shadow:var(--shadow-md);max-width:600px}.word-problem-text{font-size:18px!important;line-height:1.6!important;color:var(--text-secondary);text-align:left!important}.word-problem-text .katex{font-size:18px!important}.word-problem-text .katex-display{margin:0!important;text-align:left!important}.arithmetic-problem .word-problem-content{margin-bottom:24px}.arithmetic-problem .arithmetic-problem-type{color:var(--text-primary);margin-bottom:16px;text-align:left;font-weight:600}.arithmetic-problem .answer-input{width:200px}@media (max-width: 768px){.word-problem-content{padding:16px;margin:16px 0}.word-problem-text,.word-problem-text .katex{font-size:16px!important}}.angle-classification-container{display:flex;flex-direction:column;align-items:center;gap:20px;padding:20px;background:var(--bg-secondary);border-radius:12px;margin:20px 0}.angle-problem h3{text-align:center;font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:20px}.angle-display{display:flex;justify-content:center;margin:20px 0}.angle-svg{background:var(--bg-primary);border-radius:8px;box-shadow:var(--shadow-md)}.angle-options{display:flex;gap:12px;margin:20px 0;flex-wrap:wrap}.angle-option-button{padding:12px 24px;border:2px solid var(--border-primary);border-radius:8px;background:var(--bg-primary);font-size:16px;font-weight:500;color:var(--text-tertiary);cursor:pointer;transition:all .2s ease;min-width:80px}.angle-option-button:hover{border-color:#1f7084;background:var(--bg-secondary)}.angle-option-button.selected{border-color:#1f7084;background:var(--color-interactive-lighter);color:var(--text-primary)}.angle-option-button:disabled{cursor:not-allowed;opacity:.6}.angle-option-button.correct{border-color:#22c55e;background:var(--color-success-bg);color:var(--color-success)}.angle-option-button.incorrect{border-color:#ef4444;background:var(--color-error-bg);color:var(--color-error)}.angle-option-button.missed{border-color:#f59e0b;background:#fef3c7;color:#92400e}.angle-controls{display:flex;gap:12px;justify-content:center;margin:20px 0}.reset-button{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;background:var(--text-secondary);color:var(--text-inverse)}.angle-result{text-align:center;margin-top:20px}.result{padding:12px 16px;border-radius:8px;margin-bottom:16px;font-weight:500}.angle-legend{background:var(--bg-primary);padding:16px;border-radius:8px;border-left:4px solid var(--color-interactive);text-align:left;max-width:300px}.legend-item{margin:8px 0}.legend-text{font-size:14px;color:var(--text-tertiary)}.geometry-visual{display:flex;flex-direction:column;align-items:center;gap:20px;padding:20px;background:var(--bg-secondary);border-radius:12px;margin:20px 0}.geometry-problem-text{font-size:18px;font-weight:600;color:var(--text-primary);text-align:center}.geometry-shape{background:var(--bg-primary);border-radius:8px;padding:10px;box-shadow:var(--shadow-md)}.geometry-hint{text-align:center;font-size:14px;color:var(--text-secondary);background:var(--bg-primary);padding:12px 16px;border-radius:8px;border-left:4px solid var(--color-interactive);max-width:400px}.geometry-hint div{margin:4px 0}.geometry-problem{display:flex;flex-direction:column;align-items:center;gap:20px}.number-line-plotting-container{display:flex;flex-direction:column;align-items:center;gap:20px;padding:20px;background:var(--bg-secondary);border-radius:12px;margin:20px 0}.number-line-problem h3{text-align:center;font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:10px}.number-line-problem p{text-align:center;font-size:14px;color:var(--text-secondary);margin-bottom:20px}.number-line-display{display:flex;justify-content:center;margin:20px 0}.number-line-svg{background:var(--bg-primary);border-radius:8px;box-shadow:var(--shadow-md);cursor:crosshair;padding:10px}.number-line-svg:hover{box-shadow:0 4px 12px #00000026}.number-line-interactive{display:flex;justify-content:center}.number-line-controls{display:flex;gap:12px;justify-content:center;margin:20px 0;flex-wrap:wrap}.reset-button,.clear-button{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.reset-button{background:var(--text-secondary);color:var(--text-inverse)}.reset-button:hover{background:var(--text-tertiary)}.clear-button{background:var(--bg-secondary);color:var(--text-tertiary);border:1px solid var(--border-light)}.clear-button:hover{background:var(--bg-tertiary)}.number-line-result{text-align:center;margin-top:20px;max-width:500px}.result{padding:12px 20px 12px 16px;border-radius:8px;margin-bottom:16px;font-weight:500;width:fit-content}.result.correct{background:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-success)}.result.incorrect{background:var(--color-error-bg);color:var(--color-error);border:1px solid var(--color-error)}.number-line-hint{background:var(--bg-primary);padding:12px 16px;border-radius:8px;border-left:4px solid var(--color-interactive);font-size:14px;color:var(--text-tertiary)}.drag-drop-container{margin:2rem 0;display:flex;flex-direction:column;gap:2rem;touch-action:none}.items-pool h4{margin:0 0 1rem;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.draggable-items{display:flex;flex-wrap:wrap;gap:.75rem;min-height:60px;min-width:250px;width:fit-content;padding:1rem;border:2px dashed var(--border-light);border-radius:8px;background-color:var(--bg-secondary)}.draggable-item{background-color:var(--color-accent);color:var(--text-inverse);padding:.5rem 1rem;border-radius:6px;cursor:grab;font-weight:600;font-size:1.1rem;-webkit-user-select:none;user-select:none;transition:all .2s ease;box-shadow:0 2px 4px #0000001a;display:flex;align-items:center;justify-content:center;touch-action:none}.draggable-item:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.draggable-item:active{cursor:grabbing;transform:translateY(0)}.draggable-item.being-dragged{opacity:.3;transform:scale(.95)}.drop-zones{display:flex;gap:1rem;flex-wrap:wrap}.drop-zone{position:relative;width:120px;height:80px;border:2px dashed var(--border-secondary);border-radius:8px;background-color:var(--bg-primary);display:flex;align-items:center;justify-content:center;transition:all .2s ease}.drop-zone:hover{border-color:var(--color-accent);background-color:var(--color-accent-lighter)}.drop-zone.drag-over{border-color:var(--color-accent);background-color:var(--color-accent-light);border-style:solid;transform:scale(1.05);box-shadow:var(--shadow-md)}.drop-zone.occupied{border-color:var(--color-success);background-color:var(--color-success-bg)}.zone-number{position:absolute;top:-8px;left:8px;background-color:var(--border-secondary);color:var(--text-inverse);width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600}.placed-item{background-color:var(--color-success);color:var(--text-inverse);padding:.5rem .75rem;border-radius:6px;cursor:grab;font-weight:600;font-size:1.5rem;-webkit-user-select:none;user-select:none;transition:all .2s ease;display:flex;align-items:center;justify-content:center;touch-action:none}.placed-item:hover{transform:scale(1.05)}.placed-item:active{cursor:grabbing}.placed-item.being-dragged{opacity:.3;transform:scale(.95) rotate(5deg)}.placed-item.just-dropped{animation:straighten .3s ease-out}@keyframes straighten{0%{transform:rotate(5deg)}to{transform:rotate(0)}}.empty-zone{color:var(--text-primary);font-size:1.5rem;font-weight:600;text-align:center;pointer-events:none;opacity:.7}.equation-with-blanks{display:flex;align-items:center;gap:.75rem;font-size:1.5rem;font-weight:600;margin-top:1.5rem;color:var(--text-primary)}.equation-with-blanks .drop-zone{width:120px;height:80px;display:inline-flex}.equation-with-blanks span{font-size:inherit}.draggable-item.used{opacity:.3;cursor:not-allowed}@media (max-width: 768px){.drop-zones{gap:.5rem}.drop-zone{width:100px;height:70px}.draggable-item,.placed-item{font-size:1rem;padding:.4rem .8rem}.equation-with-blanks{font-size:1.8rem;gap:.5rem}.equation-with-blanks .drop-zone{width:90px;height:60px}.drag-drop-container{margin:0;display:flex;flex-direction:column;gap:1rem}}.practice-counter{font-family:monospace;font-size:14px;color:var(--text-secondary);padding-left:8px}.practice-counter span{font-family:inherit;font-size:inherit;color:inherit}.practice-counter .first-try{color:var(--color-success)}.practice-counter .multiple-tries{color:var(--color-interactive)}.progress-page{max-width:1200px;margin:0 auto;padding:20px;background:var(--bg-primary);color:var(--text-primary)}.loading-container,.error-container{display:flex;justify-content:center;align-items:center;min-height:400px;color:var(--text-secondary);font-size:18px}.error-message{color:var(--color-error);font-size:16px}.progress-content{display:flex;flex-direction:column;gap:32px}.progress-summary h2{color:var(--color-interactive);font-size:28px;margin-bottom:24px;font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.stat-card{background:var(--bg-primary);border:2px solid var(--border-light);border-radius:8px;padding:24px;text-align:center;transition:transform .2s,box-shadow .2s,border-color .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-accent)}.stat-card h3{color:var(--text-secondary);font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.stat-card .stat-value{color:var(--color-interactive);font-size:36px;font-weight:700;margin:0}.daily-activity h2{color:var(--color-interactive);font-size:28px;margin-bottom:24px;font-weight:600}.daily-activity .no-data{color:var(--text-secondary);font-size:16px;text-align:center;padding:40px;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:8px}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.progress-header h2{color:var(--color-interactive);font-size:28px;font-weight:600;margin:0}.reset-demo-button{background:var(--color-error);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s,transform .1s}.reset-demo-button:hover{background:var(--color-error-dark, #c53030);transform:translateY(-1px)}.reset-demo-button:active{transform:translateY(0)}.activity-list{display:flex;flex-direction:column}.activity-card{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:8px;padding:20px;transition:box-shadow .2s,border-color .2s}.activity-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-secondary)}.activity-card h3{color:var(--color-interactive);font-size:18px;margin-bottom:16px;font-weight:600}.activity-card .activity-stats{display:flex;gap:24px;margin-bottom:16px}.activity-card .activity-stats .stat-item{display:flex;flex-direction:column;gap:4px;text-align:center}.activity-card .activity-stats .stat-item .stat-label{font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.activity-card .activity-stats .stat-item .stat-value{font-size:24px;font-weight:700;color:var(--color-interactive)}.activity-card .skills-practiced .skills-label{color:var(--text-secondary);font-size:14px;margin-bottom:8px;font-weight:600}.activity-card .skills-practiced .skills-tags{display:flex;flex-wrap:wrap;gap:8px}.activity-card .skills-practiced .skills-tags .skill-tag{background:var(--bg-primary);color:var(--color-interactive);font-size:12px;font-weight:500;padding:6px 12px;border-radius:16px;border:1px solid var(--color-interactive);text-decoration:none;cursor:pointer;transition:all .2s}.activity-card .skills-practiced .skills-tags .skill-tag:hover{background:var(--color-interactive);color:var(--text-inverse);transform:translateY(-2px);box-shadow:var(--shadow-md)}.skill-stats h2{color:var(--color-interactive);font-size:28px;margin-bottom:24px;font-weight:600}.skill-stats .no-data{color:var(--text-secondary);font-size:16px;text-align:center;padding:40px;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:8px}.skills-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.skill-card{background:var(--bg-primary);border:2px solid var(--border-light);border-radius:8px;padding:20px;transition:transform .2s,box-shadow .2s,border-color .2s}.skill-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-accent)}.skill-card h3{color:var(--color-interactive);font-size:18px;margin-bottom:16px;font-weight:600}.skill-card .skill-details{display:flex;flex-direction:column;gap:10px}.skill-card .skill-details p{color:var(--text-primary);font-size:14px;margin:0;padding:8px 12px;background:var(--bg-secondary);border-radius:6px;border:1px solid var(--border-light)}.page-header{margin-bottom:30px}.progress-view{display:flex;flex-direction:column;gap:24px}.progress-view h2{font-size:24px;margin-bottom:16px}.skill-progress-card{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:8px;padding:20px}.skill-progress-card h3{font-size:18px;margin-bottom:16px;color:var(--color-interactive)}.progress-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.stat-row{display:flex;justify-content:space-between;padding:8px 12px;background:var(--bg-tertiary);border-radius:4px}.stat-row.accent{background:var(--color-interactive-lighter);border:1px solid var(--color-interactive-light);grid-column:1/-1}.stat-label{font-size:14px;color:var(--text-tertiary)}.stat-value{font-weight:600;font-size:16px}.stat-value.success{color:var(--color-success)}.stat-value.warning{color:var(--color-warning)}.stat-value.error{color:var(--color-error)}.progress-timeline{display:flex;gap:4px;padding:12px;overflow-x:auto}.timeline-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;cursor:help;transition:transform .2s}.timeline-dot:hover{transform:scale(1.5)}.timeline-dot.success{background:var(--color-success);box-shadow:0 0 4px #22c55e66}.timeline-dot.warning{background:var(--color-warning);box-shadow:0 0 4px #f59e0b66}.timeline-dot.error{background:var(--color-error);box-shadow:0 0 4px #dc262666}@media (max-width: 768px){.progress-stats{grid-template-columns:1fr}.skill-progress-card{padding:16px}.stats-grid,.skills-list{grid-template-columns:1fr}.stat-card .stat-value{font-size:28px}.progress-summary h2,.daily-activity h2,.skill-stats h2{font-size:24px}}.mark-review-button{cursor:pointer;font-size:1.5rem;padding:.4rem .8rem;background:transparent;border:none;color:var(--color-accent);transition:all .2s;line-height:1}.mark-review-button:hover{transform:scale(1.1)}.mark-review-button.marked{color:var(--color-warning)}.mark-review-modal{max-width:500px}.mark-review-modal .modal-prompt{margin-bottom:1rem;color:var(--text-secondary)}.mark-review-modal .review-note-input{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:6px;font-size:1rem;font-family:inherit;resize:vertical;min-height:80px}.mark-review-modal .review-note-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 2px #f5751c1a}.mark-review-modal .char-counter{text-align:right;font-size:.85rem;color:var(--text-secondary);margin-top:.5rem}.review-practice-page .review-practice-container{max-width:900px;margin:0 auto;padding:1rem}.review-practice-page .review-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--border-color)}.review-practice-page .review-header h2{font-size:1.75rem;color:var(--color-primary);margin:0}.review-practice-page .review-header .review-progress{font-size:1rem;color:var(--text-secondary);font-weight:600}.review-practice-page .review-navigation{display:flex;gap:1rem;justify-content:space-between;margin-top:2rem;padding-top:1.5rem;border-top:2px solid var(--border-color)}.review-practice-page .review-navigation button,.review-practice-page .review-navigation a{padding:.75rem 1.5rem;font-size:1rem;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block}.review-practice-page .review-navigation button:disabled,.review-practice-page .review-navigation a:disabled{opacity:.5;cursor:not-allowed}.review-practice-page .review-navigation .button-secondary{background:transparent;color:var(--color-accent);border:1px solid var(--color-accent)}.review-practice-page .review-navigation .button-secondary:hover:not(:disabled){background:var(--color-accent);color:var(--text-inverse)}.review-practice-page .review-navigation .button-primary{background:var(--color-accent);color:var(--text-inverse);border:1px solid var(--color-accent)}.review-practice-page .review-navigation .button-primary:hover{background:var(--color-accent-dark);border-color:var(--color-accent-dark)}.review-practice-page .empty-state{text-align:center;padding:4rem 2rem;max-width:600px;margin:0 auto}.review-practice-page .empty-state h2{font-size:2rem;color:var(--color-primary);margin-bottom:1rem}.review-practice-page .empty-state p{font-size:1.1rem;color:var(--text-secondary);margin-bottom:1rem}.review-practice-page .empty-state .hint{font-size:.95rem;color:var(--text-tertiary);margin-bottom:2rem}.review-practice-page .empty-state .button{display:inline-block;padding:.75rem 1.5rem;text-decoration:none;border-radius:6px;font-weight:600;transition:all .2s}.review-practice-page .empty-state .button-primary{background:var(--color-accent);color:var(--text-inverse)}.review-practice-page .empty-state .button-primary:hover{background:var(--color-accent-dark)}.loading-container,.error-container{text-align:center;padding:3rem 2rem}.loading-container p,.error-container p{color:var(--text-secondary);font-size:1.1rem}.error-container .error-message{color:var(--color-error)}.xp-display{display:flex;align-items:center;gap:1rem;font-family:var(--font-family-primary)}.xp-display--small{gap:.5rem}.xp-display--small .xp-display__value{font-size:1rem}.xp-display--small .xp-display__label,.xp-display--small .xp-display__streak-value,.xp-display--small .xp-display__streak-label{font-size:.75rem}.xp-display--medium .xp-display__value{font-size:1.25rem}.xp-display--medium .xp-display__label,.xp-display--medium .xp-display__streak-value,.xp-display--medium .xp-display__streak-label{font-size:.875rem}.xp-display--large{gap:1.5rem}.xp-display--large .xp-display__value{font-size:2rem}.xp-display--large .xp-display__label,.xp-display--large .xp-display__streak-value,.xp-display--large .xp-display__streak-label{font-size:1rem}.xp-display__xp{display:flex;align-items:baseline;gap:.25rem}.xp-display__value{font-weight:700;color:var(--color-primary)}.xp-display__label{font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.xp-display__streak{display:flex;align-items:baseline;gap:.25rem;padding-left:1rem;border-left:2px solid var(--color-border)}.xp-display__streak-value{font-weight:700;color:var(--color-warning, #f59e0b)}.xp-display__streak-label{font-weight:500;color:var(--color-text-secondary)}.flow-xp-footer{display:flex;align-items:center;gap:8px;font-family:var(--font-family-primary)}.flow-xp-earned{font-weight:700;font-size:1rem;color:var(--color-success, #22c55e);opacity:0;transform:translateY(4px);transition:opacity .2s ease,transform .2s ease}.flow-xp-earned--visible{opacity:1;transform:translateY(0);animation:xp-pop .3s ease-out}.flow-xp-total{font-weight:600;font-size:.875rem;color:var(--text-secondary)}@keyframes xp-pop{0%{transform:scale(.8) translateY(4px);opacity:0}50%{transform:scale(1.15) translateY(0);opacity:1}to{transform:scale(1) translateY(0);opacity:1}}.xp-toast{position:fixed;top:1rem;left:50%;transform:translate(-50%);padding:.75rem 1.5rem;background:var(--color-success, #22c55e);color:#fff;font-weight:700;font-size:1.125rem;border-radius:2rem;box-shadow:0 4px 12px #00000026;z-index:1000;transition:opacity .3s ease,transform .3s ease}.xp-toast--visible{opacity:1;transform:translate(-50%) translateY(0)}.xp-toast--hidden{opacity:0;transform:translate(-50%) translateY(-1rem);pointer-events:none}.xp-toast__text{display:inline-block;animation:xp-pulse .3s ease-out}@keyframes xp-pulse{0%{transform:scale(.8)}50%{transform:scale(1.1)}to{transform:scale(1)}}.xp-progress{display:flex;flex-direction:column;gap:.5rem;width:100%;max-width:300px}.xp-progress__header{display:flex;justify-content:space-between;align-items:center}.xp-progress__label{font-size:.875rem;font-weight:500;color:var(--color-text-secondary)}.xp-progress__count{font-size:.875rem;font-weight:600;color:var(--color-text-primary)}.xp-progress__bar-container{height:8px;background:var(--color-border);border-radius:4px;overflow:hidden}.xp-progress__bar{height:100%;background:var(--color-primary);border-radius:4px;transition:width .3s ease}.xp-progress__bar--complete{background:var(--color-success, #22c55e)}.xp-progress__complete-text{font-size:.75rem;font-weight:600;color:var(--color-success, #22c55e);text-align:center}.flow-practice-page{max-width:800px;padding:25px;min-height:calc(100vh - 120px);display:flex;flex-direction:column}.flow-daily-progress{display:flex;align-items:center;gap:15px;margin-bottom:30px;padding:12px 16px;background:var(--bg-primary);border:2px solid var(--border-light);border-radius:8px}.flow-daily-progress-bar{flex:1;height:10px;background:var(--border-light);border-radius:5px;overflow:hidden}.flow-daily-progress-fill{height:100%;background:var(--color-accent);border-radius:5px;transition:width .3s ease}.flow-daily-progress-text{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap}.flow-grade-selection{position:relative;text-align:center;padding:40px 0}.flow-title{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:10px}.flow-subtitle{font-size:16px;color:var(--text-primary);margin-bottom:30px}.flow-grade-buttons{display:flex;flex-direction:column;gap:15px;max-width:350px;margin:0 auto}.flow-choice-point{text-align:left;padding:30px 0;max-width:600px}.flow-choice-header{margin-bottom:30px}.flow-choice-result{display:flex;align-items:baseline;gap:4px;margin-bottom:10px}.flow-choice-score{font-size:42px;font-weight:700;color:var(--text-primary)}.flow-choice-score-divider{font-size:24px;color:var(--text-primary);margin:0 4px}.flow-choice-accuracy{font-size:16px;color:var(--text-primary);margin-left:8px}.flow-choice-title{font-size:20px;font-weight:600;color:var(--text-primary);margin:0}.flow-choice-topics{display:flex;flex-direction:column;gap:15px;margin-bottom:30px}.flow-topic-card{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--bg-primary);border:2px solid var(--border-light);border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s,border-color .2s;text-align:left}.flow-topic-card:hover{transform:translateY(-2px);border-color:var(--color-interactive);box-shadow:var(--shadow-md)}.flow-topic-card-current{border-color:var(--color-accent);background:var(--bg-primary)}.flow-topic-card-with-difficulty{display:flex;align-items:stretch;gap:10px}.flow-topic-card-with-difficulty .flow-topic-card{flex:1}.flow-topic-difficulty{display:flex;flex-direction:column;gap:6px}.flow-topic-difficulty .flow-difficulty-btn{flex:1;display:flex;align-items:center;justify-content:center;padding:8px 12px;font-size:13px;font-weight:600;background:var(--bg-primary);border:2px solid var(--border-light);border-radius:6px;color:var(--text-primary);cursor:pointer;transition:all .2s;white-space:nowrap}.flow-topic-difficulty .flow-difficulty-btn:hover{border-color:var(--color-interactive);box-shadow:var(--shadow-md)}.flow-topic-name{font-size:16px;font-weight:600;color:var(--text-primary)}.flow-topic-badge{font-size:13px;font-weight:600;color:var(--color-accent);background:var(--bg-tertiary);padding:4px 10px;border-radius:6px}.flow-choice-difficulty{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1.5rem;padding:.75rem;background:var(--bg-secondary);border-radius:8px}.flow-difficulty-label{font-size:.875rem;color:var(--text-secondary)}.flow-difficulty-buttons{display:flex;gap:.5rem}.flow-difficulty-btn{padding:.5rem 1rem;font-size:.875rem;font-weight:500;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:6px;color:var(--text-primary);cursor:pointer;transition:all .15s ease}.flow-difficulty-btn:hover{border-color:var(--color-interactive)}.flow-choice-break{margin-bottom:30px}.flow-break-btn{height:40px;padding:0 20px;font-size:14px;font-weight:600;background:var(--bg-primary);border:2px solid var(--border-light);border-radius:6px;color:var(--text-primary);cursor:pointer;transition:all .2s}.flow-break-btn:hover{border-color:var(--color-interactive);box-shadow:var(--shadow-md)}.flow-choice-stats{display:flex;flex-direction:column;gap:4px;font-size:14px;color:var(--text-primary);padding-top:20px;border-top:1px solid var(--border-light)}.flow-daily-goal-celebration{text-align:center;padding:40px 0}.flow-celebration-icon{font-size:48px;margin-bottom:15px;color:var(--color-success)}.flow-celebration-title{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:10px}.flow-celebration-subtitle{font-size:16px;color:var(--text-primary);margin-bottom:30px}.flow-celebration-stats{display:flex;justify-content:center;gap:30px;margin-bottom:30px}.flow-celebration-stats span{font-size:14px;font-weight:600;color:var(--text-primary)}.flow-celebration-actions{display:flex;flex-direction:column;gap:15px;max-width:350px;margin:0 auto}.beta-cta-celebration{background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%);border-radius:12px;padding:24px;margin-bottom:24px;max-width:400px;margin-left:auto;margin-right:auto}.beta-cta-celebration .beta-cta-content{text-align:center}.beta-cta-celebration .beta-cta-title{color:#fff;font-size:20px;font-weight:700;margin:0 0 8px}.beta-cta-celebration .beta-cta-description{color:#ffffffe6;font-size:14px;margin:0 0 16px;line-height:1.5}.beta-cta-celebration .beta-cta-button-primary{display:inline-block;background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.5);padding:12px 28px;border-radius:8px;font-weight:600;font-size:16px;text-decoration:none;transition:all .2s ease}.beta-cta-celebration .beta-cta-button-primary:hover{background:#ffffff4d;border-color:#fffc;transform:translateY(-2px)}.flow-daily-goal-badge{display:inline-block;padding:8px 24px;background:var(--color-success);color:var(--text-inverse);border-radius:24px;font-size:16px;font-weight:700;margin-bottom:15px}.flow-session-end-prompt{text-align:center;padding:40px 20px;max-width:400px;margin:0 auto}.flow-session-end-prompt-title{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:10px}.flow-session-end-prompt-skill{font-size:18px;color:var(--text-secondary);margin-bottom:30px}.flow-session-end-prompt-actions{display:flex;flex-direction:column;gap:15px}.flow-post-block-prompt{text-align:center;padding:40px 20px;max-width:500px;margin:0 auto}.flow-post-block-prompt-title{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:30px}.flow-post-block-prompt-actions{display:flex;flex-direction:column;gap:15px}.flow-session-summary{text-align:center;padding:30px 0}.flow-summary-header{margin-bottom:30px}.flow-summary-title{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:10px}.flow-summary-encouragement{font-size:18px;color:var(--text-primary)}.flow-summary-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;max-width:450px;margin:0 auto 30px;padding:30px;background:var(--bg-primary);border:2px solid var(--border-light);border-radius:8px}.flow-stat-card{padding:15px;background:var(--bg-tertiary);border-radius:8px}.flow-stat-value{font-size:24px;font-weight:700;color:var(--text-primary)}.flow-stat-label{font-size:13px;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}.flow-summary-skills{margin-bottom:30px;text-align:left;max-width:450px;margin-left:auto;margin-right:auto}.flow-skills-title{font-size:14px;font-weight:700;color:var(--text-primary);text-transform:uppercase;margin-bottom:10px}.flow-skills-list{list-style:none;padding:0;margin:0}.flow-skill-item{padding:10px 0;font-size:14px;color:var(--text-primary);border-bottom:1px solid var(--border-light)}.flow-skill-item:last-child{border-bottom:none}.flow-summary-actions{display:flex;flex-direction:column;gap:15px;max-width:350px;margin:0 auto}.flow-skill-picker{padding:30px 0}.flow-skill-picker h2{font-size:20px;font-weight:700;text-align:center;margin-bottom:25px;color:var(--text-primary)}.flow-skill-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:15px;max-height:400px;overflow-y:auto;margin-bottom:20px;padding:10px}.flow-btn{height:48px;padding:0 24px;font-size:16px;font-weight:700;border:none;border-radius:6px;cursor:pointer;transition:all .2s}.flow-btn:disabled{opacity:.5;cursor:not-allowed}.flow-btn-primary{background:var(--color-accent);color:var(--text-inverse)}.flow-btn-primary:hover:not(:disabled){box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--color-accent)}.flow-btn-secondary{background:var(--bg-primary);border:2px solid var(--border-light);color:var(--text-primary)}.flow-btn-secondary:hover:not(:disabled){border-color:var(--color-interactive);box-shadow:var(--shadow-md)}.flow-btn-text{background:transparent;color:var(--color-interactive);padding:8px 16px;height:auto;cursor:pointer}.flow-btn-text:hover{text-decoration:underline}.flow-btn-large{height:56px;padding:0 32px;font-size:18px}.flow-btn-back{position:absolute;top:0;left:0;height:40px;padding:0 16px;font-size:14px;font-weight:600;background:var(--bg-primary);border:2px solid var(--border-light);border-radius:6px;color:var(--text-primary);cursor:pointer;transition:all .2s}.flow-btn-back:hover{border-color:var(--color-interactive);box-shadow:var(--shadow-md)}.flow-btn-grade{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;height:56px;padding:0 24px;font-size:18px;font-weight:700;background:var(--bg-primary);border:2px solid var(--border-light);border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s,border-color .2s;color:var(--text-primary)}.flow-btn-grade:hover{transform:translateY(-2px);border-color:var(--color-interactive);box-shadow:var(--shadow-md)}.flow-btn-grade-current{border-color:var(--color-accent);background:var(--bg-primary)}.flow-grade-current-badge{font-size:12px;font-weight:600;color:var(--color-accent);background:var(--bg-tertiary);padding:4px 10px;border-radius:6px}.flow-grade-name{flex:1}.flow-btn-choice{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-width:100px;height:48px;padding:0 16px;font-size:14px;font-weight:600;background:var(--bg-primary);border:2px solid var(--border-light);border-radius:6px;cursor:pointer;transition:all .2s;color:var(--text-primary)}.flow-btn-choice:hover{border-color:var(--color-interactive);box-shadow:var(--shadow-md)}.flow-btn-skill{padding:8px 14px;font-size:14px;font-weight:600;text-align:left;height:auto;background:var(--bg-primary);border:1px solid var(--border-light);border-radius:6px;color:var(--text-primary)}.flow-btn-skill:hover{border-color:var(--color-interactive);background:var(--bg-tertiary)}.flow-transition-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.flow-transition-card{background:var(--bg-primary);border-radius:16px;padding:2rem 3rem;text-align:center;max-width:400px;margin:1rem;animation:slideUp .3s ease}.flow-transition-icon{font-size:2.5rem;margin-bottom:1rem;color:var(--color-accent);animation:pulse 1s ease infinite}.flow-transition-message{font-size:1.125rem;color:var(--text-secondary);margin-bottom:.75rem;line-height:1.5}.flow-transition-skill{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.flow-home-header{margin-bottom:30px;text-align:left}.flow-home-grade-info{display:flex;align-items:center;justify-content:flex-start;gap:12px;margin-bottom:10px}.flow-home-grade-label{font-size:14px;font-weight:600;color:var(--text-primary);background:var(--bg-tertiary);padding:4px 12px;border-radius:6px}.flow-change-grade{font-size:14px;color:var(--color-interactive);font-weight:500}.flow-choice-result-score{font-size:20px;font-weight:700;color:var(--text-primary)}.flow-choice-result-accuracy{font-size:16px;font-weight:600;color:var(--color-accent)}.flow-choice-result-session{font-size:13px;color:var(--text-secondary);margin-left:auto}.flow-choice-difficulty-label{font-size:14px;color:var(--text-secondary)}.flow-home-suggestions{display:flex;flex-direction:column;gap:15px;margin-bottom:30px}.flow-suggestion-card{position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:8px;padding:15px;background:var(--bg-primary);border:2px solid var(--border-light);border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s,border-color .2s;text-align:left}.flow-suggestion-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-interactive)}.flow-suggestion-header{display:flex;justify-content:space-between;align-items:center;width:100%;margin-bottom:8px}.flow-suggestion-xp{font-size:13px;font-weight:700;color:var(--color-accent)}.flow-suggestion-card--current{border-color:var(--color-accent);background:var(--bg-primary)}.flow-suggestion-card--auxiliary{border-style:dashed;border-color:var(--border-medium)}.flow-suggestion-card--auxiliary:hover{border-style:dashed;border-color:var(--color-interactive)}.flow-suggestion-auxiliary-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:600;color:var(--text-secondary);background:var(--bg-tertiary);border-radius:4px;cursor:help;transition:background .2s,color .2s}.flow-suggestion-auxiliary-badge:before{content:"■";font-size:8px;opacity:.7}.flow-suggestion-auxiliary-badge:hover{background:var(--bg-secondary);color:var(--text-primary)}.flow-suggestion-title{display:flex;flex-direction:column}.flow-suggestion-category{font-size:13px;font-weight:500;color:var(--text-secondary)}.flow-suggestion-name{font-size:20px;font-weight:700;color:var(--text-primary)}.flow-suggestion-meta{display:flex;align-items:center;gap:15px;width:100%}.flow-suggestion-reason{font-size:14px;color:var(--text-primary)}.flow-suggestion-mastery{font-size:13px;font-weight:600;color:var(--text-secondary)}.flow-suggestion-mastery--quiz{color:var(--color-accent)}.flow-home-auto{text-align:center;padding-top:20px;border-top:1px solid var(--border-light)}.flow-btn-auto{min-width:200px}.flow-home-auto-hint{font-size:13px;color:var(--text-primary);margin-top:8px}.flow-home-layout{display:flex;gap:30px;flex:1}.flow-home-content{flex:1;min-width:0}.flow-stats-sidebar{width:280px;flex-shrink:0}.flow-stats-panel{background:var(--bg-primary);border:2px solid var(--border-light);border-radius:8px;padding:20px;position:sticky;top:20px}.flow-stats-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border-light)}.flow-stats-row:last-child{border-bottom:none;padding-bottom:0}.flow-stats-row:first-child{padding-top:0}.flow-stats-row--primary{padding-bottom:16px;margin-bottom:4px}.flow-stats-row--primary .flow-stats-row-label{font-size:16px;font-weight:700}.flow-stats-row--clickable{width:100%;background:transparent;border:none;cursor:pointer;transition:background-color .15s}.flow-stats-row--clickable:hover{background:var(--bg-tertiary)}.flow-stats-row--streak .flow-stats-row-value{color:var(--color-accent)}.flow-stats-row-label{font-size:14px;color:var(--text-secondary)}.flow-stats-row-value{font-size:16px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:4px}.flow-stats-unit{font-weight:400;color:var(--text-secondary)}.flow-stats-completion{font-size:18px;font-weight:700;color:var(--color-accent)}.flow-stats-mobile{display:none;margin-bottom:20px;background:var(--bg-primary);border:2px solid var(--border-light);border-radius:8px;overflow:hidden}.flow-stats-mobile-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 16px;background:transparent;border:none;cursor:pointer;text-align:left}.flow-stats-mobile-summary{display:flex;align-items:center;gap:4px;font-size:14px;color:var(--text-primary);flex-wrap:wrap}.flow-stats-mobile-grade{font-weight:600}.flow-stats-mobile-grade--clickable{text-decoration:underline;cursor:pointer}.flow-stats-mobile-grade--clickable:hover{color:var(--color-interactive)}.flow-stats-mobile-change-grade{width:100%;padding:10px 0;margin-bottom:8px;background:transparent;border:none;border-bottom:1px solid var(--border-light);color:var(--color-interactive);font-size:14px;font-weight:600;text-align:left;cursor:pointer}.flow-stats-mobile-change-grade:hover{text-decoration:underline}.flow-stats-mobile-sep{color:var(--text-secondary)}.flow-stats-mobile-completion{font-weight:600;color:var(--color-accent)}.flow-stats-mobile-daily{font-weight:500}.flow-stats-mobile-chevron{color:var(--text-secondary);transition:transform .2s ease;flex-shrink:0}.flow-stats-mobile-chevron--up{transform:rotate(180deg)}.flow-stats-mobile-expanded{padding:0 16px 16px;border-top:1px solid var(--border-light)}.flow-stats-mobile-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border-light)}.flow-stats-mobile-row:last-child{border-bottom:none;padding-bottom:0}.flow-stats-mobile-row:first-child{padding-top:12px}.flow-stats-mobile-label{font-size:14px;color:var(--text-secondary)}.flow-stats-mobile-value{font-size:14px;font-weight:600;color:var(--text-primary)}@media (min-width: 769px){.flow-stats-mobile{display:none}}@media (max-width: 768px){.flow-stats-sidebar{display:none}.flow-stats-mobile{display:block}.flow-home-layout{flex-direction:column;gap:0}.flow-practice-page{padding:15px}}@media (max-width: 480px){.flow-choice-primary-row,.flow-choice-secondary-row{flex-direction:column;align-items:center}.flow-btn-choice{width:100%;max-width:200px}.flow-summary-stats{grid-template-columns:1fr}.flow-transition-card{padding:1.5rem 2rem}.flow-stats-mobile-summary{font-size:13px}.flow-choice-result-session{margin-left:0}}.flow-suggestion-wrapper{display:flex;gap:10px;align-items:stretch}.flow-suggestion-wrapper .flow-suggestion-card{flex:1}.flow-suggestion-card--quiz{border-color:var(--color-accent);background:linear-gradient(135deg,var(--bg-primary) 0%,rgba(var(--color-accent-rgb, 249, 115, 22),.05) 100%)}.flow-suggestion-card--quiz:hover{border-color:var(--color-accent)}.flow-suggestion-card--quiz.certified{border-color:var(--color-success);background:linear-gradient(135deg,var(--bg-primary) 0%,rgba(22,163,74,.05) 100%)}.flow-suggestion-card--quiz.certified:hover{border-color:var(--color-success)}.flow-suggestion-mastery--quiz{background:var(--color-accent);color:var(--text-inverse)}.flow-certification-badge{display:inline-block;width:18px;height:18px;margin-left:8px;background:var(--color-success);border-radius:50%;vertical-align:middle;position:relative}.flow-certification-badge:after{content:"";position:absolute;left:6px;top:3px;width:5px;height:9px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.quiz-taking-container{padding:0 25px;min-height:calc(100vh - 120px);display:flex;flex-direction:column}.quiz-header{display:flex;align-items:center;justify-content:space-between;padding:20px 0;margin-bottom:20px;border-bottom:1px solid var(--border-light);gap:20px;flex-wrap:wrap}.quiz-name{font-size:20px;font-weight:700;color:var(--text-primary);margin:0}.quiz-progress{font-size:14px;color:var(--text-secondary)}.quiz-header-actions{display:flex;gap:10px}.quiz-exit-button{padding:8px 16px;font-size:14px;font-weight:600;background:var(--bg-primary);border:1px solid var(--border-light);border-radius:6px;color:var(--text-primary);cursor:pointer;transition:all .15s}.quiz-exit-button:hover{border-color:var(--color-danger);color:var(--color-danger)}.quiz-problem-area{flex:1;min-height:300px;margin-bottom:30px;padding-bottom:80px}.quiz-navigation{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;gap:15px;padding:15px 25px;background:var(--bg-primary);border-top:1px solid var(--border-light);z-index:100}.quiz-navigation button{padding:12px 24px;font-size:16px;font-weight:600;background:var(--color-accent);border:none;border-radius:6px;color:var(--text-inverse);cursor:pointer;transition:all .2s}.quiz-navigation button:hover:not(:disabled){box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--color-accent)}.quiz-navigation button:disabled{opacity:.5;cursor:not-allowed}.quiz-question-legend{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.quiz-question-dot{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;border-radius:6px;cursor:pointer;transition:all .15s;border:2px solid var(--border-light);background:var(--bg-primary);color:var(--text-secondary)}.quiz-question-dot.unanswered{background:var(--bg-primary);border-color:var(--border-light);color:var(--text-secondary)}.quiz-question-dot.answered{background:var(--text-secondary);border-color:var(--text-secondary);color:var(--bg-primary)}.quiz-question-dot.current{box-shadow:0 0 0 3px var(--color-interactive)}.quiz-question-dot.current.unanswered{background:var(--bg-primary);border-color:var(--color-interactive);color:var(--color-interactive)}.quiz-question-dot.current.answered{background:var(--text-secondary);border-color:var(--color-interactive);color:var(--bg-primary)}.quiz-question-dot:hover:not(.current){border-color:var(--color-interactive);transform:scale(1.05)}.quiz-results-container{max-width:600px;margin:0 auto;text-align:center;padding:40px 20px}.quiz-results-container h1{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:10px}.quiz-results-container h2{font-size:18px;font-weight:600;color:var(--text-secondary);margin-bottom:30px}.result-improvement{color:var(--color-success)}.result-certification{margin-top:10px}.quiz-not-ready{max-width:500px;margin:60px auto;text-align:center;padding:40px;background:var(--bg-primary);border:2px solid var(--border-light);border-radius:12px}.quiz-not-ready h2{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:15px}.quiz-not-ready p{font-size:16px;color:var(--text-secondary);margin-bottom:25px}@media (max-width: 768px){.flow-suggestion-wrapper{flex-direction:column}.flow-suggestion-wrapper .flow-quiz-btn{width:100%;padding:12px}.quiz-header{flex-direction:column;align-items:flex-start;gap:15px}.quiz-navigation{flex-direction:column;gap:20px}.quiz-navigation button{width:100%}.quiz-question-legend{order:-1;width:100%}}.flow-suggestion-card--category-quiz{border-color:#8b5cf6;background:linear-gradient(135deg,var(--bg-primary) 0%,rgba(139,92,246,.05) 100%)}.flow-suggestion-card--category-quiz:hover{border-color:#7c3aed}.flow-suggestion-card--category-quiz.certified{border-color:var(--color-success);background:linear-gradient(135deg,var(--bg-primary) 0%,rgba(22,163,74,.05) 100%)}.flow-suggestion-card--category-quiz.certified:hover{border-color:var(--color-success)}.flow-suggestion-mastery--category{background:#8b5cf6;color:#fff;padding:4px 10px;border-radius:4px}.flow-suggestion-card--review{border-color:#3b82f6;background:linear-gradient(135deg,var(--bg-primary) 0%,rgba(59,130,246,.05) 100%)}.flow-suggestion-card--review:hover{border-color:#2563eb}.flow-suggestion-mastery--review{background:#3b82f6;color:#fff;padding:4px 10px;border-radius:4px}.flow-suggestion-card--unit-test{border-color:#f59e0b;background:linear-gradient(135deg,var(--bg-primary) 0%,rgba(245,158,11,.05) 100%)}.flow-suggestion-card--unit-test:hover{border-color:#d97706}.flow-suggestion-card--unit-test.certified{border-color:var(--color-success);background:linear-gradient(135deg,var(--bg-primary) 0%,rgba(22,163,74,.05) 100%)}.flow-suggestion-card--unit-test.certified:hover{border-color:var(--color-success)}.flow-suggestion-mastery--unit-test{background:#f59e0b;color:#fff;padding:4px 10px;border-radius:4px}.quiz-subtitle{font-size:14px;color:var(--text-secondary);margin-top:4px}.quiz-current-skill{color:var(--text-secondary);font-size:13px}.quiz-not-ready-subtitle{font-size:18px;font-weight:600;color:var(--color-accent);margin-bottom:20px}.quiz-not-ready-skills{text-align:left;margin-bottom:25px;padding:20px;background:var(--bg-tertiary);border-radius:8px}.quiz-not-ready-skills h3{font-size:14px;font-weight:700;text-transform:uppercase;color:var(--text-secondary);margin-bottom:12px}.skill-to-improve{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border-light)}.skill-to-improve:last-child{border-bottom:none;padding-bottom:0}.skill-to-improve .skill-mastery{font-weight:600;color:var(--color-danger)}.quiz-hint{font-size:14px;font-style:italic;color:var(--text-secondary);margin-top:-10px}.unit-test-not-ready{max-width:600px}.unit-test-category-progress{text-align:left;margin-bottom:25px;padding:20px;background:var(--bg-tertiary);border-radius:8px}.unit-test-category-progress h3{font-size:14px;font-weight:700;text-transform:uppercase;color:var(--text-secondary);margin-bottom:16px}.category-progress-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border-light)}.category-progress-item:last-child{border-bottom:none;padding-bottom:0}.category-progress-item.complete .category-percent{color:var(--color-success)}.category-name{flex:0 0 150px;font-size:14px;font-weight:500;color:var(--text-primary)}.category-progress-bar{flex:1;height:8px;background:var(--border-light);border-radius:4px;overflow:hidden}.category-progress-fill{height:100%;background:var(--color-accent);border-radius:4px;transition:width .3s ease}.category-percent{flex:0 0 40px;font-size:14px;font-weight:600;color:var(--text-primary);text-align:right}.unit-test-results .result-stat-large{margin-bottom:20px}.unit-test-results .result-stat-large .result-value{font-size:48px}.unit-test-results .result-certification-banner{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px 24px;background:linear-gradient(135deg,#f59e0b1a,#f59e0b33);border:2px solid #f59e0b;border-radius:12px;margin-top:20px}.unit-test-results .result-certification-banner .certification-icon{font-size:24px;color:#f59e0b}.unit-test-results .result-certification-banner .certification-text{font-size:18px;font-weight:700;color:#f59e0b}.results-skill-breakdown{text-align:left;margin:30px 0;padding:20px;background:var(--bg-tertiary);border-radius:8px}.results-skill-breakdown h3{font-size:14px;font-weight:700;text-transform:uppercase;color:var(--text-secondary);margin-bottom:16px}.skill-results-grid{display:flex;flex-direction:column;gap:8px}.skill-result-item{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid var(--border-light)}.skill-result-item:last-child{border-bottom:none;padding-bottom:0}.skill-result-name{flex:1;font-size:14px;color:var(--text-primary)}.skill-result-score{font-size:14px;font-weight:600;color:var(--text-secondary)}.skill-result-percent{flex:0 0 50px;font-size:14px;font-weight:700;text-align:right;color:var(--text-primary)}.review-item-wrapper{margin-bottom:20px}.review-item-wrapper .review-skill-label{font-size:12px;font-weight:600;text-transform:uppercase;color:var(--text-secondary);background:var(--bg-tertiary);padding:4px 10px;border-radius:4px;display:inline-block;margin-bottom:8px}.flow-briefing{max-width:560px;margin:0 auto;padding:32px;background:var(--bg-primary);border:2px solid var(--border-light);border-radius:12px}.flow-briefing-title{font-size:22px;font-weight:700;color:var(--text-primary);margin-bottom:24px;text-align:center}.flow-briefing-section{margin-bottom:20px}.flow-briefing-section h3{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:8px}.flow-briefing-section p{font-size:16px;line-height:1.6;color:var(--text-primary);margin:0}.flow-briefing-steps{list-style:none;padding:0;margin:0;counter-reset:step}.flow-briefing-steps li{display:flex;align-items:flex-start;gap:12px;padding:10px 0;font-size:15px;line-height:1.5;color:var(--text-primary)}.flow-briefing-steps li:before{counter-increment:step;content:counter(step);display:flex;align-items:center;justify-content:center;min-width:26px;height:26px;background:var(--color-accent);color:#fff;border-radius:50%;font-size:13px;font-weight:700}.flow-briefing-example{background:var(--bg-tertiary);padding:16px 20px;border-radius:8px;border-left:4px solid var(--color-accent);margin-bottom:20px}.flow-briefing-example h3{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:8px}.flow-briefing-example-problem{font-size:20px;font-weight:600;color:var(--text-primary);font-family:var(--font-mono)}.flow-briefing-tip{background:var(--bg-tertiary);padding:16px 20px;border-radius:8px;margin-bottom:20px}.flow-briefing-tip p{font-size:16px;line-height:1.5;color:var(--text-primary);margin:0}.flow-briefing-toggle{background:none;border:none;color:var(--color-interactive);font-size:14px;cursor:pointer;padding:8px 0;margin-bottom:16px}.flow-briefing-toggle:hover{text-decoration:underline}.flow-briefing-actions{display:flex;flex-direction:column;gap:8px;margin-top:24px}.flow-briefing-example-btn,.flow-briefing-cta{width:100%}@media (max-width: 480px){.flow-briefing{padding:24px 20px;margin:0 12px}}.flow-focus-block{position:relative}.flow-focus-toolbar{position:absolute;top:12px;right:12px;z-index:10;display:flex;align-items:center;gap:8px}.flow-help-button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:2px solid var(--border-light);border-radius:50%;font-size:16px;font-weight:700;color:var(--text-secondary);cursor:pointer;transition:all .2s}.flow-help-button:hover{border-color:var(--color-interactive);color:var(--color-interactive);background:var(--bg-secondary)}.flow-help-button:focus{outline:2px solid var(--color-interactive);outline-offset:2px}.flow-lesson-button{display:flex;align-items:center;justify-content:center;padding:6px 12px;background:var(--bg-tertiary);border:2px solid var(--border-light);border-radius:16px;font-size:13px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .2s}.flow-lesson-button:hover{border-color:var(--color-interactive);color:var(--color-interactive);background:var(--bg-secondary)}.flow-lesson-button:focus{outline:2px solid var(--color-interactive);outline-offset:2px}.flow-briefing-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.flow-briefing-modal{position:relative;max-height:90vh;overflow-y:auto}.flow-briefing-modal-close{position:absolute;top:12px;right:12px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:2px solid var(--border-light);border-radius:50%;font-size:18px;font-weight:400;color:var(--text-secondary);cursor:pointer;transition:all .2s}.flow-briefing-modal-close:hover{border-color:var(--color-interactive);color:var(--color-interactive)}.flow-worked-example{position:relative;padding:32px;background:var(--bg-primary);border:2px solid var(--border-light);border-radius:12px}.flow-worked-example-close{position:absolute;top:12px;right:12px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--text-tertiary);background:transparent;border:none;border-radius:50%;cursor:pointer;transition:all .15s ease}.flow-worked-example-close:hover{color:var(--text-secondary);background:var(--bg-tertiary)}.flow-worked-example-header{text-align:center;margin-bottom:24px}.flow-worked-example-header h2{font-size:18px;font-weight:600;color:var(--text-secondary);margin-bottom:12px}.flow-worked-example-problem{font-size:28px;font-weight:700;color:var(--text-primary);font-family:var(--font-mono);padding:16px;background:var(--bg-tertiary);border-radius:8px}.flow-worked-example-progress{font-size:13px;color:var(--text-tertiary);text-align:center;margin-bottom:20px}.flow-worked-example-step{margin-bottom:24px}.flow-worked-example-step .step-explanation{font-size:16px;line-height:1.6;color:var(--text-primary);margin-bottom:12px}.flow-worked-example-step .step-result{font-family:var(--font-mono);font-size:18px;font-weight:600;color:var(--color-accent);padding:12px 16px;background:var(--bg-tertiary);border-radius:6px;margin-bottom:16px}.flow-worked-example-question{margin-top:20px;padding-top:20px;border-top:1px solid var(--border-light)}.flow-worked-example-question .question-text{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:12px}.flow-worked-example-options{display:flex;flex-direction:column;gap:8px}.flow-worked-example-option{padding:12px 16px;border:2px solid var(--border-light);border-radius:8px;background:var(--bg-secondary);font-size:16px;cursor:pointer;transition:all .15s ease;text-align:left}.flow-worked-example-option:hover:not(:disabled){border-color:var(--color-accent);background:var(--bg-tertiary)}.flow-worked-example-option.selected{border-color:var(--color-accent);background:rgba(var(--color-accent-rgb),.1)}.flow-worked-example-option.correct{border-color:var(--color-success);background:rgba(var(--color-success-rgb),.1)}.flow-worked-example-option.incorrect{border-color:var(--color-error);background:rgba(var(--color-error-rgb),.1)}.flow-worked-example-option:disabled{cursor:default}.flow-worked-example-feedback{margin-top:16px;padding:12px 16px;border-radius:8px;font-size:15px;font-weight:500}.flow-worked-example-feedback.correct{background:rgba(var(--color-success-rgb),.1);color:var(--color-success)}.flow-worked-example-feedback.incorrect{background:rgba(var(--color-error-rgb),.1);color:var(--color-error)}.flow-worked-example-actions{display:flex;align-items:center;gap:12px;margin-top:24px}.flow-worked-example-skip,.flow-worked-example-check{flex:0 0 auto;min-width:130px;height:3rem;font-size:1.2rem;font-weight:700;border-radius:6px}.flow-worked-example-feedback-inline{font-size:14px;font-weight:600}.flow-worked-example-feedback-inline.correct{color:var(--color-success)}.flow-worked-example-ready{margin-top:16px;text-align:center}.flow-worked-example-ready p{font-size:16px;color:var(--text-secondary);margin:0}@media (max-width: 480px){.flow-worked-example{padding:24px 20px;margin:0 12px}.flow-worked-example-problem{font-size:24px;padding:12px}}.show-lesson-button{padding:.5rem 1rem;background:var(--color-accent);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease}.show-lesson-button:hover{background:var(--color-accent-hover)}.guided-lesson{max-width:900px;margin:0 auto;padding:20px 20px 60px;font-size:18px;line-height:1.7}.guided-lesson *{font-size:inherit;line-height:inherit}.content-block{margin-bottom:12px}.content-block:last-child{margin-bottom:0}.content-text{margin:0;line-height:1.7}.content-latex{padding:12px 0;text-align:center}.katex-block{display:block;text-align:center;margin:8px 0}.katex-block .katex{font-size:1.2em}.katex-inline{display:inline}.guided-lesson-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:40vh;color:var(--text-secondary, #666)}.loading-spinner,.spinner{width:24px;height:24px;border:2px solid var(--bg-tertiary, #e0e0e0);border-top-color:var(--text-primary, #333);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:12px}@keyframes spin{to{transform:rotate(360deg)}}.guided-lesson-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:40vh;padding:24px;text-align:center}.guided-lesson-error p{margin:0 0 12px;color:var(--text-primary, #333)}.guided-lesson-error .error-detail{color:var(--text-secondary, #666);font-size:.875rem;margin-bottom:20px}.guided-lesson-page{position:fixed;top:0;right:0;bottom:0;left:0;overflow-y:auto;background:var(--bg-primary, #fff)}.guided-lesson-page-header{position:sticky;top:0;z-index:100;background:var(--bg-primary, #fff);display:flex;flex-wrap:wrap;align-items:center;gap:16px 20px;padding:20px 24px;border-bottom:1px solid var(--border-primary, #e0e0e0)}.guided-lesson-page-header .back-button{padding:10px 20px;background:none;border:1px solid var(--border-primary, #e0e0e0);border-radius:6px;cursor:pointer;font-size:16px;flex-shrink:0}.guided-lesson-page-header .back-button:hover{background:var(--bg-secondary, #f5f5f5)}.guided-lesson-page-header .header-title-section{flex:1;min-width:0;display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}.guided-lesson-page-header .header-title-section h1{margin:0;font-size:22px;font-weight:600}.guided-lesson-page-header .header-title-section .lesson-sequence-indicator{font-size:13px;color:var(--text-secondary, #666);white-space:nowrap;flex-shrink:0}.guided-lesson-page-header .header-progress-dots{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.guided-lesson-page-header .header-progress-dots .progress-dot{width:12px;height:12px;border-radius:50%;background:var(--bg-tertiary, #e0e0e0);transition:background .3s ease}.guided-lesson-page-header .header-progress-dots .progress-dot.filled{background:var(--color-accent, #F5751C)}@media (max-width: 600px){.guided-lesson-page-header{padding:12px 16px;gap:10px 12px}.guided-lesson-page-header .back-button{padding:8px 12px;font-size:14px}.guided-lesson-page-header .header-title-section{gap:8px}.guided-lesson-page-header .header-title-section h1{font-size:18px}.guided-lesson-page-header .header-title-section .lesson-sequence-indicator{font-size:11px}.guided-lesson-page-header .header-progress-dots{width:100%;order:3;gap:6px}.guided-lesson-page-header .header-progress-dots .progress-dot{width:10px;height:10px}}.guided-lesson-page-content{padding:24px;min-height:calc(100vh + 100px)}.guided-lesson-page-content:has(.guided-lesson-simple.completed){min-height:auto}.btn-primary{min-width:130px;height:3rem;padding:0 24px;background-color:var(--color-accent, #F5751C);color:var(--text-inverse, white);border:none;border-radius:6px;font-size:1.2rem;font-weight:700;cursor:pointer}.btn-primary:hover:not(:disabled){box-shadow:0 0 0 4px #f5751c4d}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{padding:12px 24px;background:var(--bg-primary, #fff);color:var(--text-primary, #333);border:2px solid var(--border-light, #e0e0e0);border-radius:8px;font-size:18px;font-weight:500;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease}.btn-secondary:hover:not(:disabled){border-color:var(--color-accent, #F5751C);box-shadow:var(--shadow-md)}.btn-retry{padding:12px 24px;background:var(--bg-primary, #fff);color:var(--color-danger, #dc3545);border:2px solid var(--color-danger, #dc3545);border-radius:8px;font-size:18px;font-weight:500;cursor:pointer;transition:background-color .2s ease,box-shadow .2s ease}.btn-retry:hover:not(:disabled){background:var(--color-danger, #dc3545);color:#fff;box-shadow:0 0 0 4px #dc354533}.btn-text{padding:8px 16px;background:none;color:var(--text-secondary, #666);border:none;font-size:.875rem;cursor:pointer}.btn-text:hover{color:var(--text-primary, #333)}@media (max-width: 600px){.guided-lesson{padding:16px}.lesson-title{font-size:1.25rem}}.guided-lesson-simple{max-width:900px;margin:0 auto;padding:20px;display:flex;flex-direction:column;gap:16px}.guided-lesson-simple *{font-size:inherit;line-height:inherit}.guided-lesson-simple{font-size:18px;line-height:1.7}.lesson-item{padding:24px;border:1px solid var(--border-light, #e0e0e0);border-radius:8px;background:var(--bg-primary, #fff);scroll-margin-top:100px}.lesson-item.completed{background:var(--bg-secondary, #f8f9fa);border-color:var(--border-light, #e8e8e8)}.lesson-item.current{border-color:var(--border-primary, #d0d0d0);margin-bottom:40vh}.information-item .information-header{font-size:1.1rem;font-weight:600;color:var(--text-primary, #333);margin-bottom:12px}.information-item .item-content{color:var(--text-primary, #333);line-height:1.7}.information-item .item-content .katex{font-size:1.1em}.information-item .item-actions{margin-top:20px;padding-top:16px;border-top:1px solid var(--border-light, #f0f0f0)}.question-item .question-number{font-size:.85rem;font-weight:600;color:var(--text-secondary, #666);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.question-item .item-content{font-weight:500;margin-bottom:20px;color:var(--text-primary, #333);line-height:1.7}.question-item .item-content .katex{font-size:1.1em}.question-item.completed .question-answer{margin-top:8px;font-weight:500;color:var(--text-primary, #333)}.question-item.completed .question-answer .katex{font-size:1.1em}.question-options{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}@media (max-width: 500px){.question-options{grid-template-columns:1fr}}.question-options .option{padding:16px;border:2px solid var(--border-primary, #e0e0e0);border-radius:8px;background:var(--bg-primary, #fff);cursor:pointer;text-align:center;transition:border-color .2s ease,background .2s ease;min-height:56px;display:flex;align-items:center;justify-content:center}.question-options .option .katex{font-size:1.1em}.question-options .option .katex-block{margin:0;text-align:center}.question-options .option:hover:not(:disabled){border-color:var(--text-primary, #333);background:var(--bg-secondary, #f8f9fa)}.question-options .option.selected{border-color:var(--text-primary, #333);background:var(--bg-secondary, #f8f9fa)}.question-options .option.correct{border-color:var(--color-success, #16a34a);background:var(--color-success-bg, #f0fdf4)}.question-options .option.wrong{border-color:var(--color-error, #c62828);background:var(--color-error-bg, #fef2f2)}.question-options .option:disabled{cursor:default}.question-feedback{margin-top:20px;padding:16px;background:var(--bg-secondary, #f8f9fa);border-radius:8px}.question-feedback.correct{border-left:3px solid var(--color-success, #16a34a)}.question-feedback.wrong{border-left:3px solid var(--color-error, #c62828)}.question-feedback .feedback-answer{font-weight:600;margin-bottom:8px}.question-feedback .feedback-answer .katex{font-size:1.1em}.question-feedback .feedback-explanation{color:var(--text-secondary, #666);line-height:1.5;white-space:pre-line}.item-actions{margin-top:24px;display:flex;gap:12px;justify-content:flex-start}.guided-lesson-simple.completed .completion-message{text-align:center;padding:40px 20px;font-size:1.25rem;font-weight:600;color:var(--text-primary, #333)}.lesson-image{max-width:100%;height:auto;border-radius:4px;margin:8px 0}.integer-input-container{display:flex;align-items:center;margin-bottom:12px}.integer-input{width:200px;height:48px;padding:0 16px;font-size:1.25rem;font-weight:500;text-align:center;border:2px solid var(--border-primary, #e0e0e0);border-radius:8px;background:var(--bg-primary, #fff);transition:border-color .2s ease}.integer-input:focus{outline:none;border-color:var(--text-primary, #333)}.integer-input.correct{border-color:var(--color-success, #16a34a);background:var(--color-success-bg, #f0fdf4)}.integer-input.wrong{border-color:var(--color-error, #c62828);background:var(--color-error-bg, #fef2f2)}.integer-input:disabled{cursor:default;background:var(--bg-secondary, #f8f9fa)}.text-input-container{margin-bottom:12px}.text-input{width:100%;max-width:300px;height:48px;padding:0 16px;font-size:1.1rem;border:2px solid var(--border-primary, #e0e0e0);border-radius:8px;background:var(--bg-primary, #fff);transition:border-color .2s ease}.text-input:focus{outline:none;border-color:var(--text-primary, #333)}.text-input.correct{border-color:var(--color-success, #16a34a);background:var(--color-success-bg, #f0fdf4)}.text-input.wrong{border-color:var(--color-error, #c62828);background:var(--color-error-bg, #fef2f2)}.text-input:disabled{cursor:default;background:var(--bg-secondary, #f8f9fa)}.fraction-input-container{display:inline-flex;align-items:center;gap:12px;padding:12px 16px;border:2px solid var(--border-primary, #e0e0e0);border-radius:8px;background:var(--bg-primary, #fff);transition:border-color .2s ease}.fraction-input-container.correct{border-color:var(--color-success, #16a34a);background:var(--color-success-bg, #f0fdf4)}.fraction-input-container.wrong{border-color:var(--color-error, #c62828);background:var(--color-error-bg, #fef2f2)}.fraction-whole{width:48px;height:48px;padding:0;font-size:1.5rem;font-weight:500;text-align:center;border:1px solid var(--border-light, #e0e0e0);border-radius:4px;background:transparent}.fraction-whole:focus{outline:none;border-color:var(--text-primary, #333)}.fraction-whole:disabled{cursor:default}.fraction-stack{display:flex;flex-direction:column;align-items:center;gap:4px}.fraction-numerator,.fraction-denominator{width:56px;height:36px;padding:0;font-size:1.25rem;font-weight:500;text-align:center;border:1px solid var(--border-light, #e0e0e0);border-radius:4px;background:transparent}.fraction-numerator:focus,.fraction-denominator:focus{outline:none;border-color:var(--text-primary, #333)}.fraction-numerator:disabled,.fraction-denominator:disabled{cursor:default}.fraction-line{width:56px;height:2px;background:var(--text-primary, #333)}.division-input-container{display:inline-flex;align-items:flex-end;gap:20px;padding:12px 16px;border:2px solid var(--border-primary, #e0e0e0);border-radius:8px;background:var(--bg-primary, #fff);transition:border-color .2s ease}.division-input-container.correct{border-color:var(--color-success, #16a34a);background:var(--color-success-bg, #f0fdf4)}.division-input-container.wrong{border-color:var(--color-error, #c62828);background:var(--color-error-bg, #fef2f2)}.division-field{display:flex;flex-direction:column;align-items:center;gap:4px}.division-label{font-size:.85rem;font-weight:500;color:var(--text-secondary, #666)}.division-quotient,.division-remainder{width:80px;height:48px;padding:0;font-size:1.5rem;font-weight:500;text-align:center;border:1px solid var(--border-light, #e0e0e0);border-radius:4px;background:transparent}.division-quotient:focus,.division-remainder:focus{outline:none;border-color:var(--text-primary, #333)}.division-quotient:disabled,.division-remainder:disabled{cursor:default}.guided-lesson-visual{margin:16px 0}.guided-lesson-visual svg{max-width:100%;height:auto}.guided-lesson-visual .custom-svg-visual{max-width:400px;width:100%;height:auto}.guided-lesson-simple .fraction-comparison-container{margin:20px 0;min-height:auto;gap:20px;flex-wrap:nowrap}.guided-lesson-simple .fraction-comparison-container .fraction-option{flex-shrink:1;min-width:0;padding:10px}.guided-lesson-simple .fraction-comparison-container .fraction-bar-container{width:280px;height:55px}.guided-lesson-simple .fraction-comparison-container .fraction-circle svg{width:120px;height:120px}.guided-lesson-simple .fraction-comparison-container .fraction-squares .fraction-grid-container.grid-cols-2{grid-template-columns:repeat(2,40px);grid-template-rows:repeat(2,40px)}.guided-lesson-simple .fraction-comparison-container .fraction-squares .fraction-grid-container.grid-cols-3{grid-template-columns:repeat(3,40px);grid-template-rows:repeat(3,40px)}.guided-lesson-simple .fraction-comparison-container .fraction-squares .fraction-grid-container.grid-cols-4{grid-template-columns:repeat(4,35px);grid-template-rows:repeat(4,35px)}.guided-lesson-simple .fraction-comparison-container .fraction-squares .fraction-grid-container.grid-cols-5{grid-template-columns:repeat(5,30px);grid-template-rows:repeat(5,30px)}.guided-lesson-simple .fraction-comparison-container .fraction-squares .fraction-grid-container.grid-cols-6{grid-template-columns:repeat(6,28px);grid-template-rows:repeat(6,28px)}.guided-lesson-simple .fraction-comparison-container .fraction-squares .fraction-grid-container.grid-cols-7{grid-template-columns:repeat(7,25px);grid-template-rows:repeat(7,25px)}.guided-lesson-simple .fraction-comparison-container .fraction-squares .fraction-grid-container.grid-cols-8{grid-template-columns:repeat(8,22px);grid-template-rows:repeat(8,22px)}@media (max-width: 600px){.guided-lesson-simple .fraction-comparison-container{gap:10px}.guided-lesson-simple .fraction-comparison-container .fraction-option{padding:6px}.guided-lesson-simple .fraction-comparison-container .fraction-bar-container{width:140px;height:45px}.guided-lesson-simple .fraction-comparison-container .fraction-circle svg{width:80px;height:80px}.guided-lesson-simple .fraction-comparison-container .fraction-squares .fraction-grid-container.grid-cols-2{grid-template-columns:repeat(2,28px);grid-template-rows:repeat(2,28px)}.guided-lesson-simple .fraction-comparison-container .fraction-squares .fraction-grid-container.grid-cols-3{grid-template-columns:repeat(3,25px);grid-template-rows:repeat(3,25px)}.guided-lesson-simple .fraction-comparison-container .fraction-squares .fraction-grid-container.grid-cols-4{grid-template-columns:repeat(4,22px);grid-template-rows:repeat(4,22px)}.guided-lesson-simple .fraction-comparison-container .fraction-squares .fraction-grid-container.grid-cols-5{grid-template-columns:repeat(5,18px);grid-template-rows:repeat(5,18px)}.guided-lesson-simple .fraction-comparison-container .fraction-squares .fraction-grid-container.grid-cols-6{grid-template-columns:repeat(6,16px);grid-template-rows:repeat(6,16px)}.guided-lesson-simple .fraction-comparison-container .fraction-squares .fraction-grid-container.grid-cols-7{grid-template-columns:repeat(7,14px);grid-template-rows:repeat(7,14px)}.guided-lesson-simple .fraction-comparison-container .fraction-squares .fraction-grid-container.grid-cols-8{grid-template-columns:repeat(8,12px);grid-template-rows:repeat(8,12px)}.guided-lesson-simple .fraction-comparison-container .fraction-vs-section{min-width:50px}.guided-lesson-simple .fraction-comparison-container .fraction-vs-section .comparison-select{font-size:16px;padding:4px 6px;min-width:45px}}
